]> git.ipfire.org Git - thirdparty/binutils-gdb.git/log
thirdparty/binutils-gdb.git
6 weeks agoRemove annoying space from gas/config/obj-elf.c
Matthieu Longo [Sat, 12 Apr 2025 17:05:50 +0000 (18:05 +0100)] 
Remove annoying space from gas/config/obj-elf.c

6 weeks agostrip: Add GCC LTO IR support
H.J. Lu [Sat, 3 May 2025 21:12:46 +0000 (05:12 +0800)] 
strip: Add GCC LTO IR support

Add GCC LTO IR support to strip by copying GCC LTO IR input as unknown
object file.  Don't enable LTO plugin in strip unless all LTO sections
should be removed, assuming all LTO sections will be removed with
-R .gnu.lto_.*.  Add linker LTO tests for strip with --strip-unneeded
and GCC LTO IR inputs.

binutils/

PR binutils/21479
* objcopy.c: Include "plugin-api.h" and "plugin.h".
(lto_sections_removed): New.
(command_line_switch): Add OPTION_PLUGIN.
(strip_options): Likewise.
(strip_usage): Display "--plugin NAME".
(copy_unknown_file): New function.
(copy_unknown_object): Call copy_unknown_file.
(copy_archive): Copy input LTO IR member as unknown object.
(copy_file): Set input target to "plugin" for strip if it is
unset unless all LTO sections should be removed.  Copy input
LTO IR file as unknown file.
(strip_main): Call bfd_plugin_set_program_name. Handle
OPTION_PLUGIN.  Set lto_sections_removed to true if all GCC
LTO sections should be removed.
* doc/binutils.texi: Document --plugin for strip.

ld/

PR binutils/21479
* testsuite/ld-plugin/lto-binutils.exp: New file.
* testsuite/ld-plugin/strip-1a-fat.c: Likewise.
* testsuite/ld-plugin/strip-1a-fat.rd: Likewise.
* testsuite/ld-plugin/strip-1b-fat.c: Likewise.
* testsuite/ld-plugin/strip-1b-fat.rd: Likewise.
* testsuite/ld-plugin/strip-1a.c: Likewise.
* testsuite/ld-plugin/strip-1b.c: Likewise.
* testsuite/lib/ld-lib.exp (run_cc_link_tests): Add optional
trailing ld options.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
6 weeks agold: fix C23 issue in vers7 test
Sam James [Wed, 14 May 2025 05:38:56 +0000 (06:38 +0100)] 
ld: fix C23 issue in vers7 test

This test is UNSUPPORTED on arm64 with GCC 15 (which defaults to -std=gnu23)
because it now prototypes "no arguments".

PR ld/32546
* ld-elfvers/vers7.c: Fix function definitions for C23.

6 weeks agoAutomatic date update in version.in
GDB Administrator [Wed, 14 May 2025 00:00:10 +0000 (00:00 +0000)] 
Automatic date update in version.in

6 weeks agoaarch64: Replace incorrect comment
Alice Carlotti [Fri, 4 Apr 2025 18:23:11 +0000 (19:23 +0100)] 
aarch64: Replace incorrect comment

The comment explaining the placement of the cfinv entry before the
generic msr entry in the opcode table was incorrect.  The issue is
unrelated to the all ones bitmask for cfinv, and is actually due the
large number of architectural aliases of the msr instruction.

6 weeks agogdb/python: new gdb.ParameterPrefix class
Andrew Burgess [Sun, 13 Apr 2025 10:26:41 +0000 (11:26 +0100)] 
gdb/python: new gdb.ParameterPrefix class

This commit adds a new gdb.ParameterPrefix class to GDB's Python API.

When creating multiple gdb.Parameters, it is often desirable to group
these together under a sub-command, for example, 'set print' has lots
of parameters nested under it, like 'set print address', and 'set
print symbol'.  In the Python API the 'print' part of these commands
are called prefix commands, and are created using gdb.Command objects.

However, as parameters are set via the 'set ....' command list, and
shown through the 'show ....' command list, creating a prefix for a
parameter usually requires two prefix commands to be created, one for
the 'set' command, and one for the 'show' command.

This often leads to some duplication, or at the very least, each user
will end up creating their own helper class to simplify creation of
the two prefix commands.

This commit adds a new gdb.ParameterPrefix class.  Creating a single
instance of this class will create both the 'set' and 'show' prefix
commands, which can then be used while creating the gdb.Parameter.

Here is an example of it in use:

  gdb.ParameterPrefix('my-prefix', gdb.COMMAND_NONE)

This adds 'set my-prefix' and 'show my-prefix', both of which are
prefix commands.  The user can then add gdb.Parameter objects under
these prefixes.

The gdb.ParameterPrefix initialise method also supports documentation
strings, so we can write:

  gdb.ParameterPrefix('my-prefix', gdb.COMMAND_NONE,
      "Configuration setting relating to my special extension.")

which will set the documentation string for the prefix command.

Also, it is possible to support prefix commands that use the `invoke`
functionality to handle unknown sub-commands.  This is done by
sub-classing gdb.ParameterPrefix and overriding either 'invoke_set' or
'invoke_show' to handle the 'set' or 'show' prefix command
respectively.

Reviewed-By: Eli Zaretskii <eliz@gnu.org>
6 weeks agogdb/guile: generate general description string for parameters
Andrew Burgess [Sat, 12 Apr 2025 14:42:25 +0000 (15:42 +0100)] 
gdb/guile: generate general description string for parameters

This commit builds on the previous one, and auto-generates a general
description string for parameters defined via the Guile API.  This
brings the Guile API closer inline with the Python API.  It is worth
reading the previous commit to see some motivating examples.

This commit updates get_doc_string in guile/scm-param.c to allow for
the generation of a general description string.  Then in
gdbscm_make_parameter, if '#:doc' was not given, get_doc_string is
used to generate a suitable default.

This does invalidate (and so the commit removes) this comment that was
in gdbscm_make_parameter:

  /* If doc is NULL, leave it NULL.  See add_setshow_cmd_full.  */

First, Python already does exactly what I'm proposing here, and has
done for a while, with no issues reported.  And second, I've gone and
read add_setshow_cmd_full, and some of the functions it calls, and can
see no reasoning behind this comment...

... well, there is one reason that I can think of, but I'll discuss
that more below.

