diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-05-31 21:10:18 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-05-31 21:10:18 -0400 |
| commit | 08615d7d85e5aa02c05bf6c4dde87d940e7f85f6 (patch) | |
| tree | 18906149d313d25914160aca21cedf54b3a7e818 /init/initramfs.c | |
| parent | 9fdadb2cbaf4b482dfd6086e8bd3d2db071a1702 (diff) | |
| parent | 0a4dd35c67b144d8ef9432120105f1aab9293ee9 (diff) | |
Merge branch 'akpm' (Andrew's patch-bomb)
Merge misc patches from Andrew Morton:
- the "misc" tree - stuff from all over the map
- checkpatch updates
- fatfs
- kmod changes
- procfs
- cpumask
- UML
- kexec
- mqueue
- rapidio
- pidns
- some checkpoint-restore feature work. Reluctantly. Most of it
delayed a release. I'm still rather worried that we don't have a
clear roadmap to completion for this work.
* emailed from Andrew Morton <akpm@linux-foundation.org>: (78 patches)
kconfig: update compression algorithm info
c/r: prctl: add ability to set new mm_struct::exe_file
c/r: prctl: extend PR_SET_MM to set up more mm_struct entries
c/r: procfs: add arg_start/end, env_start/end and exit_code members to /proc/$pid/stat
syscalls, x86: add __NR_kcmp syscall
fs, proc: introduce /proc/<pid>/task/<tid>/children entry
sysctl: make kernel.ns_last_pid control dependent on CHECKPOINT_RESTORE
aio/vfs: cleanup of rw_copy_check_uvector() and compat_rw_copy_check_uvector()
eventfd: change int to __u64 in eventfd_signal()
fs/nls: add Apple NLS
pidns: make killed children autoreap
pidns: use task_active_pid_ns in do_notify_parent
rapidio/tsi721: add DMA engine support
rapidio: add DMA engine support for RIO data transfers
ipc/mqueue: add rbtree node caching support
tools/selftests: add mq_perf_tests
ipc/mqueue: strengthen checks on mqueue creation
ipc/mqueue: correct mq_attr_ok test
ipc/mqueue: improve performance of send/recv
selftests: add mq_open_tests
...
Diffstat (limited to 'init/initramfs.c')
| -rw-r--r-- | init/initramfs.c | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/init/initramfs.c b/init/initramfs.c index 8216c303b082..84c6bf111300 100644 --- a/init/initramfs.c +++ b/init/initramfs.c | |||
| @@ -1,3 +1,13 @@ | |||
| 1 | /* | ||
| 2 | * Many of the syscalls used in this file expect some of the arguments | ||
| 3 | * to be __user pointers not __kernel pointers. To limit the sparse | ||
| 4 | * noise, turn off sparse checking for this file. | ||
| 5 | */ | ||
| 6 | #ifdef __CHECKER__ | ||
| 7 | #undef __CHECKER__ | ||
| 8 | #warning "Sparse checking disabled for this file" | ||
| 9 | #endif | ||
| 10 | |||
| 1 | #include <linux/init.h> | 11 | #include <linux/init.h> |
| 2 | #include <linux/fs.h> | 12 | #include <linux/fs.h> |
| 3 | #include <linux/slab.h> | 13 | #include <linux/slab.h> |
| @@ -74,7 +84,7 @@ static void __init free_hash(void) | |||
| 74 | } | 84 | } |
| 75 | } | 85 | } |
| 76 | 86 | ||
| 77 | static long __init do_utime(char __user *filename, time_t mtime) | 87 | static long __init do_utime(char *filename, time_t mtime) |
| 78 | { | 88 | { |
| 79 | struct timespec t[2]; | 89 | struct timespec t[2]; |
| 80 | 90 | ||
| @@ -529,7 +539,7 @@ static void __init clean_rootfs(void) | |||
| 529 | struct linux_dirent64 *dirp; | 539 | struct linux_dirent64 *dirp; |
| 530 | int num; | 540 | int num; |
| 531 | 541 | ||
| 532 | fd = sys_open((const char __user __force *) "/", O_RDONLY, 0); | 542 | fd = sys_open("/", O_RDONLY, 0); |
| 533 | WARN_ON(fd < 0); | 543 | WARN_ON(fd < 0); |
| 534 | if (fd < 0) | 544 | if (fd < 0) |
| 535 | return; | 545 | return; |
| @@ -589,7 +599,7 @@ static int __init populate_rootfs(void) | |||
| 589 | } | 599 | } |
| 590 | printk(KERN_INFO "rootfs image is not initramfs (%s)" | 600 | printk(KERN_INFO "rootfs image is not initramfs (%s)" |
| 591 | "; looks like an initrd\n", err); | 601 | "; looks like an initrd\n", err); |
| 592 | fd = sys_open((const char __user __force *) "/initrd.image", | 602 | fd = sys_open("/initrd.image", |
| 593 | O_WRONLY|O_CREAT, 0700); | 603 | O_WRONLY|O_CREAT, 0700); |
| 594 | if (fd >= 0) { | 604 | if (fd >= 0) { |
| 595 | sys_write(fd, (char *)initrd_start, | 605 | sys_write(fd, (char *)initrd_start, |
