/src/elfutils/libelf/gelf_xlate.c
Line | Count | Source (jump to first uncovered line) |
1 | | /* Transformation functions for ELF data types. |
2 | | Copyright (C) 1998,1999,2000,2002,2004,2005,2006,2007,2015 Red Hat, Inc. |
3 | | Copyright (C) 2022 Mark J. Wielaard <mark@klomp.org> |
4 | | This file is part of elfutils. |
5 | | Written by Ulrich Drepper <drepper@redhat.com>, 1998. |
6 | | |
7 | | This file is free software; you can redistribute it and/or modify |
8 | | it under the terms of either |
9 | | |
10 | | * the GNU Lesser General Public License as published by the Free |
11 | | Software Foundation; either version 3 of the License, or (at |
12 | | your option) any later version |
13 | | |
14 | | or |
15 | | |
16 | | * the GNU General Public License as published by the Free |
17 | | Software Foundation; either version 2 of the License, or (at |
18 | | your option) any later version |
19 | | |
20 | | or both in parallel, as here. |
21 | | |
22 | | elfutils is distributed in the hope that it will be useful, but |
23 | | WITHOUT ANY WARRANTY; without even the implied warranty of |
24 | | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
25 | | General Public License for more details. |
26 | | |
27 | | You should have received copies of the GNU General Public License and |
28 | | the GNU Lesser General Public License along with this program. If |
29 | | not, see <http://www.gnu.org/licenses/>. */ |
30 | | |
31 | | #ifdef HAVE_CONFIG_H |
32 | | # include <config.h> |
33 | | #endif |
34 | | |
35 | | #include <stdint.h> |
36 | | #include <string.h> |
37 | | #include <stdlib.h> |
38 | | |
39 | | #include "libelfP.h" |
40 | | |
41 | | #ifndef LIBELFBITS |
42 | | # define LIBELFBITS 32 |
43 | | #endif |
44 | | |
45 | | |
46 | | /* Well, what shall I say. Nothing to do here. */ |
47 | | #define elf_cvt_Byte(dest, src, n) \ |
48 | | (__builtin_constant_p (n) && (n) == 1 \ |
49 | | ? (void) (*((char *) (dest)) = *((char *) (src))) \ |
50 | | : Elf32_cvt_Byte (dest, src, n)) |
51 | | static void |
52 | | (elf_cvt_Byte) (void *dest, const void *src, size_t n, |
53 | | int encode __attribute__ ((unused))) |
54 | 94 | { |
55 | 94 | if (n != 0) |
56 | 87 | memmove (dest, src, n); |
57 | 94 | } |
58 | | |
59 | | |
60 | | /* We'll optimize the definition of the conversion functions here a |
61 | | bit. We need only functions for 16, 32, and 64 bits. The |
62 | | functions referenced in the table will be aliases for one of these |
63 | | functions. Which one is decided by the ELFxx_FSZ_type. */ |
64 | | |
65 | | #if ALLOW_UNALIGNED |
66 | | |
67 | | #define FETCH(Bits, ptr) (*(const uint##Bits##_t *) ptr) |
68 | 483M | #define STORE(Bits, ptr, val) (*(uint##Bits##_t *) ptr = val) |
69 | | |
70 | | #else |
71 | | |
72 | | union unaligned |
73 | | { |
74 | | uint16_t u16; |
75 | | uint32_t u32; |
76 | | uint64_t u64; |
77 | | } attribute_packed; |
78 | | |
79 | | #define FETCH(Bits, ptr) (((const union unaligned *) ptr)->u##Bits) |
80 | | #define STORE(Bits, ptr, val) (((union unaligned *) ptr)->u##Bits = val) |
81 | | |
82 | | #endif |
83 | | |
84 | | /* Now define the conversion functions for the basic types. We use here |
85 | | the fact that file and memory types are the same and that we have the |
86 | | ELFxx_FSZ_* macros. |
87 | | |
88 | | At the same time we define inline functions which we will use to |
89 | | convert the complex types. */ |
90 | | #define FUNDAMENTAL(NAME, Name, Bits) \ |
91 | | INLINE2 (ELFW2(Bits,FSZ_##NAME), ElfW2(Bits,cvt_##Name), ElfW2(Bits,Name)) |
92 | | #define INLINE2(Bytes, FName, TName) \ |
93 | | INLINE3 (Bytes, FName, TName) |
94 | | #define INLINE3(Bytes, FName, TName) \ |
95 | | static inline void FName##1 (void *dest, const void *ptr) \ |
96 | 483M | { \ |
97 | 483M | switch (Bytes) \ |
98 | 483M | { \ |
99 | 2.79M | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ |
100 | 479M | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ |
101 | 1.42M | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ |
102 | 0 | default: \ |
103 | 0 | abort (); \ |
104 | 483M | } \ |
105 | 483M | } \ gelf_xlate.c:Elf32_cvt_Addr1 Line | Count | Source | 96 | 117M | { \ | 97 | 117M | switch (Bytes) \ | 98 | 117M | { \ | 99 | 0 | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 117M | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 0 | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 117M | } \ | 105 | 117M | } \ |
gelf_xlate.c:Elf32_cvt_Sword1 Line | Count | Source | 96 | 1.95M | { \ | 97 | 1.95M | switch (Bytes) \ | 98 | 1.95M | { \ | 99 | 0 | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 1.95M | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 0 | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 1.95M | } \ | 105 | 1.95M | } \ |
gelf_xlate.c:Elf32_cvt_Half1 Line | Count | Source | 96 | 1.14M | { \ | 97 | 1.14M | switch (Bytes) \ | 98 | 1.14M | { \ | 99 | 1.14M | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 0 | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 0 | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 1.14M | } \ | 105 | 1.14M | } \ |
gelf_xlate.c:Elf32_cvt_Word1 Line | Count | Source | 96 | 302M | { \ | 97 | 302M | switch (Bytes) \ | 98 | 302M | { \ | 99 | 0 | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 302M | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 0 | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 302M | } \ | 105 | 302M | } \ |
gelf_xlate.c:Elf32_cvt_Off1 Line | Count | Source | 96 | 57.3M | { \ | 97 | 57.3M | switch (Bytes) \ | 98 | 57.3M | { \ | 99 | 0 | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 57.3M | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 0 | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 57.3M | } \ | 105 | 57.3M | } \ |
gelf_xlate.c:Elf32_cvt_Xword1 Line | Count | Source | 96 | 45.3k | { \ | 97 | 45.3k | switch (Bytes) \ | 98 | 45.3k | { \ | 99 | 0 | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 0 | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 45.3k | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 45.3k | } \ | 105 | 45.3k | } \ |
Unexecuted instantiation: gelf_xlate.c:Elf32_cvt_Sxword1 Unexecuted instantiation: gelf_xlate.c:Elf32_cvt_Relr1 gelf_xlate.c:Elf64_cvt_Addr1 Line | Count | Source | 96 | 913k | { \ | 97 | 913k | switch (Bytes) \ | 98 | 913k | { \ | 99 | 0 | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 0 | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 913k | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 913k | } \ | 105 | 913k | } \ |
gelf_xlate.c:Elf64_cvt_Xword1 Line | Count | Source | 96 | 401k | { \ | 97 | 401k | switch (Bytes) \ | 98 | 401k | { \ | 99 | 0 | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 0 | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 401k | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 401k | } \ | 105 | 401k | } \ |
gelf_xlate.c:Elf64_cvt_Half1 Line | Count | Source | 96 | 1.65M | { \ | 97 | 1.65M | switch (Bytes) \ | 98 | 1.65M | { \ | 99 | 1.65M | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 0 | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 0 | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 1.65M | } \ | 105 | 1.65M | } \ |
gelf_xlate.c:Elf64_cvt_Word1 Line | Count | Source | 96 | 194k | { \ | 97 | 194k | switch (Bytes) \ | 98 | 194k | { \ | 99 | 0 | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 194k | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 0 | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 194k | } \ | 105 | 194k | } \ |
gelf_xlate.c:Elf64_cvt_Off1 Line | Count | Source | 96 | 26.0k | { \ | 97 | 26.0k | switch (Bytes) \ | 98 | 26.0k | { \ | 99 | 0 | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 0 | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 26.0k | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 26.0k | } \ | 105 | 26.0k | } \ |
gelf_xlate.c:Elf64_cvt_Sxword1 Line | Count | Source | 96 | 33.7k | { \ | 97 | 33.7k | switch (Bytes) \ | 98 | 33.7k | { \ | 99 | 0 | case 2: STORE (16, dest, bswap_16 (FETCH (16, ptr))); break; \ | 100 | 0 | case 4: STORE (32, dest, bswap_32 (FETCH (32, ptr))); break; \ | 101 | 33.7k | case 8: STORE (64, dest, bswap_64 (FETCH (64, ptr))); break; \ | 102 | 0 | default: \ | 103 | 0 | abort (); \ | 104 | 33.7k | } \ | 105 | 33.7k | } \ |
Unexecuted instantiation: gelf_xlate.c:Elf64_cvt_Sword1 Unexecuted instantiation: gelf_xlate.c:Elf64_cvt_Relr1 |
106 | | \ |
107 | | static void FName (void *dest, const void *ptr, size_t len, \ |
108 | | int encode __attribute__ ((unused))) \ |
109 | 8.18k | { \ |
110 | 8.18k | size_t n = len / sizeof (TName); \ |
111 | 8.18k | if (dest < ptr) \ |
112 | 2.70M | while (n-- > 0) \ |
113 | 2.70M | { \ |
114 | 2.70M | FName##1 (dest, ptr); \ |
115 | 2.70M | dest += Bytes; \ |
116 | 2.70M | ptr += Bytes; \ |
117 | 2.70M | } \ |
118 | 8.18k | else \ |
119 | 8.18k | { \ |
120 | 5.75k | dest += len; \ |
121 | 5.75k | ptr += len; \ |
122 | 2.24M | while (n-- > 0) \ |
123 | 2.23M | { \ |
124 | 2.23M | ptr -= Bytes; \ |
125 | 2.23M | dest -= Bytes; \ |
126 | 2.23M | FName##1 (dest, ptr); \ |
127 | 2.23M | } \ |
128 | 5.75k | } \ |
129 | 8.18k | } gelf_xlate.c:Elf32_cvt_Addr Line | Count | Source | 109 | 637 | { \ | 110 | 637 | size_t n = len / sizeof (TName); \ | 111 | 637 | if (dest < ptr) \ | 112 | 531k | while (n-- > 0) \ | 113 | 531k | { \ | 114 | 531k | FName##1 (dest, ptr); \ | 115 | 531k | dest += Bytes; \ | 116 | 531k | ptr += Bytes; \ | 117 | 531k | } \ | 118 | 637 | else \ | 119 | 637 | { \ | 120 | 439 | dest += len; \ | 121 | 439 | ptr += len; \ | 122 | 388k | while (n-- > 0) \ | 123 | 388k | { \ | 124 | 388k | ptr -= Bytes; \ | 125 | 388k | dest -= Bytes; \ | 126 | 388k | FName##1 (dest, ptr); \ | 127 | 388k | } \ | 128 | 439 | } \ | 129 | 637 | } |
gelf_xlate.c:Elf32_cvt_Half Line | Count | Source | 109 | 1.45k | { \ | 110 | 1.45k | size_t n = len / sizeof (TName); \ | 111 | 1.45k | if (dest < ptr) \ | 112 | 36.9k | while (n-- > 0) \ | 113 | 36.5k | { \ | 114 | 36.5k | FName##1 (dest, ptr); \ | 115 | 36.5k | dest += Bytes; \ | 116 | 36.5k | ptr += Bytes; \ | 117 | 36.5k | } \ | 118 | 1.45k | else \ | 119 | 1.45k | { \ | 120 | 1.08k | dest += len; \ | 121 | 1.08k | ptr += len; \ | 122 | 515k | while (n-- > 0) \ | 123 | 514k | { \ | 124 | 514k | ptr -= Bytes; \ | 125 | 514k | dest -= Bytes; \ | 126 | 514k | FName##1 (dest, ptr); \ | 127 | 514k | } \ | 128 | 1.08k | } \ | 129 | 1.45k | } |
Unexecuted instantiation: gelf_xlate.c:Elf32_cvt_Off Unexecuted instantiation: gelf_xlate.c:Elf32_cvt_Sword gelf_xlate.c:Elf32_cvt_Word Line | Count | Source | 109 | 3.33k | { \ | 110 | 3.33k | size_t n = len / sizeof (TName); \ | 111 | 3.33k | if (dest < ptr) \ | 112 | 1.13M | while (n-- > 0) \ | 113 | 1.13M | { \ | 114 | 1.13M | FName##1 (dest, ptr); \ | 115 | 1.13M | dest += Bytes; \ | 116 | 1.13M | ptr += Bytes; \ | 117 | 1.13M | } \ | 118 | 3.33k | else \ | 119 | 3.33k | { \ | 120 | 2.42k | dest += len; \ | 121 | 2.42k | ptr += len; \ | 122 | 255k | while (n-- > 0) \ | 123 | 252k | { \ | 124 | 252k | ptr -= Bytes; \ | 125 | 252k | dest -= Bytes; \ | 126 | 252k | FName##1 (dest, ptr); \ | 127 | 252k | } \ | 128 | 2.42k | } \ | 129 | 3.33k | } |
Unexecuted instantiation: gelf_xlate.c:Elf32_cvt_Xword Unexecuted instantiation: gelf_xlate.c:Elf32_cvt_Sxword Unexecuted instantiation: gelf_xlate.c:Elf32_cvt_Relr gelf_xlate.c:Elf64_cvt_Addr Line | Count | Source | 109 | 1.13k | { \ | 110 | 1.13k | size_t n = len / sizeof (TName); \ | 111 | 1.13k | if (dest < ptr) \ | 112 | 293k | while (n-- > 0) \ | 113 | 293k | { \ | 114 | 293k | FName##1 (dest, ptr); \ | 115 | 293k | dest += Bytes; \ | 116 | 293k | ptr += Bytes; \ | 117 | 293k | } \ | 118 | 1.13k | else \ | 119 | 1.13k | { \ | 120 | 816 | dest += len; \ | 121 | 816 | ptr += len; \ | 122 | 300k | while (n-- > 0) \ | 123 | 299k | { \ | 124 | 299k | ptr -= Bytes; \ | 125 | 299k | dest -= Bytes; \ | 126 | 299k | FName##1 (dest, ptr); \ | 127 | 299k | } \ | 128 | 816 | } \ | 129 | 1.13k | } |
gelf_xlate.c:Elf64_cvt_Half Line | Count | Source | 109 | 664 | { \ | 110 | 664 | size_t n = len / sizeof (TName); \ | 111 | 664 | if (dest < ptr) \ | 112 | 692k | while (n-- > 0) \ | 113 | 692k | { \ | 114 | 692k | FName##1 (dest, ptr); \ | 115 | 692k | dest += Bytes; \ | 116 | 692k | ptr += Bytes; \ | 117 | 692k | } \ | 118 | 664 | else \ | 119 | 664 | { \ | 120 | 440 | dest += len; \ | 121 | 440 | ptr += len; \ | 122 | 753k | while (n-- > 0) \ | 123 | 752k | { \ | 124 | 752k | ptr -= Bytes; \ | 125 | 752k | dest -= Bytes; \ | 126 | 752k | FName##1 (dest, ptr); \ | 127 | 752k | } \ | 128 | 440 | } \ | 129 | 664 | } |
Unexecuted instantiation: gelf_xlate.c:Elf64_cvt_Off Unexecuted instantiation: gelf_xlate.c:Elf64_cvt_Sword gelf_xlate.c:Elf64_cvt_Word Line | Count | Source | 109 | 389 | { \ | 110 | 389 | size_t n = len / sizeof (TName); \ | 111 | 389 | if (dest < ptr) \ | 112 | 9.16k | while (n-- > 0) \ | 113 | 9.00k | { \ | 114 | 9.00k | FName##1 (dest, ptr); \ | 115 | 9.00k | dest += Bytes; \ | 116 | 9.00k | ptr += Bytes; \ | 117 | 9.00k | } \ | 118 | 389 | else \ | 119 | 389 | { \ | 120 | 229 | dest += len; \ | 121 | 229 | ptr += len; \ | 122 | 9.34k | while (n-- > 0) \ | 123 | 9.11k | { \ | 124 | 9.11k | ptr -= Bytes; \ | 125 | 9.11k | dest -= Bytes; \ | 126 | 9.11k | FName##1 (dest, ptr); \ | 127 | 9.11k | } \ | 128 | 229 | } \ | 129 | 389 | } |
gelf_xlate.c:Elf64_cvt_Xword Line | Count | Source | 109 | 583 | { \ | 110 | 583 | size_t n = len / sizeof (TName); \ | 111 | 583 | if (dest < ptr) \ | 112 | 11.6k | while (n-- > 0) \ | 113 | 11.4k | { \ | 114 | 11.4k | FName##1 (dest, ptr); \ | 115 | 11.4k | dest += Bytes; \ | 116 | 11.4k | ptr += Bytes; \ | 117 | 11.4k | } \ | 118 | 583 | else \ | 119 | 583 | { \ | 120 | 327 | dest += len; \ | 121 | 327 | ptr += len; \ | 122 | 18.3k | while (n-- > 0) \ | 123 | 17.9k | { \ | 124 | 17.9k | ptr -= Bytes; \ | 125 | 17.9k | dest -= Bytes; \ | 126 | 17.9k | FName##1 (dest, ptr); \ | 127 | 17.9k | } \ | 128 | 327 | } \ | 129 | 583 | } |
Unexecuted instantiation: gelf_xlate.c:Elf64_cvt_Sxword Unexecuted instantiation: gelf_xlate.c:Elf64_cvt_Relr |
130 | | |
131 | | |
132 | | /* Now the tricky part: define the transformation functions for the |
133 | | complex types. We will use the definitions of the types in |
134 | | abstract.h. */ |
135 | | #define START(Bits, Name, EName) \ |
136 | | static void \ |
137 | | ElfW2 (Bits, cvt_##Name) (void *dest, const void *src, size_t len, \ |
138 | | int encode __attribute__ ((unused))) \ |
139 | 4.64M | { ElfW2(Bits, Name) *tdest = (ElfW2(Bits, Name) *) dest; \ |
140 | 4.64M | ElfW2(Bits, Name) *tsrc = (ElfW2(Bits, Name) *) src; \ |
141 | 4.64M | size_t sz = sizeof (ElfW2(Bits, Name)); \ |
142 | 4.64M | size_t n; \ |
143 | 69.3M | for (n = len / sz; n > 0; ++tdest, ++tsrc, --n) { |
144 | | #define END(Bits, Name) \ |
145 | 64.6M | } \ |
146 | 4.64M | if (len % sz > 0) /* Cannot convert partial structures, just copy. */ \ |
147 | 4.64M | memmove (dest, src, len % sz); \ |
148 | 4.64M | } |
149 | | #define TYPE_EXTRA(Code) |
150 | 1.94M | #define TYPE_XLATE(Code) Code |
151 | 476M | #define TYPE_NAME(Type, Name) TYPE_NAME2 (Type, Name) |
152 | 476M | #define TYPE_NAME2(Type, Name) Type##1 (&tdest->Name, &tsrc->Name); |
153 | | #define TYPE(Name, Bits) TYPE2 (Name, Bits) |
154 | | #define TYPE2(Name, Bits) TYPE3 (Name##Bits) |
155 | | #define TYPE3(Name) Name (cvt_) |
156 | | |
157 | | /* Signal that we are generating conversion functions. */ |
158 | | #define GENERATE_CONVERSION |
159 | | |
160 | | /* First generate the 32-bit conversion functions. */ |
161 | | #define LIBELFBITS 32 |
162 | | #include "gelf_xlate.h" |
163 | | |
164 | | /* Now generate the 64-bit conversion functions. */ |
165 | | #define LIBELFBITS 64 |
166 | | #include "gelf_xlate.h" |
167 | | |
168 | | |
169 | | /* We have a few functions which we must create by hand since the sections |
170 | | do not contain records of only one type. */ |
171 | | #include "version_xlate.h" |
172 | | #include "gnuhash_xlate.h" |
173 | | #include "note_xlate.h" |
174 | | #include "chdr_xlate.h" |
175 | | |
176 | | |
177 | | /* Now the externally visible table with the function pointers. */ |
178 | | const xfct_t __elf_xfctstom[ELFCLASSNUM - 1][ELF_T_NUM] = |
179 | | { |
180 | | [ELFCLASS32 - 1] = { |
181 | | #define define_xfcts(Bits) \ |
182 | | [ELF_T_BYTE] = elf_cvt_Byte, \ |
183 | | [ELF_T_ADDR] = ElfW2(Bits, cvt_Addr), \ |
184 | | [ELF_T_DYN] = ElfW2(Bits, cvt_Dyn), \ |
185 | | [ELF_T_EHDR] = ElfW2(Bits, cvt_Ehdr), \ |
186 | | [ELF_T_HALF] = ElfW2(Bits, cvt_Half), \ |
187 | | [ELF_T_OFF] = ElfW2(Bits, cvt_Off), \ |
188 | | [ELF_T_PHDR] = ElfW2(Bits, cvt_Phdr), \ |
189 | | [ELF_T_RELA] = ElfW2(Bits, cvt_Rela), \ |
190 | | [ELF_T_REL] = ElfW2(Bits, cvt_Rel), \ |
191 | | [ELF_T_SHDR] = ElfW2(Bits, cvt_Shdr), \ |
192 | | [ELF_T_SWORD] = ElfW2(Bits, cvt_Sword), \ |
193 | | [ELF_T_SYM] = ElfW2(Bits, cvt_Sym), \ |
194 | | [ELF_T_WORD] = ElfW2(Bits, cvt_Word), \ |
195 | | [ELF_T_XWORD] = ElfW2(Bits, cvt_Xword), \ |
196 | | [ELF_T_SXWORD] = ElfW2(Bits, cvt_Sxword), \ |
197 | | [ELF_T_VDEF] = elf_cvt_Verdef, \ |
198 | | [ELF_T_VDAUX] = elf_cvt_Verdef, \ |
199 | | [ELF_T_VNEED] = elf_cvt_Verneed, \ |
200 | | [ELF_T_VNAUX] = elf_cvt_Verneed, \ |
201 | | [ELF_T_NHDR] = elf_cvt_note4, \ |
202 | | [ELF_T_NHDR8] = elf_cvt_note8, \ |
203 | | [ELF_T_SYMINFO] = ElfW2(Bits, cvt_Syminfo), \ |
204 | | [ELF_T_MOVE] = ElfW2(Bits, cvt_Move), \ |
205 | | [ELF_T_LIB] = ElfW2(Bits, cvt_Lib), \ |
206 | | [ELF_T_AUXV] = ElfW2(Bits, cvt_auxv_t), \ |
207 | | [ELF_T_CHDR] = ElfW2(Bits, cvt_chdr), \ |
208 | | [ELF_T_RELR] = ElfW2(Bits, cvt_Relr) |
209 | | define_xfcts (32), |
210 | | [ELF_T_GNUHASH] = Elf32_cvt_Word |
211 | | }, |
212 | | [ELFCLASS64 - 1] = { |
213 | | define_xfcts (64), |
214 | | [ELF_T_GNUHASH] = elf_cvt_gnuhash |
215 | | } |
216 | | }; |