All of lore.kernel.org
 help / color / mirror / Atom feed
From: Tetsuyuki Kobayashi <koba@kmckk.co.jp>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH] arm: bugfix: Move vector table before jumping relocated code
Date: Thu, 28 Jun 2012 10:27:50 +0900	[thread overview]
Message-ID: <4FEBB316.6010502@kmckk.co.jp> (raw)
In-Reply-To: <20120627182306.GB18004@bill-the-cat>

Hi Tom and all,

(2012/06/28 3:23), Tom Rini wrote:
> On Mon, Jun 25, 2012 at 09:40:57PM +0900, Tetsuyuki Kobayashi wrote:
>
>> Interrupts and exceptions doesn't work in relocated code.
>> It badly use IRQ_STACK_START_IN in rom area as interrupt stack.
>> It is because the vecotr table is not moved to ram area.
>> This patch moves vector table before jumping relocated code.
>>
>> Signed-off-by: Tetsuyuki Kobayashi<koba@kmckk.co.jp>
>> ---
>>   arch/arm/cpu/armv7/start.S |   12 ++++++++++++
>>   1 file changed, 12 insertions(+)
>>
>> diff --git a/arch/arm/cpu/armv7/start.S b/arch/arm/cpu/armv7/start.S
>> index 52f7f6e..5098f7b 100644
>> --- a/arch/arm/cpu/armv7/start.S
>> +++ b/arch/arm/cpu/armv7/start.S
>> @@ -277,6 +277,18 @@ jump_2_ram:
>>   	mcr     p15, 0, r0, c7, c10, 4	@ DSB
>>   	mcr     p15, 0, r0, c7, c5, 4	@ ISB
>>   #endif
>> +/*
>> + * Move vector table
>> + */
>> +#if !defined(CONFIG_TEGRA2)
>> +#if !(defined(CONFIG_OMAP44XX)&&  defined(CONFIG_SPL_BUILD))
>> +	/* Set vector address in CP15 VBAR register */
>> +	ldr     r0, =_start
>> +	add     r0, r0, r9
>> +	mcr     p15, 0, r0, c12, c0, 0  @Set VBAR
>> +#endif
>> +#endif /* !Tegra2 */
>> +	
>>   	ldr	r0, _board_init_r_ofs
>>   	adr	r1, _start
>>   	add	lr, r0, r1
>
> I think this code should get boot tested on a few platforms to make sure
> it's OK.  As such, I've tried on am335x and omap3 and they're still
> fine.
>
> Tested-by: Tom Rini<trini@ti.com>
>
Tom, thank you for testing.

Easy way to test this patch.
Jump any bad address using go command on U-boot prompt.

Good restult:

 > go 0x0badc0de
## Starting application at 0x0BADC0DE ...
undefined instruction
pc : [<0badc0e0>]          lr : [<5ff91354>]
sp : 5feefb98  ip : 0000001c     fp : 5feefbdd
r10: 00000002  r9 : 5feefbdd     r8 : 5feeff68
r7 : 5feeff14  r6 : 0badc0de     r5 : 5feefed4  r4 : 00000002
r3 : 0badc0de  r2 : 5feefed4     r1 : 5feefed4  r0 : 00000001
Flags: nZCv  IRQs off  FIQs off  Mode SVC_32
Resetting CPU ...

resetting ...


Bad result:
 > go 0x0badc0de

(.. hang up without any crash dump.)

  reply	other threads:[~2012-06-28  1:27 UTC|newest]

Thread overview: 11+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-06-25 12:40 [U-Boot] [PATCH] arm: bugfix: Move vector table before jumping relocated code Tetsuyuki Kobayashi
2012-06-25 15:10 ` Stephen Warren
2012-06-26  1:03   ` Tetsuyuki Kobayashi
2012-06-26 16:24     ` Stephen Warren
2012-07-05  9:27       ` Albert ARIBAUD
2012-06-27 18:23 ` Tom Rini
2012-06-28  1:27   ` Tetsuyuki Kobayashi [this message]
2012-12-21 15:17     ` Joel A Fernandes
2012-12-25 23:18       ` Tetsuyuki Kobayashi
2012-12-26  0:08         ` Joel A Fernandes
2012-07-05 12:00 ` Albert ARIBAUD

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4FEBB316.6010502@kmckk.co.jp \
    --to=koba@kmckk.co.jp \
    --cc=u-boot@lists.denx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.