Page Menu
Home
FreeBSD
Search
Configure Global Search
Log In
Files
F107297192
D19053.id53509.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Flag For Later
Award Token
Size
4 KB
Referenced Files
None
Subscribers
None
D19053.id53509.diff
View Options
Index: contrib/elftoolchain/readelf/readelf.c
===================================================================
--- contrib/elftoolchain/readelf/readelf.c
+++ contrib/elftoolchain/readelf/readelf.c
@@ -220,6 +220,11 @@
const char *desc;
};
+struct flag_desc {
+ uint64_t flag;
+ const char *desc;
+};
+
static void add_dumpop(struct readelf *re, size_t si, const char *sn, int op,
int t);
static const char *aeabi_adv_simd_arch(uint64_t simd);
@@ -293,8 +298,7 @@
static void dump_dwarf_str(struct readelf *re);
static void dump_eflags(struct readelf *re, uint64_t e_flags);
static void dump_elf(struct readelf *re);
-static void dump_dt_flags_val(uint64_t d_val);
-static void dump_dt_flags_1_val(uint64_t d_val);
+static void dump_flags(struct flag_desc *fd, uint64_t flags);
static void dump_dyn_val(struct readelf *re, GElf_Dyn *dyn, uint32_t stab);
static void dump_dynamic(struct readelf *re);
static void dump_liblist(struct readelf *re);
@@ -2722,6 +2726,58 @@
}
}
+static void
+dump_flags(struct flag_desc *desc, uint64_t val)
+{
+ struct flag_desc *fd;
+
+ for (fd = desc; fd->flag != 0; fd++) {
+ if (val & fd->flag) {
+ val ^= fd->flag;
+ printf(" %s", fd->desc);
+ }
+ }
+ if (val != 0)
+ printf(" %jx", (uintmax_t)val);
+}
+
+static struct flag_desc dt_flags[] = {
+ { DF_ORIGIN, "ORIGIN" },
+ { DF_SYMBOLIC, "SYMBOLIC" },
+ { DF_TEXTREL, "TEXTREL" },
+ { DF_BIND_NOW, "BIND_NOW" },
+ { DF_STATIC_TLS, "STATIC_TLS" },
+ { 0, NULL }
+};
+
+static struct flag_desc dt_flags_1[] = {
+ { DF_1_BIND_NOW, "NOW" },
+ { DF_1_GLOBAL, "GLOBAL" },
+ { 0x4, "GROUP" },
+ { DF_1_NODELETE, "NODELETE" },
+ { DF_1_LOADFLTR, "LOADFLTR" },
+ { 0x20, "INITFIRST" },
+ { DF_1_NOOPEN, "NOOPEN" },
+ { DF_1_ORIGIN, "ORIGIN" },
+ { 0x100, "DIRECT" },
+ { DF_1_INTERPOSE, "INTERPOSE" },
+ { DF_1_NODEFLIB, "NODEFLIB" },
+ { 0x1000, "NODUMP" },
+ { 0x2000, "CONFALT" },
+ { 0x4000, "ENDFILTEE" },
+ { 0x8000, "DISPRELDNE" },
+ { 0x10000, "DISPRELPND" },
+ { 0x20000, "NODIRECT" },
+ { 0x40000, "IGNMULDEF" },
+ { 0x80000, "NOKSYMS" },
+ { 0x100000, "NOHDR" },
+ { 0x200000, "EDITED" },
+ { 0x400000, "NORELOC" },
+ { 0x800000, "SYMINTPOSE" },
+ { 0x1000000, "GLOBAUDIT" },
+ { 0, NULL }
+};
+
static void
dump_dyn_val(struct readelf *re, GElf_Dyn *dyn, uint32_t stab)
{
@@ -2807,148 +2863,16 @@
printf(" %s\n", timestamp(dyn->d_un.d_val));
break;
case DT_FLAGS:
- dump_dt_flags_val(dyn->d_un.d_val);
+ dump_flags(dt_flags, dyn->d_un.d_val);
break;
case DT_FLAGS_1:
- dump_dt_flags_1_val(dyn->d_un.d_val);
+ dump_flags(dt_flags_1, dyn->d_un.d_val);
break;
default:
printf("\n");
}
}
-static void
-dump_dt_flags_val(uint64_t d_val)
-{
- if (d_val & 0x1) {
- d_val ^= 0x1;
- printf(" ORIGIN");
- }
- if (d_val & 0x2) {
- d_val ^= 0x2;
- printf(" SYMBOLIC");
- }
- if (d_val & 0x4) {
- d_val ^= 0x4;
- printf(" TEXTREL");
- }
- if (d_val & 0x8) {
- d_val ^= 0x8;
- printf(" BIND_NOW");
- }
- if (d_val & 0x10) {
- d_val ^= 0x10;
- printf(" STATIC_TLS");
- }
- if (d_val)
- printf(" %jx", (uintmax_t)d_val);
- printf("\n");
-}
-
-static void
-dump_dt_flags_1_val(uint64_t d_val)
-{
- if (d_val & 0x1) {
- d_val ^= 0x1;
- printf(" NOW");
- }
- if (d_val & 0x2) {
- d_val ^= 0x2;
- printf(" GLOBAL");
- }
- if (d_val & 0x4) {
- d_val ^= 0x4;
- printf(" GROUP");
- }
- if (d_val & 0x8) {
- d_val ^= 0x8;
- printf(" NODELETE");
- }
- if (d_val & 0x10) {
- d_val ^= 0x10;
- printf(" LOADFLTR");
- }
- if (d_val & 0x20) {
- d_val ^= 0x20;
- printf(" INITFIRST");
- }
- if (d_val & 0x40) {
- d_val ^= 0x40;
- printf(" NOOPEN");
- }
- if (d_val & 0x80) {
- d_val ^= 0x80;
- printf(" ORIGIN");
- }
- if (d_val & 0x100) {
- d_val ^= 0x100;
- printf(" DIRECT");
- }
- if (d_val & 0x400) {
- d_val ^= 0x400;
- printf(" INTERPOSE");
- }
- if (d_val & 0x800) {
- d_val ^= 0x800;
- printf(" NODEFLIB");
- }
- if (d_val & 0x1000) {
- d_val ^= 0x1000;
- printf(" NODUMP");
- }
- if (d_val & 0x2000) {
- d_val ^= 0x2000;
- printf(" CONFALT");
- }
- if (d_val & 0x4000) {
- d_val ^= 0x4000;
- printf(" ENDFILTEE");
- }
- if (d_val & 0x8000) {
- d_val ^= 0x8000;
- printf(" DISPRELDNE");
- }
- if (d_val & 0x10000) {
- d_val ^= 0x10000;
- printf(" DISPRELPND");
- }
- if (d_val & 0x20000) {
- d_val ^= 0x20000;
- printf(" NODIRECT");
- }
- if (d_val & 0x40000) {
- d_val ^= 0x40000;
- printf(" IGNMULDEF");
- }
- if (d_val & 0x80000) {
- d_val ^= 0x80000;
- printf(" NOKSYMS");
- }
- if (d_val & 0x100000) {
- d_val ^= 0x100000;
- printf(" NOHDR");
- }
- if (d_val & 0x200000) {
- d_val ^= 0x200000;
- printf(" EDITED");
- }
- if (d_val & 0x400000) {
- d_val ^= 0x400000;
- printf(" NORELOC");
- }
- if (d_val & 0x800000) {
- d_val ^= 0x800000;
- printf(" SYMINTPOSE");
- }
- if (d_val & 0x1000000) {
- d_val ^= 0x1000000;
- printf(" GLOBAUDIT");
- }
- if (d_val)
- printf(" %jx", (uintmax_t)d_val);
- printf("\n");
-}
-
static void
dump_rel(struct readelf *re, struct section *s, Elf_Data *d)
{
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Mon, Jan 13, 4:01 AM (18 h, 33 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
15775967
Default Alt Text
D19053.id53509.diff (4 KB)
Attached To
Mode
D19053: readelf: use table-based DT_FLAGS and DT_FLAGS_1 decoding
Attached
Detach File
Event Timeline
Log In to Comment