xref: /freebsd/contrib/llvm-project/lldb/source/Plugins/Process/Utility/AuxVector.h (revision 35c0a8c449fd2b7f75029ebed5e10852240f0865)
1 //===-- AuxVector.h ---------------------------------------------*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
9 #ifndef LLDB_SOURCE_PLUGINS_PROCESS_UTILITY_AUXVECTOR_H
10 #define LLDB_SOURCE_PLUGINS_PROCESS_UTILITY_AUXVECTOR_H
11 
12 #include "lldb/Utility/DataExtractor.h"
13 #include "lldb/Utility/Log.h"
14 #include <optional>
15 #include <unordered_map>
16 
17 class AuxVector {
18 
19 public:
20   AuxVector(const lldb_private::DataExtractor &data);
21 
22   /// Constants describing the type of entry.
23   /// On Linux and FreeBSD, running "LD_SHOW_AUXV=1 ./executable" will spew AUX
24   /// information. Added AUXV prefix to avoid potential conflicts with system-
25   /// defined macros. For FreeBSD, the numbers can be found in sys/elf_common.h.
26   enum EntryType {
27     AUXV_AT_NULL = 0,    ///< End of auxv.
28     AUXV_AT_IGNORE = 1,  ///< Ignore entry.
29     AUXV_AT_EXECFD = 2,  ///< File descriptor of program.
30     AUXV_AT_PHDR = 3,    ///< Program headers.
31     AUXV_AT_PHENT = 4,   ///< Size of program header.
32     AUXV_AT_PHNUM = 5,   ///< Number of program headers.
33     AUXV_AT_PAGESZ = 6,  ///< Page size.
34     AUXV_AT_BASE = 7,    ///< Interpreter base address.
35     AUXV_AT_FLAGS = 8,   ///< Flags.
36     AUXV_AT_ENTRY = 9,   ///< Program entry point.
37     AUXV_AT_NOTELF = 10, ///< Set if program is not an ELF.
38     AUXV_AT_UID = 11,    ///< UID.
39     AUXV_AT_EUID = 12,   ///< Effective UID.
40     AUXV_AT_GID = 13,    ///< GID.
41     AUXV_AT_EGID = 14,   ///< Effective GID.
42 
43     // At this point Linux and FreeBSD diverge and many of the following values
44     // are Linux specific. If you use them make sure you are in Linux specific
45     // code or they have the same value on other platforms.
46 
47     AUXV_AT_CLKTCK = 17,   ///< Clock frequency (e.g. times(2)).
48     AUXV_AT_PLATFORM = 15, ///< String identifying platform.
49     AUXV_AT_HWCAP =
50         16, ///< Machine dependent hints about processor capabilities.
51     AUXV_AT_FPUCW = 18,         ///< Used FPU control word.
52     AUXV_AT_DCACHEBSIZE = 19,   ///< Data cache block size.
53     AUXV_AT_ICACHEBSIZE = 20,   ///< Instruction cache block size.
54     AUXV_AT_UCACHEBSIZE = 21,   ///< Unified cache block size.
55     AUXV_AT_IGNOREPPC = 22,     ///< Entry should be ignored.
56     AUXV_AT_SECURE = 23,        ///< Boolean, was exec setuid-like?
57     AUXV_AT_BASE_PLATFORM = 24, ///< String identifying real platforms.
58     AUXV_AT_RANDOM = 25,        ///< Address of 16 random bytes.
59     AUXV_AT_HWCAP2 = 26,        ///< Extension of AT_HWCAP.
60     AUXV_AT_EXECFN = 31,        ///< Filename of executable.
61     AUXV_AT_SYSINFO = 32, ///< Pointer to the global system page used for system
62                           /// calls and other nice things.
63     AUXV_AT_SYSINFO_EHDR = 33,
64     AUXV_AT_L1I_CACHESHAPE = 34, ///< Shapes of the caches.
65     AUXV_AT_L1D_CACHESHAPE = 35,
66     AUXV_AT_L2_CACHESHAPE = 36,
67     AUXV_AT_L3_CACHESHAPE = 37,
68 
69     // Platform specific values which may overlap the Linux values.
70 
71     AUXV_FREEBSD_AT_HWCAP = 25, ///< FreeBSD specific AT_HWCAP value.
72   };
73 
74   std::optional<uint64_t> GetAuxValue(enum EntryType entry_type) const;
75   void DumpToLog(lldb_private::Log *log) const;
76   const char *GetEntryName(EntryType type) const;
77 
78 private:
79   void ParseAuxv(const lldb_private::DataExtractor &data);
80 
81   std::unordered_map<uint64_t, uint64_t> m_auxv_entries;
82 };
83 
84 #endif
85