link 32bit .o with 64bit .o
GuoMinskey
minskey_guo@hotmail.com
Tue Apr 26 06:26:00 GMT 2011
Thank you for helping.
I use objcopy to transform 32 bit object into 64 bit, and then link it intoother 64 bit objects. Now, I can call my function from 32 bit code part(.code32) of head_64.S (mixed 32/64 bit code).
However, in my C code, I cannot access data which is allocated in .data or .bss section. Since there is an offset between compile addressand load address, I guess that I need to have my C code deal with theoffset.
In Linux kernel source: arch/x86/boot/compressed/head_64.S, that offset is calculated by the following snippet:
leal (BP_scratch+4)(%esi), %esp call 1f1: popl %ebp subl $1b, %ebp
So, the offset is saved in ebp register. I think that my Code might workif I can have it aware the offset. But how can I have the C code add anoffset to all variables in .data and .bss sections ?
-minskey
----------------------------------------
> From: iant@google.com
> To: minskey_guo@hotmail.com
> CC: gcc-help@gcc.gnu.org
> Subject: Re: link 32bit .o with 64bit .o
> Date: Mon, 11 Apr 2011 13:47:58 -0700
>
> GuoMinskey writes:
>
> > On x86 platform, is there any means to link 32 bit ELF output into 64 bit ?
> > In Linux kernel, arch/x86/boot/compressed/head_64.S, starts from32-bit code and enables CPU to jump into 64-bit. So, that file is assembled into 64 bit ELF object with mixed 32/64 bit code.
> > Now, I want to call a routine from somewhere in the 32bit code part of head_64.S. And I write the routine by C language, say test.c and compile it with "gcc -m32 -c -o test.o". How can I link mytest.o to head_64.o ? Or I have to use assembly language to rewritemy routine and embed it directly into head_64.S source code ?
>
> On x86, 32-bit code can not call 64-bit code, nor vice-versa. The Linux
> kernel uses some tricks to start up in 32-bit mode, convert to 64-bit
> mode, and branch to 64-bit code as it converts. You can't do the same
> tricks yourself; only the kernel can do them.
>
> So, the answer is that you can link 32-bit and 64-bit code together
> easily enough, using the linker's -b option as the kernel build does,
> but you can't do anything useful with the result.
>
> Ian
More information about the Gcc-help
mailing list