diff options
author | Luis Machado <luis.machado@linaro.org> | 2020-06-15 14:24:53 -0300 |
---|---|---|
committer | Luis Machado <luis.machado@linaro.org> | 2021-03-24 14:54:50 -0300 |
commit | 1e735120b95236b1f0fd8c383e64b02b64909d7c (patch) | |
tree | 9db3580d29028767a59b98cb49c7d2cb142e704d /gdb/linux-tdep.h | |
parent | Convert char array to std::string in linux_find_memory_regions_full (diff) | |
download | binutils-gdb-1e735120b95236b1f0fd8c383e64b02b64909d7c.tar.gz binutils-gdb-1e735120b95236b1f0fd8c383e64b02b64909d7c.tar.bz2 binutils-gdb-1e735120b95236b1f0fd8c383e64b02b64909d7c.zip |
Refactor parsing of /proc/<pid>/smaps
The Linux kernel exposes the information about MTE-protected pages via the
proc filesystem, more specifically through the smaps file.
What we're looking for is a mapping with the 'mt' flag, which tells us that
mapping was created with a PROT_MTE flag and, thus, is capable of using memory
tagging.
We already parse that file for other purposes (core file
generation/filtering), so this patch refactors the code to make the parsing
of the smaps file reusable for memory tagging.
The function linux_address_in_memtag_page uses the refactored code to allow
querying for memory tag support in a particular address, and it gets used in the
next patch.
gdb/ChangeLog:
2021-03-24 Luis Machado <luis.machado@linaro.org>
* linux-tdep.c (struct smaps_vmflags) <memory_tagging>: New flag
bit.
(struct smaps_data): New struct.
(decode_vmflags): Handle the 'mt' flag.
(parse_smaps_data): New function, refactored from
linux_find_memory_regions_full.
(linux_address_in_memtag_page): New function.
(linux_find_memory_regions_full): Refactor into parse_smaps_data.
* linux-tdep.h (linux_address_in_memtag_page): New prototype.
Diffstat (limited to 'gdb/linux-tdep.h')
-rw-r--r-- | gdb/linux-tdep.h | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/gdb/linux-tdep.h b/gdb/linux-tdep.h index 7db6eceeab1..28b60e46579 100644 --- a/gdb/linux-tdep.h +++ b/gdb/linux-tdep.h @@ -43,6 +43,10 @@ DEF_ENUM_FLAGS_TYPE (enum linux_siginfo_extra_field_values, struct type *linux_get_siginfo_type_with_fields (struct gdbarch *gdbarch, linux_siginfo_extra_fields); +/* Return true if ADDRESS is within the boundaries of a page mapped with + memory tagging protection. */ +bool linux_address_in_memtag_page (CORE_ADDR address); + typedef char *(*linux_collect_thread_registers_ftype) (const struct regcache *, ptid_t, bfd *, char *, int *, |