public inbox for binutils@sourceware.org
 help / color / mirror / Atom feed
From: "H.J. Lu" <hjl.tools@gmail.com>
To: binutils@sourceware.org
Subject: Re: [PATCH v2] ld: Turn on --error-execstack/--error-rwx-segments
Date: Sun, 28 Jan 2024 07:04:54 -0800	[thread overview]
Message-ID: <CAMe9rOrdLof6HG6ZirddP-c25iENwU-ALDE9zD+-sBfAZbagBw@mail.gmail.com> (raw)
In-Reply-To: <20240126214553.46536-1-hjl.tools@gmail.com>

On Fri, Jan 26, 2024 at 1:45 PM H.J. Lu <hjl.tools@gmail.com> wrote:
>
> Changes in v2:
>
> 1. Update the expected error in testsuite/ld-elf/pr31299-1.error to
> allow different error messages.
>
> ---
> Since --fatal-warnings always turns a warning to an error, turn on
> --error-execstack for --warn-execstack and --error-rwx-segments for
> --warn-rwx-segments if --fatal-warnings is used, overriding
> --no-error-execstack and --no-error-rwx-segments.
>
>         PR ld/31299
>         * lexsup.c (parse_args): Turn on --error-execstack for
>         --warn-execstack and --error-rwx-segments for --warn-rwx-segments
>         if --fatal-warnings is used.
>         * testsuite/ld-elf/elf.exp: Run PR ld/31299 tests.
>         * testsuite/ld-elf/pr31299-1.error: New file.
>         * testsuite/ld-elf/pr31299-2.error: Likewise.
>         * testsuite/ld-elf/pr31299-3.error: Likewise.
> ---
>  ld/lexsup.c                         | 11 +++++++++++
>  ld/testsuite/ld-elf/elf.exp         | 26 +++++++++++++++++++++++++-
>  ld/testsuite/ld-elf/pr31299-1.error |  2 ++
>  ld/testsuite/ld-elf/pr31299-2.error |  1 +
>  ld/testsuite/ld-elf/pr31299-3.error |  1 +
>  5 files changed, 40 insertions(+), 1 deletion(-)
>  create mode 100644 ld/testsuite/ld-elf/pr31299-1.error
>  create mode 100644 ld/testsuite/ld-elf/pr31299-2.error
>  create mode 100644 ld/testsuite/ld-elf/pr31299-3.error
>
> diff --git a/ld/lexsup.c b/ld/lexsup.c
> index 099dff8ecde..787d3d02e51 100644
> --- a/ld/lexsup.c
> +++ b/ld/lexsup.c
> @@ -1947,6 +1947,17 @@ parse_args (unsigned argc, char **argv)
>        && command_line.check_section_addresses < 0)
>      command_line.check_section_addresses = 0;
>
> +  /* Override --no-error-execstack and --no-warn-execstack and turn on
> +     --error-execstack for --warn-execstack and --error-rwx-segments for
> +     --warn-rwx-segments if --fatal-warnings is used.  */
> +  if (config.fatal_warnings)
> +    {
> +      if (link_info.warn_execstack)
> +       link_info.error_execstack = 1;
> +      if (!link_info.no_warn_rwx_segments)
> +       link_info.warn_is_error_for_rwx_segments = 1;
> +    }
> +
>    if (export_list)
>      {
>        struct bfd_elf_version_expr *head = export_list->head.list;
> diff --git a/ld/testsuite/ld-elf/elf.exp b/ld/testsuite/ld-elf/elf.exp
> index 685b87588e7..6ece36b7931 100644
> --- a/ld/testsuite/ld-elf/elf.exp
> +++ b/ld/testsuite/ld-elf/elf.exp
> @@ -305,7 +305,23 @@ if {   [istarget *-*-*linux*]
>             {nobits-1.s} \
>              {} \
>             "rwx-segments-3.exe"] \
> -         ]
> +       [list "Ensure that an error issued when creating a segment with RWX permissions" \
> +           "-e 0 -Tnobits-1.t --warn-rwx-segments \
> +            --fatal-warnings --no-error-rwx-segments" \
> +           "" \
> +           "" \
> +           {nobits-1.s} \
> +           {{ld pr31299-2.error}} \
> +           "pr31299-2.exe"] \
> +       [list "Ensure that an error issued when creating a TLS segment with execute permission" \
> +           "-e 0 -T rwx-segments-2.t --warn-rwx-segments \
> +            --fatal-warnings --no-error-rwx-segments" \
> +           "" \
> +           "" \
> +           {size-2.s} \
> +           {{ld pr31299-3.error}} \
> +           "pr31299-3.exe"] \
> +    ]
>
>      set LDFLAGS $curr_ldflags
>
> @@ -318,6 +334,14 @@ if {   [istarget *-*-*linux*]
>             {pr29072-b.s} \
>             {{ld pr29072.b.warn}} \
>             "pr29072-b.exe"] \
> +          [list "PR ld/31299 (error about absent .note.GNU-stack)" \
> +           "-e 0 -z stack-size=0x123400 --warn-execstack \
> +            --fatal-warnings --no-error-execstack" \
> +           "" \
> +           "" \
> +           {pr29072-b.s} \
> +           {{ld pr31299-1.error}} \
> +           "pr31299-1.exe"] \
>         ]
>      } else {
>         run_ld_link_tests [list \
> diff --git a/ld/testsuite/ld-elf/pr31299-1.error b/ld/testsuite/ld-elf/pr31299-1.error
> new file mode 100644
> index 00000000000..eb2598df3e6
> --- /dev/null
> +++ b/ld/testsuite/ld-elf/pr31299-1.error
> @@ -0,0 +1,2 @@
> +.*: error: .*\.o: is triggering the generation of an executable stack because it does not have a \.note\.GNU-stack section
> +.*: failed to set dynamic section sizes: .*
> diff --git a/ld/testsuite/ld-elf/pr31299-2.error b/ld/testsuite/ld-elf/pr31299-2.error
> new file mode 100644
> index 00000000000..e5b73657069
> --- /dev/null
> +++ b/ld/testsuite/ld-elf/pr31299-2.error
> @@ -0,0 +1 @@
> +.*: error: .* has a LOAD segment with RWX permissions
> diff --git a/ld/testsuite/ld-elf/pr31299-3.error b/ld/testsuite/ld-elf/pr31299-3.error
> new file mode 100644
> index 00000000000..b9ba368ba2c
> --- /dev/null
> +++ b/ld/testsuite/ld-elf/pr31299-3.error
> @@ -0,0 +1 @@
> +.*: error: .* has a TLS segment with execute permission
> --
> 2.43.0
>

If there is no objection, I will check it tomorrow.

Thanks.

-- 
H.J.

  reply	other threads:[~2024-01-28 15:05 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-01-26 21:45 H.J. Lu
2024-01-28 15:04 ` H.J. Lu [this message]
2024-01-29  7:33   ` Jan Beulich
2024-01-29 12:59     ` H.J. Lu
2024-01-29  7:30 ` Jan Beulich
2024-01-29 13:03   ` H.J. Lu
2024-01-29 14:03     ` Jan Beulich
2024-01-29 14:10       ` H.J. Lu

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=CAMe9rOrdLof6HG6ZirddP-c25iENwU-ALDE9zD+-sBfAZbagBw@mail.gmail.com \
    --to=hjl.tools@gmail.com \
    --cc=binutils@sourceware.org \
    /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;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).