binfmt_elf: remove the set_fs in fill_siginfo_note
[linux-block.git] / fs / binfmt_elf.c
CommitLineData
09c434b8 1// SPDX-License-Identifier: GPL-2.0-only
1da177e4
LT
2/*
3 * linux/fs/binfmt_elf.c
4 *
5 * These are the functions used to load ELF format executables as used
6 * on SVr4 machines. Information on the format may be found in the book
7 * "UNIX SYSTEM V RELEASE 4 Programmers Guide: Ansi C and Programming Support
8 * Tools".
9 *
10 * Copyright 1993, 1994: Eric Youngdale (ericy@cais.com).
11 */
12
13#include <linux/module.h>
14#include <linux/kernel.h>
15#include <linux/fs.h>
1da177e4
LT
16#include <linux/mm.h>
17#include <linux/mman.h>
1da177e4
LT
18#include <linux/errno.h>
19#include <linux/signal.h>
20#include <linux/binfmts.h>
21#include <linux/string.h>
22#include <linux/file.h>
1da177e4 23#include <linux/slab.h>
1da177e4
LT
24#include <linux/personality.h>
25#include <linux/elfcore.h>
26#include <linux/init.h>
27#include <linux/highuid.h>
1da177e4
LT
28#include <linux/compiler.h>
29#include <linux/highmem.h>
03911132 30#include <linux/hugetlb.h>
1da177e4 31#include <linux/pagemap.h>
2aa362c4 32#include <linux/vmalloc.h>
1da177e4 33#include <linux/security.h>
1da177e4 34#include <linux/random.h>
f4e5cc2c 35#include <linux/elf.h>
d1fd836d 36#include <linux/elf-randomize.h>
7e80d0d0 37#include <linux/utsname.h>
088e7af7 38#include <linux/coredump.h>
6fac4829 39#include <linux/sched.h>
f7ccbae4 40#include <linux/sched/coredump.h>
68db0cf1 41#include <linux/sched/task_stack.h>
32ef5517 42#include <linux/sched/cputime.h>
5b825c3a 43#include <linux/cred.h>
5037835c 44#include <linux/dax.h>
7c0f6ba6 45#include <linux/uaccess.h>
1da177e4
LT
46#include <asm/param.h>
47#include <asm/page.h>
48
2aa362c4
DV
49#ifndef user_long_t
50#define user_long_t long
51#endif
49ae4d4b
DV
52#ifndef user_siginfo_t
53#define user_siginfo_t siginfo_t
54#endif
55
4755200b
NP
56/* That's for binfmt_elf_fdpic to deal with */
57#ifndef elf_check_fdpic
58#define elf_check_fdpic(ex) false
59#endif
60
71613c3b 61static int load_elf_binary(struct linux_binprm *bprm);
1da177e4 62
69369a70
JT
63#ifdef CONFIG_USELIB
64static int load_elf_library(struct file *);
65#else
66#define load_elf_library NULL
67#endif
68
1da177e4
LT
69/*
70 * If we don't support core dumping, then supply a NULL so we
71 * don't even try.
72 */
698ba7b5 73#ifdef CONFIG_ELF_CORE
f6151dfe 74static int elf_core_dump(struct coredump_params *cprm);
1da177e4
LT
75#else
76#define elf_core_dump NULL
77#endif
78
79#if ELF_EXEC_PAGESIZE > PAGE_SIZE
f4e5cc2c 80#define ELF_MIN_ALIGN ELF_EXEC_PAGESIZE
1da177e4 81#else
f4e5cc2c 82#define ELF_MIN_ALIGN PAGE_SIZE
1da177e4
LT
83#endif
84
85#ifndef ELF_CORE_EFLAGS
86#define ELF_CORE_EFLAGS 0
87#endif
88
89#define ELF_PAGESTART(_v) ((_v) & ~(unsigned long)(ELF_MIN_ALIGN-1))
90#define ELF_PAGEOFFSET(_v) ((_v) & (ELF_MIN_ALIGN-1))
91#define ELF_PAGEALIGN(_v) (((_v) + ELF_MIN_ALIGN - 1) & ~(ELF_MIN_ALIGN - 1))
92
93static struct linux_binfmt elf_format = {
f670d0ec
MP
94 .module = THIS_MODULE,
95 .load_binary = load_elf_binary,
96 .load_shlib = load_elf_library,
97 .core_dump = elf_core_dump,
98 .min_coredump = ELF_EXEC_PAGESIZE,
1da177e4
LT
99};
100
18676ffc 101#define BAD_ADDR(x) (unlikely((unsigned long)(x) >= TASK_SIZE))
1da177e4 102
16e72e9b 103static int set_brk(unsigned long start, unsigned long end, int prot)
1da177e4
LT
104{
105 start = ELF_PAGEALIGN(start);
106 end = ELF_PAGEALIGN(end);
107 if (end > start) {
16e72e9b
DV
108 /*
109 * Map the last of the bss segment.
110 * If the header is requesting these pages to be
111 * executable, honour that (ppc32 needs this).
112 */
113 int error = vm_brk_flags(start, end - start,
114 prot & PROT_EXEC ? VM_EXEC : 0);
5d22fc25
LT
115 if (error)
116 return error;
1da177e4
LT
117 }
118 current->mm->start_brk = current->mm->brk = end;
119 return 0;
120}
121
1da177e4
LT
122/* We need to explicitly zero any fractional pages
123 after the data section (i.e. bss). This would
124 contain the junk from the file that should not
f4e5cc2c
JJ
125 be in memory
126 */
1da177e4
LT
127static int padzero(unsigned long elf_bss)
128{
129 unsigned long nbyte;
130
131 nbyte = ELF_PAGEOFFSET(elf_bss);
132 if (nbyte) {
133 nbyte = ELF_MIN_ALIGN - nbyte;
134 if (clear_user((void __user *) elf_bss, nbyte))
135 return -EFAULT;
136 }
137 return 0;
138}
139
09c6dd3c 140/* Let's use some macros to make this stack manipulation a little clearer */
1da177e4
LT
141#ifdef CONFIG_STACK_GROWSUP
142#define STACK_ADD(sp, items) ((elf_addr_t __user *)(sp) + (items))
143#define STACK_ROUND(sp, items) \
144 ((15 + (unsigned long) ((sp) + (items))) &~ 15UL)
f4e5cc2c
JJ
145#define STACK_ALLOC(sp, len) ({ \
146 elf_addr_t __user *old_sp = (elf_addr_t __user *)sp; sp += len; \
147 old_sp; })
1da177e4
LT
148#else
149#define STACK_ADD(sp, items) ((elf_addr_t __user *)(sp) - (items))
150#define STACK_ROUND(sp, items) \
151 (((unsigned long) (sp - items)) &~ 15UL)
152#define STACK_ALLOC(sp, len) ({ sp -= len ; sp; })
153#endif
154
483fad1c
NL
155#ifndef ELF_BASE_PLATFORM
156/*
157 * AT_BASE_PLATFORM indicates the "real" hardware/microarchitecture.
158 * If the arch defines ELF_BASE_PLATFORM (in asm/elf.h), the value
159 * will be copied to the user stack in the same manner as AT_PLATFORM.
160 */
161#define ELF_BASE_PLATFORM NULL
162#endif
163
1da177e4 164static int
a62c5b1b
AD
165create_elf_tables(struct linux_binprm *bprm, const struct elfhdr *exec,
166 unsigned long load_addr, unsigned long interp_load_addr,
167 unsigned long e_entry)
1da177e4 168{
03c6d723 169 struct mm_struct *mm = current->mm;
1da177e4
LT
170 unsigned long p = bprm->p;
171 int argc = bprm->argc;
172 int envc = bprm->envc;
1da177e4
LT
173 elf_addr_t __user *sp;
174 elf_addr_t __user *u_platform;
483fad1c 175 elf_addr_t __user *u_base_platform;
f06295b4 176 elf_addr_t __user *u_rand_bytes;
1da177e4 177 const char *k_platform = ELF_PLATFORM;
483fad1c 178 const char *k_base_platform = ELF_BASE_PLATFORM;
f06295b4 179 unsigned char k_rand_bytes[16];
1da177e4
LT
180 int items;
181 elf_addr_t *elf_info;
1f83d806 182 int ei_index;
86a264ab 183 const struct cred *cred = current_cred();
b6a2fea3 184 struct vm_area_struct *vma;
1da177e4 185
d68c9d6a
FBH
186 /*
187 * In some cases (e.g. Hyper-Threading), we want to avoid L1
188 * evictions by the processes running on the same package. One
189 * thing we can do is to shuffle the initial stack for them.
190 */
191
192 p = arch_align_stack(p);
193
1da177e4
LT
194 /*
195 * If this architecture has a platform capability string, copy it
196 * to userspace. In some cases (Sparc), this info is impossible
197 * for userspace to get any other way, in others (i386) it is
198 * merely difficult.
199 */
1da177e4
LT
200 u_platform = NULL;
201 if (k_platform) {
202 size_t len = strlen(k_platform) + 1;
203
1da177e4
LT
204 u_platform = (elf_addr_t __user *)STACK_ALLOC(p, len);
205 if (__copy_to_user(u_platform, k_platform, len))
206 return -EFAULT;
207 }
208
483fad1c
NL
209 /*
210 * If this architecture has a "base" platform capability
211 * string, copy it to userspace.
212 */
213 u_base_platform = NULL;
214 if (k_base_platform) {
215 size_t len = strlen(k_base_platform) + 1;
216
217 u_base_platform = (elf_addr_t __user *)STACK_ALLOC(p, len);
218 if (__copy_to_user(u_base_platform, k_base_platform, len))
219 return -EFAULT;
220 }
221
f06295b4
KC
222 /*
223 * Generate 16 random bytes for userspace PRNG seeding.
224 */
225 get_random_bytes(k_rand_bytes, sizeof(k_rand_bytes));
226 u_rand_bytes = (elf_addr_t __user *)
227 STACK_ALLOC(p, sizeof(k_rand_bytes));
228 if (__copy_to_user(u_rand_bytes, k_rand_bytes, sizeof(k_rand_bytes)))
229 return -EFAULT;
230
1da177e4 231 /* Create the ELF interpreter info */
03c6d723 232 elf_info = (elf_addr_t *)mm->saved_auxv;
4f9a58d7 233 /* update AT_VECTOR_SIZE_BASE if the number of NEW_AUX_ENT() changes */
1da177e4 234#define NEW_AUX_ENT(id, val) \
f4e5cc2c 235 do { \
1f83d806
AD
236 *elf_info++ = id; \
237 *elf_info++ = val; \
f4e5cc2c 238 } while (0)
1da177e4
LT
239
240#ifdef ARCH_DLINFO
241 /*
242 * ARCH_DLINFO must come first so PPC can do its special alignment of
243 * AUXV.
4f9a58d7
OH
244 * update AT_VECTOR_SIZE_ARCH if the number of NEW_AUX_ENT() in
245 * ARCH_DLINFO changes
1da177e4
LT
246 */
247 ARCH_DLINFO;
248#endif
249 NEW_AUX_ENT(AT_HWCAP, ELF_HWCAP);
250 NEW_AUX_ENT(AT_PAGESZ, ELF_EXEC_PAGESIZE);
251 NEW_AUX_ENT(AT_CLKTCK, CLOCKS_PER_SEC);
252 NEW_AUX_ENT(AT_PHDR, load_addr + exec->e_phoff);
f4e5cc2c 253 NEW_AUX_ENT(AT_PHENT, sizeof(struct elf_phdr));
1da177e4
LT
254 NEW_AUX_ENT(AT_PHNUM, exec->e_phnum);
255 NEW_AUX_ENT(AT_BASE, interp_load_addr);
256 NEW_AUX_ENT(AT_FLAGS, 0);
a62c5b1b 257 NEW_AUX_ENT(AT_ENTRY, e_entry);
ebc887b2
EB
258 NEW_AUX_ENT(AT_UID, from_kuid_munged(cred->user_ns, cred->uid));
259 NEW_AUX_ENT(AT_EUID, from_kuid_munged(cred->user_ns, cred->euid));
260 NEW_AUX_ENT(AT_GID, from_kgid_munged(cred->user_ns, cred->gid));
261 NEW_AUX_ENT(AT_EGID, from_kgid_munged(cred->user_ns, cred->egid));
c425e189 262 NEW_AUX_ENT(AT_SECURE, bprm->secureexec);
f06295b4 263 NEW_AUX_ENT(AT_RANDOM, (elf_addr_t)(unsigned long)u_rand_bytes);
2171364d
MN
264#ifdef ELF_HWCAP2
265 NEW_AUX_ENT(AT_HWCAP2, ELF_HWCAP2);
266#endif
65191087 267 NEW_AUX_ENT(AT_EXECFN, bprm->exec);
1da177e4 268 if (k_platform) {
f4e5cc2c 269 NEW_AUX_ENT(AT_PLATFORM,
785d5570 270 (elf_addr_t)(unsigned long)u_platform);
1da177e4 271 }
483fad1c
NL
272 if (k_base_platform) {
273 NEW_AUX_ENT(AT_BASE_PLATFORM,
274 (elf_addr_t)(unsigned long)u_base_platform);
275 }
1da177e4 276 if (bprm->interp_flags & BINPRM_FLAGS_EXECFD) {
785d5570 277 NEW_AUX_ENT(AT_EXECFD, bprm->interp_data);
1da177e4
LT
278 }
279#undef NEW_AUX_ENT
280 /* AT_NULL is zero; clear the rest too */
03c6d723
AD
281 memset(elf_info, 0, (char *)mm->saved_auxv +
282 sizeof(mm->saved_auxv) - (char *)elf_info);
1da177e4
LT
283
284 /* And advance past the AT_NULL entry. */
1f83d806 285 elf_info += 2;
1da177e4 286
03c6d723 287 ei_index = elf_info - (elf_addr_t *)mm->saved_auxv;
1da177e4
LT
288 sp = STACK_ADD(p, ei_index);
289
d20894a2 290 items = (argc + 1) + (envc + 1) + 1;
1da177e4
LT
291 bprm->p = STACK_ROUND(sp, items);
292
293 /* Point sp at the lowest address on the stack */
294#ifdef CONFIG_STACK_GROWSUP
295 sp = (elf_addr_t __user *)bprm->p - items - ei_index;
f4e5cc2c 296 bprm->exec = (unsigned long)sp; /* XXX: PARISC HACK */
1da177e4
LT
297#else
298 sp = (elf_addr_t __user *)bprm->p;
299#endif
300
b6a2fea3
OW
301
302 /*
303 * Grow the stack manually; some architectures have a limit on how
304 * far ahead a user-space access may be in order to grow the stack.
305 */
03c6d723 306 vma = find_extend_vma(mm, bprm->p);
b6a2fea3
OW
307 if (!vma)
308 return -EFAULT;
309
1da177e4
LT
310 /* Now, let's put argc (and argv, envp if appropriate) on the stack */
311 if (__put_user(argc, sp++))
312 return -EFAULT;
1da177e4 313
67c6777a 314 /* Populate list of argv pointers back to argv strings. */
03c6d723 315 p = mm->arg_end = mm->arg_start;
1da177e4
LT
316 while (argc-- > 0) {
317 size_t len;
67c6777a 318 if (__put_user((elf_addr_t)p, sp++))
841d5fb7 319 return -EFAULT;
b6a2fea3
OW
320 len = strnlen_user((void __user *)p, MAX_ARG_STRLEN);
321 if (!len || len > MAX_ARG_STRLEN)
23c4971e 322 return -EINVAL;
1da177e4
LT
323 p += len;
324 }
67c6777a 325 if (__put_user(0, sp++))
1da177e4 326 return -EFAULT;
03c6d723 327 mm->arg_end = p;
67c6777a
KC
328
329 /* Populate list of envp pointers back to envp strings. */
03c6d723 330 mm->env_end = mm->env_start = p;
1da177e4
LT
331 while (envc-- > 0) {
332 size_t len;
67c6777a 333 if (__put_user((elf_addr_t)p, sp++))
841d5fb7 334 return -EFAULT;
b6a2fea3
OW
335 len = strnlen_user((void __user *)p, MAX_ARG_STRLEN);
336 if (!len || len > MAX_ARG_STRLEN)
23c4971e 337 return -EINVAL;
1da177e4
LT
338 p += len;
339 }
67c6777a 340 if (__put_user(0, sp++))
1da177e4 341 return -EFAULT;
03c6d723 342 mm->env_end = p;
1da177e4
LT
343
344 /* Put the elf_info on the stack in the right place. */
03c6d723 345 if (copy_to_user(sp, mm->saved_auxv, ei_index * sizeof(elf_addr_t)))
1da177e4
LT
346 return -EFAULT;
347 return 0;
348}
349
c07380be
JH
350#ifndef elf_map
351
1da177e4 352static unsigned long elf_map(struct file *filep, unsigned long addr,
49ac9819 353 const struct elf_phdr *eppnt, int prot, int type,
cc503c1b 354 unsigned long total_size)
1da177e4
LT
355{
356 unsigned long map_addr;
cc503c1b
JK
357 unsigned long size = eppnt->p_filesz + ELF_PAGEOFFSET(eppnt->p_vaddr);
358 unsigned long off = eppnt->p_offset - ELF_PAGEOFFSET(eppnt->p_vaddr);
359 addr = ELF_PAGESTART(addr);
360 size = ELF_PAGEALIGN(size);
1da177e4 361
dda6ebde
DG
362 /* mmap() will return -EINVAL if given a zero size, but a
363 * segment with zero filesize is perfectly valid */
cc503c1b
JK
364 if (!size)
365 return addr;
366
cc503c1b
JK
367 /*
368 * total_size is the size of the ELF (interpreter) image.
369 * The _first_ mmap needs to know the full size, otherwise
370 * randomization might put this image into an overlapping
371 * position with the ELF binary image. (since size < total_size)
372 * So we first map the 'big' image - and unmap the remainder at
373 * the end. (which unmap is needed for ELF images with holes.)
374 */
375 if (total_size) {
376 total_size = ELF_PAGEALIGN(total_size);
5a5e4c2e 377 map_addr = vm_mmap(filep, addr, total_size, prot, type, off);
cc503c1b 378 if (!BAD_ADDR(map_addr))
5a5e4c2e 379 vm_munmap(map_addr+size, total_size-size);
cc503c1b 380 } else
5a5e4c2e 381 map_addr = vm_mmap(filep, addr, size, prot, type, off);
cc503c1b 382
d23a61ee
TH
383 if ((type & MAP_FIXED_NOREPLACE) &&
384 PTR_ERR((void *)map_addr) == -EEXIST)
385 pr_info("%d (%s): Uhuuh, elf segment at %px requested but the memory is mapped already\n",
386 task_pid_nr(current), current->comm, (void *)addr);
4ed28639 387
1da177e4
LT
388 return(map_addr);
389}
390
c07380be
JH
391#endif /* !elf_map */
392
49ac9819 393static unsigned long total_mapping_size(const struct elf_phdr *cmds, int nr)
cc503c1b
JK
394{
395 int i, first_idx = -1, last_idx = -1;
396
397 for (i = 0; i < nr; i++) {
398 if (cmds[i].p_type == PT_LOAD) {
399 last_idx = i;
400 if (first_idx == -1)
401 first_idx = i;
402 }
403 }
404 if (first_idx == -1)
405 return 0;
406
407 return cmds[last_idx].p_vaddr + cmds[last_idx].p_memsz -
408 ELF_PAGESTART(cmds[first_idx].p_vaddr);
409}
410
658c0335
AD
411static int elf_read(struct file *file, void *buf, size_t len, loff_t pos)
412{
413 ssize_t rv;
414
415 rv = kernel_read(file, buf, len, &pos);
416 if (unlikely(rv != len)) {
417 return (rv < 0) ? rv : -EIO;
418 }
419 return 0;
420}
421
6a8d3894
PB
422/**
423 * load_elf_phdrs() - load ELF program headers
424 * @elf_ex: ELF header of the binary whose program headers should be loaded
425 * @elf_file: the opened ELF binary file
426 *
427 * Loads ELF program headers from the binary file elf_file, which has the ELF
428 * header pointed to by elf_ex, into a newly allocated array. The caller is
429 * responsible for freeing the allocated data. Returns an ERR_PTR upon failure.
430 */
49ac9819 431static struct elf_phdr *load_elf_phdrs(const struct elfhdr *elf_ex,
6a8d3894
PB
432 struct file *elf_file)
433{
434 struct elf_phdr *elf_phdata = NULL;
faf1c315 435 int retval, err = -1;
faf1c315 436 unsigned int size;
6a8d3894
PB
437
438 /*
439 * If the size of this structure has changed, then punt, since
440 * we will be doing the wrong thing.
441 */
442 if (elf_ex->e_phentsize != sizeof(struct elf_phdr))
443 goto out;
444
445 /* Sanity check the number of program headers... */
6a8d3894
PB
446 /* ...and their total size. */
447 size = sizeof(struct elf_phdr) * elf_ex->e_phnum;
faf1c315 448 if (size == 0 || size > 65536 || size > ELF_MIN_ALIGN)
6a8d3894
PB
449 goto out;
450
451 elf_phdata = kmalloc(size, GFP_KERNEL);
452 if (!elf_phdata)
453 goto out;
454
455 /* Read in the program headers */
658c0335
AD
456 retval = elf_read(elf_file, elf_phdata, size, elf_ex->e_phoff);
457 if (retval < 0) {
458 err = retval;
6a8d3894
PB
459 goto out;
460 }
461
462 /* Success! */
463 err = 0;
464out:
465 if (err) {
466 kfree(elf_phdata);
467 elf_phdata = NULL;
468 }
469 return elf_phdata;
470}
cc503c1b 471
774c105e
PB
472#ifndef CONFIG_ARCH_BINFMT_ELF_STATE
473
474/**
475 * struct arch_elf_state - arch-specific ELF loading state
476 *
477 * This structure is used to preserve architecture specific data during
478 * the loading of an ELF file, throughout the checking of architecture
479 * specific ELF headers & through to the point where the ELF load is
480 * known to be proceeding (ie. SET_PERSONALITY).
481 *
482 * This implementation is a dummy for architectures which require no
483 * specific state.
484 */
485struct arch_elf_state {
486};
487
488#define INIT_ARCH_ELF_STATE {}
489
490/**
491 * arch_elf_pt_proc() - check a PT_LOPROC..PT_HIPROC ELF program header
492 * @ehdr: The main ELF header
493 * @phdr: The program header to check
494 * @elf: The open ELF file
495 * @is_interp: True if the phdr is from the interpreter of the ELF being
496 * loaded, else false.
497 * @state: Architecture-specific state preserved throughout the process
498 * of loading the ELF.
499 *
500 * Inspects the program header phdr to validate its correctness and/or
501 * suitability for the system. Called once per ELF program header in the
502 * range PT_LOPROC to PT_HIPROC, for both the ELF being loaded and its
503 * interpreter.
504 *
505 * Return: Zero to proceed with the ELF load, non-zero to fail the ELF load
506 * with that return code.
507 */
508static inline int arch_elf_pt_proc(struct elfhdr *ehdr,
509 struct elf_phdr *phdr,
510 struct file *elf, bool is_interp,
511 struct arch_elf_state *state)
512{
513 /* Dummy implementation, always proceed */
514 return 0;
515}
516
517/**
54d15714 518 * arch_check_elf() - check an ELF executable
774c105e
PB
519 * @ehdr: The main ELF header
520 * @has_interp: True if the ELF has an interpreter, else false.
eb4bc076 521 * @interp_ehdr: The interpreter's ELF header
774c105e
PB
522 * @state: Architecture-specific state preserved throughout the process
523 * of loading the ELF.
524 *
525 * Provides a final opportunity for architecture code to reject the loading
526 * of the ELF & cause an exec syscall to return an error. This is called after
527 * all program headers to be checked by arch_elf_pt_proc have been.
528 *
529 * Return: Zero to proceed with the ELF load, non-zero to fail the ELF load
530 * with that return code.
531 */
532static inline int arch_check_elf(struct elfhdr *ehdr, bool has_interp,
eb4bc076 533 struct elfhdr *interp_ehdr,
774c105e
PB
534 struct arch_elf_state *state)
535{
536 /* Dummy implementation, always proceed */
537 return 0;
538}
539
540#endif /* !CONFIG_ARCH_BINFMT_ELF_STATE */
cc503c1b 541
d8e7cb39
AD
542static inline int make_prot(u32 p_flags)
543{
544 int prot = 0;
545
546 if (p_flags & PF_R)
547 prot |= PROT_READ;
548 if (p_flags & PF_W)
549 prot |= PROT_WRITE;
550 if (p_flags & PF_X)
551 prot |= PROT_EXEC;
552 return prot;
553}
554
1da177e4
LT
555/* This is much more generalized than the library routine read function,
556 so we keep this separate. Technically the library read function
557 is only provided so that we can read a.out libraries that have
558 an ELF header */
559
f4e5cc2c 560static unsigned long load_elf_interp(struct elfhdr *interp_elf_ex,
81696d5d 561 struct file *interpreter,
a9d9ef13 562 unsigned long no_base, struct elf_phdr *interp_elf_phdata)
1da177e4 563{
1da177e4
LT
564 struct elf_phdr *eppnt;
565 unsigned long load_addr = 0;
566 int load_addr_set = 0;
567 unsigned long last_bss = 0, elf_bss = 0;
16e72e9b 568 int bss_prot = 0;
1da177e4 569 unsigned long error = ~0UL;
cc503c1b 570 unsigned long total_size;
6a8d3894 571 int i;
1da177e4
LT
572
573 /* First of all, some simple consistency checks */
574 if (interp_elf_ex->e_type != ET_EXEC &&
575 interp_elf_ex->e_type != ET_DYN)
576 goto out;
4755200b
NP
577 if (!elf_check_arch(interp_elf_ex) ||
578 elf_check_fdpic(interp_elf_ex))
1da177e4 579 goto out;
72c2d531 580 if (!interpreter->f_op->mmap)
1da177e4
LT
581 goto out;
582
a9d9ef13
PB
583 total_size = total_mapping_size(interp_elf_phdata,
584 interp_elf_ex->e_phnum);
cc503c1b
JK
585 if (!total_size) {
586 error = -EINVAL;
a9d9ef13 587 goto out;
cc503c1b
JK
588 }
589
a9d9ef13 590 eppnt = interp_elf_phdata;
f4e5cc2c
JJ
591 for (i = 0; i < interp_elf_ex->e_phnum; i++, eppnt++) {
592 if (eppnt->p_type == PT_LOAD) {
593 int elf_type = MAP_PRIVATE | MAP_DENYWRITE;
d8e7cb39 594 int elf_prot = make_prot(eppnt->p_flags);
f4e5cc2c
JJ
595 unsigned long vaddr = 0;
596 unsigned long k, map_addr;
597
f4e5cc2c
JJ
598 vaddr = eppnt->p_vaddr;
599 if (interp_elf_ex->e_type == ET_EXEC || load_addr_set)
4ed28639 600 elf_type |= MAP_FIXED_NOREPLACE;
cc503c1b
JK
601 else if (no_base && interp_elf_ex->e_type == ET_DYN)
602 load_addr = -vaddr;
f4e5cc2c
JJ
603
604 map_addr = elf_map(interpreter, load_addr + vaddr,
bb1ad820 605 eppnt, elf_prot, elf_type, total_size);
cc503c1b 606 total_size = 0;
f4e5cc2c
JJ
607 error = map_addr;
608 if (BAD_ADDR(map_addr))
a9d9ef13 609 goto out;
f4e5cc2c
JJ
610
611 if (!load_addr_set &&
612 interp_elf_ex->e_type == ET_DYN) {
613 load_addr = map_addr - ELF_PAGESTART(vaddr);
614 load_addr_set = 1;
615 }
616
617 /*
618 * Check to see if the section's size will overflow the
619 * allowed task size. Note that p_filesz must always be
620 * <= p_memsize so it's only necessary to check p_memsz.
621 */
622 k = load_addr + eppnt->p_vaddr;
ce51059b 623 if (BAD_ADDR(k) ||
f4e5cc2c
JJ
624 eppnt->p_filesz > eppnt->p_memsz ||
625 eppnt->p_memsz > TASK_SIZE ||
626 TASK_SIZE - eppnt->p_memsz < k) {
627 error = -ENOMEM;
a9d9ef13 628 goto out;
f4e5cc2c
JJ
629 }
630
631 /*
632 * Find the end of the file mapping for this phdr, and
633 * keep track of the largest address we see for this.
634 */
635 k = load_addr + eppnt->p_vaddr + eppnt->p_filesz;
636 if (k > elf_bss)
637 elf_bss = k;
638
639 /*
640 * Do the same thing for the memory mapping - between
641 * elf_bss and last_bss is the bss section.
642 */
0036d1f7 643 k = load_addr + eppnt->p_vaddr + eppnt->p_memsz;
16e72e9b 644 if (k > last_bss) {
f4e5cc2c 645 last_bss = k;
16e72e9b
DV
646 bss_prot = elf_prot;
647 }
f4e5cc2c 648 }
1da177e4
LT
649 }
650
0036d1f7
KC
651 /*
652 * Now fill out the bss section: first pad the last page from
653 * the file up to the page boundary, and zero it from elf_bss
654 * up to the end of the page.
655 */
656 if (padzero(elf_bss)) {
657 error = -EFAULT;
658 goto out;
659 }
660 /*
661 * Next, align both the file and mem bss up to the page size,
662 * since this is where elf_bss was just zeroed up to, and where
16e72e9b 663 * last_bss will end after the vm_brk_flags() below.
0036d1f7
KC
664 */
665 elf_bss = ELF_PAGEALIGN(elf_bss);
666 last_bss = ELF_PAGEALIGN(last_bss);
667 /* Finally, if there is still more bss to allocate, do it. */
752015d1 668 if (last_bss > elf_bss) {
16e72e9b
DV
669 error = vm_brk_flags(elf_bss, last_bss - elf_bss,
670 bss_prot & PROT_EXEC ? VM_EXEC : 0);
5d22fc25 671 if (error)
a9d9ef13 672 goto out;
1da177e4
LT
673 }
674
cc503c1b 675 error = load_addr;
1da177e4
LT
676out:
677 return error;
678}
679
1da177e4
LT
680/*
681 * These are the functions used to load ELF style executables and shared
682 * libraries. There is no binary dependent code anywhere else.
683 */
684
71613c3b 685static int load_elf_binary(struct linux_binprm *bprm)
1da177e4
LT
686{
687 struct file *interpreter = NULL; /* to shut gcc up */
688 unsigned long load_addr = 0, load_bias = 0;
689 int load_addr_set = 0;
1da177e4 690 unsigned long error;
a9d9ef13 691 struct elf_phdr *elf_ppnt, *elf_phdata, *interp_elf_phdata = NULL;
1da177e4 692 unsigned long elf_bss, elf_brk;
16e72e9b 693 int bss_prot = 0;
1da177e4 694 int retval, i;
cc503c1b 695 unsigned long elf_entry;
a62c5b1b 696 unsigned long e_entry;
cc503c1b 697 unsigned long interp_load_addr = 0;
1da177e4 698 unsigned long start_code, end_code, start_data, end_data;
1a530a6f 699 unsigned long reloc_func_desc __maybe_unused = 0;
8de61e69 700 int executable_stack = EXSTACK_DEFAULT;
a62c5b1b 701 struct elfhdr *elf_ex = (struct elfhdr *)bprm->buf;
0693ffeb 702 struct elfhdr *interp_elf_ex = NULL;
774c105e 703 struct arch_elf_state arch_state = INIT_ARCH_ELF_STATE;
03c6d723 704 struct mm_struct *mm;
249b08e4 705 struct pt_regs *regs;
1da177e4 706
1da177e4
LT
707 retval = -ENOEXEC;
708 /* First of all, some simple consistency checks */
a62c5b1b 709 if (memcmp(elf_ex->e_ident, ELFMAG, SELFMAG) != 0)
1da177e4
LT
710 goto out;
711
a62c5b1b 712 if (elf_ex->e_type != ET_EXEC && elf_ex->e_type != ET_DYN)
1da177e4 713 goto out;
a62c5b1b 714 if (!elf_check_arch(elf_ex))
1da177e4 715 goto out;
a62c5b1b 716 if (elf_check_fdpic(elf_ex))
4755200b 717 goto out;
72c2d531 718 if (!bprm->file->f_op->mmap)
1da177e4
LT
719 goto out;
720
a62c5b1b 721 elf_phdata = load_elf_phdrs(elf_ex, bprm->file);
1da177e4
LT
722 if (!elf_phdata)
723 goto out;
724
1da177e4 725 elf_ppnt = elf_phdata;
a62c5b1b 726 for (i = 0; i < elf_ex->e_phnum; i++, elf_ppnt++) {
be0deb58 727 char *elf_interpreter;
1da177e4 728
be0deb58
AD
729 if (elf_ppnt->p_type != PT_INTERP)
730 continue;
1fb84496 731
be0deb58
AD
732 /*
733 * This is the program interpreter used for shared libraries -
734 * for now assume that this is an a.out format binary.
735 */
736 retval = -ENOEXEC;
737 if (elf_ppnt->p_filesz > PATH_MAX || elf_ppnt->p_filesz < 2)
738 goto out_free_ph;
1da177e4 739
be0deb58
AD
740 retval = -ENOMEM;
741 elf_interpreter = kmalloc(elf_ppnt->p_filesz, GFP_KERNEL);
742 if (!elf_interpreter)
743 goto out_free_ph;
cc338010 744
658c0335
AD
745 retval = elf_read(bprm->file, elf_interpreter, elf_ppnt->p_filesz,
746 elf_ppnt->p_offset);
747 if (retval < 0)
be0deb58 748 goto out_free_interp;
be0deb58
AD
749 /* make sure path is NULL terminated */
750 retval = -ENOEXEC;
751 if (elf_interpreter[elf_ppnt->p_filesz - 1] != '\0')
752 goto out_free_interp;
753
754 interpreter = open_exec(elf_interpreter);
755 kfree(elf_interpreter);
756 retval = PTR_ERR(interpreter);
757 if (IS_ERR(interpreter))
cc338010 758 goto out_free_ph;
be0deb58
AD
759
760 /*
761 * If the binary is not readable then enforce mm->dumpable = 0
762 * regardless of the interpreter's permissions.
763 */
764 would_dump(bprm, interpreter);
765
0693ffeb
AD
766 interp_elf_ex = kmalloc(sizeof(*interp_elf_ex), GFP_KERNEL);
767 if (!interp_elf_ex) {
768 retval = -ENOMEM;
769 goto out_free_ph;
770 }
771
be0deb58 772 /* Get the exec headers */
c69bcc93
AD
773 retval = elf_read(interpreter, interp_elf_ex,
774 sizeof(*interp_elf_ex), 0);
658c0335 775 if (retval < 0)
be0deb58 776 goto out_free_dentry;
be0deb58
AD
777
778 break;
779
780out_free_interp:
781 kfree(elf_interpreter);
782 goto out_free_ph;
1da177e4
LT
783 }
784
785 elf_ppnt = elf_phdata;
a62c5b1b 786 for (i = 0; i < elf_ex->e_phnum; i++, elf_ppnt++)
774c105e
PB
787 switch (elf_ppnt->p_type) {
788 case PT_GNU_STACK:
1da177e4
LT
789 if (elf_ppnt->p_flags & PF_X)
790 executable_stack = EXSTACK_ENABLE_X;
791 else
792 executable_stack = EXSTACK_DISABLE_X;
793 break;
774c105e
PB
794
795 case PT_LOPROC ... PT_HIPROC:
a62c5b1b 796 retval = arch_elf_pt_proc(elf_ex, elf_ppnt,
774c105e
PB
797 bprm->file, false,
798 &arch_state);
799 if (retval)
800 goto out_free_dentry;
801 break;
1da177e4 802 }
1da177e4
LT
803
804 /* Some simple consistency checks for the interpreter */
cc338010 805 if (interpreter) {
1da177e4 806 retval = -ELIBBAD;
d20894a2 807 /* Not an ELF interpreter */
c69bcc93 808 if (memcmp(interp_elf_ex->e_ident, ELFMAG, SELFMAG) != 0)
1da177e4 809 goto out_free_dentry;
1da177e4 810 /* Verify the interpreter has a valid arch */
c69bcc93
AD
811 if (!elf_check_arch(interp_elf_ex) ||
812 elf_check_fdpic(interp_elf_ex))
1da177e4 813 goto out_free_dentry;
a9d9ef13
PB
814
815 /* Load the interpreter program headers */
c69bcc93 816 interp_elf_phdata = load_elf_phdrs(interp_elf_ex,
a9d9ef13
PB
817 interpreter);
818 if (!interp_elf_phdata)
819 goto out_free_dentry;
774c105e
PB
820
821 /* Pass PT_LOPROC..PT_HIPROC headers to arch code */
822 elf_ppnt = interp_elf_phdata;
c69bcc93 823 for (i = 0; i < interp_elf_ex->e_phnum; i++, elf_ppnt++)
774c105e
PB
824 switch (elf_ppnt->p_type) {
825 case PT_LOPROC ... PT_HIPROC:
c69bcc93 826 retval = arch_elf_pt_proc(interp_elf_ex,
774c105e
PB
827 elf_ppnt, interpreter,
828 true, &arch_state);
829 if (retval)
830 goto out_free_dentry;
831 break;
832 }
1da177e4
LT
833 }
834
774c105e
PB
835 /*
836 * Allow arch code to reject the ELF at this point, whilst it's
837 * still possible to return an error to the code that invoked
838 * the exec syscall.
839 */
a62c5b1b 840 retval = arch_check_elf(elf_ex,
c69bcc93 841 !!interpreter, interp_elf_ex,
eb4bc076 842 &arch_state);
774c105e
PB
843 if (retval)
844 goto out_free_dentry;
845
1da177e4
LT
846 /* Flush all traces of the currently running executable */
847 retval = flush_old_exec(bprm);
848 if (retval)
849 goto out_free_dentry;
850
1da177e4
LT
851 /* Do this immediately, since STACK_TOP as used in setup_arg_pages
852 may depend on the personality. */
a62c5b1b
AD
853 SET_PERSONALITY2(*elf_ex, &arch_state);
854 if (elf_read_implies_exec(*elf_ex, executable_stack))
1da177e4
LT
855 current->personality |= READ_IMPLIES_EXEC;
856
f4e5cc2c 857 if (!(current->personality & ADDR_NO_RANDOMIZE) && randomize_va_space)
1da177e4 858 current->flags |= PF_RANDOMIZE;
221af7f8
LT
859
860 setup_new_exec(bprm);
9f834ec1 861 install_exec_creds(bprm);
1da177e4
LT
862
863 /* Do this so that we can load the interpreter, if need be. We will
864 change some of these later */
1da177e4
LT
865 retval = setup_arg_pages(bprm, randomize_stack_top(STACK_TOP),
866 executable_stack);
19d860a1 867 if (retval < 0)
1da177e4 868 goto out_free_dentry;
1da177e4 869
85264316
AD
870 elf_bss = 0;
871 elf_brk = 0;
872
873 start_code = ~0UL;
874 end_code = 0;
875 start_data = 0;
876 end_data = 0;
877
af901ca1 878 /* Now we do a little grungy work by mmapping the ELF image into
cc503c1b 879 the correct location in memory. */
f4e5cc2c 880 for(i = 0, elf_ppnt = elf_phdata;
a62c5b1b 881 i < elf_ex->e_phnum; i++, elf_ppnt++) {
b212921b 882 int elf_prot, elf_flags;
1da177e4 883 unsigned long k, vaddr;
a87938b2 884 unsigned long total_size = 0;
1da177e4
LT
885
886 if (elf_ppnt->p_type != PT_LOAD)
887 continue;
888
889 if (unlikely (elf_brk > elf_bss)) {
890 unsigned long nbyte;
891
892 /* There was a PT_LOAD segment with p_memsz > p_filesz
893 before this one. Map anonymous pages, if needed,
894 and clear the area. */
f670d0ec 895 retval = set_brk(elf_bss + load_bias,
16e72e9b
DV
896 elf_brk + load_bias,
897 bss_prot);
19d860a1 898 if (retval)
1da177e4 899 goto out_free_dentry;
1da177e4
LT
900 nbyte = ELF_PAGEOFFSET(elf_bss);
901 if (nbyte) {
902 nbyte = ELF_MIN_ALIGN - nbyte;
903 if (nbyte > elf_brk - elf_bss)
904 nbyte = elf_brk - elf_bss;
905 if (clear_user((void __user *)elf_bss +
906 load_bias, nbyte)) {
907 /*
908 * This bss-zeroing can fail if the ELF
f4e5cc2c 909 * file specifies odd protections. So
1da177e4
LT
910 * we don't check the return value
911 */
912 }
913 }
914 }
915
d8e7cb39 916 elf_prot = make_prot(elf_ppnt->p_flags);
1da177e4 917
f4e5cc2c 918 elf_flags = MAP_PRIVATE | MAP_DENYWRITE | MAP_EXECUTABLE;
1da177e4
LT
919
920 vaddr = elf_ppnt->p_vaddr;
eab09532
KC
921 /*
922 * If we are loading ET_EXEC or we have already performed
923 * the ET_DYN load_addr calculations, proceed normally.
924 */
a62c5b1b 925 if (elf_ex->e_type == ET_EXEC || load_addr_set) {
b212921b 926 elf_flags |= MAP_FIXED;
a62c5b1b 927 } else if (elf_ex->e_type == ET_DYN) {
eab09532
KC
928 /*
929 * This logic is run once for the first LOAD Program
930 * Header for ET_DYN binaries to calculate the
931 * randomization (load_bias) for all the LOAD
932 * Program Headers, and to calculate the entire
933 * size of the ELF mapping (total_size). (Note that
934 * load_addr_set is set to true later once the
935 * initial mapping is performed.)
936 *
937 * There are effectively two types of ET_DYN
938 * binaries: programs (i.e. PIE: ET_DYN with INTERP)
939 * and loaders (ET_DYN without INTERP, since they
940 * _are_ the ELF interpreter). The loaders must
941 * be loaded away from programs since the program
942 * may otherwise collide with the loader (especially
943 * for ET_EXEC which does not have a randomized
944 * position). For example to handle invocations of
945 * "./ld.so someprog" to test out a new version of
946 * the loader, the subsequent program that the
947 * loader loads must avoid the loader itself, so
948 * they cannot share the same load range. Sufficient
949 * room for the brk must be allocated with the
950 * loader as well, since brk must be available with
951 * the loader.
952 *
953 * Therefore, programs are loaded offset from
954 * ELF_ET_DYN_BASE and loaders are loaded into the
955 * independently randomized mmap region (0 load_bias
956 * without MAP_FIXED).
957 */
cc338010 958 if (interpreter) {
eab09532
KC
959 load_bias = ELF_ET_DYN_BASE;
960 if (current->flags & PF_RANDOMIZE)
961 load_bias += arch_mmap_rnd();
b212921b 962 elf_flags |= MAP_FIXED;
eab09532
KC
963 } else
964 load_bias = 0;
965
966 /*
967 * Since load_bias is used for all subsequent loading
968 * calculations, we must lower it by the first vaddr
969 * so that the remaining calculations based on the
970 * ELF vaddrs will be correctly offset. The result
971 * is then page aligned.
972 */
973 load_bias = ELF_PAGESTART(load_bias - vaddr);
974
a87938b2 975 total_size = total_mapping_size(elf_phdata,
a62c5b1b 976 elf_ex->e_phnum);
a87938b2 977 if (!total_size) {
2b1d3ae9 978 retval = -EINVAL;
a87938b2
MD
979 goto out_free_dentry;
980 }
1da177e4
LT
981 }
982
f4e5cc2c 983 error = elf_map(bprm->file, load_bias + vaddr, elf_ppnt,
a87938b2 984 elf_prot, elf_flags, total_size);
1da177e4 985 if (BAD_ADDR(error)) {
b140f251
AK
986 retval = IS_ERR((void *)error) ?
987 PTR_ERR((void*)error) : -EINVAL;
1da177e4
LT
988 goto out_free_dentry;
989 }
990
991 if (!load_addr_set) {
992 load_addr_set = 1;
993 load_addr = (elf_ppnt->p_vaddr - elf_ppnt->p_offset);
a62c5b1b 994 if (elf_ex->e_type == ET_DYN) {
1da177e4
LT
995 load_bias += error -
996 ELF_PAGESTART(load_bias + vaddr);
997 load_addr += load_bias;
998 reloc_func_desc = load_bias;
999 }
1000 }
1001 k = elf_ppnt->p_vaddr;
f67ef446 1002 if ((elf_ppnt->p_flags & PF_X) && k < start_code)
f4e5cc2c
JJ
1003 start_code = k;
1004 if (start_data < k)
1005 start_data = k;
1da177e4
LT
1006
1007 /*
1008 * Check to see if the section's size will overflow the
1009 * allowed task size. Note that p_filesz must always be
1010 * <= p_memsz so it is only necessary to check p_memsz.
1011 */
ce51059b 1012 if (BAD_ADDR(k) || elf_ppnt->p_filesz > elf_ppnt->p_memsz ||
1da177e4
LT
1013 elf_ppnt->p_memsz > TASK_SIZE ||
1014 TASK_SIZE - elf_ppnt->p_memsz < k) {
f4e5cc2c 1015 /* set_brk can never work. Avoid overflows. */
b140f251 1016 retval = -EINVAL;
1da177e4
LT
1017 goto out_free_dentry;
1018 }
1019
1020 k = elf_ppnt->p_vaddr + elf_ppnt->p_filesz;
1021
1022 if (k > elf_bss)
1023 elf_bss = k;
1024 if ((elf_ppnt->p_flags & PF_X) && end_code < k)
1025 end_code = k;
1026 if (end_data < k)
1027 end_data = k;
1028 k = elf_ppnt->p_vaddr + elf_ppnt->p_memsz;
16e72e9b
DV
1029 if (k > elf_brk) {
1030 bss_prot = elf_prot;
1da177e4 1031 elf_brk = k;
16e72e9b 1032 }
1da177e4
LT
1033 }
1034
a62c5b1b 1035 e_entry = elf_ex->e_entry + load_bias;
1da177e4
LT
1036 elf_bss += load_bias;
1037 elf_brk += load_bias;
1038 start_code += load_bias;
1039 end_code += load_bias;
1040 start_data += load_bias;
1041 end_data += load_bias;
1042
1043 /* Calling set_brk effectively mmaps the pages that we need
1044 * for the bss and break sections. We must do this before
1045 * mapping in the interpreter, to make sure it doesn't wind
1046 * up getting placed where the bss needs to go.
1047 */
16e72e9b 1048 retval = set_brk(elf_bss, elf_brk, bss_prot);
19d860a1 1049 if (retval)
1da177e4 1050 goto out_free_dentry;
6de50517 1051 if (likely(elf_bss != elf_brk) && unlikely(padzero(elf_bss))) {
1da177e4
LT
1052 retval = -EFAULT; /* Nobody gets to see this, but.. */
1053 goto out_free_dentry;
1054 }
1055
cc338010 1056 if (interpreter) {
c69bcc93 1057 elf_entry = load_elf_interp(interp_elf_ex,
d20894a2 1058 interpreter,
a9d9ef13 1059 load_bias, interp_elf_phdata);
d20894a2
AK
1060 if (!IS_ERR((void *)elf_entry)) {
1061 /*
1062 * load_elf_interp() returns relocation
1063 * adjustment
1064 */
1065 interp_load_addr = elf_entry;
c69bcc93 1066 elf_entry += interp_elf_ex->e_entry;
cc503c1b 1067 }
1da177e4 1068 if (BAD_ADDR(elf_entry)) {
ce51059b
CE
1069 retval = IS_ERR((void *)elf_entry) ?
1070 (int)elf_entry : -EINVAL;
1da177e4
LT
1071 goto out_free_dentry;
1072 }
1073 reloc_func_desc = interp_load_addr;
1074
1075 allow_write_access(interpreter);
1076 fput(interpreter);
0693ffeb
AD
1077
1078 kfree(interp_elf_ex);
aa0d1564 1079 kfree(interp_elf_phdata);
1da177e4 1080 } else {
a62c5b1b 1081 elf_entry = e_entry;
5342fba5 1082 if (BAD_ADDR(elf_entry)) {
ce51059b 1083 retval = -EINVAL;
5342fba5
SS
1084 goto out_free_dentry;
1085 }
1da177e4
LT
1086 }
1087
1088 kfree(elf_phdata);
1089
1da177e4
LT
1090 set_binfmt(&elf_format);
1091
547ee84c 1092#ifdef ARCH_HAS_SETUP_ADDITIONAL_PAGES
cc338010 1093 retval = arch_setup_additional_pages(bprm, !!interpreter);
19d860a1 1094 if (retval < 0)
18c8baff 1095 goto out;
547ee84c
BH
1096#endif /* ARCH_HAS_SETUP_ADDITIONAL_PAGES */
1097
a62c5b1b
AD
1098 retval = create_elf_tables(bprm, elf_ex,
1099 load_addr, interp_load_addr, e_entry);
19d860a1 1100 if (retval < 0)
b6a2fea3 1101 goto out;
03c6d723
AD
1102
1103 mm = current->mm;
1104 mm->end_code = end_code;
1105 mm->start_code = start_code;
1106 mm->start_data = start_data;
1107 mm->end_data = end_data;
1108 mm->start_stack = bprm->p;
1da177e4 1109
4471a675 1110 if ((current->flags & PF_RANDOMIZE) && (randomize_va_space > 1)) {
bbdc6076
KC
1111 /*
1112 * For architectures with ELF randomization, when executing
1113 * a loader directly (i.e. no interpreter listed in ELF
1114 * headers), move the brk area out of the mmap region
1115 * (since it grows up, and may collide early with the stack
1116 * growing down), and into the unused ELF_ET_DYN_BASE region.
1117 */
7be3cb01 1118 if (IS_ENABLED(CONFIG_ARCH_HAS_ELF_RANDOMIZE) &&
03c6d723
AD
1119 elf_ex->e_type == ET_DYN && !interpreter) {
1120 mm->brk = mm->start_brk = ELF_ET_DYN_BASE;
1121 }
bbdc6076 1122
03c6d723 1123 mm->brk = mm->start_brk = arch_randomize_brk(mm);
204db6ed 1124#ifdef compat_brk_randomized
4471a675
JK
1125 current->brk_randomized = 1;
1126#endif
1127 }
c1d171a0 1128
1da177e4
LT
1129 if (current->personality & MMAP_PAGE_ZERO) {
1130 /* Why this, you ask??? Well SVr4 maps page 0 as read-only,
1131 and some applications "depend" upon this behavior.
1132 Since we do not have the power to recompile these, we
f4e5cc2c 1133 emulate the SVr4 behavior. Sigh. */
6be5ceb0 1134 error = vm_mmap(NULL, 0, PAGE_SIZE, PROT_READ | PROT_EXEC,
1da177e4 1135 MAP_FIXED | MAP_PRIVATE, 0);
1da177e4
LT
1136 }
1137
249b08e4 1138 regs = current_pt_regs();
1da177e4
LT
1139#ifdef ELF_PLAT_INIT
1140 /*
1141 * The ABI may specify that certain registers be set up in special
1142 * ways (on i386 %edx is the address of a DT_FINI function, for
1143 * example. In addition, it may also specify (eg, PowerPC64 ELF)
1144 * that the e_entry field is the address of the function descriptor
1145 * for the startup routine, rather than the address of the startup
1146 * routine itself. This macro performs whatever initialization to
1147 * the regs structure is required as well as any relocations to the
1148 * function descriptor entries when executing dynamically links apps.
1149 */
1150 ELF_PLAT_INIT(regs, reloc_func_desc);
1151#endif
1152
b8383831 1153 finalize_exec(bprm);
1da177e4 1154 start_thread(regs, elf_entry, bprm->p);
1da177e4
LT
1155 retval = 0;
1156out:
1da177e4
LT
1157 return retval;
1158
1159 /* error cleanup */
1160out_free_dentry:
0693ffeb 1161 kfree(interp_elf_ex);
a9d9ef13 1162 kfree(interp_elf_phdata);
1da177e4
LT
1163 allow_write_access(interpreter);
1164 if (interpreter)
1165 fput(interpreter);
1da177e4
LT
1166out_free_ph:
1167 kfree(elf_phdata);
1168 goto out;
1169}
1170
69369a70 1171#ifdef CONFIG_USELIB
1da177e4
LT
1172/* This is really simpleminded and specialized - we are loading an
1173 a.out library that is given an ELF header. */
1da177e4
LT
1174static int load_elf_library(struct file *file)
1175{
1176 struct elf_phdr *elf_phdata;
1177 struct elf_phdr *eppnt;
1178 unsigned long elf_bss, bss, len;
1179 int retval, error, i, j;
1180 struct elfhdr elf_ex;
1181
1182 error = -ENOEXEC;
658c0335
AD
1183 retval = elf_read(file, &elf_ex, sizeof(elf_ex), 0);
1184 if (retval < 0)
1da177e4
LT
1185 goto out;
1186
1187 if (memcmp(elf_ex.e_ident, ELFMAG, SELFMAG) != 0)
1188 goto out;
1189
1190 /* First of all, some simple consistency checks */
1191 if (elf_ex.e_type != ET_EXEC || elf_ex.e_phnum > 2 ||
72c2d531 1192 !elf_check_arch(&elf_ex) || !file->f_op->mmap)
1da177e4 1193 goto out;
4755200b
NP
1194 if (elf_check_fdpic(&elf_ex))
1195 goto out;
1da177e4
LT
1196
1197 /* Now read in all of the header information */
1198
1199 j = sizeof(struct elf_phdr) * elf_ex.e_phnum;
1200 /* j < ELF_MIN_ALIGN because elf_ex.e_phnum <= 2 */
1201
1202 error = -ENOMEM;
1203 elf_phdata = kmalloc(j, GFP_KERNEL);
1204 if (!elf_phdata)
1205 goto out;
1206
1207 eppnt = elf_phdata;
1208 error = -ENOEXEC;
658c0335
AD
1209 retval = elf_read(file, eppnt, j, elf_ex.e_phoff);
1210 if (retval < 0)
1da177e4
LT
1211 goto out_free_ph;
1212
1213 for (j = 0, i = 0; i<elf_ex.e_phnum; i++)
1214 if ((eppnt + i)->p_type == PT_LOAD)
1215 j++;
1216 if (j != 1)
1217 goto out_free_ph;
1218
1219 while (eppnt->p_type != PT_LOAD)
1220 eppnt++;
1221
1222 /* Now use mmap to map the library into memory. */
6be5ceb0 1223 error = vm_mmap(file,
1da177e4
LT
1224 ELF_PAGESTART(eppnt->p_vaddr),
1225 (eppnt->p_filesz +
1226 ELF_PAGEOFFSET(eppnt->p_vaddr)),
1227 PROT_READ | PROT_WRITE | PROT_EXEC,
4ed28639 1228 MAP_FIXED_NOREPLACE | MAP_PRIVATE | MAP_DENYWRITE,
1da177e4
LT
1229 (eppnt->p_offset -
1230 ELF_PAGEOFFSET(eppnt->p_vaddr)));
1da177e4
LT
1231 if (error != ELF_PAGESTART(eppnt->p_vaddr))
1232 goto out_free_ph;
1233
1234 elf_bss = eppnt->p_vaddr + eppnt->p_filesz;
1235 if (padzero(elf_bss)) {
1236 error = -EFAULT;
1237 goto out_free_ph;
1238 }
1239
24962af7
OS
1240 len = ELF_PAGEALIGN(eppnt->p_filesz + eppnt->p_vaddr);
1241 bss = ELF_PAGEALIGN(eppnt->p_memsz + eppnt->p_vaddr);
ecc2bc8a
MH
1242 if (bss > len) {
1243 error = vm_brk(len, bss - len);
5d22fc25 1244 if (error)
ecc2bc8a
MH
1245 goto out_free_ph;
1246 }
1da177e4
LT
1247 error = 0;
1248
1249out_free_ph:
1250 kfree(elf_phdata);
1251out:
1252 return error;
1253}
69369a70 1254#endif /* #ifdef CONFIG_USELIB */
1da177e4 1255
698ba7b5 1256#ifdef CONFIG_ELF_CORE
1da177e4
LT
1257/*
1258 * ELF core dumper
1259 *
1260 * Modelled on fs/exec.c:aout_core_dump()
1261 * Jeremy Fitzhardinge <jeremy@sw.oz.au>
1262 */
1da177e4 1263
909af768
JB
1264/*
1265 * The purpose of always_dump_vma() is to make sure that special kernel mappings
1266 * that are useful for post-mortem analysis are included in every core dump.
1267 * In that way we ensure that the core dump is fully interpretable later
1268 * without matching up the same kernel and hardware config to see what PC values
1269 * meant. These special mappings include - vDSO, vsyscall, and other
1270 * architecture specific mappings
1271 */
1272static bool always_dump_vma(struct vm_area_struct *vma)
1273{
1274 /* Any vsyscall mappings? */
1275 if (vma == get_gate_vma(vma->vm_mm))
1276 return true;
78d683e8
AL
1277
1278 /*
1279 * Assume that all vmas with a .name op should always be dumped.
1280 * If this changes, a new vm_ops field can easily be added.
1281 */
1282 if (vma->vm_ops && vma->vm_ops->name && vma->vm_ops->name(vma))
1283 return true;
1284
909af768
JB
1285 /*
1286 * arch_vma_name() returns non-NULL for special architecture mappings,
1287 * such as vDSO sections.
1288 */
1289 if (arch_vma_name(vma))
1290 return true;
1291
1292 return false;
1293}
1294
1da177e4 1295/*
82df3973 1296 * Decide what to dump of a segment, part, all or none.
1da177e4 1297 */
82df3973
RM
1298static unsigned long vma_dump_size(struct vm_area_struct *vma,
1299 unsigned long mm_flags)
1da177e4 1300{
e575f111
KM
1301#define FILTER(type) (mm_flags & (1UL << MMF_DUMP_##type))
1302
909af768
JB
1303 /* always dump the vdso and vsyscall sections */
1304 if (always_dump_vma(vma))
82df3973 1305 goto whole;
e5b97dde 1306
0103bd16 1307 if (vma->vm_flags & VM_DONTDUMP)
accb61fe
JB
1308 return 0;
1309
5037835c
RZ
1310 /* support for DAX */
1311 if (vma_is_dax(vma)) {
1312 if ((vma->vm_flags & VM_SHARED) && FILTER(DAX_SHARED))
1313 goto whole;
1314 if (!(vma->vm_flags & VM_SHARED) && FILTER(DAX_PRIVATE))
1315 goto whole;
1316 return 0;
1317 }
1318
e575f111 1319 /* Hugetlb memory check */
03911132 1320 if (is_vm_hugetlb_page(vma)) {
e575f111
KM
1321 if ((vma->vm_flags & VM_SHARED) && FILTER(HUGETLB_SHARED))
1322 goto whole;
1323 if (!(vma->vm_flags & VM_SHARED) && FILTER(HUGETLB_PRIVATE))
1324 goto whole;
23d9e482 1325 return 0;
e575f111
KM
1326 }
1327
1da177e4 1328 /* Do not dump I/O mapped devices or special mappings */
314e51b9 1329 if (vma->vm_flags & VM_IO)
1da177e4
LT
1330 return 0;
1331
a1b59e80
KH
1332 /* By default, dump shared memory if mapped from an anonymous file. */
1333 if (vma->vm_flags & VM_SHARED) {
496ad9aa 1334 if (file_inode(vma->vm_file)->i_nlink == 0 ?
82df3973
RM
1335 FILTER(ANON_SHARED) : FILTER(MAPPED_SHARED))
1336 goto whole;
1337 return 0;
a1b59e80 1338 }
1da177e4 1339
82df3973
RM
1340 /* Dump segments that have been written to. */
1341 if (vma->anon_vma && FILTER(ANON_PRIVATE))
1342 goto whole;
1343 if (vma->vm_file == NULL)
1344 return 0;
1da177e4 1345
82df3973
RM
1346 if (FILTER(MAPPED_PRIVATE))
1347 goto whole;
1348
1349 /*
1350 * If this looks like the beginning of a DSO or executable mapping,
1351 * check for an ELF header. If we find one, dump the first page to
1352 * aid in determining what was mapped here.
1353 */
92dc07b1
RM
1354 if (FILTER(ELF_HEADERS) &&
1355 vma->vm_pgoff == 0 && (vma->vm_flags & VM_READ)) {
82df3973
RM
1356 u32 __user *header = (u32 __user *) vma->vm_start;
1357 u32 word;
92dc07b1 1358 mm_segment_t fs = get_fs();
82df3973
RM
1359 /*
1360 * Doing it this way gets the constant folded by GCC.
1361 */
1362 union {
1363 u32 cmp;
1364 char elfmag[SELFMAG];
1365 } magic;
1366 BUILD_BUG_ON(SELFMAG != sizeof word);
1367 magic.elfmag[EI_MAG0] = ELFMAG0;
1368 magic.elfmag[EI_MAG1] = ELFMAG1;
1369 magic.elfmag[EI_MAG2] = ELFMAG2;
1370 magic.elfmag[EI_MAG3] = ELFMAG3;
92dc07b1
RM
1371 /*
1372 * Switch to the user "segment" for get_user(),
1373 * then put back what elf_core_dump() had in place.
1374 */
1375 set_fs(USER_DS);
1376 if (unlikely(get_user(word, header)))
1377 word = 0;
1378 set_fs(fs);
1379 if (word == magic.cmp)
82df3973
RM
1380 return PAGE_SIZE;
1381 }
1382
1383#undef FILTER
1384
1385 return 0;
1386
1387whole:
1388 return vma->vm_end - vma->vm_start;
1da177e4
LT
1389}
1390
1da177e4
LT
1391/* An ELF note in memory */
1392struct memelfnote
1393{
1394 const char *name;
1395 int type;
1396 unsigned int datasz;
1397 void *data;
1398};
1399
1400static int notesize(struct memelfnote *en)
1401{
1402 int sz;
1403
1404 sz = sizeof(struct elf_note);
1405 sz += roundup(strlen(en->name) + 1, 4);
1406 sz += roundup(en->datasz, 4);
1407
1408 return sz;
1409}
1410
ecc8c772 1411static int writenote(struct memelfnote *men, struct coredump_params *cprm)
d025c9db
AK
1412{
1413 struct elf_note en;
1da177e4
LT
1414 en.n_namesz = strlen(men->name) + 1;
1415 en.n_descsz = men->datasz;
1416 en.n_type = men->type;
1417
ecc8c772 1418 return dump_emit(cprm, &en, sizeof(en)) &&
22a8cb82
AV
1419 dump_emit(cprm, men->name, en.n_namesz) && dump_align(cprm, 4) &&
1420 dump_emit(cprm, men->data, men->datasz) && dump_align(cprm, 4);
1da177e4 1421}
1da177e4 1422
3aba481f 1423static void fill_elf_header(struct elfhdr *elf, int segs,
d3330cf0 1424 u16 machine, u32 flags)
1da177e4 1425{
6970c8ef
CG
1426 memset(elf, 0, sizeof(*elf));
1427
1da177e4
LT
1428 memcpy(elf->e_ident, ELFMAG, SELFMAG);
1429 elf->e_ident[EI_CLASS] = ELF_CLASS;
1430 elf->e_ident[EI_DATA] = ELF_DATA;
1431 elf->e_ident[EI_VERSION] = EV_CURRENT;
1432 elf->e_ident[EI_OSABI] = ELF_OSABI;
1da177e4
LT
1433
1434 elf->e_type = ET_CORE;
3aba481f 1435 elf->e_machine = machine;
1da177e4 1436 elf->e_version = EV_CURRENT;
1da177e4 1437 elf->e_phoff = sizeof(struct elfhdr);
3aba481f 1438 elf->e_flags = flags;
1da177e4
LT
1439 elf->e_ehsize = sizeof(struct elfhdr);
1440 elf->e_phentsize = sizeof(struct elf_phdr);
1441 elf->e_phnum = segs;
1da177e4
LT
1442}
1443
8d6b5eee 1444static void fill_elf_note_phdr(struct elf_phdr *phdr, int sz, loff_t offset)
1da177e4
LT
1445{
1446 phdr->p_type = PT_NOTE;
1447 phdr->p_offset = offset;
1448 phdr->p_vaddr = 0;
1449 phdr->p_paddr = 0;
1450 phdr->p_filesz = sz;
1451 phdr->p_memsz = 0;
1452 phdr->p_flags = 0;
1453 phdr->p_align = 0;
1da177e4
LT
1454}
1455
1456static void fill_note(struct memelfnote *note, const char *name, int type,
1457 unsigned int sz, void *data)
1458{
1459 note->name = name;
1460 note->type = type;
1461 note->datasz = sz;
1462 note->data = data;
1da177e4
LT
1463}
1464
1465/*
f4e5cc2c
JJ
1466 * fill up all the fields in prstatus from the given task struct, except
1467 * registers which need to be filled up separately.
1da177e4
LT
1468 */
1469static void fill_prstatus(struct elf_prstatus *prstatus,
f4e5cc2c 1470 struct task_struct *p, long signr)
1da177e4
LT
1471{
1472 prstatus->pr_info.si_signo = prstatus->pr_cursig = signr;
1473 prstatus->pr_sigpend = p->pending.signal.sig[0];
1474 prstatus->pr_sighold = p->blocked.sig[0];
3b34fc58
ON
1475 rcu_read_lock();
1476 prstatus->pr_ppid = task_pid_vnr(rcu_dereference(p->real_parent));
1477 rcu_read_unlock();
b488893a 1478 prstatus->pr_pid = task_pid_vnr(p);
b488893a
PE
1479 prstatus->pr_pgrp = task_pgrp_vnr(p);
1480 prstatus->pr_sid = task_session_vnr(p);
1da177e4 1481 if (thread_group_leader(p)) {
cd19c364 1482 struct task_cputime cputime;
f06febc9 1483
1da177e4 1484 /*
f06febc9
FM
1485 * This is the record for the group leader. It shows the
1486 * group-wide total, not its individual thread total.
1da177e4 1487 */
cd19c364 1488 thread_group_cputime(p, &cputime);
e2bb80d5
AB
1489 prstatus->pr_utime = ns_to_kernel_old_timeval(cputime.utime);
1490 prstatus->pr_stime = ns_to_kernel_old_timeval(cputime.stime);
1da177e4 1491 } else {
cd19c364 1492 u64 utime, stime;
6fac4829 1493
cd19c364 1494 task_cputime(p, &utime, &stime);
e2bb80d5
AB
1495 prstatus->pr_utime = ns_to_kernel_old_timeval(utime);
1496 prstatus->pr_stime = ns_to_kernel_old_timeval(stime);
1da177e4 1497 }
5613fda9 1498
e2bb80d5
AB
1499 prstatus->pr_cutime = ns_to_kernel_old_timeval(p->signal->cutime);
1500 prstatus->pr_cstime = ns_to_kernel_old_timeval(p->signal->cstime);
1da177e4
LT
1501}
1502
1503static int fill_psinfo(struct elf_prpsinfo *psinfo, struct task_struct *p,
1504 struct mm_struct *mm)
1505{
c69e8d9c 1506 const struct cred *cred;
a84a5059 1507 unsigned int i, len;
1da177e4
LT
1508
1509 /* first copy the parameters from user space */
1510 memset(psinfo, 0, sizeof(struct elf_prpsinfo));
1511
1512 len = mm->arg_end - mm->arg_start;
1513 if (len >= ELF_PRARGSZ)
1514 len = ELF_PRARGSZ-1;
1515 if (copy_from_user(&psinfo->pr_psargs,
1516 (const char __user *)mm->arg_start, len))
1517 return -EFAULT;
1518 for(i = 0; i < len; i++)
1519 if (psinfo->pr_psargs[i] == 0)
1520 psinfo->pr_psargs[i] = ' ';
1521 psinfo->pr_psargs[len] = 0;
1522
3b34fc58
ON
1523 rcu_read_lock();
1524 psinfo->pr_ppid = task_pid_vnr(rcu_dereference(p->real_parent));
1525 rcu_read_unlock();
b488893a 1526 psinfo->pr_pid = task_pid_vnr(p);
b488893a
PE
1527 psinfo->pr_pgrp = task_pgrp_vnr(p);
1528 psinfo->pr_sid = task_session_vnr(p);
1da177e4
LT
1529
1530 i = p->state ? ffz(~p->state) + 1 : 0;
1531 psinfo->pr_state = i;
55148548 1532 psinfo->pr_sname = (i > 5) ? '.' : "RSDTZW"[i];
1da177e4
LT
1533 psinfo->pr_zomb = psinfo->pr_sname == 'Z';
1534 psinfo->pr_nice = task_nice(p);
1535 psinfo->pr_flag = p->flags;
c69e8d9c
DH
1536 rcu_read_lock();
1537 cred = __task_cred(p);
ebc887b2
EB
1538 SET_UID(psinfo->pr_uid, from_kuid_munged(cred->user_ns, cred->uid));
1539 SET_GID(psinfo->pr_gid, from_kgid_munged(cred->user_ns, cred->gid));
c69e8d9c 1540 rcu_read_unlock();
1da177e4
LT
1541 strncpy(psinfo->pr_fname, p->comm, sizeof(psinfo->pr_fname));
1542
1543 return 0;
1544}
1545
3aba481f
RM
1546static void fill_auxv_note(struct memelfnote *note, struct mm_struct *mm)
1547{
1548 elf_addr_t *auxv = (elf_addr_t *) mm->saved_auxv;
1549 int i = 0;
1550 do
1551 i += 2;
1552 while (auxv[i - 2] != AT_NULL);
1553 fill_note(note, "CORE", NT_AUXV, i * sizeof(elf_addr_t), auxv);
1554}
1555
49ae4d4b 1556static void fill_siginfo_note(struct memelfnote *note, user_siginfo_t *csigdata,
ae7795bc 1557 const kernel_siginfo_t *siginfo)
49ae4d4b 1558{
fa4751f4 1559 copy_siginfo_to_external(csigdata, siginfo);
49ae4d4b
DV
1560 fill_note(note, "CORE", NT_SIGINFO, sizeof(*csigdata), csigdata);
1561}
1562
2aa362c4
DV
1563#define MAX_FILE_NOTE_SIZE (4*1024*1024)
1564/*
1565 * Format of NT_FILE note:
1566 *
1567 * long count -- how many files are mapped
1568 * long page_size -- units for file_ofs
1569 * array of [COUNT] elements of
1570 * long start
1571 * long end
1572 * long file_ofs
1573 * followed by COUNT filenames in ASCII: "FILE1" NUL "FILE2" NUL...
1574 */
72023656 1575static int fill_files_note(struct memelfnote *note)
2aa362c4 1576{
03c6d723 1577 struct mm_struct *mm = current->mm;
2aa362c4
DV
1578 struct vm_area_struct *vma;
1579 unsigned count, size, names_ofs, remaining, n;
1580 user_long_t *data;
1581 user_long_t *start_end_ofs;
1582 char *name_base, *name_curpos;
1583
1584 /* *Estimated* file count and total data size needed */
03c6d723 1585 count = mm->map_count;
60c9d92f
AD
1586 if (count > UINT_MAX / 64)
1587 return -EINVAL;
2aa362c4
DV
1588 size = count * 64;
1589
1590 names_ofs = (2 + 3 * count) * sizeof(data[0]);
1591 alloc:
1592 if (size >= MAX_FILE_NOTE_SIZE) /* paranoia check */
72023656 1593 return -EINVAL;
2aa362c4 1594 size = round_up(size, PAGE_SIZE);
1fbede6e
AD
1595 /*
1596 * "size" can be 0 here legitimately.
1597 * Let it ENOMEM and omit NT_FILE section which will be empty anyway.
1598 */
86a2bb5a
AD
1599 data = kvmalloc(size, GFP_KERNEL);
1600 if (ZERO_OR_NULL_PTR(data))
72023656 1601 return -ENOMEM;
2aa362c4
DV
1602
1603 start_end_ofs = data + 2;
1604 name_base = name_curpos = ((char *)data) + names_ofs;
1605 remaining = size - names_ofs;
1606 count = 0;
03c6d723 1607 for (vma = mm->mmap; vma != NULL; vma = vma->vm_next) {
2aa362c4
DV
1608 struct file *file;
1609 const char *filename;
1610
1611 file = vma->vm_file;
1612 if (!file)
1613 continue;
9bf39ab2 1614 filename = file_path(file, name_curpos, remaining);
2aa362c4
DV
1615 if (IS_ERR(filename)) {
1616 if (PTR_ERR(filename) == -ENAMETOOLONG) {
86a2bb5a 1617 kvfree(data);
2aa362c4
DV
1618 size = size * 5 / 4;
1619 goto alloc;
1620 }
1621 continue;
1622 }
1623
9bf39ab2 1624 /* file_path() fills at the end, move name down */
2aa362c4
DV
1625 /* n = strlen(filename) + 1: */
1626 n = (name_curpos + remaining) - filename;
1627 remaining = filename - name_curpos;
1628 memmove(name_curpos, filename, n);
1629 name_curpos += n;
1630
1631 *start_end_ofs++ = vma->vm_start;
1632 *start_end_ofs++ = vma->vm_end;
1633 *start_end_ofs++ = vma->vm_pgoff;
1634 count++;
1635 }
1636
1637 /* Now we know exact count of files, can store it */
1638 data[0] = count;
1639 data[1] = PAGE_SIZE;
1640 /*
03c6d723 1641 * Count usually is less than mm->map_count,
2aa362c4
DV
1642 * we need to move filenames down.
1643 */
03c6d723 1644 n = mm->map_count - count;
2aa362c4
DV
1645 if (n != 0) {
1646 unsigned shift_bytes = n * 3 * sizeof(data[0]);
1647 memmove(name_base - shift_bytes, name_base,
1648 name_curpos - name_base);
1649 name_curpos -= shift_bytes;
1650 }
1651
1652 size = name_curpos - (char *)data;
1653 fill_note(note, "CORE", NT_FILE, size, data);
72023656 1654 return 0;
2aa362c4
DV
1655}
1656
4206d3aa
RM
1657#ifdef CORE_DUMP_USE_REGSET
1658#include <linux/regset.h>
1659
1660struct elf_thread_core_info {
1661 struct elf_thread_core_info *next;
1662 struct task_struct *task;
1663 struct elf_prstatus prstatus;
1664 struct memelfnote notes[0];
1665};
1666
1667struct elf_note_info {
1668 struct elf_thread_core_info *thread;
1669 struct memelfnote psinfo;
49ae4d4b 1670 struct memelfnote signote;
4206d3aa 1671 struct memelfnote auxv;
2aa362c4 1672 struct memelfnote files;
49ae4d4b 1673 user_siginfo_t csigdata;
4206d3aa
RM
1674 size_t size;
1675 int thread_notes;
1676};
1677
d31472b6
RM
1678/*
1679 * When a regset has a writeback hook, we call it on each thread before
1680 * dumping user memory. On register window machines, this makes sure the
1681 * user memory backing the register data is up to date before we read it.
1682 */
1683static void do_thread_regset_writeback(struct task_struct *task,
1684 const struct user_regset *regset)
1685{
1686 if (regset->writeback)
1687 regset->writeback(task, regset, 1);
1688}
1689
0953f65d 1690#ifndef PRSTATUS_SIZE
90954e7b 1691#define PRSTATUS_SIZE(S, R) sizeof(S)
0953f65d
L
1692#endif
1693
1694#ifndef SET_PR_FPVALID
90954e7b 1695#define SET_PR_FPVALID(S, V, R) ((S)->pr_fpvalid = (V))
0953f65d
L
1696#endif
1697
4206d3aa
RM
1698static int fill_thread_core_info(struct elf_thread_core_info *t,
1699 const struct user_regset_view *view,
1700 long signr, size_t *total)
1701{
1702 unsigned int i;
27e64b4b 1703 unsigned int regset0_size = regset_size(t->task, &view->regsets[0]);
4206d3aa
RM
1704
1705 /*
1706 * NT_PRSTATUS is the one special case, because the regset data
1707 * goes into the pr_reg field inside the note contents, rather
1708 * than being the whole note contents. We fill the reset in here.
1709 * We assume that regset 0 is NT_PRSTATUS.
1710 */
1711 fill_prstatus(&t->prstatus, t->task, signr);
27e64b4b 1712 (void) view->regsets[0].get(t->task, &view->regsets[0], 0, regset0_size,
90954e7b 1713 &t->prstatus.pr_reg, NULL);
4206d3aa
RM
1714
1715 fill_note(&t->notes[0], "CORE", NT_PRSTATUS,
27e64b4b 1716 PRSTATUS_SIZE(t->prstatus, regset0_size), &t->prstatus);
4206d3aa
RM
1717 *total += notesize(&t->notes[0]);
1718
d31472b6
RM
1719 do_thread_regset_writeback(t->task, &view->regsets[0]);
1720
4206d3aa
RM
1721 /*
1722 * Each other regset might generate a note too. For each regset
1723 * that has no core_note_type or is inactive, we leave t->notes[i]
1724 * all zero and we'll know to skip writing it later.
1725 */
1726 for (i = 1; i < view->n; ++i) {
1727 const struct user_regset *regset = &view->regsets[i];
d31472b6 1728 do_thread_regset_writeback(t->task, regset);
c8e25258 1729 if (regset->core_note_type && regset->get &&
2f819db5 1730 (!regset->active || regset->active(t->task, regset) > 0)) {
4206d3aa 1731 int ret;
27e64b4b 1732 size_t size = regset_size(t->task, regset);
4206d3aa
RM
1733 void *data = kmalloc(size, GFP_KERNEL);
1734 if (unlikely(!data))
1735 return 0;
1736 ret = regset->get(t->task, regset,
1737 0, size, data, NULL);
1738 if (unlikely(ret))
1739 kfree(data);
1740 else {
1741 if (regset->core_note_type != NT_PRFPREG)
1742 fill_note(&t->notes[i], "LINUX",
1743 regset->core_note_type,
1744 size, data);
1745 else {
90954e7b 1746 SET_PR_FPVALID(&t->prstatus,
27e64b4b 1747 1, regset0_size);
4206d3aa
RM
1748 fill_note(&t->notes[i], "CORE",
1749 NT_PRFPREG, size, data);
1750 }
1751 *total += notesize(&t->notes[i]);
1752 }
1753 }
1754 }
1755
1756 return 1;
1757}
1758
1759static int fill_note_info(struct elfhdr *elf, int phdrs,
1760 struct elf_note_info *info,
ae7795bc 1761 const kernel_siginfo_t *siginfo, struct pt_regs *regs)
4206d3aa
RM
1762{
1763 struct task_struct *dump_task = current;
1764 const struct user_regset_view *view = task_user_regset_view(dump_task);
1765 struct elf_thread_core_info *t;
1766 struct elf_prpsinfo *psinfo;
83914441 1767 struct core_thread *ct;
4206d3aa
RM
1768 unsigned int i;
1769
1770 info->size = 0;
1771 info->thread = NULL;
1772
1773 psinfo = kmalloc(sizeof(*psinfo), GFP_KERNEL);
6899e92d
AC
1774 if (psinfo == NULL) {
1775 info->psinfo.data = NULL; /* So we don't free this wrongly */
4206d3aa 1776 return 0;
6899e92d 1777 }
4206d3aa 1778
e2dbe125
AW
1779 fill_note(&info->psinfo, "CORE", NT_PRPSINFO, sizeof(*psinfo), psinfo);
1780
4206d3aa
RM
1781 /*
1782 * Figure out how many notes we're going to need for each thread.
1783 */
1784 info->thread_notes = 0;
1785 for (i = 0; i < view->n; ++i)
1786 if (view->regsets[i].core_note_type != 0)
1787 ++info->thread_notes;
1788
1789 /*
1790 * Sanity check. We rely on regset 0 being in NT_PRSTATUS,
1791 * since it is our one special case.
1792 */
1793 if (unlikely(info->thread_notes == 0) ||
1794 unlikely(view->regsets[0].core_note_type != NT_PRSTATUS)) {
1795 WARN_ON(1);
1796 return 0;
1797 }
1798
1799 /*
1800 * Initialize the ELF file header.
1801 */
1802 fill_elf_header(elf, phdrs,
d3330cf0 1803 view->e_machine, view->e_flags);
4206d3aa
RM
1804
1805 /*
1806 * Allocate a structure for each thread.
1807 */
83914441
ON
1808 for (ct = &dump_task->mm->core_state->dumper; ct; ct = ct->next) {
1809 t = kzalloc(offsetof(struct elf_thread_core_info,
1810 notes[info->thread_notes]),
1811 GFP_KERNEL);
1812 if (unlikely(!t))
1813 return 0;
1814
1815 t->task = ct->task;
1816 if (ct->task == dump_task || !info->thread) {
1817 t->next = info->thread;
1818 info->thread = t;
1819 } else {
1820 /*
1821 * Make sure to keep the original task at
1822 * the head of the list.
1823 */
1824 t->next = info->thread->next;
1825 info->thread->next = t;
4206d3aa 1826 }
83914441 1827 }
4206d3aa
RM
1828
1829 /*
1830 * Now fill in each thread's information.
1831 */
1832 for (t = info->thread; t != NULL; t = t->next)
5ab1c309 1833 if (!fill_thread_core_info(t, view, siginfo->si_signo, &info->size))
4206d3aa
RM
1834 return 0;
1835
1836 /*
1837 * Fill in the two process-wide notes.
1838 */
1839 fill_psinfo(psinfo, dump_task->group_leader, dump_task->mm);
1840 info->size += notesize(&info->psinfo);
1841
49ae4d4b
DV
1842 fill_siginfo_note(&info->signote, &info->csigdata, siginfo);
1843 info->size += notesize(&info->signote);
1844
4206d3aa
RM
1845 fill_auxv_note(&info->auxv, current->mm);
1846 info->size += notesize(&info->auxv);
1847
72023656
DA
1848 if (fill_files_note(&info->files) == 0)
1849 info->size += notesize(&info->files);
2aa362c4 1850
4206d3aa
RM
1851 return 1;
1852}
1853
1854static size_t get_note_info_size(struct elf_note_info *info)
1855{
1856 return info->size;
1857}
1858
1859/*
1860 * Write all the notes for each thread. When writing the first thread, the
1861 * process-wide notes are interleaved after the first thread-specific note.
1862 */
1863static int write_note_info(struct elf_note_info *info,
ecc8c772 1864 struct coredump_params *cprm)
4206d3aa 1865{
b219e25f 1866 bool first = true;
4206d3aa
RM
1867 struct elf_thread_core_info *t = info->thread;
1868
1869 do {
1870 int i;
1871
ecc8c772 1872 if (!writenote(&t->notes[0], cprm))
4206d3aa
RM
1873 return 0;
1874
ecc8c772 1875 if (first && !writenote(&info->psinfo, cprm))
4206d3aa 1876 return 0;
ecc8c772 1877 if (first && !writenote(&info->signote, cprm))
49ae4d4b 1878 return 0;
ecc8c772 1879 if (first && !writenote(&info->auxv, cprm))
4206d3aa 1880 return 0;
72023656 1881 if (first && info->files.data &&
ecc8c772 1882 !writenote(&info->files, cprm))
2aa362c4 1883 return 0;
4206d3aa
RM
1884
1885 for (i = 1; i < info->thread_notes; ++i)
1886 if (t->notes[i].data &&
ecc8c772 1887 !writenote(&t->notes[i], cprm))
4206d3aa
RM
1888 return 0;
1889
b219e25f 1890 first = false;
4206d3aa
RM
1891 t = t->next;
1892 } while (t);
1893
1894 return 1;
1895}
1896
1897static void free_note_info(struct elf_note_info *info)
1898{
1899 struct elf_thread_core_info *threads = info->thread;
1900 while (threads) {
1901 unsigned int i;
1902 struct elf_thread_core_info *t = threads;
1903 threads = t->next;
1904 WARN_ON(t->notes[0].data && t->notes[0].data != &t->prstatus);
1905 for (i = 1; i < info->thread_notes; ++i)
1906 kfree(t->notes[i].data);
1907 kfree(t);
1908 }
1909 kfree(info->psinfo.data);
86a2bb5a 1910 kvfree(info->files.data);
4206d3aa
RM
1911}
1912
1913#else
1914
1da177e4
LT
1915/* Here is the structure in which status of each thread is captured. */
1916struct elf_thread_status
1917{
1918 struct list_head list;
1919 struct elf_prstatus prstatus; /* NT_PRSTATUS */
1920 elf_fpregset_t fpu; /* NT_PRFPREG */
1921 struct task_struct *thread;
1922#ifdef ELF_CORE_COPY_XFPREGS
5b20cd80 1923 elf_fpxregset_t xfpu; /* ELF_CORE_XFPREG_TYPE */
1da177e4
LT
1924#endif
1925 struct memelfnote notes[3];
1926 int num_notes;
1927};
1928
1929/*
1930 * In order to add the specific thread information for the elf file format,
f4e5cc2c
JJ
1931 * we need to keep a linked list of every threads pr_status and then create
1932 * a single section for them in the final core file.
1da177e4
LT
1933 */
1934static int elf_dump_thread_status(long signr, struct elf_thread_status *t)
1935{
1936 int sz = 0;
1937 struct task_struct *p = t->thread;
1938 t->num_notes = 0;
1939
1940 fill_prstatus(&t->prstatus, p, signr);
1941 elf_core_copy_task_regs(p, &t->prstatus.pr_reg);
1942
f4e5cc2c
JJ
1943 fill_note(&t->notes[0], "CORE", NT_PRSTATUS, sizeof(t->prstatus),
1944 &(t->prstatus));
1da177e4
LT
1945 t->num_notes++;
1946 sz += notesize(&t->notes[0]);
1947
f4e5cc2c
JJ
1948 if ((t->prstatus.pr_fpvalid = elf_core_copy_task_fpregs(p, NULL,
1949 &t->fpu))) {
1950 fill_note(&t->notes[1], "CORE", NT_PRFPREG, sizeof(t->fpu),
1951 &(t->fpu));
1da177e4
LT
1952 t->num_notes++;
1953 sz += notesize(&t->notes[1]);
1954 }
1955
1956#ifdef ELF_CORE_COPY_XFPREGS
1957 if (elf_core_copy_task_xfpregs(p, &t->xfpu)) {
5b20cd80
MN
1958 fill_note(&t->notes[2], "LINUX", ELF_CORE_XFPREG_TYPE,
1959 sizeof(t->xfpu), &t->xfpu);
1da177e4
LT
1960 t->num_notes++;
1961 sz += notesize(&t->notes[2]);
1962 }
1963#endif
1964 return sz;
1965}
1966
3aba481f
RM
1967struct elf_note_info {
1968 struct memelfnote *notes;
72023656 1969 struct memelfnote *notes_files;
3aba481f
RM
1970 struct elf_prstatus *prstatus; /* NT_PRSTATUS */
1971 struct elf_prpsinfo *psinfo; /* NT_PRPSINFO */
1972 struct list_head thread_list;
1973 elf_fpregset_t *fpu;
1974#ifdef ELF_CORE_COPY_XFPREGS
1975 elf_fpxregset_t *xfpu;
1976#endif
49ae4d4b 1977 user_siginfo_t csigdata;
3aba481f
RM
1978 int thread_status_size;
1979 int numnote;
1980};
1981
0cf062d0 1982static int elf_note_info_init(struct elf_note_info *info)
3aba481f 1983{
0cf062d0 1984 memset(info, 0, sizeof(*info));
3aba481f
RM
1985 INIT_LIST_HEAD(&info->thread_list);
1986
49ae4d4b 1987 /* Allocate space for ELF notes */
6da2ec56 1988 info->notes = kmalloc_array(8, sizeof(struct memelfnote), GFP_KERNEL);
3aba481f
RM
1989 if (!info->notes)
1990 return 0;
1991 info->psinfo = kmalloc(sizeof(*info->psinfo), GFP_KERNEL);
1992 if (!info->psinfo)
f34f9d18 1993 return 0;
3aba481f
RM
1994 info->prstatus = kmalloc(sizeof(*info->prstatus), GFP_KERNEL);
1995 if (!info->prstatus)
f34f9d18 1996 return 0;
3aba481f
RM
1997 info->fpu = kmalloc(sizeof(*info->fpu), GFP_KERNEL);
1998 if (!info->fpu)
f34f9d18 1999 return 0;
3aba481f
RM
2000#ifdef ELF_CORE_COPY_XFPREGS
2001 info->xfpu = kmalloc(sizeof(*info->xfpu), GFP_KERNEL);
2002 if (!info->xfpu)
f34f9d18 2003 return 0;
3aba481f 2004#endif
0cf062d0 2005 return 1;
0cf062d0
AW
2006}
2007
2008static int fill_note_info(struct elfhdr *elf, int phdrs,
2009 struct elf_note_info *info,
ae7795bc 2010 const kernel_siginfo_t *siginfo, struct pt_regs *regs)
0cf062d0 2011{
afabada9
AV
2012 struct core_thread *ct;
2013 struct elf_thread_status *ets;
0cf062d0
AW
2014
2015 if (!elf_note_info_init(info))
2016 return 0;
3aba481f 2017
afabada9
AV
2018 for (ct = current->mm->core_state->dumper.next;
2019 ct; ct = ct->next) {
2020 ets = kzalloc(sizeof(*ets), GFP_KERNEL);
2021 if (!ets)
2022 return 0;
83914441 2023
afabada9
AV
2024 ets->thread = ct->task;
2025 list_add(&ets->list, &info->thread_list);
2026 }
83914441 2027
93f044e2 2028 list_for_each_entry(ets, &info->thread_list, list) {
afabada9 2029 int sz;
3aba481f 2030
afabada9
AV
2031 sz = elf_dump_thread_status(siginfo->si_signo, ets);
2032 info->thread_status_size += sz;
3aba481f
RM
2033 }
2034 /* now collect the dump for the current */
2035 memset(info->prstatus, 0, sizeof(*info->prstatus));
5ab1c309 2036 fill_prstatus(info->prstatus, current, siginfo->si_signo);
3aba481f
RM
2037 elf_core_copy_regs(&info->prstatus->pr_reg, regs);
2038
2039 /* Set up header */
d3330cf0 2040 fill_elf_header(elf, phdrs, ELF_ARCH, ELF_CORE_EFLAGS);
3aba481f
RM
2041
2042 /*
2043 * Set up the notes in similar form to SVR4 core dumps made
2044 * with info from their /proc.
2045 */
2046
2047 fill_note(info->notes + 0, "CORE", NT_PRSTATUS,
2048 sizeof(*info->prstatus), info->prstatus);
2049 fill_psinfo(info->psinfo, current->group_leader, current->mm);
2050 fill_note(info->notes + 1, "CORE", NT_PRPSINFO,
2051 sizeof(*info->psinfo), info->psinfo);
2052
2aa362c4
DV
2053 fill_siginfo_note(info->notes + 2, &info->csigdata, siginfo);
2054 fill_auxv_note(info->notes + 3, current->mm);
72023656 2055 info->numnote = 4;
3aba481f 2056
72023656
DA
2057 if (fill_files_note(info->notes + info->numnote) == 0) {
2058 info->notes_files = info->notes + info->numnote;
2059 info->numnote++;
2060 }
3aba481f
RM
2061
2062 /* Try to dump the FPU. */
2063 info->prstatus->pr_fpvalid = elf_core_copy_task_fpregs(current, regs,
2064 info->fpu);
2065 if (info->prstatus->pr_fpvalid)
2066 fill_note(info->notes + info->numnote++,
2067 "CORE", NT_PRFPREG, sizeof(*info->fpu), info->fpu);
2068#ifdef ELF_CORE_COPY_XFPREGS
2069 if (elf_core_copy_task_xfpregs(current, info->xfpu))
2070 fill_note(info->notes + info->numnote++,
2071 "LINUX", ELF_CORE_XFPREG_TYPE,
2072 sizeof(*info->xfpu), info->xfpu);
2073#endif
2074
2075 return 1;
3aba481f
RM
2076}
2077
2078static size_t get_note_info_size(struct elf_note_info *info)
2079{
2080 int sz = 0;
2081 int i;
2082
2083 for (i = 0; i < info->numnote; i++)
2084 sz += notesize(info->notes + i);
2085
2086 sz += info->thread_status_size;
2087
2088 return sz;
2089}
2090
2091static int write_note_info(struct elf_note_info *info,
ecc8c772 2092 struct coredump_params *cprm)
3aba481f 2093{
93f044e2 2094 struct elf_thread_status *ets;
3aba481f 2095 int i;
3aba481f
RM
2096
2097 for (i = 0; i < info->numnote; i++)
ecc8c772 2098 if (!writenote(info->notes + i, cprm))
3aba481f
RM
2099 return 0;
2100
2101 /* write out the thread status notes section */
93f044e2
AD
2102 list_for_each_entry(ets, &info->thread_list, list) {
2103 for (i = 0; i < ets->num_notes; i++)
2104 if (!writenote(&ets->notes[i], cprm))
3aba481f
RM
2105 return 0;
2106 }
2107
2108 return 1;
2109}
2110
2111static void free_note_info(struct elf_note_info *info)
2112{
2113 while (!list_empty(&info->thread_list)) {
2114 struct list_head *tmp = info->thread_list.next;
2115 list_del(tmp);
2116 kfree(list_entry(tmp, struct elf_thread_status, list));
2117 }
2118
72023656
DA
2119 /* Free data possibly allocated by fill_files_note(): */
2120 if (info->notes_files)
86a2bb5a 2121 kvfree(info->notes_files->data);
2aa362c4 2122
3aba481f
RM
2123 kfree(info->prstatus);
2124 kfree(info->psinfo);
2125 kfree(info->notes);
2126 kfree(info->fpu);
2127#ifdef ELF_CORE_COPY_XFPREGS
2128 kfree(info->xfpu);
2129#endif
2130}
2131
4206d3aa
RM
2132#endif
2133
f47aef55
RM
2134static struct vm_area_struct *first_vma(struct task_struct *tsk,
2135 struct vm_area_struct *gate_vma)
2136{
2137 struct vm_area_struct *ret = tsk->mm->mmap;
2138
2139 if (ret)
2140 return ret;
2141 return gate_vma;
2142}
2143/*
2144 * Helper function for iterating across a vma list. It ensures that the caller
2145 * will visit `gate_vma' prior to terminating the search.
2146 */
2147static struct vm_area_struct *next_vma(struct vm_area_struct *this_vma,
2148 struct vm_area_struct *gate_vma)
2149{
2150 struct vm_area_struct *ret;
2151
2152 ret = this_vma->vm_next;
2153 if (ret)
2154 return ret;
2155 if (this_vma == gate_vma)
2156 return NULL;
2157 return gate_vma;
2158}
2159
8d9032bb
DH
2160static void fill_extnum_info(struct elfhdr *elf, struct elf_shdr *shdr4extnum,
2161 elf_addr_t e_shoff, int segs)
2162{
2163 elf->e_shoff = e_shoff;
2164 elf->e_shentsize = sizeof(*shdr4extnum);
2165 elf->e_shnum = 1;
2166 elf->e_shstrndx = SHN_UNDEF;
2167
2168 memset(shdr4extnum, 0, sizeof(*shdr4extnum));
2169
2170 shdr4extnum->sh_type = SHT_NULL;
2171 shdr4extnum->sh_size = elf->e_shnum;
2172 shdr4extnum->sh_link = elf->e_shstrndx;
2173 shdr4extnum->sh_info = segs;
2174}
2175
1da177e4
LT
2176/*
2177 * Actual dumper
2178 *
2179 * This is a two-pass process; first we find the offsets of the bits,
2180 * and then they are actually written out. If we run out of core limit
2181 * we just truncate.
2182 */
f6151dfe 2183static int elf_core_dump(struct coredump_params *cprm)
1da177e4 2184{
1da177e4
LT
2185 int has_dumped = 0;
2186 mm_segment_t fs;
52f5592e
JL
2187 int segs, i;
2188 size_t vma_data_size = 0;
f47aef55 2189 struct vm_area_struct *vma, *gate_vma;
225a3f53 2190 struct elfhdr elf;
cdc3d562 2191 loff_t offset = 0, dataoff;
72023656 2192 struct elf_note_info info = { };
93eb211e 2193 struct elf_phdr *phdr4note = NULL;
8d9032bb
DH
2194 struct elf_shdr *shdr4extnum = NULL;
2195 Elf_Half e_phnum;
2196 elf_addr_t e_shoff;
52f5592e 2197 elf_addr_t *vma_filesz = NULL;
1da177e4
LT
2198
2199 /*
2200 * We no longer stop all VM operations.
2201 *
f4e5cc2c
JJ
2202 * This is because those proceses that could possibly change map_count
2203 * or the mmap / vma pages are now blocked in do_exit on current
2204 * finishing this core dump.
1da177e4
LT
2205 *
2206 * Only ptrace can touch these memory addresses, but it doesn't change
f4e5cc2c 2207 * the map_count or the pages allocated. So no possibility of crashing
1da177e4
LT
2208 * exists while dumping the mm->vm_next areas to the core file.
2209 */
2210
341c87bf
KH
2211 /*
2212 * The number of segs are recored into ELF header as 16bit value.
2213 * Please check DEFAULT_MAX_MAP_COUNT definition when you modify here.
2214 */
1da177e4 2215 segs = current->mm->map_count;
1fcccbac 2216 segs += elf_core_extra_phdrs();
1da177e4 2217
31db58b3 2218 gate_vma = get_gate_vma(current->mm);
f47aef55
RM
2219 if (gate_vma != NULL)
2220 segs++;
2221
8d9032bb
DH
2222 /* for notes section */
2223 segs++;
2224
2225 /* If segs > PN_XNUM(0xffff), then e_phnum overflows. To avoid
2226 * this, kernel supports extended numbering. Have a look at
2227 * include/linux/elf.h for further information. */
2228 e_phnum = segs > PN_XNUM ? PN_XNUM : segs;
2229
1da177e4 2230 /*
3aba481f
RM
2231 * Collect all the non-memory information about the process for the
2232 * notes. This also sets up the file header.
1da177e4 2233 */
225a3f53 2234 if (!fill_note_info(&elf, e_phnum, &info, cprm->siginfo, cprm->regs))
3aba481f 2235 goto cleanup;
1da177e4 2236
3aba481f 2237 has_dumped = 1;
079148b9 2238
1da177e4
LT
2239 fs = get_fs();
2240 set_fs(KERNEL_DS);
2241
225a3f53 2242 offset += sizeof(elf); /* Elf header */
8d9032bb 2243 offset += segs * sizeof(struct elf_phdr); /* Program headers */
1da177e4
LT
2244
2245 /* Write notes phdr entry */
2246 {
3aba481f 2247 size_t sz = get_note_info_size(&info);
1da177e4 2248
e5501492 2249 sz += elf_coredump_extra_notes_size();
bf1ab978 2250
93eb211e
DH
2251 phdr4note = kmalloc(sizeof(*phdr4note), GFP_KERNEL);
2252 if (!phdr4note)
088e7af7 2253 goto end_coredump;
93eb211e
DH
2254
2255 fill_elf_note_phdr(phdr4note, sz, offset);
2256 offset += sz;
1da177e4
LT
2257 }
2258
1da177e4
LT
2259 dataoff = offset = roundup(offset, ELF_EXEC_PAGESIZE);
2260
1fbede6e
AD
2261 /*
2262 * Zero vma process will get ZERO_SIZE_PTR here.
2263 * Let coredump continue for register state at least.
2264 */
86a2bb5a
AD
2265 vma_filesz = kvmalloc(array_size(sizeof(*vma_filesz), (segs - 1)),
2266 GFP_KERNEL);
1fbede6e 2267 if (!vma_filesz)
52f5592e
JL
2268 goto end_coredump;
2269
2270 for (i = 0, vma = first_vma(current, gate_vma); vma != NULL;
2271 vma = next_vma(vma, gate_vma)) {
2272 unsigned long dump_size;
2273
2274 dump_size = vma_dump_size(vma, cprm->mm_flags);
2275 vma_filesz[i++] = dump_size;
2276 vma_data_size += dump_size;
2277 }
2278
2279 offset += vma_data_size;
8d9032bb
DH
2280 offset += elf_core_extra_data_size();
2281 e_shoff = offset;
2282
2283 if (e_phnum == PN_XNUM) {
2284 shdr4extnum = kmalloc(sizeof(*shdr4extnum), GFP_KERNEL);
2285 if (!shdr4extnum)
2286 goto end_coredump;
225a3f53 2287 fill_extnum_info(&elf, shdr4extnum, e_shoff, segs);
8d9032bb
DH
2288 }
2289
2290 offset = dataoff;
2291
225a3f53 2292 if (!dump_emit(cprm, &elf, sizeof(elf)))
93eb211e
DH
2293 goto end_coredump;
2294
ecc8c772 2295 if (!dump_emit(cprm, phdr4note, sizeof(*phdr4note)))
93eb211e
DH
2296 goto end_coredump;
2297
1da177e4 2298 /* Write program headers for segments dump */
52f5592e 2299 for (i = 0, vma = first_vma(current, gate_vma); vma != NULL;
f47aef55 2300 vma = next_vma(vma, gate_vma)) {
1da177e4 2301 struct elf_phdr phdr;
1da177e4
LT
2302
2303 phdr.p_type = PT_LOAD;
2304 phdr.p_offset = offset;
2305 phdr.p_vaddr = vma->vm_start;
2306 phdr.p_paddr = 0;
52f5592e 2307 phdr.p_filesz = vma_filesz[i++];
82df3973 2308 phdr.p_memsz = vma->vm_end - vma->vm_start;
1da177e4
LT
2309 offset += phdr.p_filesz;
2310 phdr.p_flags = vma->vm_flags & VM_READ ? PF_R : 0;
f4e5cc2c
JJ
2311 if (vma->vm_flags & VM_WRITE)
2312 phdr.p_flags |= PF_W;
2313 if (vma->vm_flags & VM_EXEC)
2314 phdr.p_flags |= PF_X;
1da177e4
LT
2315 phdr.p_align = ELF_EXEC_PAGESIZE;
2316
ecc8c772 2317 if (!dump_emit(cprm, &phdr, sizeof(phdr)))
088e7af7 2318 goto end_coredump;
1da177e4
LT
2319 }
2320
506f21c5 2321 if (!elf_core_write_extra_phdrs(cprm, offset))
1fcccbac 2322 goto end_coredump;
1da177e4
LT
2323
2324 /* write out the notes section */
ecc8c772 2325 if (!write_note_info(&info, cprm))
3aba481f 2326 goto end_coredump;
1da177e4 2327
cdc3d562 2328 if (elf_coredump_extra_notes_write(cprm))
e5501492 2329 goto end_coredump;
bf1ab978 2330
d025c9db 2331 /* Align to page */
1607f09c 2332 if (!dump_skip(cprm, dataoff - cprm->pos))
f3e8fccd 2333 goto end_coredump;
1da177e4 2334
52f5592e 2335 for (i = 0, vma = first_vma(current, gate_vma); vma != NULL;
f47aef55 2336 vma = next_vma(vma, gate_vma)) {
1da177e4 2337 unsigned long addr;
82df3973 2338 unsigned long end;
1da177e4 2339
52f5592e 2340 end = vma->vm_start + vma_filesz[i++];
1da177e4 2341
82df3973 2342 for (addr = vma->vm_start; addr < end; addr += PAGE_SIZE) {
f4e5cc2c 2343 struct page *page;
f3e8fccd
HD
2344 int stop;
2345
2346 page = get_dump_page(addr);
2347 if (page) {
2348 void *kaddr = kmap(page);
13046ece 2349 stop = !dump_emit(cprm, kaddr, PAGE_SIZE);
f3e8fccd 2350 kunmap(page);
09cbfeaf 2351 put_page(page);
f3e8fccd 2352 } else
9b56d543 2353 stop = !dump_skip(cprm, PAGE_SIZE);
f3e8fccd
HD
2354 if (stop)
2355 goto end_coredump;
1da177e4
LT
2356 }
2357 }
4d22c75d 2358 dump_truncate(cprm);
1da177e4 2359
aa3e7eaf 2360 if (!elf_core_write_extra_data(cprm))
1fcccbac 2361 goto end_coredump;
1da177e4 2362
8d9032bb 2363 if (e_phnum == PN_XNUM) {
13046ece 2364 if (!dump_emit(cprm, shdr4extnum, sizeof(*shdr4extnum)))
8d9032bb
DH
2365 goto end_coredump;
2366 }
2367
1da177e4
LT
2368end_coredump:
2369 set_fs(fs);
2370
2371cleanup:
3aba481f 2372 free_note_info(&info);
8d9032bb 2373 kfree(shdr4extnum);
86a2bb5a 2374 kvfree(vma_filesz);
93eb211e 2375 kfree(phdr4note);
1da177e4 2376 return has_dumped;
1da177e4
LT
2377}
2378
698ba7b5 2379#endif /* CONFIG_ELF_CORE */
1da177e4
LT
2380
2381static int __init init_elf_binfmt(void)
2382{
8fc3dc5a
AV
2383 register_binfmt(&elf_format);
2384 return 0;
1da177e4
LT
2385}
2386
2387static void __exit exit_elf_binfmt(void)
2388{
2389 /* Remove the COFF and ELF loaders. */
2390 unregister_binfmt(&elf_format);
2391}
2392
2393core_initcall(init_elf_binfmt);
2394module_exit(exit_elf_binfmt);
2395MODULE_LICENSE("GPL");