jumping to code in RAM in a MPC55xx
Tehn Yit Chin
tehn.yit.chin at gmail.com
Fri Jul 18 16:29:34 EST 2008
Hi,
This question is not directly related to linux, but a question on how to
execute code from.
My test code is as follows..
void ram(unsigned int cat) __attribute__ ((section(".ram_code")));
void ram1(void) __attribute__ ((section(".ram_code")));
void flash(void) __attribute__ ((section(".text")));
void flash1(unsigned int y) __attribute__ ((section(".text")));
void ram(unsigned int cat)
{
unsigned int abc;
abc += 12;
abc += cat;
}
void ram1(void)
{
ram(123);
}
void flash1(unsigned int y)
{
unsigned int x;
x = x + y;
}
void flash(void)
{
unsigned int def;
def += 12;
asm (" bel ram1\n\t");
}
I have the section .ram_code mapped into the internal SRAM of the MPC55xx,
which starts at 0x40000000. Code in .text are mapped into MPC55xx's internal
FLASH, starting at 0x00000000.
When I attempt to link the code together, I get the error
U:\src\applications\comms/fatdog.c(35,1): relocation truncated to fit:
R_PPC_REL24 against symbol `ram1' defined in .ram_code section in
U:\src\applications\comms\fatdog.o
I googled the error and I think it means that the ram1() is too far away and
the branch address has been truncated to fit into the binary.
Other than assembler bel instruction, I have also tried bl, b and bea and
all of them gave the same link error.
I was wondering if anyone can give some insight on how I can get the MPC55xx
to branch between FLASH and SRAM?
Many thanks,
Tehn Yit Chin
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://ozlabs.org/pipermail/linuxppc-embedded/attachments/20080718/703958f3/attachment.htm>
More information about the Linuxppc-embedded
mailing list