Linux进程调用execve,linux内核系统调用函数do_execve()解析实例源码

本文详细分析了Linux内核系统调用`do_execve()`的实现,涉及`sys_execve()`、`open_exec()`、`init_new_context()`等多个关键函数,以及`linux_binprm`和`struct pt_regs`等结构体。通过`do_execve()`,系统调用实现了从用户空间到内核空间的切换,执行新的可执行文件。文章还探讨了内存分配、参数传递和错误处理等方面。
摘要由CSDN通过智能技术生成

linux内核系统调用函数do_execve()解析,彻底解析内核调用用户空间代码入口函数do_execve()

sys_execve() –> do_execve()

/usr/src/linux/fs/exec.c

int do_execve(char * filename,

char __user *__user *argv,

char __user *__user *envp,

struct pt_regs * regs){

struct linux_binprm *bprm;

struct file *file;

int retval;

int i;

retval = -ENOMEM;

bprm = kzalloc(sizeof(*bprm), GFP_KERNEL);

if (!bprm)

goto out_ret;

file = open_exec(filename);

retval = PTR_ERR(file);

if (IS_ERR(file))

goto out_kfree;

sched_exec();

bprm->p = PAGE_SIZE*MAX_ARG_PAGES-sizeof(void *);

bprm->file = file;

bprm->filename = filename;

bprm->interp = filename;

bprm->mm = mm_alloc();

retval = -ENOMEM;

if (!bprm->mm)

goto out_file;

retval = init_new_context(current, bprm->mm);

if (retval < 0)

goto out_mm;

bprm->argc = count(argv, bprm->p / sizeof(void *));

if ((retval = bprm->argc) < 0)

goto out_mm;

bprm->envc = count(envp, bprm->p / sizeof(void *));

if ((retval = bprm->envc) < 0)

goto out_mm;

retval = security_bprm_alloc(bprm);

if (retval)

goto out;

retval = prepare_binprm(bprm);

if (retval < 0)

goto out;

retval = copy_strings_kernel(1, &bprm->filename, bprm);

if (retval < 0)

goto out;

bprm->exec = bprm->p;

retval = copy_strings(bprm->envc, envp, bprm);

if (retval < 0)

goto out;

retval = copy_strings(bprm->argc, argv, bprm);

if (retval < 0)

goto out;

retval = search_binary_handler(bprm,regs);

if (retval >= 0)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值