[PATCH] elfnote: mark all .note sections SHF_ALLOC

3 views
Skip to first unread message

Nick Desaulniers

unread,
Mar 25, 2020, 7:13:06 PM3/25/20
to Thomas Gleixner, Andrew Morton, clang-bu...@googlegroups.com, Nick Desaulniers, Jeremy Fitzhardinge, Ilie Halip, Vincenzo Frascino, linux-...@vger.kernel.org
ELFNOTE_START allows callers to specify flags for .pushsection assembler
directives. All callsites but ELF_NOTE use "a" for SHF_ALLOC. For
vdso's that explicitly use ELF_NOTE_START and BUILD_SALT, the same
section is specified twice after preprocessing, once with "a" flag, once
without. Example:

.pushsection .note.Linux, "a", @note ;
.pushsection .note.Linux, "", @note ;

While GNU as allows this ordering, it warns for the opposite ordering,
making these directives position dependent. We'd prefer not to precisely
match this behavior in Clang's integrated assembler. Instead, the non
__ASSEMBLY__ definition of ELF_NOTE uses
__attribute__((section(".note.Linux"))) which is created with SHF_ALLOC,
so let's make the __ASSEMBLY__ definition of ELF_NOTE consistent with C
and just always use "a" flag.

This allows Clang to assemble a working mainline (5.6) kernel via:
$ make CC=clang AS=clang

Link: https://github.com/ClangBuiltLinux/linux/issues/913
Cc: Jeremy Fitzhardinge <jer...@xensource.com>
Debugged-by: Ilie Halip <ilie....@gmail.com>
Signed-off-by: Nick Desaulniers <ndesau...@google.com>
---
Ilie has further treewide cleanups:
https://github.com/ihalip/linux/commits/elfnote
This patch is the simplest to move us forwards.

include/linux/elfnote.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/include/linux/elfnote.h b/include/linux/elfnote.h
index 594d4e78654f..69b136e4dd2b 100644
--- a/include/linux/elfnote.h
+++ b/include/linux/elfnote.h
@@ -54,7 +54,7 @@
.popsection ;

#define ELFNOTE(name, type, desc) \
- ELFNOTE_START(name, type, "") \
+ ELFNOTE_START(name, type, "a") \
desc ; \
ELFNOTE_END

--
2.26.0.rc2.310.g2932bb562d-goog

Nick Desaulniers

unread,
Apr 3, 2020, 6:13:47 PM4/3/20
to Thomas Gleixner, Andrew Morton, clang-built-linux, Ilie Halip, Vincenzo Frascino, LKML
dropping Jeremy; I got bounceback from the email address. Ping for review?
--
Thanks,
~Nick Desaulniers

Nathan Chancellor

unread,
Apr 3, 2020, 6:25:01 PM4/3/20
to Nick Desaulniers, Thomas Gleixner, Andrew Morton, clang-built-linux, Ilie Halip, Vincenzo Frascino, LKML
On Fri, Apr 03, 2020 at 03:13:34PM -0700, 'Nick Desaulniers' via Clang Built Linux wrote:
> dropping Jeremy; I got bounceback from the email address. Ping for review?
>
> On Wed, Mar 25, 2020 at 4:13 PM Nick Desaulniers
> <ndesau...@google.com> wrote:
> >
> > ELFNOTE_START allows callers to specify flags for .pushsection assembler
> > directives. All callsites but ELF_NOTE use "a" for SHF_ALLOC. For
> > vdso's that explicitly use ELF_NOTE_START and BUILD_SALT, the same
> > section is specified twice after preprocessing, once with "a" flag, once
> > without. Example:
> >
> > .pushsection .note.Linux, "a", @note ;
> > .pushsection .note.Linux, "", @note ;
> >
> > While GNU as allows this ordering, it warns for the opposite ordering,
> > making these directives position dependent. We'd prefer not to precisely
> > match this behavior in Clang's integrated assembler. Instead, the non
> > __ASSEMBLY__ definition of ELF_NOTE uses
> > __attribute__((section(".note.Linux"))) which is created with SHF_ALLOC,
> > so let's make the __ASSEMBLY__ definition of ELF_NOTE consistent with C
> > and just always use "a" flag.
> >
> > This allows Clang to assemble a working mainline (5.6) kernel via:
> > $ make CC=clang AS=clang
> >
> > Link: https://github.com/ClangBuiltLinux/linux/issues/913
> > Cc: Jeremy Fitzhardinge <jer...@xensource.com>
> > Debugged-by: Ilie Halip <ilie....@gmail.com>
> > Signed-off-by: Nick Desaulniers <ndesau...@google.com>

Reviewed-by: Nathan Chancellor <natecha...@gmail.com>

Fangrui Song

unread,
Apr 3, 2020, 8:40:25 PM4/3/20
to Nathan Chancellor, Nick Desaulniers, Thomas Gleixner, Andrew Morton, clang-built-linux, Ilie Halip, Vincenzo Frascino, LKML
I asked on binu...@sourceware.org whether GNU as is willing to change.
https://sourceware.org/pipermail/binutils/2020-March/109997.html
I'll also ping that thread.


Reviewed-by: Fangrui Song <mas...@google.com>

>> > ---
>> > Ilie has further treewide cleanups:
>> > https://github.com/ihalip/linux/commits/elfnote
>> > This patch is the simplest to move us forwards.
>> >
>> > include/linux/elfnote.h | 2 +-
>> > 1 file changed, 1 insertion(+), 1 deletion(-)
>> >
>> > diff --git a/include/linux/elfnote.h b/include/linux/elfnote.h
>> > index 594d4e78654f..69b136e4dd2b 100644
>> > --- a/include/linux/elfnote.h
>> > +++ b/include/linux/elfnote.h
>> > @@ -54,7 +54,7 @@
>> > .popsection ;
>> >
>> > #define ELFNOTE(name, type, desc) \
>> > - ELFNOTE_START(name, type, "") \
>> > + ELFNOTE_START(name, type, "a") \
>> > desc ; \
>> > ELFNOTE_END
>> >
>> > --
>> > 2.26.0.rc2.310.g2932bb562d-goog
>> >
>>
>>
>> --
>> Thanks,
>> ~Nick Desaulniers
>
>
>--
>You received this message because you are subscribed to the Google Groups "Clang Built Linux" group.
>To unsubscribe from this group and stop receiving emails from it, send an email to clang-built-li...@googlegroups.com.
>To view this discussion on the web visit https://groups.google.com/d/msgid/clang-built-linux/20200403222458.GA49554%40ubuntu-m2-xlarge-x86.

Gulshan Kumar

unread,
Apr 3, 2020, 8:53:20 PM4/3/20
to Nathan Chancellor, Nick Desaulniers, Thomas Gleixner, Andrew Morton, clang-built-linux, Ilie Halip, Vincenzo Frascino, LKML
unsubscribe


Nick Desaulniers

unread,
Apr 10, 2020, 3:12:30 PM4/10/20
to Thomas Gleixner, Andrew Morton, Nathan Chancellor, clang-built-linux, Ilie Halip, Vincenzo Frascino, LKML, Fangrui Song
(bumping for review)
--
Thanks,
~Nick Desaulniers
Reply all
Reply to author
Forward
0 new messages