OMAP 3530 arch_shutdown "undefined instruction"
Orjan Friberg
of at flatfrog.com
Wed May 26 10:48:09 EDT 2010
Hi,
I'm trying to use barebox as both the 2nd and 3rd stage bootloader (boot
ROM being the 1st) on an OMAP 3530 (BeagleBoard).
Every go <address> command in the 2nd stage, regardless of whether I
have uploaded anything to this address or not, is met with a
go 0x80e80000
## Starting application at 0x80E80000 ...
undefined instruction
pc : [<40208b00>] lr : [<40203a34>]
sp : 87bff21c ip : 00000028 fp : 87bffa4d
r10: 00000000 r9 : 00000000 r8 : 87bff64d
r7 : 87bffe44 r6 : 00000002 r5 : 4020b1e8 r4 : 80e80000
r3 : 00000000 r2 : 00000001 r1 : 0000843f r0 : 4020ae50
Flags: nZCv IRQs off FIQs off Mode SVC_32
Resetting CPU ...
which is in arch_shutdown:
40208af8 <arch_shutdown>:
40208af8: e3a03000 mov r3, #0 ; 0x0
40208afc: ee073f17 mcr 15, 0, r3, cr7, cr7, {0}
40208b00: e12fff1e bx lr
This is from the 2010.05.0 snapshot, though it seems that code hasn't
changed in the latest trunk (arch/arm/cpu/cpu.c):
/* flush I/D-cache */
i = 0;
asm ("mcr p15, 0, %0, c7, c7, 0": :"r" (i));
This is compiled with the CodeSourcery 2009q1 tool chain.
Commenting out the call to arch_shutdown makes the go command work
without any obvious deficiencies, but that doesn't seem like the right
way to do it.
(I haven't tried the latest trunk as it doesn't compile.)
Thanks for any suggestions,
Orjan
--
Orjan Friberg
FlatFrog Laboratories AB
More information about the barebox
mailing list