mail archive of the barebox mailing list
 help / color / mirror / Atom feed
* bug in arm_cpu_lowlevel_init ??
@ 2014-02-27  6:15 zzs
  2014-02-27  6:53 ` Alexander Shiyan
  2014-02-27  7:27 ` Sascha Hauer
  0 siblings, 2 replies; 6+ messages in thread
From: zzs @ 2014-02-27  6:15 UTC (permalink / raw)
  To: barebox

My cpu is at91rm9200

When start barebox at reset time by burn it in Nor flash, all things Ok.

But when start it by my first stage boot program, It's crash.  And
Execption process code which install by my boot program, report Undef
instruction detected.

The only diff is my boot program change the cpu to svc mode already.

I try the flowwing patch:

------------------------------------------------
--- a/arch/arm/cpu/lowlevel.S
+++ b/arch/arm/cpu/lowlevel.S
@@ -4,6 +4,7 @@

 .section ".text_bare_init_","ax"
 ENTRY(arm_cpu_lowlevel_init)
+       mov     r2, lr
        /* set the cpu to SVC32 mode */
        mrs     r12, cpsr
        bic     r12, r12, #0x1f
@@ -35,5 +36,5 @@ ENTRY(arm_cpu_lowlevel_init)

        mcr     p15, 0, r12, c1, c0, 0

-       mov     pc, lr
+       mov     pc, r2
 ENDPROC(arm_cpu_lowlevel_init)
------------------------------------------------

The problem dispeared, All things worked!!

I'm not very familiar with asm code,

Anybody tell me is this a bug, Or my boot program has strange behavior?

Thanks!!

-- 
Best Regards,
zzs



_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2014-02-27  8:02 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-02-27  6:15 bug in arm_cpu_lowlevel_init ?? zzs
2014-02-27  6:53 ` Alexander Shiyan
2014-02-27  7:53   ` zzs
2014-02-27  7:27 ` Sascha Hauer
2014-02-27  7:51   ` zzs
2014-02-27  8:01     ` Sascha Hauer

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox