blob: 7394b5b349ffc82c2ea42e51188dc3839229fed1 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _LINUX_BINFMTS_H
2#define _LINUX_BINFMTS_H
3
4#include <linux/capability.h>
5
6struct pt_regs;
7
8/*
Ollie Wildb6a2fea2007-07-19 01:48:16 -07009 * These are the maximum length and maximum number of strings passed to the
10 * execve() system call. MAX_ARG_STRLEN is essentially random but serves to
11 * prevent the kernel from being unduly impacted by misaddressed pointers.
12 * MAX_ARG_STRINGS is chosen to fit in a signed 32-bit integer.
Linus Torvalds1da177e2005-04-16 15:20:36 -070013 */
Ollie Wildb6a2fea2007-07-19 01:48:16 -070014#define MAX_ARG_STRLEN (PAGE_SIZE * 32)
15#define MAX_ARG_STRINGS 0x7FFFFFFF
Linus Torvalds1da177e2005-04-16 15:20:36 -070016
17/* sizeof(linux_binprm->buf) */
18#define BINPRM_BUF_SIZE 128
19
20#ifdef __KERNEL__
21
Dan Aloni71ce92f2007-05-16 22:11:16 -070022#define CORENAME_MAX_SIZE 128
23
Linus Torvalds1da177e2005-04-16 15:20:36 -070024/*
25 * This structure is used to hold the arguments that are used when loading binaries.
26 */
27struct linux_binprm{
28 char buf[BINPRM_BUF_SIZE];
Ollie Wildb6a2fea2007-07-19 01:48:16 -070029#ifdef CONFIG_MMU
30 struct vm_area_struct *vma;
31#else
32# define MAX_ARG_PAGES 32
Linus Torvalds1da177e2005-04-16 15:20:36 -070033 struct page *page[MAX_ARG_PAGES];
Ollie Wildb6a2fea2007-07-19 01:48:16 -070034#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070035 struct mm_struct *mm;
36 unsigned long p; /* current top of mem */
Pavel Emelyanov3a2e7f42008-04-29 00:59:24 -070037 unsigned int sh_bang:1,
38 misc_bang:1;
Kirill A. Shutemov53112482008-10-15 22:02:37 -070039#ifdef __alpha__
40 unsigned int taso:1;
41#endif
Kirill A. Shutemovbf2a9a32008-10-15 22:02:39 -070042 unsigned int recursion_depth;
Linus Torvalds1da177e2005-04-16 15:20:36 -070043 struct file * file;
44 int e_uid, e_gid;
Andrew G. Morgan5459c162008-07-23 21:28:24 -070045 kernel_cap_t cap_post_exec_permitted;
Serge E. Hallynb5376772007-10-16 23:31:36 -070046 bool cap_effective;
Linus Torvalds1da177e2005-04-16 15:20:36 -070047 void *security;
48 int argc, envc;
49 char * filename; /* Name of binary as seen by procps */
50 char * interp; /* Name of the binary really executed. Most
51 of the time same as filename, but could be
52 different for binfmt_{misc,script} */
53 unsigned interp_flags;
54 unsigned interp_data;
55 unsigned long loader, exec;
56};
57
58#define BINPRM_FLAGS_ENFORCE_NONDUMP_BIT 0
59#define BINPRM_FLAGS_ENFORCE_NONDUMP (1 << BINPRM_FLAGS_ENFORCE_NONDUMP_BIT)
60
61/* fd of the binary should be passed to the interpreter */
62#define BINPRM_FLAGS_EXECFD_BIT 1
63#define BINPRM_FLAGS_EXECFD (1 << BINPRM_FLAGS_EXECFD_BIT)
64
Kirill A. Shutemovbf2a9a32008-10-15 22:02:39 -070065#define BINPRM_MAX_RECURSION 4
Linus Torvalds1da177e2005-04-16 15:20:36 -070066
67/*
68 * This structure defines the functions that are used to load the binary formats that
69 * linux accepts.
70 */
71struct linux_binfmt {
Alexey Dobriyane4dc1b12007-10-16 23:26:03 -070072 struct list_head lh;
Linus Torvalds1da177e2005-04-16 15:20:36 -070073 struct module *module;
74 int (*load_binary)(struct linux_binprm *, struct pt_regs * regs);
75 int (*load_shlib)(struct file *);
Neil Horman7dc0b222007-10-16 23:26:34 -070076 int (*core_dump)(long signr, struct pt_regs *regs, struct file *file, unsigned long limit);
Linus Torvalds1da177e2005-04-16 15:20:36 -070077 unsigned long min_coredump; /* minimal dump size */
Andi Kleen9fbbd4d2007-02-13 13:26:26 +010078 int hasvdso;
Linus Torvalds1da177e2005-04-16 15:20:36 -070079};
80
81extern int register_binfmt(struct linux_binfmt *);
Alexey Dobriyanf6b450d2007-10-16 23:26:04 -070082extern void unregister_binfmt(struct linux_binfmt *);
Linus Torvalds1da177e2005-04-16 15:20:36 -070083
84extern int prepare_binprm(struct linux_binprm *);
Ollie Wildb6a2fea2007-07-19 01:48:16 -070085extern int __must_check remove_arg_zero(struct linux_binprm *);
Linus Torvalds1da177e2005-04-16 15:20:36 -070086extern int search_binary_handler(struct linux_binprm *,struct pt_regs *);
87extern int flush_old_exec(struct linux_binprm * bprm);
88
Alan Coxd6e71142005-06-23 00:09:43 -070089extern int suid_dumpable;
90#define SUID_DUMP_DISABLE 0 /* No setuid dumping */
91#define SUID_DUMP_USER 1 /* Dump as user of process */
92#define SUID_DUMP_ROOT 2 /* Dump as root */
93
Linus Torvalds1da177e2005-04-16 15:20:36 -070094/* Stack area protections */
95#define EXSTACK_DEFAULT 0 /* Whatever the arch defaults to */
96#define EXSTACK_DISABLE_X 1 /* Disable executable stacks */
97#define EXSTACK_ENABLE_X 2 /* Enable executable stacks */
98
99extern int setup_arg_pages(struct linux_binprm * bprm,
100 unsigned long stack_top,
101 int executable_stack);
Ollie Wildb6a2fea2007-07-19 01:48:16 -0700102extern int bprm_mm_init(struct linux_binprm *bprm);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700103extern int copy_strings_kernel(int argc,char ** argv,struct linux_binprm *bprm);
104extern void compute_creds(struct linux_binprm *binprm);
105extern int do_coredump(long signr, int exit_code, struct pt_regs * regs);
106extern int set_binfmt(struct linux_binfmt *new);
Al Viro08a6fac2008-05-10 16:38:25 -0400107extern void free_bprm(struct linux_binprm *);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700108
109#endif /* __KERNEL__ */
110#endif /* _LINUX_BINFMTS_H */