Search code examples
cgccld

How to access variable define in linker script in c?


In the linker script, I defined PROVIDE(__KERNEL_BEGIN__ = .);.

The address can be accessed from:

extern uint32_t __KERNEL_BEGIN__[];

But, the following does not work (gives an incorrect address):

extern uint32_t * __KERNEL_BEGIN__;

I looked at the assembly. The first method, __KERNEL_BEGIN__, provides the exact address. The second one, __KERNEL_BEGIN__ = [address], looks up a value at the address.

So, must it be this way? I cannot tell the difference.


Solution

  • You need to take the address of the extern variable. It is not completely intuitive but is explained in the manual.

    In theory, the extern can be any primitive data type. For reasons which I am unaware, the convention is to use a char:

    extern char __KERNEL_BEGIN__;
    

    Then to get the address exported from the linker script, take the address of __KERNEL_BEGIN__:

    printf("Address: %08x\n", &__KERNEL_BEGIN__);
    

    You can read about this in the manual for ld.