diff options
Diffstat (limited to 'include')
-rw-r--r-- | include/asm-x86/elf.h | 107 |
1 files changed, 60 insertions, 47 deletions
diff --git a/include/asm-x86/elf.h b/include/asm-x86/elf.h index 77325646e2f4..8f232dc5b5fe 100644 --- a/include/asm-x86/elf.h +++ b/include/asm-x86/elf.h | |||
@@ -11,7 +11,7 @@ | |||
11 | 11 | ||
12 | typedef unsigned long elf_greg_t; | 12 | typedef unsigned long elf_greg_t; |
13 | 13 | ||
14 | #define ELF_NGREG (sizeof (struct user_regs_struct) / sizeof(elf_greg_t)) | 14 | #define ELF_NGREG (sizeof(struct user_regs_struct) / sizeof(elf_greg_t)) |
15 | typedef elf_greg_t elf_gregset_t[ELF_NGREG]; | 15 | typedef elf_greg_t elf_gregset_t[ELF_NGREG]; |
16 | 16 | ||
17 | typedef struct user_i387_struct elf_fpregset_t; | 17 | typedef struct user_i387_struct elf_fpregset_t; |
@@ -100,10 +100,11 @@ extern unsigned int vdso_enabled; | |||
100 | We might as well make sure everything else is cleared too (except for %esp), | 100 | We might as well make sure everything else is cleared too (except for %esp), |
101 | just to make things more deterministic. | 101 | just to make things more deterministic. |
102 | */ | 102 | */ |
103 | #define ELF_PLAT_INIT(_r, load_addr) do { \ | 103 | #define ELF_PLAT_INIT(_r, load_addr) \ |
104 | _r->bx = 0; _r->cx = 0; _r->dx = 0; \ | 104 | do { \ |
105 | _r->si = 0; _r->di = 0; _r->bp = 0; \ | 105 | _r->bx = 0; _r->cx = 0; _r->dx = 0; \ |
106 | _r->ax = 0; \ | 106 | _r->si = 0; _r->di = 0; _r->bp = 0; \ |
107 | _r->ax = 0; \ | ||
107 | } while (0) | 108 | } while (0) |
108 | 109 | ||
109 | /* | 110 | /* |
@@ -111,24 +112,25 @@ extern unsigned int vdso_enabled; | |||
111 | * now struct_user_regs, they are different) | 112 | * now struct_user_regs, they are different) |
112 | */ | 113 | */ |
113 | 114 | ||
114 | #define ELF_CORE_COPY_REGS(pr_reg, regs) do { \ | 115 | #define ELF_CORE_COPY_REGS(pr_reg, regs) \ |
115 | pr_reg[0] = regs->bx; \ | 116 | do { \ |
116 | pr_reg[1] = regs->cx; \ | 117 | pr_reg[0] = regs->bx; \ |
117 | pr_reg[2] = regs->dx; \ | 118 | pr_reg[1] = regs->cx; \ |
118 | pr_reg[3] = regs->si; \ | 119 | pr_reg[2] = regs->dx; \ |
119 | pr_reg[4] = regs->di; \ | 120 | pr_reg[3] = regs->si; \ |
120 | pr_reg[5] = regs->bp; \ | 121 | pr_reg[4] = regs->di; \ |
121 | pr_reg[6] = regs->ax; \ | 122 | pr_reg[5] = regs->bp; \ |
122 | pr_reg[7] = regs->ds & 0xffff; \ | 123 | pr_reg[6] = regs->ax; \ |
123 | pr_reg[8] = regs->es & 0xffff; \ | 124 | pr_reg[7] = regs->ds & 0xffff; \ |
124 | pr_reg[9] = regs->fs & 0xffff; \ | 125 | pr_reg[8] = regs->es & 0xffff; \ |
125 | savesegment(gs, pr_reg[10]); \ | 126 | pr_reg[9] = regs->fs & 0xffff; \ |
126 | pr_reg[11] = regs->orig_ax; \ | 127 | savesegment(gs, pr_reg[10]); \ |
127 | pr_reg[12] = regs->ip; \ | 128 | pr_reg[11] = regs->orig_ax; \ |
128 | pr_reg[13] = regs->cs & 0xffff; \ | 129 | pr_reg[12] = regs->ip; \ |
129 | pr_reg[14] = regs->flags; \ | 130 | pr_reg[13] = regs->cs & 0xffff; \ |
130 | pr_reg[15] = regs->sp; \ | 131 | pr_reg[14] = regs->flags; \ |
131 | pr_reg[16] = regs->ss & 0xffff; \ | 132 | pr_reg[15] = regs->sp; \ |
133 | pr_reg[16] = regs->ss & 0xffff; \ | ||
132 | } while (0); | 134 | } while (0); |
133 | 135 | ||
134 | #define ELF_PLATFORM (utsname()->machine) | 136 | #define ELF_PLATFORM (utsname()->machine) |
@@ -139,7 +141,7 @@ extern unsigned int vdso_enabled; | |||
139 | /* | 141 | /* |
140 | * This is used to ensure we don't load something for the wrong architecture. | 142 | * This is used to ensure we don't load something for the wrong architecture. |
141 | */ | 143 | */ |
142 | #define elf_check_arch(x) \ | 144 | #define elf_check_arch(x) \ |
143 | ((x)->e_machine == EM_X86_64) | 145 | ((x)->e_machine == EM_X86_64) |
144 | 146 | ||
145 | #define compat_elf_check_arch(x) elf_check_arch_ia32(x) | 147 | #define compat_elf_check_arch(x) elf_check_arch_ia32(x) |
@@ -168,24 +170,30 @@ static inline void elf_common_init(struct thread_struct *t, | |||
168 | t->ds = t->es = ds; | 170 | t->ds = t->es = ds; |
169 | } | 171 | } |
170 | 172 | ||
171 | #define ELF_PLAT_INIT(_r, load_addr) do { \ | 173 | #define ELF_PLAT_INIT(_r, load_addr) \ |
172 | elf_common_init(¤t->thread, _r, 0); \ | 174 | do { \ |
173 | clear_thread_flag(TIF_IA32); \ | 175 | elf_common_init(¤t->thread, _r, 0); \ |
176 | clear_thread_flag(TIF_IA32); \ | ||
174 | } while (0) | 177 | } while (0) |
175 | 178 | ||
176 | #define COMPAT_ELF_PLAT_INIT(regs, load_addr) \ | 179 | #define COMPAT_ELF_PLAT_INIT(regs, load_addr) \ |
177 | elf_common_init(¤t->thread, regs, __USER_DS) | 180 | elf_common_init(¤t->thread, regs, __USER_DS) |
178 | #define compat_start_thread(regs, ip, sp) do { \ | 181 | |
179 | start_ia32_thread(regs, ip, sp); \ | 182 | #define compat_start_thread(regs, ip, sp) \ |
180 | set_fs(USER_DS); \ | 183 | do { \ |
181 | } while (0) | 184 | start_ia32_thread(regs, ip, sp); \ |
182 | #define COMPAT_SET_PERSONALITY(ex, ibcs2) do { \ | 185 | set_fs(USER_DS); \ |
183 | if (test_thread_flag(TIF_IA32)) \ | 186 | } while (0) |
184 | clear_thread_flag(TIF_ABI_PENDING); \ | 187 | |
185 | else \ | 188 | #define COMPAT_SET_PERSONALITY(ex, ibcs2) \ |
186 | set_thread_flag(TIF_ABI_PENDING); \ | 189 | do { \ |
187 | current->personality |= force_personality32; \ | 190 | if (test_thread_flag(TIF_IA32)) \ |
188 | } while (0) | 191 | clear_thread_flag(TIF_ABI_PENDING); \ |
192 | else \ | ||
193 | set_thread_flag(TIF_ABI_PENDING); \ | ||
194 | current->personality |= force_personality32; \ | ||
195 | } while (0) | ||
196 | |||
189 | #define COMPAT_ELF_PLATFORM ("i686") | 197 | #define COMPAT_ELF_PLATFORM ("i686") |
190 | 198 | ||
191 | /* | 199 | /* |
@@ -194,7 +202,8 @@ static inline void elf_common_init(struct thread_struct *t, | |||
194 | * getting dumped. | 202 | * getting dumped. |
195 | */ | 203 | */ |
196 | 204 | ||
197 | #define ELF_CORE_COPY_REGS(pr_reg, regs) do { \ | 205 | #define ELF_CORE_COPY_REGS(pr_reg, regs) \ |
206 | do { \ | ||
198 | unsigned v; \ | 207 | unsigned v; \ |
199 | (pr_reg)[0] = (regs)->r15; \ | 208 | (pr_reg)[0] = (regs)->r15; \ |
200 | (pr_reg)[1] = (regs)->r14; \ | 209 | (pr_reg)[1] = (regs)->r14; \ |
@@ -268,10 +277,12 @@ extern int force_personality32; | |||
268 | 277 | ||
269 | struct task_struct; | 278 | struct task_struct; |
270 | 279 | ||
271 | #define ARCH_DLINFO_IA32(vdso_enabled) \ | 280 | #define ARCH_DLINFO_IA32(vdso_enabled) \ |
272 | do if (vdso_enabled) { \ | 281 | do { \ |
282 | if (vdso_enabled) { \ | ||
273 | NEW_AUX_ENT(AT_SYSINFO, VDSO_ENTRY); \ | 283 | NEW_AUX_ENT(AT_SYSINFO, VDSO_ENTRY); \ |
274 | NEW_AUX_ENT(AT_SYSINFO_EHDR, VDSO_CURRENT_BASE); \ | 284 | NEW_AUX_ENT(AT_SYSINFO_EHDR, VDSO_CURRENT_BASE); \ |
285 | } \ | ||
275 | } while (0) | 286 | } while (0) |
276 | 287 | ||
277 | #ifdef CONFIG_X86_32 | 288 | #ifdef CONFIG_X86_32 |
@@ -289,9 +300,11 @@ do if (vdso_enabled) { \ | |||
289 | /* 1GB for 64bit, 8MB for 32bit */ | 300 | /* 1GB for 64bit, 8MB for 32bit */ |
290 | #define STACK_RND_MASK (test_thread_flag(TIF_IA32) ? 0x7ff : 0x3fffff) | 301 | #define STACK_RND_MASK (test_thread_flag(TIF_IA32) ? 0x7ff : 0x3fffff) |
291 | 302 | ||
292 | #define ARCH_DLINFO \ | 303 | #define ARCH_DLINFO \ |
293 | do if (vdso_enabled) { \ | 304 | do { \ |
294 | NEW_AUX_ENT(AT_SYSINFO_EHDR,(unsigned long)current->mm->context.vdso);\ | 305 | if (vdso_enabled) \ |
306 | NEW_AUX_ENT(AT_SYSINFO_EHDR, \ | ||
307 | (unsigned long)current->mm->context.vdso); \ | ||
295 | } while (0) | 308 | } while (0) |
296 | 309 | ||
297 | #define AT_SYSINFO 32 | 310 | #define AT_SYSINFO 32 |
@@ -304,8 +317,8 @@ do if (vdso_enabled) { \ | |||
304 | 317 | ||
305 | #define VDSO_CURRENT_BASE ((unsigned long)current->mm->context.vdso) | 318 | #define VDSO_CURRENT_BASE ((unsigned long)current->mm->context.vdso) |
306 | 319 | ||
307 | #define VDSO_ENTRY \ | 320 | #define VDSO_ENTRY \ |
308 | ((unsigned long) VDSO32_SYMBOL(VDSO_CURRENT_BASE, vsyscall)) | 321 | ((unsigned long)VDSO32_SYMBOL(VDSO_CURRENT_BASE, vsyscall)) |
309 | 322 | ||
310 | struct linux_binprm; | 323 | struct linux_binprm; |
311 | 324 | ||