| tag | line | file | source code |
| bprm | 51 | fs/binfmt_elf.c | static int load_elf_binary(struct linux_binprm * bprm, struct pt_regs * regs); |
| bprm | 340 | fs/binfmt_elf.c | load_elf_binary(struct linux_binprm * bprm, struct pt_regs * regs) |
| bprm | 369 | fs/binfmt_elf.c | elf_ex = *((struct elfhdr *) bprm->buf); /* exec-header */ |
| bprm | 382 | fs/binfmt_elf.c | (!bprm->inode->i_op || !bprm->inode->i_op->default_file_ops || |
| bprm | 383 | fs/binfmt_elf.c | !bprm->inode->i_op->default_file_ops->mmap)){ |
| bprm | 397 | fs/binfmt_elf.c | retval = read_exec(bprm->inode, elf_ex.e_phoff, (char *) elf_phdata, |
| bprm | 410 | fs/binfmt_elf.c | elf_exec_fileno = open_inode(bprm->inode, O_RDONLY); |
| bprm | 439 | fs/binfmt_elf.c | retval = read_exec(bprm->inode,elf_ppnt->p_offset,elf_interpreter, |
| bprm | 458 | fs/binfmt_elf.c | retval = read_exec(interpreter_inode,0,bprm->buf,128, 1); |
| bprm | 461 | fs/binfmt_elf.c | interp_ex = *((struct exec *) bprm->buf); /* exec-header */ |
| bprm | 462 | fs/binfmt_elf.c | interp_elf_ex = *((struct elfhdr *) bprm->buf); /* exec-header */ |
| bprm | 506 | fs/binfmt_elf.c | if (!bprm->sh_bang) { |
| bprm | 514 | fs/binfmt_elf.c | bprm->p = copy_strings(1,&passed_p,bprm->page,bprm->p,2); |
| bprm | 515 | fs/binfmt_elf.c | bprm->argc++; |
| bprm | 518 | fs/binfmt_elf.c | if (!bprm->p) { |
| bprm | 529 | fs/binfmt_elf.c | flush_old_exec(bprm); |
| bprm | 540 | fs/binfmt_elf.c | bprm->p += setup_arg_pages(0, bprm->page); |
| bprm | 541 | fs/binfmt_elf.c | current->mm->start_stack = bprm->p; |
| bprm | 630 | fs/binfmt_elf.c | current->executable = bprm->inode; |
| bprm | 631 | fs/binfmt_elf.c | bprm->inode->i_count++; |
| bprm | 636 | fs/binfmt_elf.c | bprm->p -= MAX_ARG_PAGES*PAGE_SIZE; |
| bprm | 637 | fs/binfmt_elf.c | bprm->p = (unsigned long) |
| bprm | 638 | fs/binfmt_elf.c | create_elf_tables((char *)bprm->p, |
| bprm | 639 | fs/binfmt_elf.c | bprm->argc, |
| bprm | 640 | fs/binfmt_elf.c | bprm->envc, |
| bprm | 651 | fs/binfmt_elf.c | current->mm->start_stack = bprm->p; |
| bprm | 652 | fs/binfmt_elf.c | current->suid = current->euid = current->fsuid = bprm->e_uid; |
| bprm | 653 | fs/binfmt_elf.c | current->sgid = current->egid = current->fsgid = bprm->e_gid; |
| bprm | 690 | fs/binfmt_elf.c | start_thread(regs, elf_entry, bprm->p); |
| bprm | 305 | fs/exec.c | unsigned long * create_tables(char * p, struct linux_binprm * bprm, int ibcs) |
| bprm | 310 | fs/exec.c | int argc = bprm->argc; |
| bprm | 311 | fs/exec.c | int envc = bprm->envc; |
| bprm | 331 | fs/exec.c | if (bprm->loader) { |
| bprm | 334 | fs/exec.c | put_user(bprm->loader, --sp); |
| bprm | 337 | fs/exec.c | put_user(bprm->exec, --sp); |
| bprm | 559 | fs/exec.c | void flush_old_exec(struct linux_binprm * bprm) |
| bprm | 567 | fs/exec.c | name = bprm->filename; |
| bprm | 582 | fs/exec.c | if (bprm->e_uid != current->euid || bprm->e_gid != current->egid || |
| bprm | 583 | fs/exec.c | permission(bprm->inode,MAY_READ)) |
| bprm | 606 | fs/exec.c | struct linux_binprm bprm; |
| bprm | 615 | fs/exec.c | bprm.p = PAGE_SIZE*MAX_ARG_PAGES-sizeof(void *); |
| bprm | 617 | fs/exec.c | bprm.page[i] = 0; |
| bprm | 618 | fs/exec.c | retval = open_namei(filename, 0, 0, &bprm.inode, NULL); |
| bprm | 621 | fs/exec.c | bprm.filename = filename; |
| bprm | 622 | fs/exec.c | bprm.loader = 0; |
| bprm | 623 | fs/exec.c | bprm.exec = 0; |
| bprm | 624 | fs/exec.c | if ((bprm.argc = count(argv)) < 0) |
| bprm | 625 | fs/exec.c | return bprm.argc; |
| bprm | 626 | fs/exec.c | if ((bprm.envc = count(envp)) < 0) |
| bprm | 627 | fs/exec.c | return bprm.envc; |
| bprm | 630 | fs/exec.c | if (!S_ISREG(bprm.inode->i_mode)) { /* must be regular file */ |
| bprm | 634 | fs/exec.c | if (IS_NOEXEC(bprm.inode)) { /* FS mustn't be mounted noexec */ |
| bprm | 638 | fs/exec.c | if (!bprm.inode->i_sb) { |
| bprm | 642 | fs/exec.c | i = bprm.inode->i_mode; |
| bprm | 643 | fs/exec.c | if (IS_NOSUID(bprm.inode) && (((i & S_ISUID) && bprm.inode->i_uid != current-> |
| bprm | 644 | fs/exec.c | euid) || ((i & S_ISGID) && !in_group_p(bprm.inode->i_gid))) && !suser()) { |
| bprm | 650 | fs/exec.c | bprm.e_uid = current->euid; |
| bprm | 651 | fs/exec.c | bprm.e_gid = current->egid; |
| bprm | 653 | fs/exec.c | bprm.e_uid = (i & S_ISUID) ? bprm.inode->i_uid : current->euid; |
| bprm | 654 | fs/exec.c | bprm.e_gid = (i & S_ISGID) ? bprm.inode->i_gid : current->egid; |
| bprm | 656 | fs/exec.c | if ((retval = permission(bprm.inode, MAY_EXEC)) != 0) |
| bprm | 658 | fs/exec.c | if (!(bprm.inode->i_mode & 0111) && fsuser()) { |
| bprm | 663 | fs/exec.c | if (bprm.inode->i_wcount > 0) { |
| bprm | 667 | fs/exec.c | memset(bprm.buf,0,sizeof(bprm.buf)); |
| bprm | 668 | fs/exec.c | retval = read_exec(bprm.inode,0,bprm.buf,128,1); |
| bprm | 671 | fs/exec.c | if ((bprm.buf[0] == '#') && (bprm.buf[1] == '!') && (!sh_bang)) { |
| bprm | 679 | fs/exec.c | iput(bprm.inode); |
| bprm | 680 | fs/exec.c | bprm.buf[127] = '\0'; |
| bprm | 681 | fs/exec.c | if ((cp = strchr(bprm.buf, '\n')) == NULL) |
| bprm | 682 | fs/exec.c | cp = bprm.buf+127; |
| bprm | 684 | fs/exec.c | while (cp > bprm.buf) { |
| bprm | 691 | fs/exec.c | for (cp = bprm.buf+2; (*cp == ' ') || (*cp == '\t'); cp++); |
| bprm | 711 | fs/exec.c | bprm.p = copy_strings(bprm.envc, envp, bprm.page, bprm.p, 0); |
| bprm | 712 | fs/exec.c | bprm.p = copy_strings(--bprm.argc, argv+1, bprm.page, bprm.p, 0); |
| bprm | 722 | fs/exec.c | bprm.p = copy_strings(1, &bprm.filename, bprm.page, bprm.p, 2); |
| bprm | 723 | fs/exec.c | bprm.argc++; |
| bprm | 725 | fs/exec.c | bprm.p = copy_strings(1, &i_arg, bprm.page, bprm.p, 2); |
| bprm | 726 | fs/exec.c | bprm.argc++; |
| bprm | 728 | fs/exec.c | bprm.p = copy_strings(1, &i_name, bprm.page, bprm.p, 2); |
| bprm | 729 | fs/exec.c | bprm.argc++; |
| bprm | 730 | fs/exec.c | if (!bprm.p) { |
| bprm | 739 | fs/exec.c | retval = open_namei(interp, 0, 0, &bprm.inode, NULL); |
| bprm | 746 | fs/exec.c | if (!loader && (((struct exec *) bprm.buf)->fh.f_flags & 0x3000)) { |
| bprm | 748 | fs/exec.c | iput(bprm.inode); |
| bprm | 750 | fs/exec.c | bprm.p = copy_strings(1, dynloader, bprm.page, bprm.p, 2); |
| bprm | 751 | fs/exec.c | bprm.loader = bprm.p; |
| bprm | 752 | fs/exec.c | retval = open_namei(dynloader[0], 0, 0, &bprm.inode, NULL); |
| bprm | 759 | fs/exec.c | bprm.p = copy_strings(1, &bprm.filename, bprm.page, bprm.p, 2); |
| bprm | 760 | fs/exec.c | bprm.exec = bprm.p; |
| bprm | 761 | fs/exec.c | bprm.p = copy_strings(bprm.envc,envp,bprm.page,bprm.p,0); |
| bprm | 762 | fs/exec.c | bprm.p = copy_strings(bprm.argc,argv,bprm.page,bprm.p,0); |
| bprm | 763 | fs/exec.c | if (!bprm.p) { |
| bprm | 769 | fs/exec.c | bprm.sh_bang = sh_bang; |
| bprm | 774 | fs/exec.c | retval = fn(&bprm, regs); |
| bprm | 776 | fs/exec.c | iput(bprm.inode); |
| bprm | 784 | fs/exec.c | iput(bprm.inode); |
| bprm | 787 | fs/exec.c | free_page(bprm.page[i]); |
| bprm | 807 | fs/exec.c | static int load_aout_binary(struct linux_binprm * bprm, struct pt_regs * regs) |
| bprm | 813 | fs/exec.c | unsigned long p = bprm->p; |
| bprm | 816 | fs/exec.c | ex = *((struct exec *) bprm->buf); /* exec-header */ |
| bprm | 820 | fs/exec.c | bprm->inode->i_size < ex.a_text+ex.a_data+N_SYMSIZE(ex)+N_TXTOFF(ex)) { |
| bprm | 834 | fs/exec.c | (fd_offset < bprm->inode->i_sb->s_blocksize)) { |
| bprm | 841 | fs/exec.c | flush_old_exec(bprm); |
| bprm | 852 | fs/exec.c | current->suid = current->euid = current->fsuid = bprm->e_uid; |
| bprm | 853 | fs/exec.c | current->sgid = current->egid = current->fsgid = bprm->e_gid; |
| bprm | 858 | fs/exec.c | read_exec(bprm->inode, 32, (char *) 0, ex.a_text+ex.a_data, 0); |
| bprm | 863 | fs/exec.c | fd = open_inode(bprm->inode, O_RDONLY); |
| bprm | 873 | fs/exec.c | read_exec(bprm->inode, fd_offset, |
| bprm | 913 | fs/exec.c | fd_offset = setup_arg_pages(ex.a_text,bprm->page) - MAX_ARG_PAGES*PAGE_SIZE; |
| bprm | 915 | fs/exec.c | if (bprm->loader) |
| bprm | 916 | fs/exec.c | bprm->loader += fd_offset; |
| bprm | 917 | fs/exec.c | bprm->exec += fd_offset; |
| bprm | 919 | fs/exec.c | p = (unsigned long)create_tables((char *)p, bprm, |
| bprm | 49 | include/linux/binfmts.h | extern void flush_old_exec(struct linux_binprm * bprm); |
| bprm | 51 | include/linux/binfmts.h | extern unsigned long * create_tables(char * p,struct linux_binprm * bprm,int ibcs); |