]> git.ipfire.org Git - thirdparty/linux.git/blame - fs/binfmt_elf.c
Merge tag 'x86-fpu-2020-06-01' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
[thirdparty/linux.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
DV
1558{
1559 mm_segment_t old_fs = get_fs();
1560 set_fs(KERNEL_DS);
1561 copy_siginfo_to_user((user_siginfo_t __user *) csigdata, siginfo);
1562 set_fs(old_fs);
1563 fill_note(note, "CORE", NT_SIGINFO, sizeof(*csigdata), csigdata);
1564}
1565
2aa362c4
DV
1566#define MAX_FILE_NOTE_SIZE (4*1024*1024)
1567/*
1568 * Format of NT_FILE note:
1569 *
1570 * long count -- how many files are mapped
1571 * long page_size -- units for file_ofs
1572 * array of [COUNT] elements of
1573 * long start
1574 * long end
1575 * long file_ofs
1576 * followed by COUNT filenames in ASCII: "FILE1" NUL "FILE2" NUL...
1577 */
72023656 1578static int fill_files_note(struct memelfnote *note)
2aa362c4 1579{
03c6d723 1580 struct mm_struct *mm = current->mm;
2aa362c4
DV
1581 struct vm_area_struct *vma;
1582 unsigned count, size, names_ofs, remaining, n;
1583 user_long_t *data;
1584 user_long_t *start_end_ofs;
1585 char *name_base, *name_curpos;
1586
1587 /* *Estimated* file count and total data size needed */
03c6d723 1588 count = mm->map_count;
60c9d92f
AD
1589 if (count > UINT_MAX / 64)
1590 return -EINVAL;
2aa362c4
DV
1591 size = count * 64;
1592
1593 names_ofs = (2 + 3 * count) * sizeof(data[0]);
1594 alloc:
1595 if (size >= MAX_FILE_NOTE_SIZE) /* paranoia check */
72023656 1596 return -EINVAL;
2aa362c4 1597 size = round_up(size, PAGE_SIZE);
1fbede6e
AD
1598 /*
1599 * "size" can be 0 here legitimately.
1600 * Let it ENOMEM and omit NT_FILE section which will be empty anyway.
1601 */
86a2bb5a
AD
1602 data = kvmalloc(size, GFP_KERNEL);
1603 if (ZERO_OR_NULL_PTR(data))
72023656 1604 return -ENOMEM;
2aa362c4
DV
1605
1606 start_end_ofs = data + 2;
1607 name_base = name_curpos = ((char *)data) + names_ofs;
1608 remaining = size - names_ofs;
1609 count = 0;
03c6d723 1610 for (vma = mm->mmap; vma != NULL; vma = vma->vm_next) {
2aa362c4
DV
1611 struct file *file;
1612 const char *filename;
1613
1614 file = vma->vm_file;
1615 if (!file)
1616 continue;
9bf39ab2 1617 filename = file_path(file, name_curpos, remaining);
2aa362c4
DV
1618 if (IS_ERR(filename)) {
1619 if (PTR_ERR(filename) == -ENAMETOOLONG) {
86a2bb5a 1620 kvfree(data);
2aa362c4
DV
1621 size = size * 5 / 4;
1622 goto alloc;
1623 }
1624 continue;
1625 }
1626
9bf39ab2 1627 /* file_path() fills at the end, move name down */
2aa362c4
DV
1628 /* n = strlen(filename) + 1: */
1629 n = (name_curpos + remaining) - filename;
1630 remaining = filename - name_curpos;
1631 memmove(name_curpos, filename, n);
1632 name_curpos += n;
1633
1634 *start_end_ofs++ = vma->vm_start;
1635 *start_end_ofs++ = vma->vm_end;
1636 *start_end_ofs++ = vma->vm_pgoff;
1637 count++;
1638 }
1639
1640 /* Now we know exact count of files, can store it */
1641 data[0] = count;
1642 data[1] = PAGE_SIZE;
1643 /*
03c6d723 1644 * Count usually is less than mm->map_count,
2aa362c4
DV
1645 * we need to move filenames down.
1646 */
03c6d723 1647 n = mm->map_count - count;
2aa362c4
DV
1648 if (n != 0) {
1649 unsigned shift_bytes = n * 3 * sizeof(data[0]);
1650 memmove(name_base - shift_bytes, name_base,
1651 name_curpos - name_base);
1652 name_curpos -= shift_bytes;
1653 }
1654
1655 size = name_curpos - (char *)data;
1656 fill_note(note, "CORE", NT_FILE, size, data);
72023656 1657 return 0;
2aa362c4
DV
1658}
1659
4206d3aa
RM
1660#ifdef CORE_DUMP_USE_REGSET
1661#include <linux/regset.h>
1662
1663struct elf_thread_core_info {
1664 struct elf_thread_core_info *next;
1665 struct task_struct *task;
1666 struct elf_prstatus prstatus;
1667 struct memelfnote notes[0];
1668};
1669
1670struct elf_note_info {
1671 struct elf_thread_core_info *thread;
1672 struct memelfnote psinfo;
49ae4d4b 1673 struct memelfnote signote;
4206d3aa 1674 struct memelfnote auxv;
2aa362c4 1675 struct memelfnote files;
49ae4d4b 1676 user_siginfo_t csigdata;
4206d3aa
RM
1677 size_t size;
1678 int thread_notes;
1679};
1680
d31472b6
RM
1681/*
1682 * When a regset has a writeback hook, we call it on each thread before
1683 * dumping user memory. On register window machines, this makes sure the
1684 * user memory backing the register data is up to date before we read it.
1685 */
1686static void do_thread_regset_writeback(struct task_struct *task,
1687 const struct user_regset *regset)
1688{
1689 if (regset->writeback)
1690 regset->writeback(task, regset, 1);
1691}
1692
0953f65d 1693#ifndef PRSTATUS_SIZE
90954e7b 1694#define PRSTATUS_SIZE(S, R) sizeof(S)
0953f65d
L
1695#endif
1696
1697#ifndef SET_PR_FPVALID
90954e7b 1698#define SET_PR_FPVALID(S, V, R) ((S)->pr_fpvalid = (V))
0953f65d
L
1699#endif
1700
4206d3aa
RM
1701static int fill_thread_core_info(struct elf_thread_core_info *t,
1702 const struct user_regset_view *view,
1703 long signr, size_t *total)
1704{
1705 unsigned int i;
27e64b4b 1706 unsigned int regset0_size = regset_size(t->task, &view->regsets[0]);
4206d3aa
RM
1707
1708 /*
1709 * NT_PRSTATUS is the one special case, because the regset data
1710 * goes into the pr_reg field inside the note contents, rather
1711 * than being the whole note contents. We fill the reset in here.
1712 * We assume that regset 0 is NT_PRSTATUS.
1713 */
1714 fill_prstatus(&t->prstatus, t->task, signr);
27e64b4b 1715 (void) view->regsets[0].get(t->task, &view->regsets[0], 0, regset0_size,
90954e7b 1716 &t->prstatus.pr_reg, NULL);
4206d3aa
RM
1717
1718 fill_note(&t->notes[0], "CORE", NT_PRSTATUS,
27e64b4b 1719 PRSTATUS_SIZE(t->prstatus, regset0_size), &t->prstatus);
4206d3aa
RM
1720 *total += notesize(&t->notes[0]);
1721
d31472b6
RM
1722 do_thread_regset_writeback(t->task, &view->regsets[0]);
1723
4206d3aa
RM
1724 /*
1725 * Each other regset might generate a note too. For each regset
1726 * that has no core_note_type or is inactive, we leave t->notes[i]
1727 * all zero and we'll know to skip writing it later.
1728 */
1729 for (i = 1; i < view->n; ++i) {
1730 const struct user_regset *regset = &view->regsets[i];
d31472b6 1731 do_thread_regset_writeback(t->task, regset);
c8e25258 1732 if (regset->core_note_type && regset->get &&
2f819db5 1733 (!regset->active || regset->active(t->task, regset) > 0)) {
4206d3aa 1734 int ret;
27e64b4b 1735 size_t size = regset_size(t->task, regset);
1d605416 1736 void *data = kzalloc(size, GFP_KERNEL);
4206d3aa
RM
1737 if (unlikely(!data))
1738 return 0;
1739 ret = regset->get(t->task, regset,
1740 0, size, data, NULL);
1741 if (unlikely(ret))
1742 kfree(data);
1743 else {
1744 if (regset->core_note_type != NT_PRFPREG)
1745 fill_note(&t->notes[i], "LINUX",
1746 regset->core_note_type,
1747 size, data);
1748 else {
90954e7b 1749 SET_PR_FPVALID(&t->prstatus,
27e64b4b 1750 1, regset0_size);
4206d3aa
RM
1751 fill_note(&t->notes[i], "CORE",
1752 NT_PRFPREG, size, data);
1753 }
1754 *total += notesize(&t->notes[i]);
1755 }
1756 }
1757 }
1758
1759 return 1;
1760}
1761
1762static int fill_note_info(struct elfhdr *elf, int phdrs,
1763 struct elf_note_info *info,
ae7795bc 1764 const kernel_siginfo_t *siginfo, struct pt_regs *regs)
4206d3aa
RM
1765{
1766 struct task_struct *dump_task = current;
1767 const struct user_regset_view *view = task_user_regset_view(dump_task);
1768 struct elf_thread_core_info *t;
1769 struct elf_prpsinfo *psinfo;
83914441 1770 struct core_thread *ct;
4206d3aa
RM
1771 unsigned int i;
1772
1773 info->size = 0;
1774 info->thread = NULL;
1775
1776 psinfo = kmalloc(sizeof(*psinfo), GFP_KERNEL);
6899e92d
AC
1777 if (psinfo == NULL) {
1778 info->psinfo.data = NULL; /* So we don't free this wrongly */
4206d3aa 1779 return 0;
6899e92d 1780 }
4206d3aa 1781
e2dbe125
AW
1782 fill_note(&info->psinfo, "CORE", NT_PRPSINFO, sizeof(*psinfo), psinfo);
1783
4206d3aa
RM
1784 /*
1785 * Figure out how many notes we're going to need for each thread.
1786 */
1787 info->thread_notes = 0;
1788 for (i = 0; i < view->n; ++i)
1789 if (view->regsets[i].core_note_type != 0)
1790 ++info->thread_notes;
1791
1792 /*
1793 * Sanity check. We rely on regset 0 being in NT_PRSTATUS,
1794 * since it is our one special case.
1795 */
1796 if (unlikely(info->thread_notes == 0) ||
1797 unlikely(view->regsets[0].core_note_type != NT_PRSTATUS)) {
1798 WARN_ON(1);
1799 return 0;
1800 }
1801
1802 /*
1803 * Initialize the ELF file header.
1804 */
1805 fill_elf_header(elf, phdrs,
d3330cf0 1806 view->e_machine, view->e_flags);
4206d3aa
RM
1807
1808 /*
1809 * Allocate a structure for each thread.
1810 */
83914441
ON
1811 for (ct = &dump_task->mm->core_state->dumper; ct; ct = ct->next) {
1812 t = kzalloc(offsetof(struct elf_thread_core_info,
1813 notes[info->thread_notes]),
1814 GFP_KERNEL);
1815 if (unlikely(!t))
1816 return 0;
1817
1818 t->task = ct->task;
1819 if (ct->task == dump_task || !info->thread) {
1820 t->next = info->thread;
1821 info->thread = t;
1822 } else {
1823 /*
1824 * Make sure to keep the original task at
1825 * the head of the list.
1826 */
1827 t->next = info->thread->next;
1828 info->thread->next = t;
4206d3aa 1829 }
83914441 1830 }
4206d3aa
RM
1831
1832 /*
1833 * Now fill in each thread's information.
1834 */
1835 for (t = info->thread; t != NULL; t = t->next)
5ab1c309 1836 if (!fill_thread_core_info(t, view, siginfo->si_signo, &info->size))
4206d3aa
RM
1837 return 0;
1838
1839 /*
1840 * Fill in the two process-wide notes.
1841 */
1842 fill_psinfo(psinfo, dump_task->group_leader, dump_task->mm);
1843 info->size += notesize(&info->psinfo);
1844
49ae4d4b
DV
1845 fill_siginfo_note(&info->signote, &info->csigdata, siginfo);
1846 info->size += notesize(&info->signote);
1847
4206d3aa
RM
1848 fill_auxv_note(&info->auxv, current->mm);
1849 info->size += notesize(&info->auxv);
1850
72023656
DA
1851 if (fill_files_note(&info->files) == 0)
1852 info->size += notesize(&info->files);
2aa362c4 1853
4206d3aa
RM
1854 return 1;
1855}
1856
1857static size_t get_note_info_size(struct elf_note_info *info)
1858{
1859 return info->size;
1860}
1861
1862/*
1863 * Write all the notes for each thread. When writing the first thread, the
1864 * process-wide notes are interleaved after the first thread-specific note.
1865 */
1866static int write_note_info(struct elf_note_info *info,
ecc8c772 1867 struct coredump_params *cprm)
4206d3aa 1868{
b219e25f 1869 bool first = true;
4206d3aa
RM
1870 struct elf_thread_core_info *t = info->thread;
1871
1872 do {
1873 int i;
1874
ecc8c772 1875 if (!writenote(&t->notes[0], cprm))
4206d3aa
RM
1876 return 0;
1877
ecc8c772 1878 if (first && !writenote(&info->psinfo, cprm))
4206d3aa 1879 return 0;
ecc8c772 1880 if (first && !writenote(&info->signote, cprm))
49ae4d4b 1881 return 0;
ecc8c772 1882 if (first && !writenote(&info->auxv, cprm))
4206d3aa 1883 return 0;
72023656 1884 if (first && info->files.data &&
ecc8c772 1885 !writenote(&info->files, cprm))
2aa362c4 1886 return 0;
4206d3aa
RM
1887
1888 for (i = 1; i < info->thread_notes; ++i)
1889 if (t->notes[i].data &&
ecc8c772 1890 !writenote(&t->notes[i], cprm))
4206d3aa
RM
1891 return 0;
1892
b219e25f 1893 first = false;
4206d3aa
RM
1894 t = t->next;
1895 } while (t);
1896
1897 return 1;
1898}
1899
1900static void free_note_info(struct elf_note_info *info)
1901{
1902 struct elf_thread_core_info *threads = info->thread;
1903 while (threads) {
1904 unsigned int i;
1905 struct elf_thread_core_info *t = threads;
1906 threads = t->next;
1907 WARN_ON(t->notes[0].data && t->notes[0].data != &t->prstatus);
1908 for (i = 1; i < info->thread_notes; ++i)
1909 kfree(t->notes[i].data);
1910 kfree(t);
1911 }
1912 kfree(info->psinfo.data);
86a2bb5a 1913 kvfree(info->files.data);
4206d3aa
RM
1914}
1915
1916#else
1917
1da177e4
LT
1918/* Here is the structure in which status of each thread is captured. */
1919struct elf_thread_status
1920{
1921 struct list_head list;
1922 struct elf_prstatus prstatus; /* NT_PRSTATUS */
1923 elf_fpregset_t fpu; /* NT_PRFPREG */
1924 struct task_struct *thread;
1925#ifdef ELF_CORE_COPY_XFPREGS
5b20cd80 1926 elf_fpxregset_t xfpu; /* ELF_CORE_XFPREG_TYPE */
1da177e4
LT
1927#endif
1928 struct memelfnote notes[3];
1929 int num_notes;
1930};
1931
1932/*
1933 * In order to add the specific thread information for the elf file format,
f4e5cc2c
JJ
1934 * we need to keep a linked list of every threads pr_status and then create
1935 * a single section for them in the final core file.
1da177e4
LT
1936 */
1937static int elf_dump_thread_status(long signr, struct elf_thread_status *t)
1938{
1939 int sz = 0;
1940 struct task_struct *p = t->thread;
1941 t->num_notes = 0;
1942
1943 fill_prstatus(&t->prstatus, p, signr);
1944 elf_core_copy_task_regs(p, &t->prstatus.pr_reg);
1945
f4e5cc2c
JJ
1946 fill_note(&t->notes[0], "CORE", NT_PRSTATUS, sizeof(t->prstatus),
1947 &(t->prstatus));
1da177e4
LT
1948 t->num_notes++;
1949 sz += notesize(&t->notes[0]);
1950
f4e5cc2c
JJ
1951 if ((t->prstatus.pr_fpvalid = elf_core_copy_task_fpregs(p, NULL,
1952 &t->fpu))) {
1953 fill_note(&t->notes[1], "CORE", NT_PRFPREG, sizeof(t->fpu),
1954 &(t->fpu));
1da177e4
LT
1955 t->num_notes++;
1956 sz += notesize(&t->notes[1]);
1957 }
1958
1959#ifdef ELF_CORE_COPY_XFPREGS
1960 if (elf_core_copy_task_xfpregs(p, &t->xfpu)) {
5b20cd80
MN
1961 fill_note(&t->notes[2], "LINUX", ELF_CORE_XFPREG_TYPE,
1962 sizeof(t->xfpu), &t->xfpu);
1da177e4
LT
1963 t->num_notes++;
1964 sz += notesize(&t->notes[2]);
1965 }
1966#endif
1967 return sz;
1968}
1969
3aba481f
RM
1970struct elf_note_info {
1971 struct memelfnote *notes;
72023656 1972 struct memelfnote *notes_files;
3aba481f
RM
1973 struct elf_prstatus *prstatus; /* NT_PRSTATUS */
1974 struct elf_prpsinfo *psinfo; /* NT_PRPSINFO */
1975 struct list_head thread_list;
1976 elf_fpregset_t *fpu;
1977#ifdef ELF_CORE_COPY_XFPREGS
1978 elf_fpxregset_t *xfpu;
1979#endif
49ae4d4b 1980 user_siginfo_t csigdata;
3aba481f
RM
1981 int thread_status_size;
1982 int numnote;
1983};
1984
0cf062d0 1985static int elf_note_info_init(struct elf_note_info *info)
3aba481f 1986{
0cf062d0 1987 memset(info, 0, sizeof(*info));
3aba481f
RM
1988 INIT_LIST_HEAD(&info->thread_list);
1989
49ae4d4b 1990 /* Allocate space for ELF notes */
6da2ec56 1991 info->notes = kmalloc_array(8, sizeof(struct memelfnote), GFP_KERNEL);
3aba481f
RM
1992 if (!info->notes)
1993 return 0;
1994 info->psinfo = kmalloc(sizeof(*info->psinfo), GFP_KERNEL);
1995 if (!info->psinfo)
f34f9d18 1996 return 0;
3aba481f
RM
1997 info->prstatus = kmalloc(sizeof(*info->prstatus), GFP_KERNEL);
1998 if (!info->prstatus)
f34f9d18 1999 return 0;
3aba481f
RM
2000 info->fpu = kmalloc(sizeof(*info->fpu), GFP_KERNEL);
2001 if (!info->fpu)
f34f9d18 2002 return 0;
3aba481f
RM
2003#ifdef ELF_CORE_COPY_XFPREGS
2004 info->xfpu = kmalloc(sizeof(*info->xfpu), GFP_KERNEL);
2005 if (!info->xfpu)
f34f9d18 2006 return 0;
3aba481f 2007#endif
0cf062d0 2008 return 1;
0cf062d0
AW
2009}
2010
2011static int fill_note_info(struct elfhdr *elf, int phdrs,
2012 struct elf_note_info *info,
ae7795bc 2013 const kernel_siginfo_t *siginfo, struct pt_regs *regs)
0cf062d0 2014{
afabada9
AV
2015 struct core_thread *ct;
2016 struct elf_thread_status *ets;
0cf062d0
AW
2017
2018 if (!elf_note_info_init(info))
2019 return 0;
3aba481f 2020
afabada9
AV
2021 for (ct = current->mm->core_state->dumper.next;
2022 ct; ct = ct->next) {
2023 ets = kzalloc(sizeof(*ets), GFP_KERNEL);
2024 if (!ets)
2025 return 0;
83914441 2026
afabada9
AV
2027 ets->thread = ct->task;
2028 list_add(&ets->list, &info->thread_list);
2029 }
83914441 2030
93f044e2 2031 list_for_each_entry(ets, &info->thread_list, list) {
afabada9 2032 int sz;
3aba481f 2033
afabada9
AV
2034 sz = elf_dump_thread_status(siginfo->si_signo, ets);
2035 info->thread_status_size += sz;
3aba481f
RM
2036 }
2037 /* now collect the dump for the current */
2038 memset(info->prstatus, 0, sizeof(*info->prstatus));
5ab1c309 2039 fill_prstatus(info->prstatus, current, siginfo->si_signo);
3aba481f
RM
2040 elf_core_copy_regs(&info->prstatus->pr_reg, regs);
2041
2042 /* Set up header */
d3330cf0 2043 fill_elf_header(elf, phdrs, ELF_ARCH, ELF_CORE_EFLAGS);
3aba481f
RM
2044
2045 /*
2046 * Set up the notes in similar form to SVR4 core dumps made
2047 * with info from their /proc.
2048 */
2049
2050 fill_note(info->notes + 0, "CORE", NT_PRSTATUS,
2051 sizeof(*info->prstatus), info->prstatus);
2052 fill_psinfo(info->psinfo, current->group_leader, current->mm);
2053 fill_note(info->notes + 1, "CORE", NT_PRPSINFO,
2054 sizeof(*info->psinfo), info->psinfo);
2055
2aa362c4
DV
2056 fill_siginfo_note(info->notes + 2, &info->csigdata, siginfo);
2057 fill_auxv_note(info->notes + 3, current->mm);
72023656 2058 info->numnote = 4;
3aba481f 2059
72023656
DA
2060 if (fill_files_note(info->notes + info->numnote) == 0) {
2061 info->notes_files = info->notes + info->numnote;
2062 info->numnote++;
2063 }
3aba481f
RM
2064
2065 /* Try to dump the FPU. */
2066 info->prstatus->pr_fpvalid = elf_core_copy_task_fpregs(current, regs,
2067 info->fpu);
2068 if (info->prstatus->pr_fpvalid)
2069 fill_note(info->notes + info->numnote++,
2070 "CORE", NT_PRFPREG, sizeof(*info->fpu), info->fpu);
2071#ifdef ELF_CORE_COPY_XFPREGS
2072 if (elf_core_copy_task_xfpregs(current, info->xfpu))
2073 fill_note(info->notes + info->numnote++,
2074 "LINUX", ELF_CORE_XFPREG_TYPE,
2075 sizeof(*info->xfpu), info->xfpu);
2076#endif
2077
2078 return 1;
3aba481f
RM
2079}
2080
2081static size_t get_note_info_size(struct elf_note_info *info)
2082{
2083 int sz = 0;
2084 int i;
2085
2086 for (i = 0; i < info->numnote; i++)
2087 sz += notesize(info->notes + i);
2088
2089 sz += info->thread_status_size;
2090
2091 return sz;
2092}
2093
2094static int write_note_info(struct elf_note_info *info,
ecc8c772 2095 struct coredump_params *cprm)
3aba481f 2096{
93f044e2 2097 struct elf_thread_status *ets;
3aba481f 2098 int i;
3aba481f
RM
2099
2100 for (i = 0; i < info->numnote; i++)
ecc8c772 2101 if (!writenote(info->notes + i, cprm))
3aba481f
RM
2102 return 0;
2103
2104 /* write out the thread status notes section */
93f044e2
AD
2105 list_for_each_entry(ets, &info->thread_list, list) {
2106 for (i = 0; i < ets->num_notes; i++)
2107 if (!writenote(&ets->notes[i], cprm))
3aba481f
RM
2108 return 0;
2109 }
2110
2111 return 1;
2112}
2113
2114static void free_note_info(struct elf_note_info *info)
2115{
2116 while (!list_empty(&info->thread_list)) {
2117 struct list_head *tmp = info->thread_list.next;
2118 list_del(tmp);
2119 kfree(list_entry(tmp, struct elf_thread_status, list));
2120 }
2121
72023656
DA
2122 /* Free data possibly allocated by fill_files_note(): */
2123 if (info->notes_files)
86a2bb5a 2124 kvfree(info->notes_files->data);
2aa362c4 2125
3aba481f
RM
2126 kfree(info->prstatus);
2127 kfree(info->psinfo);
2128 kfree(info->notes);
2129 kfree(info->fpu);
2130#ifdef ELF_CORE_COPY_XFPREGS
2131 kfree(info->xfpu);
2132#endif
2133}
2134
4206d3aa
RM
2135#endif
2136
f47aef55
RM
2137static struct vm_area_struct *first_vma(struct task_struct *tsk,
2138 struct vm_area_struct *gate_vma)
2139{
2140 struct vm_area_struct *ret = tsk->mm->mmap;
2141
2142 if (ret)
2143 return ret;
2144 return gate_vma;
2145}
2146/*
2147 * Helper function for iterating across a vma list. It ensures that the caller
2148 * will visit `gate_vma' prior to terminating the search.
2149 */
2150static struct vm_area_struct *next_vma(struct vm_area_struct *this_vma,
2151 struct vm_area_struct *gate_vma)
2152{
2153 struct vm_area_struct *ret;
2154
2155 ret = this_vma->vm_next;
2156 if (ret)
2157 return ret;
2158 if (this_vma == gate_vma)
2159 return NULL;
2160 return gate_vma;
2161}
2162
8d9032bb
DH
2163static void fill_extnum_info(struct elfhdr *elf, struct elf_shdr *shdr4extnum,
2164 elf_addr_t e_shoff, int segs)
2165{
2166 elf->e_shoff = e_shoff;
2167 elf->e_shentsize = sizeof(*shdr4extnum);
2168 elf->e_shnum = 1;
2169 elf->e_shstrndx = SHN_UNDEF;
2170
2171 memset(shdr4extnum, 0, sizeof(*shdr4extnum));
2172
2173 shdr4extnum->sh_type = SHT_NULL;
2174 shdr4extnum->sh_size = elf->e_shnum;
2175 shdr4extnum->sh_link = elf->e_shstrndx;
2176 shdr4extnum->sh_info = segs;
2177}
2178
1da177e4
LT
2179/*
2180 * Actual dumper
2181 *
2182 * This is a two-pass process; first we find the offsets of the bits,
2183 * and then they are actually written out. If we run out of core limit
2184 * we just truncate.
2185 */
f6151dfe 2186static int elf_core_dump(struct coredump_params *cprm)
1da177e4 2187{
1da177e4
LT
2188 int has_dumped = 0;
2189 mm_segment_t fs;
52f5592e
JL
2190 int segs, i;
2191 size_t vma_data_size = 0;
f47aef55 2192 struct vm_area_struct *vma, *gate_vma;
225a3f53 2193 struct elfhdr elf;
cdc3d562 2194 loff_t offset = 0, dataoff;
72023656 2195 struct elf_note_info info = { };
93eb211e 2196 struct elf_phdr *phdr4note = NULL;
8d9032bb
DH
2197 struct elf_shdr *shdr4extnum = NULL;
2198 Elf_Half e_phnum;
2199 elf_addr_t e_shoff;
52f5592e 2200 elf_addr_t *vma_filesz = NULL;
1da177e4
LT
2201
2202 /*
2203 * We no longer stop all VM operations.
2204 *
f4e5cc2c
JJ
2205 * This is because those proceses that could possibly change map_count
2206 * or the mmap / vma pages are now blocked in do_exit on current
2207 * finishing this core dump.
1da177e4
LT
2208 *
2209 * Only ptrace can touch these memory addresses, but it doesn't change
f4e5cc2c 2210 * the map_count or the pages allocated. So no possibility of crashing
1da177e4
LT
2211 * exists while dumping the mm->vm_next areas to the core file.
2212 */
2213
341c87bf
KH
2214 /*
2215 * The number of segs are recored into ELF header as 16bit value.
2216 * Please check DEFAULT_MAX_MAP_COUNT definition when you modify here.
2217 */
1da177e4 2218 segs = current->mm->map_count;
1fcccbac 2219 segs += elf_core_extra_phdrs();
1da177e4 2220
31db58b3 2221 gate_vma = get_gate_vma(current->mm);
f47aef55
RM
2222 if (gate_vma != NULL)
2223 segs++;
2224
8d9032bb
DH
2225 /* for notes section */
2226 segs++;
2227
2228 /* If segs > PN_XNUM(0xffff), then e_phnum overflows. To avoid
2229 * this, kernel supports extended numbering. Have a look at
2230 * include/linux/elf.h for further information. */
2231 e_phnum = segs > PN_XNUM ? PN_XNUM : segs;
2232
1da177e4 2233 /*
3aba481f
RM
2234 * Collect all the non-memory information about the process for the
2235 * notes. This also sets up the file header.
1da177e4 2236 */
225a3f53 2237 if (!fill_note_info(&elf, e_phnum, &info, cprm->siginfo, cprm->regs))
3aba481f 2238 goto cleanup;
1da177e4 2239
3aba481f 2240 has_dumped = 1;
079148b9 2241
1da177e4
LT
2242 fs = get_fs();
2243 set_fs(KERNEL_DS);
2244
225a3f53 2245 offset += sizeof(elf); /* Elf header */
8d9032bb 2246 offset += segs * sizeof(struct elf_phdr); /* Program headers */
1da177e4
LT
2247
2248 /* Write notes phdr entry */
2249 {
3aba481f 2250 size_t sz = get_note_info_size(&info);
1da177e4 2251
e5501492 2252 sz += elf_coredump_extra_notes_size();
bf1ab978 2253
93eb211e
DH
2254 phdr4note = kmalloc(sizeof(*phdr4note), GFP_KERNEL);
2255 if (!phdr4note)
088e7af7 2256 goto end_coredump;
93eb211e
DH
2257
2258 fill_elf_note_phdr(phdr4note, sz, offset);
2259 offset += sz;
1da177e4
LT
2260 }
2261
1da177e4
LT
2262 dataoff = offset = roundup(offset, ELF_EXEC_PAGESIZE);
2263
1fbede6e
AD
2264 /*
2265 * Zero vma process will get ZERO_SIZE_PTR here.
2266 * Let coredump continue for register state at least.
2267 */
86a2bb5a
AD
2268 vma_filesz = kvmalloc(array_size(sizeof(*vma_filesz), (segs - 1)),
2269 GFP_KERNEL);
1fbede6e 2270 if (!vma_filesz)
52f5592e
JL
2271 goto end_coredump;
2272
2273 for (i = 0, vma = first_vma(current, gate_vma); vma != NULL;
2274 vma = next_vma(vma, gate_vma)) {
2275 unsigned long dump_size;
2276
2277 dump_size = vma_dump_size(vma, cprm->mm_flags);
2278 vma_filesz[i++] = dump_size;
2279 vma_data_size += dump_size;
2280 }
2281
2282 offset += vma_data_size;
8d9032bb
DH
2283 offset += elf_core_extra_data_size();
2284 e_shoff = offset;
2285
2286 if (e_phnum == PN_XNUM) {
2287 shdr4extnum = kmalloc(sizeof(*shdr4extnum), GFP_KERNEL);
2288 if (!shdr4extnum)
2289 goto end_coredump;
225a3f53 2290 fill_extnum_info(&elf, shdr4extnum, e_shoff, segs);
8d9032bb
DH
2291 }
2292
2293 offset = dataoff;
2294
225a3f53 2295 if (!dump_emit(cprm, &elf, sizeof(elf)))
93eb211e
DH
2296 goto end_coredump;
2297
ecc8c772 2298 if (!dump_emit(cprm, phdr4note, sizeof(*phdr4note)))
93eb211e
DH
2299 goto end_coredump;
2300
1da177e4 2301 /* Write program headers for segments dump */
52f5592e 2302 for (i = 0, vma = first_vma(current, gate_vma); vma != NULL;
f47aef55 2303 vma = next_vma(vma, gate_vma)) {
1da177e4 2304 struct elf_phdr phdr;
1da177e4
LT
2305
2306 phdr.p_type = PT_LOAD;
2307 phdr.p_offset = offset;
2308 phdr.p_vaddr = vma->vm_start;
2309 phdr.p_paddr = 0;
52f5592e 2310 phdr.p_filesz = vma_filesz[i++];
82df3973 2311 phdr.p_memsz = vma->vm_end - vma->vm_start;
1da177e4
LT
2312 offset += phdr.p_filesz;
2313 phdr.p_flags = vma->vm_flags & VM_READ ? PF_R : 0;
f4e5cc2c
JJ
2314 if (vma->vm_flags & VM_WRITE)
2315 phdr.p_flags |= PF_W;
2316 if (vma->vm_flags & VM_EXEC)
2317 phdr.p_flags |= PF_X;
1da177e4
LT
2318 phdr.p_align = ELF_EXEC_PAGESIZE;
2319
ecc8c772 2320 if (!dump_emit(cprm, &phdr, sizeof(phdr)))
088e7af7 2321 goto end_coredump;
1da177e4
LT
2322 }
2323
506f21c5 2324 if (!elf_core_write_extra_phdrs(cprm, offset))
1fcccbac 2325 goto end_coredump;
1da177e4
LT
2326
2327 /* write out the notes section */
ecc8c772 2328 if (!write_note_info(&info, cprm))
3aba481f 2329 goto end_coredump;
1da177e4 2330
cdc3d562 2331 if (elf_coredump_extra_notes_write(cprm))
e5501492 2332 goto end_coredump;
bf1ab978 2333
d025c9db 2334 /* Align to page */
1607f09c 2335 if (!dump_skip(cprm, dataoff - cprm->pos))
f3e8fccd 2336 goto end_coredump;
1da177e4 2337
52f5592e 2338 for (i = 0, vma = first_vma(current, gate_vma); vma != NULL;
f47aef55 2339 vma = next_vma(vma, gate_vma)) {
1da177e4 2340 unsigned long addr;
82df3973 2341 unsigned long end;
1da177e4 2342
52f5592e 2343 end = vma->vm_start + vma_filesz[i++];
1da177e4 2344
82df3973 2345 for (addr = vma->vm_start; addr < end; addr += PAGE_SIZE) {
f4e5cc2c 2346 struct page *page;
f3e8fccd
HD
2347 int stop;
2348
2349 page = get_dump_page(addr);
2350 if (page) {
2351 void *kaddr = kmap(page);
13046ece 2352 stop = !dump_emit(cprm, kaddr, PAGE_SIZE);
f3e8fccd 2353 kunmap(page);
09cbfeaf 2354 put_page(page);
f3e8fccd 2355 } else
9b56d543 2356 stop = !dump_skip(cprm, PAGE_SIZE);
f3e8fccd
HD
2357 if (stop)
2358 goto end_coredump;
1da177e4
LT
2359 }
2360 }
4d22c75d 2361 dump_truncate(cprm);
1da177e4 2362
aa3e7eaf 2363 if (!elf_core_write_extra_data(cprm))
1fcccbac 2364 goto end_coredump;
1da177e4 2365
8d9032bb 2366 if (e_phnum == PN_XNUM) {
13046ece 2367 if (!dump_emit(cprm, shdr4extnum, sizeof(*shdr4extnum)))
8d9032bb
DH
2368 goto end_coredump;
2369 }
2370
1da177e4
LT
2371end_coredump:
2372 set_fs(fs);
2373
2374cleanup:
3aba481f 2375 free_note_info(&info);
8d9032bb 2376 kfree(shdr4extnum);
86a2bb5a 2377 kvfree(vma_filesz);
93eb211e 2378 kfree(phdr4note);
1da177e4 2379 return has_dumped;
1da177e4
LT
2380}
2381
698ba7b5 2382#endif /* CONFIG_ELF_CORE */
1da177e4
LT
2383
2384static int __init init_elf_binfmt(void)
2385{
8fc3dc5a
AV
2386 register_binfmt(&elf_format);
2387 return 0;
1da177e4
LT
2388}
2389
2390static void __exit exit_elf_binfmt(void)
2391{
2392 /* Remove the COFF and ELF loaders. */
2393 unregister_binfmt(&elf_format);
2394}
2395
2396core_initcall(init_elf_binfmt);
2397module_exit(exit_elf_binfmt);
2398MODULE_LICENSE("GPL");