public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
From: Albert ARIBAUD <albert.u.boot@aribaud.net>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH 1/3] arm: make .vectors section allocatable
Date: Wed, 24 Sep 2014 09:34:52 +0200	[thread overview]
Message-ID: <E1XWh6D-0007eA-MQ@janus> (raw)
In-Reply-To: <1411335230-26907-2-git-send-email-savoundg@gmail.com>

Hi Georges,

On Sun, 21 Sep 2014 23:33:48 +0200, Georges Savoundararadj
<savoundg@gmail.com> wrote:

> Before the commit 41623c91, the exception vector was in a .text
> section which is allocatable. After this, the .vectors section was
> introduced to contain the exception vector without specifying it as a
> .text section but only as a executable section ("x").
> This fix marks the section .vectors as allocatable as well ("ax") allowing
> symbols to be relocated.

Could you explain (on the list, not in the commit message, although I
might ask you to do it there too later on) the exact effects of adding
the "a" flag, i.e., what symbol exactly was broken by commit 41623c91,
how it is broken, and how "a" changes this?

On a deeper level, note that many ARM targets around do not have free
rein on where they can put vectors, e.g., they are limited to base
addresses of 0x00000000 or 0xFFFF0000. Thus, in many cases, vector are
relocated along with the rest of the image, but in fact, their base
address will not be their relocated address, and they will require
copying into whatever fixed location the target supports.

If you're going to fix general exception handling files (which I am
quite fine with), I would prefer that you solve the general problem,
i.e. either relocate vectors along with the code and fix VBAR on
plaforms that can use it, or relocate them to the fixed location wher
e the target expects them.

> Signed-off-by: Georges Savoundararadj <savoundg@gmail.com>
> ---
>  arch/arm/lib/vectors.S | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/arch/arm/lib/vectors.S b/arch/arm/lib/vectors.S
> index 0cb87ce..49238ed 100644
> --- a/arch/arm/lib/vectors.S
> +++ b/arch/arm/lib/vectors.S
> @@ -33,7 +33,7 @@
>   *************************************************************************
>   */
>  
> -	.section ".vectors", "x"
> +	.section ".vectors", "ax"
>  
>  /*
>   *************************************************************************


Amicalement,
-- 
Albert.

  reply	other threads:[~2014-09-24  7:34 UTC|newest]

Thread overview: 56+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-09-21 21:33 [U-Boot] [PATCH 0/3] arm: add interrupt support Georges Savoundararadj
2014-09-21 21:33 ` [U-Boot] [PATCH 1/3] arm: make .vectors section allocatable Georges Savoundararadj
2014-09-24  7:34   ` Albert ARIBAUD [this message]
2014-09-25 20:11     ` Georges Savoundararadj
2014-09-21 21:33 ` [U-Boot] [PATCH 2/3] arm1176: move exception vectors after relocation Georges Savoundararadj
2014-09-21 21:33 ` [U-Boot] [PATCH 3/3] arm: enable_interrupts: set sp in IRQ/FIQ modes Georges Savoundararadj
2014-09-22  1:35 ` [U-Boot] [PATCH 0/3] arm: add interrupt support Masahiro Yamada
2014-09-22 18:24   ` Georges Savoundararadj
2014-09-23  3:17     ` Masahiro YAMADA
2014-09-24  7:20       ` Albert ARIBAUD
2014-09-24  7:22 ` Albert ARIBAUD
2014-09-27 19:48 ` [U-Boot] [PATCH v2 0/3] arm: fix exception handling Georges Savoundararadj
2014-09-27 19:48   ` [U-Boot] [PATCH v2 1/3] arm: make .vectors section allocatable Georges Savoundararadj
2014-09-27 19:48   ` [U-Boot] [PATCH v2 2/3] arm: relocate the exception vectors Georges Savoundararadj
2014-10-11 10:47     ` Albert ARIBAUD
2014-10-14 20:02       ` Georges Savoundararadj
2014-10-14 22:11         ` Albert ARIBAUD
2014-10-20 21:08           ` Georges Savoundararadj
2014-10-21  5:41             ` Masahiro Yamada
2014-10-21 14:05               ` Albert ARIBAUD
2014-10-22  9:50                 ` Masahiro Yamada
2014-10-22 20:29               ` Georges Savoundararadj
2014-10-21 13:54             ` Albert ARIBAUD
2014-10-22  9:54               ` Masahiro Yamada
2014-10-22 20:52                 ` Georges Savoundararadj
2014-09-27 19:58   ` [U-Boot] [PATCH v2 3/3] arm: interrupt_init: set sp in IRQ/FIQ modes Georges Savoundararadj
2014-10-26 22:25   ` [U-Boot] [PATCH v3 0/4] arm: fix exception handling Georges Savoundararadj
2014-10-26 22:25     ` [U-Boot] [PATCH v3 1/4] kconfig: arm: introduce symbol for ARM CPUs Georges Savoundararadj
2014-10-27 16:50       ` Masahiro YAMADA
2014-10-27 17:09         ` Albert ARIBAUD
2014-10-27 17:23           ` Masahiro YAMADA
2014-10-28  7:01             ` Albert ARIBAUD
2014-10-28 16:10               ` Masahiro YAMADA
2014-10-28 15:57         ` Masahiro YAMADA
2014-10-28 18:58           ` Georges Savoundararadj
2014-10-26 22:25     ` [U-Boot] [PATCH v3 2/4] arm: make .vectors section allocatable Georges Savoundararadj
2014-10-26 23:20       ` Albert ARIBAUD
2014-10-26 22:25     ` [U-Boot] [PATCH v3 3/4] arm: relocate the exception vectors Georges Savoundararadj
2014-10-26 22:25     ` [U-Boot] [PATCH v3 4/4] arm: interrupt_init: set sp in IRQ/FIQ modes Georges Savoundararadj
2014-10-26 23:16       ` Albert ARIBAUD
2014-10-26 23:32         ` Albert ARIBAUD
2014-10-28 22:16     ` [U-Boot] [PATCH v4 0/4] arm: fix exception handling Georges Savoundararadj
2014-10-28 22:16       ` [U-Boot] [PATCH v4 1/4] kconfig: arm: introduce symbol for ARM CPUs Georges Savoundararadj
2014-10-29  8:07         ` Masahiro Yamada
2014-10-29 12:37           ` Tom Rini
2014-10-29 12:50         ` Albert ARIBAUD
2014-10-29 15:22         ` Tom Rini
2014-10-28 22:16       ` [U-Boot] [PATCH v4 2/4] arm: make .vectors section allocatable Georges Savoundararadj
2014-10-29 12:49         ` Albert ARIBAUD
2014-10-29 15:22         ` Tom Rini
2014-10-28 22:16       ` [U-Boot] [PATCH v4 3/4] arm: relocate the exception vectors Georges Savoundararadj
2014-10-29 12:49         ` Albert ARIBAUD
2014-10-29 15:22         ` Tom Rini
2014-10-28 22:16       ` [U-Boot] [PATCH v4 4/4] arm: interrupt_init: set sp in IRQ/FIQ modes Georges Savoundararadj
2014-10-29 12:49         ` Albert ARIBAUD
2014-10-29 15:22         ` Tom Rini

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=E1XWh6D-0007eA-MQ@janus \
    --to=albert.u.boot@aribaud.net \
    --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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox