cregit-Linux how code gets into the kernel

Release 4.12 include/linux/binfmts.h

Directory: include/linux
#ifndef _LINUX_BINFMTS_H

#define _LINUX_BINFMTS_H

#include <linux/sched.h>
#include <linux/unistd.h>
#include <asm/exec.h>
#include <uapi/linux/binfmts.h>

struct filename;


#define CORENAME_MAX_SIZE 128

/*
 * This structure is used to hold the arguments that are used when loading binaries.
 */

struct linux_binprm {
	
char buf[BINPRM_BUF_SIZE];
#ifdef CONFIG_MMU
	
struct vm_area_struct *vma;
	
unsigned long vma_pages;
#else

# define MAX_ARG_PAGES	32
	
struct page *page[MAX_ARG_PAGES];
#endif
	
struct mm_struct *mm;
	
unsigned long p; /* current top of mem */
	unsigned int
		
cred_prepared:1,/* true if creds already prepared (multiple
                                 * preps happen for interpreters) */
		
cap_effective:1;/* true if has elevated effective capabilities,
                                 * false if not; except for init which inherits
                                 * its parent's caps anyway */
#ifdef __alpha__
	
unsigned int taso:1;
#endif
	
unsigned int recursion_depth; /* only for search_binary_handler() */
	
struct file * file;
	
struct cred *cred;	/* new credentials */
	
int unsafe;		/* how unsafe this exec is (mask of LSM_UNSAFE_*) */
	
unsigned int per_clear;	/* bits to clear in current->personality */
	

int argc, envc;
	
const char * filename;	/* Name of binary as seen by procps */
	
const char * interp;	/* Name of the binary really executed. Most
                                   of the time same as filename, but could be
                                   different for binfmt_{misc,script} */
	
unsigned interp_flags;
	
unsigned interp_data;
	

unsigned long loader, exec;
};


#define BINPRM_FLAGS_ENFORCE_NONDUMP_BIT 0

#define BINPRM_FLAGS_ENFORCE_NONDUMP (1 << BINPRM_FLAGS_ENFORCE_NONDUMP_BIT)

/* fd of the binary should be passed to the interpreter */

#define BINPRM_FLAGS_EXECFD_BIT 1

#define BINPRM_FLAGS_EXECFD (1 << BINPRM_FLAGS_EXECFD_BIT)

/* filename of the binary will be inaccessible after exec */

#define BINPRM_FLAGS_PATH_INACCESSIBLE_BIT 2

#define BINPRM_FLAGS_PATH_INACCESSIBLE (1 << BINPRM_FLAGS_PATH_INACCESSIBLE_BIT)

/* Function parameter for binfmt->coredump */

struct coredump_params {
	
const siginfo_t *siginfo;
	
struct pt_regs *regs;
	
struct file *file;
	
unsigned long limit;
	
unsigned long mm_flags;
	
loff_t written;
	
loff_t pos;
};

/*
 * This structure defines the functions that are used to load the binary formats that
 * linux accepts.
 */

struct linux_binfmt {
	
struct list_head lh;
	
struct module *module;
	
int (*load_binary)(struct linux_binprm *);
	
int (*load_shlib)(struct file *);
	
int (*core_dump)(struct coredump_params *cprm);
	
unsigned long min_coredump;	/* minimal dump size */
};

extern void __register_binfmt(struct linux_binfmt *fmt, int insert);

/* Registration of default binfmt handlers */

static inline void register_binfmt(struct linux_binfmt *fmt) { __register_binfmt(fmt, 0); }

Contributors

PersonTokensPropCommitsCommitProp
Ivan Kokshaysky1789.47%150.00%
Al Viro210.53%150.00%
Total19100.00%2100.00%

/* Same as above, but adds a new binfmt at the top of the list */
static inline void insert_binfmt(struct linux_binfmt *fmt) { __register_binfmt(fmt, 1); }

Contributors

PersonTokensPropCommitsCommitProp
Ivan Kokshaysky1789.47%150.00%
Al Viro210.53%150.00%
Total19100.00%2100.00%

extern void unregister_binfmt(struct linux_binfmt *); extern int prepare_binprm(struct linux_binprm *); extern int __must_check remove_arg_zero(struct linux_binprm *); extern int search_binary_handler(struct linux_binprm *); extern int flush_old_exec(struct linux_binprm * bprm); extern void setup_new_exec(struct linux_binprm * bprm); extern void would_dump(struct linux_binprm *, struct file *); extern int suid_dumpable; /* Stack area protections */ #define EXSTACK_DEFAULT 0 /* Whatever the arch defaults to */ #define EXSTACK_DISABLE_X 1 /* Disable executable stacks */ #define EXSTACK_ENABLE_X 2 /* Enable executable stacks */ extern int setup_arg_pages(struct linux_binprm * bprm, unsigned long stack_top, int executable_stack); extern int transfer_args_to_stack(struct linux_binprm *bprm, unsigned long *sp_location); extern int bprm_change_interp(char *interp, struct linux_binprm *bprm); extern int copy_strings_kernel(int argc, const char *const *argv, struct linux_binprm *bprm); extern int prepare_bprm_creds(struct linux_binprm *bprm); extern void install_exec_creds(struct linux_binprm *bprm); extern void set_binfmt(struct linux_binfmt *new); extern ssize_t read_code(struct file *, unsigned long, loff_t, size_t); extern int do_execve(struct filename *, const char __user * const __user *, const char __user * const __user *); extern int do_execveat(int, struct filename *, const char __user * const __user *, const char __user * const __user *, int); #endif /* _LINUX_BINFMTS_H */

Overall Contributors

PersonTokensPropCommitsCommitProp
Linus Torvalds (pre-git)20535.41%1830.00%
Ingo Molnar579.84%11.67%
Al Viro427.25%813.33%
Ivan Kokshaysky417.08%11.67%
David Howells356.04%46.67%
Masami Hiramatsu274.66%23.33%
Andrew Morton254.32%23.33%
Yoav Zach233.97%23.33%
Ollie Wild183.11%11.67%
Oleg Nesterov162.76%46.67%
Kirill A. Shutemov152.59%23.33%
Nico Pitre152.59%11.67%
Linus Torvalds152.59%23.33%
Kees Cook142.42%11.67%
David Drysdale91.55%11.67%
Alan Cox40.69%11.67%
Dan Aloni40.69%11.67%
Mateusz Guzik30.52%11.67%
Denys Vlasenko30.52%11.67%
Alexey Dobriyan30.52%23.33%
Hiroshi Shimamoto20.35%11.67%
Greg Kroah-Hartman10.17%11.67%
Serge E. Hallyn10.17%11.67%
Pavel Emelyanov10.17%11.67%
Total579100.00%60100.00%
Directory: include/linux
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.