/* * Copyright (C) 2004-2006 Atmel Corporation * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. */ #include <linux/errno.h> #include <linux/fs.h> #include <linux/file.h> #include <linux/mm.h> #include <linux/unistd.h> #include <asm/mman.h> #include <asm/uaccess.h> #include <asm/syscalls.h> asmlinkage long sys_mmap2(unsigned long addr, unsigned long len, unsigned long prot, unsigned long flags, unsigned long fd, off_t offset) { int error = -EBADF; struct file *file = NULL; flags &= ~(MAP_EXECUTABLE | MAP_DENYWRITE); if (!(flags & MAP_ANONYMOUS)) { file = fget(fd); if (!file) return error; } down_write(¤t->mm->mmap_sem); error = do_mmap_pgoff(file, addr, len, prot, flags, offset); up_write(¤t->mm->mmap_sem); if (file) fput(file); return error; } int kernel_execve(const char *file, char **argv, char **envp) { register long scno asm("r8") = __NR_execve; register long sc1 asm("r12") = (long)file; register long sc2 asm("r11") = (long)argv; register long sc3 asm("r10") = (long)envp; asm volatile("scall" : "=r"(sc1) : "r"(scno), "0"(sc1), "r"(sc2), "r"(sc3) : "cc", "memory"); return sc1; }