With this commit, if I define a parameter like this:

  (use-modules (gdb))
  (register-parameter! (make-parameter
                        "print test"
                        #:command-class COMMAND_NONE
                        #:parameter-type PARAM_BOOLEAN))

Then, in GDB, I now see this behaviour:

  (gdb) help show print test
  Show the current value of 'print test'.
  This command is not documented.
  (gdb) help set print test
  Set the current value of 'print test'.
  This command is not documented.
  (gdb)

The two 'This command is not documented.' lines are new.  This output
is what we get from a similarly defined parameter using the Python
API (see the previous commit for an example).

I mentioned above that I can think of one reason for the (now deleted)
comment in gdbscm_make_parameter about leaving the doc field as NULL,
and that is this: consider the following GDB behaviour:

  (gdb) help show style filename foreground
  Show the foreground color for this property.
  (gdb)

Notice there is only a single line of output.  If I want to get the
same behaviour from a parameter defined in Guile, I might try skipping
the #:doc argument, but (after this commit), if I do that, GDB will
auto-generate some text for me, giving two lines of output (see
above).

So, next, maybe I try setting #:doc to the empty string, but if I do
that, then I get this:

  (use-modules (gdb))
  (register-parameter! (make-parameter
                        "print test"
#:doc ""
                        #:command-class COMMAND_NONE
                        #:parameter-type PARAM_BOOLEAN))

  (gdb) help show print test
  Show the current value of 'print test'.

  (gdb)

Notice the blank line, that's not what I wanted.  In fact, the only
way to get rid of the second line is to leave the 'doc' variable as
NULL in gdbscm_make_parameter, which, due to the new auto-generation,
is no longer possible.

This issue also existed in the Python API, and was addressed in
commit:

  commit 4b68d4ac98aec7cb73a4b276ac7dd38d112786b4
  Date:   Fri Apr 11 23:45:51 2025 +0100

      gdb/python: allow empty gdb.Parameter.__doc__ string

After this commit, an empty __doc__ string for a gdb.Parameter is
translated into a NULL pointer passed to the add_setshow_* command,
which means the second line of output is completely skipped.

And this commit includes the same solution for the Guile API.  Now,
with this commit, and the Guile parameter using an empty '#:doc'
string, GDB has the following behaviour:

  (gdb) help show print test
  Show the current value of 'print test'.
  (gdb)

This matches the output for a similarly defined parameter in Python.

6 weeks agogdb/guile: improve auto-generated strings for parameters
Andrew Burgess [Sat, 12 Apr 2025 13:19:20 +0000 (14:19 +0100)] 
gdb/guile: improve auto-generated strings for parameters

Consider this user defined parameter created in Python:

  class test_param(gdb.Parameter):
     def __init__(self, name):
        super ().__init__(name, gdb.COMMAND_NONE, gdb.PARAM_BOOLEAN)
        self.value = True

  test_param('print test')

If this is loaded into GDB, then we observe the following behaviour:

  (gdb) show print test
  The current value of 'print test' is "on".
  (gdb) help show print test
  Show the current value of 'print test'.
  This command is not documented.
  (gdb) help set print test
  Set the current value of 'print test'.
  This command is not documented.
  (gdb)

If we now define the same parameter using Guile:

  (use-modules (gdb))
  (register-parameter! (make-parameter
                        "print test"
                        #:command-class COMMAND_NONE
                        #:parameter-type PARAM_BOOLEAN))

And load this into a fresh GDB session, we see the following:

  (gdb) show print test
  Command is not documented is off.
  (gdb) help show print test
  This command is not documented.
  (gdb) help set print test
  This command is not documented.
  (gdb)

The output of 'show print test' doesn't make much sense, and is
certainly worse than the Python equivalent.  For both the 'help'
commands it appears as if the first line is missing, but what is
actually happening is that the first line has become 'This command is
not documented.', and the second line is then missing.

The problems can all be traced back to 'get_doc_string' in
guile/scm-param.c.  This is the guile version of this function.  There
is a similar function in python/py-param.c, however, the Python
version returns one of three different strings depending on the use
case.  In contrast, the Guile version just returns 'This command is
not documented.' in all cases.

The three cases that the Python code handles are, the 'set' string,
the 'show' string, and the general 'description' string.

Right now the Guile get_doc_string only returns the general
'description' string, which is funny, because, in
gdbscm_make_parameter, where get_doc_string is used, the one case that
we currently don't need is the general 'description' string.  Instead,
right now, the general 'description' string is used for both the 'set'
and 'show' cases.

In this commit I plan to bring the Guile API a little more inline with
the Python API.  I will update get_doc_string (in scm-param.c) to
return either a 'set' or 'show' string, and gdbscm_make_parameter will
make use of these strings.

The changes to the Guile get_doc_string are modelled on the Python
version of this function.  It is also worth checking out the next
commit, which is related, and helps motivate how the changes have been
implemented in this commit.

After this commit, the same Guile parameter description shown above,
now gives this behaviour:

  (gdb) show print test
  The current value of 'print test' is off.
  (gdb) help show print test
  Show the current value of 'print test'.
  (gdb) help set print test
  Set the current value of 'print test'.
  (gdb)

The 'show print test' output now matches the Python behaviour, and is
much more descriptive.  The set and show 'help' output are now missing
the second line when compared to the Python output, but the first line
is now correct, and I think this is better than the previous Guile
output.

In the next commit I'll address the problem of the missing second
line.

Existing tests have been updated to expect the new output.

6 weeks agogdb/python: allow empty gdb.Parameter.__doc__ string
Andrew Burgess [Fri, 11 Apr 2025 22:45:51 +0000 (23:45 +0100)] 
gdb/python: allow empty gdb.Parameter.__doc__ string

I was recently attempting to create some parameters via the Python
API.  I wanted these parameters to appear similar to how GDB handles
the existing 'style' parameters.

Specifically, I was interested in this behaviour:

  (gdb) help show style filename foreground
  Show the foreground color for this property.
  (gdb) help set style filename foreground
  Set the foreground color for this property.
  (gdb)

Notice how each 'help' command only gets a single line of output.

I tried to reproduce this behaviour via the Python API and was unable.

The problem is that, in order to get just a single line of output like
this, the style parameters are registered with a call to
add_setshow_color_cmd with the 'help_doc' being passed as nullptr.

On the Python side, when parameters are created, the 'help_doc' is
obtained with a call to get_doc_string (python/py-param.c).  This
function either returns the __doc__ string, or a default string: "This
command is not documented.".

To avoid returning the default we could try setting __doc__ to an
empty string, but setting this field to any string means that GDB
prints a line for that string, like this:

  class test_param(gdb.Parameter):
     __doc__ = ""
     def __init__(self, name):
        super ().__init__(name, gdb.COMMAND_NONE, gdb.PARAM_BOOLEAN)
        self.value = True

  test_param('print test')

Then in GDB:

  (gdb) help set print test
  Set the current value of 'print test'.

  (gdb)

The blank line is the problem I'd like to solve.

This commit makes a couple of changes to how parameter doc strings are
handled.

If the doc string is set to an empty string, then GDB now converts
this to nullptr, which removes the blank line problem, the new
behaviour in GDB (for the above `test_param`) is:

  (gdb) help set print test
  Set the current value of 'print test'.
  (gdb)

Next, I noticed that if the set/show docs are set to empty strings,
then the results are less than ideal:

  class test_param(gdb.Parameter):
     set_doc = ""
     def __init__(self, name):
        super ().__init__(name, gdb.COMMAND_NONE, gdb.PARAM_BOOLEAN)
        self.value = True

  test_param('print test')

And in GDB:

  (gdb) help set print test

  This command is not documented.
  (gdb)

So, if the set/show docs are the empty string, GDB now forces these to
be the default string instead, the new behaviour in GDB is:

  (gdb) help set print test
  Set the current value of 'print test'.
  This command is not documented.
  (gdb)

I've added some additional asserts; the set/show docs should always be
non-empty strings, which I believe is the case after this commit.  And
the 'doc' string returned from get_doc_string should never nullptr,
but could be empty.

There are new tests to cover all these changes.

6 weeks agogdb/python/guile: check for invalid prefixes in Command/Parameter creation
Andrew Burgess [Fri, 11 Apr 2025 15:01:02 +0000 (16:01 +0100)] 
gdb/python/guile: check for invalid prefixes in Command/Parameter creation

The manual for gdb.Parameter says:

  If NAME consists of multiple words, and no prefix parameter group
  can be found, an exception is raised.

This makes sense; we cannot create a parameter within a prefix group,
if the prefix doesn't exist.  And this almost works, so:

  (gdb) python gdb.Parameter("xxx foo", gdb.COMMAND_NONE, gdb.PARAM_BOOLEAN)
  Python Exception <class 'RuntimeError'>: Could not find command prefix xxx.
  Error occurred in Python: Could not find command prefix xxx.

The prefix 'xxx' doesn't exist, and we get an error.  But, if we try
multiple levels of prefix:

  (gdb) python gdb.Parameter("print xxx foo", gdb.COMMAND_NONE, gdb.PARAM_BOOLEAN)

This completes without error, however, we didn't get what we were
maybe expecting:

  (gdb) show print xxx foo
  Undefined show print command: "xxx foo".  Try "help show print".

But we did get:

  (gdb) show print foo
  The current value of 'print foo' is "off".

GDB stopped scanning the prefix string at the unknown 'xxx', and just
created the parameter there.  I don't think this makes sense, nor is
it inline with the manual.

An identical problem exists with gdb.Command creation; GDB stops
parsing the prefix at the first unknown prefix, and just creates the
command there.  The manual for gdb.Command says:

  NAME is the name of the command.  If NAME consists of multiple
  words, then the initial words are looked for as prefix commands.
  In this case, if one of the prefix commands does not exist, an
  exception is raised.

So again, the correct action is, I believe, to raise an exception.

The problem is in gdbpy_parse_command_name (python/py-cmd.c), GDB
calls lookup_cmd_1 to look through the prefix string and return the
last prefix group.  If the very first prefix word is invalid then
lookup_cmd_1 returns NULL, and this case is handled.  However, if
there is a valid prefix, followed by an invalid prefix, then
lookup_cmd_1 will return a pointer to the last valid prefix list, and
will update the input argument to point to the start of the invalid
prefix word.  This final case, where the input is left pointing to an
unknown prefix, was previously not handled.

I've fixed gdbpy_parse_command_name, and added tests for command and
parameter creation to cover this case.

The exact same error is present in the guile API too.  The guile
documentation for make-parameter and make-command says the same things
about unknown prefixes resulting in an exception, but the same error
is present in gdbscm_parse_command_name (guile/scm-cmd.c), so I've
fixed that too, and added some tests.

6 weeks agoAutomatic date update in version.in
GDB Administrator [Tue, 13 May 2025 00:00:09 +0000 (00:00 +0000)] 
Automatic date update in version.in

6 weeks agogdb/dwarf: skip broken .debug_macro.dwo
Simon Marchi [Tue, 6 May 2025 17:03:47 +0000 (13:03 -0400)] 
gdb/dwarf: skip broken .debug_macro.dwo

Running gdb.base/errno.exp with gcc <= 13 with split DWARF results in:

    $ make check TESTS="gdb.base/errno.exp" RUNTESTFLAGS="CC_FOR_TARGET=gcc-13 --target_board=fission"
    (gdb) break -qualified main
    /home/smarchi/src/binutils-gdb/gdb/dwarf2/read.c:7549: internal-error: locate_dwo_sections: Assertion `!dw_sect->readin' failed.
    A problem internal to GDB has been detected,
    further debugging may prove unreliable.
    ...
    FAIL: gdb.base/errno.exp: macros: gdb_breakpoint: set breakpoint at main (GDB internal error)

The assert being hit has been added in 28f15782adab ("gdb/dwarf: read
multiple .debug_info.dwo sections"), but it merely exposed an existing
problem.

gcc versions <= 13 are affected by this bug:

  https://gcc.gnu.org/bugzilla/show_bug.cgi?id=111409

Basically, it produces .dwo files with multiple .debug_macro.dwo
sections, with some unresolved links between them.  I think that this
macro debug info is unusable, and all we can do is ignore it.

In locate_dwo_sections, if we detect a second .debug_macro.dwo section,
forget about the previous .debug_macro.dwo and any subsequent one.  This
will effectively make it as if the macro debug info wasn't there at all.

The errno test seems happy with it:

    # of expected passes            84
    # of expected failures          8

Change-Id: I6489b4713954669bf69f6e91865063ddcd1ac2c8
Approved-By: Tom Tromey <tom@tromey.com>
6 weeks agogdb/dwarf: move loops into locate_dw{o,z}_sections
Simon Marchi [Tue, 6 May 2025 17:03:46 +0000 (13:03 -0400)] 
gdb/dwarf: move loops into locate_dw{o,z}_sections

For a subsequent patch, it would be easier if the loop over sections
inside locate_dwo_sections (I want to maintain some state for the
duration of the loop).  Move the for loop in there.  And because
locate_dwz_sections is very similar, modify that one too, to keep both
in sync.

Change-Id: I90b3d44184910cc2d86af265bb4b41828a5d2c2e
Approved-By: Tom Tromey <tom@tromey.com>
6 weeks agogdb/dap: fix decode_source
oltolm [Sat, 10 May 2025 08:56:12 +0000 (10:56 +0200)] 
gdb/dap: fix decode_source

The documentation for the Source interface says

   * The path of the source to be shown in the UI.
   * It is only used to locate and load the content of the source if no
   * `sourceReference` is specified (or its value is 0).

but the code used `path` first. I fixed it to use `sourceReference` first.

Approved-By: Tom Tromey <tom@tromey.com>
6 weeks ago[PATCH] Add syscall tests when following/detaching from fork
Keith Seitz [Mon, 12 May 2025 16:28:02 +0000 (09:28 -0700)] 
[PATCH] Add syscall tests when following/detaching from fork

breakpoints/13457 discusses issues with syscall catchpoints when
following forks, lamenting that there is no coverage for the
various permutations of `follow-fork-mode' and `detach-on-fork'.

This is an attempt to try and cover some of this ground. Unfortunately
the state of syscall support when detaching after the fork is
very, very inconsistent across various architectures. [I've tested
extensively Fedora/RHEL platforms.]

Right now, the only reliable platform to run tests on is x86_64/i?86
for the specific case where we do not detach from the fork. Consequently,
this patch limits testing to those architectures.

I have updated breakpoints/13457 with my findings on failures with the
detaching case.

Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=13457
Approved-By: Andrew Burgess <aburgess@redhat.com>
6 weeks agoaarch64: Support for FEAT_RME_GPC3
Ezra Sitorus [Fri, 2 May 2025 17:08:21 +0000 (18:08 +0100)] 
aarch64: Support for FEAT_RME_GPC3

FEAT_RME_GPC3 - RME Granule Protection Check 3 Extension - introduces
a method for defining a set of windows in the memory map for which
Granule Protection Checks are skipped, and instead applies a set of
default settings associated with the window.

This patch introduces the sysreg gpcbw_el3. Add -march=armv9.5-a to
access this sysreg since this feature is optional from armv9.5-a.

6 weeks agoaarch64: Support for FEAT_OCCMO
Ezra Sitorus [Fri, 2 May 2025 16:14:07 +0000 (17:14 +0100)] 
aarch64: Support for FEAT_OCCMO

FEAT_OCCMO - Outer Cacheable Cache Maintenance Operation - introduces
system instructions that provides software with a mechanism to publish
writes to the Outer cache level.

6 weeks agogdbsupport/event-loop: do not truncate poll timeouts to lower second
Patrick Monnerat [Mon, 12 May 2025 15:36:17 +0000 (17:36 +0200)] 
gdbsupport/event-loop: do not truncate poll timeouts to lower second

In update_wait_timeout function, microseconds were not taken into account
in poll timeout computation, resulting in 100% cpu time consumption in
the event loop while waiting for a sub-second timeout.

The bug has been introduced in commit c2c6d25.

This patch adds the microseconds converted to milliseconds in poll
timeout computation. Conversion by excess (ceil) is performed to
avoid the same problem with sub-millisecond timeouts too.

6 weeks agogdb: pass std::string from linux_find_memory_regions_full
Andrew Burgess [Wed, 7 May 2025 10:00:13 +0000 (11:00 +0100)] 
gdb: pass std::string from linux_find_memory_regions_full

Update linux_find_memory_region_ftype to take 'const std::string &'
instead of 'const char *', update the two functions which are passed
as callbacks to linux_find_memory_regions_full.

There should be no user visible changes after this commit.

Approved-By: Simon Marchi <simon.marchi@efficios.com>
6 weeks agogdb: remove unnecessary function declaration
Andrew Burgess [Wed, 7 May 2025 09:57:17 +0000 (10:57 +0100)] 
gdb: remove unnecessary function declaration

There's no need to declare a function immediately before its
definition.  Lets not do that.

There should be no user visible changes after this commit.

Approved-By: Simon Marchi <simon.marchi@efficios.com>
6 weeks agogdb: move extra checks into dump_note_entry_p
Andrew Burgess [Wed, 7 May 2025 09:53:41 +0000 (10:53 +0100)] 
gdb: move extra checks into dump_note_entry_p

Now that dump_note_entry_p is always called (see previous commit), we
can move some of the checks out of linux_make_mappings_callback into
dump_note_entry_p.

The checks only exist in linux_make_mappings_callback because, before
the previous commit, we couldn't be sure that dump_note_entry_p would
be called or not, so linux_make_mappings_callback had to run its own
checks.

Now that dump_note_entry_p is always called we can rely on that
function to filter out which mappings should result in an NT_FILE
entry, and linux_make_mappings_callback can just create an entry for
everything it is passed.

As a result of this change I was able to remove the inode argument
from linux_make_mappings_callback and
linux_find_memory_regions_thunk.  The inode check has now moved to
dump_note_entry_p.

There should be no user visible changes after this commit.

Approved-By: Simon Marchi <simon.marchi@efficios.com>
6 weeks agogdb: always call should_dump_mapping_p during core file creation
Andrew Burgess [Wed, 7 May 2025 09:33:09 +0000 (10:33 +0100)] 
gdb: always call should_dump_mapping_p during core file creation

This commit moves the logic for whether should_dump_mapping_p is
called out of linux_find_memory_regions_full and pushes it down into
the two callback functions that are used as the should_dump_mapping_p
callback; `dump_mapping_p` and `dump_note_entry_p`.

Older Linux kernels don't make the 'Anonymous' information available
in the smaps file, and currently, GDB handles this by not calling the
should_dump_mapping_p callback in linux_find_memory_regions_full,
instead the answer is hard-coded to true.

This is (maybe) fine for dump_mapping_p, but for dump_note_entry_p,
this choice makes little sense.  The dump_note_entry_p function
doesn't even use the anonymous mapping information.

I propose that the 'has_anonymous' check should be moved out of
linux_find_memory_regions_full, and pushed into dump_mapping_p.  Then
in dump_note_entry_p there will be no has_anonymous check; it just
isn't needed.

This allows linux_find_memory_regions_full to be simplified a little,
and will allow some additional clean ups in
linux_make_mappings_callback, which is the partner function to
dump_note_entry_p (see linux_make_mappings_corefile_notes), now that
we know dump_note_entry_p is always called.  This follow on clean up
will be done in a later commit in this series.

Looking at dump_mapping_p, I do wonder if the ::has_anonymous check
could be moved later in the function.  The first few checks in
dump_mapping_p don't rely on the anonymous information, so running
them might give better results.  However, the lack of the anonymous
information is only for older kernels, so testing any changes in this
area would likely require spinning up an older kernel, and as the
years pass, we likely care about this case less.  So for now I've left
the ::has_anonymous check as the first thing in dump_mapping_p as this
keeps the existing behaviour.

There should be no user visible changes after this commit.

Approved-By: Simon Marchi <simon.marchi@efficios.com>
6 weeks agogdb: pass struct smaps_data to linux_dump_mapping_p_ftype
Andrew Burgess [Wed, 7 May 2025 09:22:37 +0000 (10:22 +0100)] 
gdb: pass struct smaps_data to linux_dump_mapping_p_ftype

Simplify the argument passing in linux_find_memory_regions_full when
calling the should_dump_mapping_p callback.  Instead of pulling all
the components from the smaps_data object and passing them separately,
just pass the smaps_data object.

I think this change is justified on its own; the code seems cleaner,
and easier to read to my eye.  But additionally, in a later commit in
this series I want to pass smaps_data::has_anonymous to the
should_dump_mapping_p callback, which would mean adding yet another
argument, and I think the argument list is already long enough.
Changing the function now to pass the smaps_data object means that I
will already have the ::has_anonymous field available in the later
commit.

There should be no user visible changes after this commit.

Approved-By: Simon Marchi <simon.marchi@efficios.com>
6 weeks agogdb: use bool more in linux-tdep.c
Andrew Burgess [Wed, 7 May 2025 09:09:43 +0000 (10:09 +0100)] 
gdb: use bool more in linux-tdep.c

Convert linux_dump_mapping_p_ftype to return a bool, and then update
everything that is needed to handle the fallout from this change.

There should be no user visible changes from this commit.

Approved-By: Simon Marchi <simon.marchi@efficios.com>
6 weeks agogdb: add '-stopped' and '-running' options to "info threads"
Tankut Baris Aktemur [Mon, 12 May 2025 07:10:56 +0000 (09:10 +0200)] 
gdb: add '-stopped' and '-running' options to "info threads"

Add two options to "info threads": `-stopped` and `-running`.

The purpose of these options is to filter the output of the command.
The `-stopped` option means "print stopped threads only" and,
similarly, `-running` means "print the running threads only".  When
both options are provided by the user, the indication is that the user
wants the union.  That is, the output contains both stopped and
running threads.

Suppose we have an application with 5 threads, 2 of which have hit a
breakpoint.  The "info threads" command in the non-stop mode gives:

  (gdb) info threads
    Id   Target Id             Frame
  * 1    Thread 0x7ffff7d99740 (running)
    2    Thread 0x7ffff7d98700 something () at file.c:30
    3    Thread 0x7ffff7597700 (running)
    4    Thread 0x7ffff6d96700 something () at file.c:30
    5    Thread 0x7ffff6595700 (running)
  (gdb)

Using the "-stopped" flag, we get

  (gdb) info threads -stopped
    Id   Target Id             Frame
    2    Thread 0x7ffff7d98700 something () at file.c:30
    4    Thread 0x7ffff6d96700 something () at file.c:30
  (gdb)

Using the "-running" flag, we get

  (gdb) info threads -running
    Id   Target Id             Frame
  * 1    Thread 0x7ffff7d99740 (running)
    3    Thread 0x7ffff7597700 (running)
    5    Thread 0x7ffff6595700 (running)
  (gdb)

Using both flags prints all:

  (gdb) info threads -stopped -running
    Id   Target Id             Frame
  * 1    Thread 0x7ffff7d99740 (running)
    2    Thread 0x7ffff7d98700 something () at file.c:30
    3    Thread 0x7ffff7597700 (running)
    4    Thread 0x7ffff6d96700 something () at file.c:30
    5    Thread 0x7ffff6595700 (running)
  (gdb)

When combined with a thread ID, filtering applies to those threads that
are matched by the ID.

  (gdb) info threads 3
    Id   Target Id             Frame
    3    Thread 0x7ffff7597700 (running)
  (gdb) info threads -stopped 3
  No threads matched.
  (gdb)

Regression-tested on X86_64 Linux.

Reviewed-By: Eli Zaretskii <eliz@gnu.org>
Reviewed-By: Guinevere Larsen <guinevere@redhat.com>
Approved-by: Pedro Alves <pedro@palves.net
6 weeks agogdb: update "info threads" output when no threads match the arguments
Tankut Baris Aktemur [Mon, 12 May 2025 07:10:55 +0000 (09:10 +0200)] 
gdb: update "info threads" output when no threads match the arguments

If "info threads" is provided with the thread ID argument but no such
threads matching the thread ID(s) are found, GDB prints

  No threads match '<ID...>'.

Update this output to the more generalized

  No threads matched.

The intention is that the next patch, and potentially future ones,
will extend the command with more filter/match arguments.  We cannot
customize the output to each such argument.  Hence, be more generic.

Reviewed-By: Eli Zaretskii <eliz@gnu.org>
Approved-by: Pedro Alves <pedro@palves.net
6 weeks agogdb: pass info_threads_opts to print_thread_info_1
Tankut Baris Aktemur [Mon, 12 May 2025 07:10:55 +0000 (09:10 +0200)] 
gdb: pass info_threads_opts to print_thread_info_1

The "info threads" command tracks its options in a struct named
'info_threads_opts', which currently has only one option.  Pass the
whole options object to helper functions, instead of passing
the option value individually.  This is a refactoring to make adding
more options easier.

Reviewed-By: Guinevere Larsen <guinevere@redhat.com>
Approved-by: Pedro Alves <pedro@palves.net
6 weeks agoAutomatic date update in version.in
GDB Administrator [Mon, 12 May 2025 00:00:12 +0000 (00:00 +0000)] 
Automatic date update in version.in

6 weeks agoubsan: size_inc_line_addr integer overflow
Alan Modra [Sat, 10 May 2025 02:47:23 +0000 (12:17 +0930)] 
ubsan: size_inc_line_addr integer overflow

Fix a fuzzer testcase where a large positive line_delta causes signed
overflow when subtracting -5.  Signed overflow is perfectly OK here.

6 weeks agomsan: use of uninitialised data in get_cie_info
Alan Modra [Fri, 9 May 2025 03:46:24 +0000 (13:16 +0930)] 
msan: use of uninitialised data in get_cie_info

This completely bogus oss-fuzz x86 testcase results in a read from an
uninitialised (at the time check_eh_frame is called) part of an insn
frag:
 .section .debug_frame
 orl $1,x
 .long x
 .uleb128 0,x,0
x:

Fix the problem by verifying the assumption in get_cie_info that a CIE
starts at the beginning of .eh_frame or .debug_frame.  Or at least
exclude silliness involving instructions placed there.  That seems a
useful sanity check.  Also sanity check sizes of initial FDE fields.

Yes, this doesn't completely stop the problem since you could place an
insn with a relocated field later in the CIE.  If fuzzers find such a
testcase I'll ignore it.

* ehopt.c (struct cie_info): Add "f" field.
(get_cie_info): Return a bool.  Verify frag at start of chain
is one with the CIE size found by check_eh_frame.
(check_eh_frame): Save CIE start frag.  Only accept 4 or 8
byte fields in state_saw_size, state_saw_cie_offset and
state_saw_pc_begin.  Formatting.  Localise "fix" variable.

6 weeks agoAutomatic date update in version.in
GDB Administrator [Sun, 11 May 2025 00:00:09 +0000 (00:00 +0000)] 
Automatic date update in version.in

6 weeks agogdb: LoongArch: Emulate floating-point branch instructions
Tiezhu Yang [Wed, 30 Apr 2025 07:10:15 +0000 (15:10 +0800)] 
gdb: LoongArch: Emulate floating-point branch instructions

Add bceqz and bcnez cases in loongarch_insn_is_cond_branch() and
loongarch_next_pc() to emulate floating-point branch instructions.

Here are the references:

https://loongson.github.io/LoongArch-Documentation/LoongArch-Vol1-EN.html#_bceqz_bcnez
https://loongson.github.io/LoongArch-Documentation/LoongArch-Vol1-EN.html#table-table-of-instruction-encoding

Approved-by: Kevin Buettner <kevinb@redhat.com>
Signed-off-by: Tiezhu Yang <yangtiezhu@loongson.cn>
6 weeks agoAutomatic date update in version.in
GDB Administrator [Sat, 10 May 2025 00:00:07 +0000 (00:00 +0000)] 
Automatic date update in version.in

6 weeks agoMAINTAINERS: Update my email address
Peter Bergner [Thu, 8 May 2025 15:55:45 +0000 (10:55 -0500)] 
MAINTAINERS: Update my email address

Update my email address and move up Surya's name as the main PPC contact.

Signed-off-by: Peter Bergner <bergner@tenstorrent.com>
6 weeks agoFix two comments in cli-style.c
Tom Tromey [Fri, 9 May 2025 19:43:17 +0000 (13:43 -0600)] 
Fix two comments in cli-style.c

I noticed that a couple of new comments in cli-style.c mentioned the
wrong command name.  This patch fixes the comments.

6 weeks agoMove "show style sources" documentation
Tom Tromey [Fri, 9 May 2025 19:39:55 +0000 (13:39 -0600)] 
Move "show style sources" documentation

I noticed that I had inadvertently put the "set style warning-prefix"
documentation between the paragraph for "set style sources" and the
paragraph for "show style sources".  This patch moves the latter up a
bit to clean this up.

6 weeks agoaarch64: Mark predicate-as-counter pseudo instructions
Alice Carlotti [Sun, 20 Apr 2025 20:42:39 +0000 (21:42 +0100)] 
aarch64: Mark predicate-as-counter pseudo instructions

Using explicit pseudo aliases is clearer and more consistent with other
instruction aliases.

This does not change behaviour.  For the non-alias instructions
(everything except mov) we already picked the first matching entry for
disassembly by default.  For mov we picked the last matching aliased
entry, which remained the original alias since do_misc_decoding doesn't
recognise OP_MOV_PN_PN.

6 weeks agoaarch64: Mark clearbhb as a pseudo instruction
Alice Carlotti [Thu, 17 Apr 2025 19:42:32 +0000 (20:42 +0100)] 
aarch64: Mark clearbhb as a pseudo instruction

This was an early name for the clrbhb hint instruction.  Some software
was written with the old name before it was renamed, so we support it
for assembly but should never use it in disassembly.

This patch has no functional change, because we already pick (by
default) the last matching alias in the opcode table, and clrbhb is
listed later than clearbhb.

6 weeks agoaarch64: Merge dgh tests into system.d
Alice Carlotti [Thu, 17 Apr 2025 19:39:26 +0000 (20:39 +0100)] 
aarch64: Merge dgh tests into system.d

6 weeks agoaarch64: Fix dgh disassembly
Alice Carlotti [Thu, 17 Apr 2025 19:37:25 +0000 (20:37 +0100)] 
aarch64: Fix dgh disassembly

6 weeks agoaarch64: Mark SME mova aliases
Alice Carlotti [Thu, 17 Apr 2025 19:24:08 +0000 (20:24 +0100)] 
aarch64: Mark SME mova aliases

This will only change behaviour during disassembly with -M no-aliases.

6 weeks agoaarch64: Mark rev64 as a pseudo instruction
Alice Carlotti [Thu, 17 Apr 2025 19:22:22 +0000 (20:22 +0100)] 
aarch64: Mark rev64 as a pseudo instruction

This is more natural than raising the priority of rev with F_P1, and
is functionally equivalent.

6 weeks agoaarch64: Add new test original-missing-misc.d
Alice Carlotti [Sun, 20 Apr 2025 22:14:00 +0000 (23:14 +0100)] 
aarch64: Add new test original-missing-misc.d

This test file includes all the remaining untested instructions that
weren't part of a larger group of new or existing tests.

6 weeks agoaarch64: Add new test mov-wide.d
Alice Carlotti [Sun, 20 Apr 2025 22:12:35 +0000 (23:12 +0100)] 
aarch64: Add new test mov-wide.d

Only movn was previously untested.

6 weeks agoaarch64: Add new test exception-generation.d
Alice Carlotti [Sun, 20 Apr 2025 22:12:00 +0000 (23:12 +0100)] 
aarch64: Add new test exception-generation.d

svc and dcps* were already tested, but are included here as part of the
same encoding group.

6 weeks agoaarch64: Add new test conditional-compare.d
Alice Carlotti [Sun, 20 Apr 2025 22:11:29 +0000 (23:11 +0100)] 
aarch64: Add new test conditional-compare.d

The register form of ccmp was already tested.

6 weeks agoaarch64: Add new test branch-cond-pseudos.d
Alice Carlotti [Sun, 20 Apr 2025 22:11:04 +0000 (23:11 +0100)] 
aarch64: Add new test branch-cond-pseudos.d

beq, bne, bcs and bcc were already tested, and bge and ble are also used
in scfi tests.

6 weeks agoaarch64: Add new test ldst-unpriv.d
Alice Carlotti [Sun, 20 Apr 2025 22:10:33 +0000 (23:10 +0100)] 
aarch64: Add new test ldst-unpriv.d

All instructions were previously untested.

6 weeks agoaarch64: Add new test ldst-extend-general.d
Alice Carlotti [Sun, 20 Apr 2025 22:09:55 +0000 (23:09 +0100)] 
aarch64: Add new test ldst-extend-general.d

All instructions were previously untested.

6 weeks agoaarch64: Add new test dp-general-two-source.d
Alice Carlotti [Sun, 20 Apr 2025 22:09:08 +0000 (23:09 +0100)] 
aarch64: Add new test dp-general-two-source.d

lsl was already tested but is included here as part of the same encoding
group.

6 weeks agoaarch64: Add new test dp-general-one-source.d
Alice Carlotti [Sun, 20 Apr 2025 22:08:30 +0000 (23:08 +0100)] 
aarch64: Add new test dp-general-one-source.d

rev16 and the 64-bit rev/rev64 instructions were already tested, but are
included here as part of the same encoding group.

6 weeks agoaarch64: Add new test addsub-carry.d
Alice Carlotti [Sun, 20 Apr 2025 22:07:31 +0000 (23:07 +0100)] 
aarch64: Add new test addsub-carry.d

All instructions were previously untested.

6 weeks agoaarch64: Add new test advsimd-scalar-doubling-mul.d
Alice Carlotti [Sun, 20 Apr 2025 22:06:42 +0000 (23:06 +0100)] 
aarch64: Add new test advsimd-scalar-doubling-mul.d

All instructions were previously untested.

6 weeks agoaarch64: Add new test advsimd-scalar-two-reg-misc.d
Alice Carlotti [Sun, 20 Apr 2025 22:05:31 +0000 (23:05 +0100)] 
aarch64: Add new test advsimd-scalar-two-reg-misc.d

sqabs, sqneg, abs and neg were already tested, but are included here as
part of the same encoding group.

6 weeks agoaarch64: Add new test advsimd-scalar-shift-immediate.d
Alice Carlotti [Sun, 20 Apr 2025 22:03:39 +0000 (23:03 +0100)] 
aarch64: Add new test advsimd-scalar-shift-immediate.d

All instructions were previously untested.

6 weeks agoaarch64: Add new test advsimd-scalar-three-same.d
Alice Carlotti [Sun, 20 Apr 2025 22:02:42 +0000 (23:02 +0100)] 
aarch64: Add new test advsimd-scalar-three-same.d

All instructions were previously untested.

6 weeks agoaarch64: Add new test advsimd-copy.d
Alice Carlotti [Sun, 20 Apr 2025 22:02:01 +0000 (23:02 +0100)] 
aarch64: Add new test advsimd-copy.d

Only smov and the second dup variant were previously untested.  However,
the only test for umov was a disassembly test with -M no-aliases, and
the first dup variant was only tested in assembly in diagnostic.d with
the non-architectural syntax `dup v0.2d, v1.2d[0]`.

6 weeks agoaarch64: Add new test advsimd-permute.d
Alice Carlotti [Sun, 20 Apr 2025 22:01:26 +0000 (23:01 +0100)] 
aarch64: Add new test advsimd-permute.d

All instructions were previously untested.

6 weeks agoaarch64: Add new test advsimd-modified-immediate.d
Alice Carlotti [Sun, 20 Apr 2025 22:00:36 +0000 (23:00 +0100)] 
aarch64: Add new test advsimd-modified-immediate.d

All instructions (7 opcode table entries) were previously untested.

6 weeks agoaarch64: Add new test advsimd-two-reg-misc-hilo.d
Alice Carlotti [Sun, 20 Apr 2025 21:58:30 +0000 (22:58 +0100)] 
aarch64: Add new test advsimd-two-reg-misc-hilo.d

All instructions were previously untested.

6 weeks agoaarch64: Add new test advsimd-two-reg-misc.d
Alice Carlotti [Sun, 20 Apr 2025 21:57:53 +0000 (22:57 +0100)] 
aarch64: Add new test advsimd-two-reg-misc.d

sqabs, abs, not, mvn, sqneg and neg were already tested, and cmeq was
already assembled in an error test (sve-reg-diagnostic.d), but they are
all included here as part of the same encoding group.

6 weeks agoaarch64: Add new test advsimd-mul-element.d
Alice Carlotti [Sun, 20 Apr 2025 21:57:17 +0000 (22:57 +0100)] 
aarch64: Add new test advsimd-mul-element.d

All instructions were previously untested.

6 weeks agoaarch64: Add new test advsimd-widening-narrowing.d
Alice Carlotti [Sun, 20 Apr 2025 21:56:29 +0000 (22:56 +0100)] 
aarch64: Add new test advsimd-widening-narrowing.d

All instructions were previously untested.

6 weeks agoaarch64: Add new test advsimd-three-same.d
Alice Carlotti [Sun, 20 Apr 2025 21:55:12 +0000 (22:55 +0100)] 
aarch64: Add new test advsimd-three-same.d

All instructions except orr/mov were previously untested.

6 weeks agoaarch64: Add missing widening fmops test
Alice Carlotti [Sun, 20 Apr 2025 16:38:59 +0000 (17:38 +0100)] 
aarch64: Add missing widening fmops test

Also remove the valid instructions from the test for invalid
instructions - this meant that the instruction was previously being
tested for assembly but not disassembly.

6 weeks agoaarch64: Add tests for fabd, urecpe and ursqrt
Alice Carlotti [Sun, 20 Apr 2025 22:25:11 +0000 (23:25 +0100)] 
aarch64: Add tests for fabd, urecpe and ursqrt

Other instructions in the encoding group are tested in advsimd-fp16.d,
so add these instructions to the existing test file.

6 weeks agoaarch64: Add tests for fcvt, fcvtzs and fcvtzu
Alice Carlotti [Sun, 20 Apr 2025 22:23:42 +0000 (23:23 +0100)] 
aarch64: Add tests for fcvt, fcvtzs and fcvtzu

Other instructions in the encoding group are tested in float-fp16.d, so
add these instructions to the existing test file.

6 weeks agoaarch64: Add tests for csdb and eret to system.d
Alice Carlotti [Sun, 20 Apr 2025 22:20:44 +0000 (23:20 +0100)] 
aarch64: Add tests for csdb and eret to system.d

6 weeks agoaarch64: Add test for ands and bics
Alice Carlotti [Sun, 20 Apr 2025 22:16:02 +0000 (23:16 +0100)] 
aarch64: Add test for ands and bics

The other instructions in the encoding group are tested in shifted.d, so
add these to the existing test file.

6 weeks agoaarch64: Adjust float-fp16.d test patterns
Alice Carlotti [Sun, 20 Apr 2025 22:30:47 +0000 (23:30 +0100)] 
aarch64: Adjust float-fp16.d test patterns

Adjust the test to match instruction addresses of any length.

6 weeks agoaarch64: Adjust advsimd-fp16.d test patterns
Alice Carlotti [Sun, 20 Apr 2025 21:43:29 +0000 (22:43 +0100)] 
aarch64: Adjust advsimd-fp16.d test patterns

Adjust the test to match instruction addresses of any length, and escape
literal '.' characters for a stricter match.

6 weeks agoaarch64: Adjust shifted.d test patterns
Alice Carlotti [Tue, 15 Apr 2025 17:33:03 +0000 (18:33 +0100)] 
aarch64: Adjust shifted.d test patterns

Adjust the test to match any instruction addresses, so that the test can
be extended more easily.

6 weeks agoaarch64: Eliminate AARCH64_OPND_SVE_ADDR_R
Alice Carlotti [Mon, 7 Apr 2025 19:21:07 +0000 (20:21 +0100)] 
aarch64: Eliminate AARCH64_OPND_SVE_ADDR_R

Adjust parsing for AARCH64_OPND_SVE_ADDR_RR{_LSL*} operands to accept
implicit XZR offsets.  Add new AARCH64_OPND_SVE_ADDR_RM{_LSL*} operands
to support instructions where an XZR offset is allowed but must be
specified explicitly.  This allows the removal of the duplicate opcode
table entries using AARCH64_OPND_SVE_ADDR_R.

7 weeks agoaarch64: Disallow invalid SVE addressing modes
Alice Carlotti [Tue, 8 Apr 2025 16:30:39 +0000 (17:30 +0100)] 
aarch64: Disallow invalid SVE addressing modes

The fix for PR22988 in 2018 added a new operand AARCH64_OPND_SVE_ADDR_R
to support implicit XZR offsets, but this fix had several flaws that
meant it accepted several invalid addressing modes:

1. The base register type wasn't properly checked when the optional
register offset was omitted.  This meant that
  ldff1b {z1.s}, p1/z,[z1.d]
was parsed as if it were
  ldff1b z1.d, p1/z, [x1.d, xzr].

2. The explicit offset parsing didn't include a shift type, so the new
operand would incorrectly parse
  ldff1h{z0.s}, p0/z, [x0, x0]
as if it were
  ldff1h{z0.s}, p0/z, [x0, x0, lsl #1].

3. Regardless of the above correctness issues, support for implicit
offsets should have been added by amending the operands in the existing
opcode table entries, instead of adding new duplicate table entires.

Issue 1 can be fixed by using an "if" instead of an "else if" in
parse_operands, while issue 2 can be fixed by failing when the first
condition is false.  This patch applies just these two fixes, leaving
issue 3 to be addressed in a subsequent more invasive patch.

The instructions removed from the test sme-5.d are architecturally
invalid. The new tests cover all of the affected ldff1 variants; the
issue also affected SME ZA ld1*/st1* instructions using the same operand
type.

7 weeks agoRISC-V: Support Zce 1.0
Jerry Zhang Jian [Fri, 9 May 2025 09:34:49 +0000 (17:34 +0800)] 
RISC-V: Support Zce 1.0

Zce is the extension defined in code-size-reduction

Ref: https://github.com/riscvarchive/riscv-code-size-reduction

Co-authored-by: Kito Cheng <kito.cheng@sifive.com>
7 weeks agoRISC-V: Base for complex extension implications
Tsukasa OI [Fri, 9 May 2025 09:34:48 +0000 (17:34 +0800)] 
RISC-V: Base for complex extension implications

Thanks to the commit 48558a5e5471 ("RISC-V: Allow nested implications for
extensions"), we can write complex extension implications in theory.
However, to actually do that, we need to pass more information to
check_func.

For example, we want to imply 'Zcf' from 'F' if and only if the 'Zce'
extension is also enabled and XLEN is 32.  Passing rps is a way to
enable this.

This commit prepares for such complex extension implications.

7 weeks agoRISC-V: Add augmented hypervisor extension 'sha' support.
Jiawei [Fri, 9 May 2025 02:55:25 +0000 (10:55 +0800)] 
RISC-V: Add augmented hypervisor extension 'sha' support.

The augmented hypervisor extension 'sha'[1] is a new profile-defined extension
that captures the full set of features that are mandated to be supported along
with the H extension.

https://github.com/riscv/riscv-profiles/blob/main/src/rva23-profile.adoc#rva23s64-profile

bfd/ChangeLog:

* elfxx-riscv.c: New extension and implies.

gas/ChangeLog:

* NEWS: New extension.
* testsuite/gas/riscv/imply.d: New test for sha.
* testsuite/gas/riscv/imply.s: Ditto.
* testsuite/gas/riscv/march-help.l: New extension.

7 weeks agoRISC-V: Add Privileged Architecture 1.13 CSRs.
Jiawei [Fri, 9 May 2025 02:22:45 +0000 (10:22 +0800)] 
RISC-V: Add Privileged Architecture 1.13 CSRs.

This patch support RISC-V Privileged Architecture 1.13 CSRs 'medelegh' and
'hedelegh'. More details between 1.12 and 1.13 see [1].

[1] https://github.com/riscv/riscv-isa-manual/blob/main/src/priv-preface.adoc

Version log: Remove gas/po changes.

bfd/ChangeLog:

        * cpu-riscv.c: New option.
        * cpu-riscv.h (enum riscv_spec_class): Ditto.

binutils/ChangeLog:

        * doc/binutils.texi: New option.

gas/ChangeLog:

        * NEWS: Add priv-1.13 support.
        * config/tc-riscv.c: New option.
        * configure: Ditto.
        * configure.ac: Ditto.
        * testsuite/gas/riscv/csr-version-1p10.d: New CSR.
        * testsuite/gas/riscv/csr-version-1p10.l: New warning.
        * testsuite/gas/riscv/csr-version-1p11.d: New CSR.
        * testsuite/gas/riscv/csr-version-1p11.l: New warning.
        * testsuite/gas/riscv/csr-version-1p12.d: New CSR.
        * testsuite/gas/riscv/csr-version-1p12.l: New warning.
        * testsuite/gas/riscv/csr.s: New CSR.
        * testsuite/gas/riscv/attribute-15.d: New test.
        * testsuite/gas/riscv/attribute-16.d: New test.
        * testsuite/gas/riscv/csr-version-1p13.d: New test.
        * testsuite/gas/riscv/csr-version-1p13.l: New test.

include/ChangeLog:

        * opcode/riscv-opc.h (CSR_MEDELEGH): New CSR.
        (CSR_HEDELEGH): Ditto.
        (DECLARE_CSR): Ditto.

7 weeks agoRISC-V: Added vendor extensions, xmipscbop, xmipscmov, xmipsexectl and xmipslsp
Chao-ying Fu [Fri, 9 May 2025 01:52:17 +0000 (09:52 +0800)] 
RISC-V: Added vendor extensions, xmipscbop, xmipscmov, xmipsexectl and xmipslsp

Spec:
https://mips.com/wp-content/uploads/2025/03/P8700-F_Programmers_Reference_Manual_Rev1.82_3-19-2025.pdf

Added MIPS vendor extensions, xmipscbop, xmipscmov, xmipsexectl and xmipslsp
with verison 1.0.

Passed binutils testsuites of targets elf32/elf64/linux32/linux64.

Signed-off-by: Jovan Dmitrović <jovan.dmitrovic@htecgroup.com>
Signed-off-by: Chao-ying Fu <cfu@wavecomp.com>
7 weeks agoAutomatic date update in version.in
GDB Administrator [Fri, 9 May 2025 00:00:09 +0000 (00:00 +0000)] 
Automatic date update in version.in

7 weeks agoChange substitute_path_component to use std::string
Tom Tromey [Sat, 19 Apr 2025 20:50:01 +0000 (14:50 -0600)] 
Change substitute_path_component to use std::string

This changes substitute_path_component to use std::string and
std::string_view, simplifying it greatly and removing some manual
memory management.

Approved-By: Simon Marchi <simon.marchi@efficios.com>
7 weeks agoMove substitute_path_component
Tom Tromey [Sat, 19 Apr 2025 18:40:18 +0000 (12:40 -0600)] 
Move substitute_path_component

This moves substitute_path_component out of utils.c.  I considered
making a new file for this (still could if someone wants that), but
since the only caller is in auto-load.c, I moved it there instead.

I've also moved the tests into auto-load.c as well.  This way
substitute_path_component can be static.

Approved-By: Simon Marchi <simon.marchi@efficios.com>
7 weeks agoAutomatic date update in version.in
GDB Administrator [Thu, 8 May 2025 00:00:11 +0000 (00:00 +0000)] 
Automatic date update in version.in

7 weeks agowindres: buffer overflow
Alan Modra [Wed, 7 May 2025 23:50:23 +0000 (09:20 +0930)] 
windres: buffer overflow

bin_to_res_menuexitems can be called with random data offsets (and thus
remaining lengths), confusing code that expects 4-byte aligned data.
Prevent an item length adjustment for alignment exceeding the
remaining length and then overflowing.

7 weeks agoRemove unnecessary use of pragma once in pr25618 test
Alan Modra [Wed, 7 May 2025 01:45:49 +0000 (11:15 +0930)] 
Remove unnecessary use of pragma once in pr25618 test

7 weeks agos390: Fix format specifier for VR in disassembler
Jens Remus [Wed, 7 May 2025 15:17:10 +0000 (17:17 +0200)] 
s390: Fix format specifier for VR in disassembler

Vector register (VR) numbers are unsigned.  Use format specifier %u
instead of %i.

Reported-by: Florian Krohm <flo2030@eich-krohm.de>
Signed-off-by: Jens Remus <jremus@linux.ibm.com>
7 weeks agoAutomatic date update in version.in
GDB Administrator [Wed, 7 May 2025 00:00:33 +0000 (00:00 +0000)] 
Automatic date update in version.in

7 weeks agoDo not set yydebug in cp-name-parser.y
Tom Tromey [Sat, 3 May 2025 17:28:22 +0000 (11:28 -0600)] 
Do not set yydebug in cp-name-parser.y

This reverts the change to cp-name-parser.y, avoiding a TSan report.

Approved-By: Simon Marchi <simon.marchi@efficios.com>
7 weeks agoRemove kfail from templates.exp
Tom Tromey [Sun, 4 May 2025 14:39:15 +0000 (08:39 -0600)] 
Remove kfail from templates.exp

templates.exp has one remaining kfail.  However, the output in
question has been stabilized ever since the cp-name-parser.y work --
the test just wasn't updated.

Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=8617
Reviewed-By: Keith Seitz <keiths@redhat.com>
7 weeks agoRewrite bug references in templates.exp
Tom Tromey [Sun, 4 May 2025 14:32:44 +0000 (08:32 -0600)] 
Rewrite bug references in templates.exp

templates.exp has many kfails that refer to old GNATS bug numbers.
This patch updates them to refer to Bugzilla instead.

Reviewed-By: Keith Seitz <keiths@redhat.com>
7 weeks agoRevert "gdb: support zero inode in generate-core-file command"
Andrew Burgess [Tue, 6 May 2025 15:55:44 +0000 (16:55 +0100)] 
Revert "gdb: support zero inode in generate-core-file command"

This reverts commit 1e21c846c275fc6e387ca903a129096be2a53d0b.

This change was causing unexpected mappings to be included in the core
files generated by GDB, which was triggering warnings when GDB opened
a core file, like this:

  warning: Can't open file [stack] during file-backed mapping note processing

  warning: Can't open file [vvar] during file-backed mapping note processing

For now I'm reverting the above commit and will come to the list again
when I have a solution that addresses the original issue without also
including the unexpected mappings.

7 weeks agoHandle field with dynamic bit offset
Tom Tromey [Fri, 18 Apr 2025 15:28:13 +0000 (09:28 -0600)] 
Handle field with dynamic bit offset

I discovered that GCC emitted incorrect DWARF for the test case
included in this patch.  Eric wrote a fix for GCC, but then he found
that gdb crashed on the resulting file.

This test has a field that is at a non-constant bit offset from the
start of the type.  DWARF 5 does not allow for this situation (I've
sent a report to the DWARF list), but DWARF 3 did allow for this via a
combination of an expression for the byte offset and then the use of
DW_AT_bit_offset.  This looks like:

 <5><117a>: Abbrev Number: 17 (DW_TAG_member)
    <117b>   DW_AT_name        : (indirect string, offset: 0x1959): another_field
...
    <1188>   DW_AT_bit_offset  : 6
    <1189>   DW_AT_data_member_location: 6 byte block: 99 3d 1 0 0 22  (DW_OP_call4: <0x1193>; DW_OP_plus)
...
 <3><1193>: Abbrev Number: 2 (DW_TAG_dwarf_procedure)
    <1194>   DW_AT_location    : 15 byte block: 97 94 1 37 1a 32 1e 23 7 38 1b 31 1c 23 3  (DW_OP_push_object_address; DW_OP_deref_size: 1; DW_OP_lit7; DW_OP_and; DW_OP_lit2; DW_OP_mul; DW_OP_plus_uconst: 7; DW_OP_lit8; DW_OP_div; DW_OP_lit1; DW_OP_minus; DW_OP_plus_uconst: 3)

Now, that combination is not fully general, in that the bit offset
must be a constant -- only the byte offset may really vary.  However,
I couldn't come up with a situation where full generality is needed,
mainly because GNAT won't seem to pack fields into the padding of a
variable-length array.

Meanwhile, the reason for the gdb crash is that the code handling
DW_AT_bit_offset assumes that the byte offset is a constant.  This
causes an assertion failure.

This patch arranges for DW_AT_bit_offset to be applied during field
resolution, when needed.

7 weeks agoIntroduce apply_bit_offset_to_field helper function
Tom Tromey [Fri, 18 Apr 2025 14:54:52 +0000 (08:54 -0600)] 
Introduce apply_bit_offset_to_field helper function

This patch makes a new function, apply_bit_offset_to_field, that is
used to handle the logic of DW_AT_bit_offset.  Currently there is just
a single caller, but the next patch will change this.

7 weeks agoUse OBSTACK_ZALLOC when allocating batons
Tom Tromey [Fri, 18 Apr 2025 14:22:24 +0000 (08:22 -0600)] 
Use OBSTACK_ZALLOC when allocating batons

I found some places in dwarf2/read.c that allocate a location baton,
but fail to initialize one of the fields.  It seems safer to me to use
OBSTACK_ZALLOC here, so this patch makes this change.  This will be
useful in a subsequent patch as well, where a new field is added to
one of the batons.

7 weeks agoClean up handle_member_location
Tom Tromey [Thu, 17 Apr 2025 20:48:24 +0000 (14:48 -0600)] 
Clean up handle_member_location

This removes a redundant check from handle_member_location, and also
changes the complaint -- currently it will issue the "complex
location" complaint, but really what is happening here is an
unrecognized form.

7 weeks agoHandle dynamic field properties
Tom Tromey [Tue, 15 Apr 2025 15:08:52 +0000 (09:08 -0600)] 
Handle dynamic field properties

I found a situation where gdb could not properly decode an Ada type.
In this first scenario, the discriminant of a type is a bit-field.
PROP_ADDR_OFFSET does not handle this situation, because it only
allows an offset -- not a bit-size.

My original approach to this just added a bit size as well, but after
some discussion with Eric Botcazou, we found another failing case: a
tagged type can have a second discriminant that appears at a variable
offset.

So, this patch changes this code to accept a general 'struct field'
instead of trying to replicate the field-finding machinery by itself.

This is handled at property-evaluation time by simply using a 'field'
and resolving its dynamic properties.  Then the usual field-extraction
function is called to get the value.

Because the baton now just holds a field, I renamed PROP_ADDR_OFFSET
to PROP_FIELD.

The DWARF reader now defers filling in the property baton until the
fields have been attached to the type.

Finally, I noticed that if the discriminant field has a biased
representation, then unpack_field_as_long would not handle this
either.  This bug is also fixed here, and the test case checks this.

Regression tested on x86-64 Fedora 41.

7 weeks agoAdd new unpack_field_as_long overload
Tom Tromey [Thu, 17 Apr 2025 14:46:47 +0000 (08:46 -0600)] 
Add new unpack_field_as_long overload

This introduces a new unpack_field_as_long that takes the field object
directly, rather than a type and an index.  This will be used in the
next patch.

7 weeks agoAdd resolve_dynamic_field
Tom Tromey [Wed, 16 Apr 2025 20:58:06 +0000 (14:58 -0600)] 
Add resolve_dynamic_field

The final patch in this series will change one dynamic property
approach to use a struct field rather than an offset and a field type.
This is convenient because the reference in DWARF is indeed to a field
-- and this approach lets us reuse the field-extraction logic that
already exists in gdb.

However, the field in question may have dynamic properties which must
be resolved before it can be used.  This patch prepares for this by
introducing a separate resolve_dynamic_field function.

This patch should cause no visible changes to behavior.

7 weeks agoConstify property_addr_info
Tom Tromey [Wed, 16 Apr 2025 21:18:43 +0000 (15:18 -0600)] 
Constify property_addr_info

This changes most places to use a const property_addr_info.  This
seems more correct to me because normally the user of a
property_addr_info should not modify it.  Furthermore, some functions
already take a const object, and for a subsequent patch it is
convenient if other functions do as well.

7 weeks agogdb/testsuite: Add require allow_hipcc_tests in gdb.rocm/mi-attach.exp
Lancelot SIX [Tue, 6 May 2025 10:39:55 +0000 (11:39 +0100)] 
gdb/testsuite: Add require allow_hipcc_tests in gdb.rocm/mi-attach.exp

The gdb.rocm/mi-attach.exp test is missing a proper `require` check to
ensure that the current configuration can run ROCm tests.  This issue
has been reported by Baris.

This patch adds the missing `allow_hipcc_tests` requirement, and also
adds `load_lib rocm.exp` to enable this test.

Change-Id: Ie136adfc2d0854268b92af5c4df2dd0334dce259
Reviewed-By: Tankut Baris Aktemur <tankut.baris.aktemur@intel.com>
Approved-By: Tom Tromey <tom@tromey.com>