diff options
| author | David S. Miller <davem@davemloft.net> | 2010-08-16 17:09:34 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2010-08-16 17:09:34 -0400 |
| commit | 300a103d1504134f8c4a7e831f995e917ea9b1e4 (patch) | |
| tree | 7f94d5fff513d132bd0b57a9e3bd96c4cc80d707 /arch/um | |
| parent | 0a492896ac07336c98f37ad7fab4a6387b6ada78 (diff) | |
| parent | da5cabf80e2433131bf0ed8993abc0f7ea618c73 (diff) | |
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6
Diffstat (limited to 'arch/um')
| -rw-r--r-- | arch/um/drivers/chan_kern.c | 8 | ||||
| -rw-r--r-- | arch/um/drivers/hostaudio_kern.c | 10 | ||||
| -rw-r--r-- | arch/um/drivers/ubd_kern.c | 7 | ||||
| -rw-r--r-- | arch/um/include/asm/dma-mapping.h | 1 | ||||
| -rw-r--r-- | arch/um/include/shared/os.h | 3 | ||||
| -rw-r--r-- | arch/um/kernel/exec.c | 6 | ||||
| -rw-r--r-- | arch/um/kernel/internal.h | 2 | ||||
| -rw-r--r-- | arch/um/kernel/ksyms.c | 3 | ||||
| -rw-r--r-- | arch/um/kernel/ptrace.c | 21 | ||||
| -rw-r--r-- | arch/um/kernel/syscall.c | 2 | ||||
| -rw-r--r-- | arch/um/os-Linux/file.c | 15 | ||||
| -rw-r--r-- | arch/um/os-Linux/user_syms.c | 4 |
12 files changed, 50 insertions, 32 deletions
diff --git a/arch/um/drivers/chan_kern.c b/arch/um/drivers/chan_kern.c index 6e51424745ab..25e1965df7ce 100644 --- a/arch/um/drivers/chan_kern.c +++ b/arch/um/drivers/chan_kern.c | |||
| @@ -210,9 +210,9 @@ void free_irqs(void) | |||
| 210 | list_for_each(ele, &list) { | 210 | list_for_each(ele, &list) { |
| 211 | chan = list_entry(ele, struct chan, free_list); | 211 | chan = list_entry(ele, struct chan, free_list); |
| 212 | 212 | ||
| 213 | if (chan->input) | 213 | if (chan->input && chan->enabled) |
| 214 | free_irq(chan->line->driver->read_irq, chan); | 214 | free_irq(chan->line->driver->read_irq, chan); |
| 215 | if (chan->output) | 215 | if (chan->output && chan->enabled) |
| 216 | free_irq(chan->line->driver->write_irq, chan); | 216 | free_irq(chan->line->driver->write_irq, chan); |
| 217 | chan->enabled = 0; | 217 | chan->enabled = 0; |
| 218 | } | 218 | } |
| @@ -231,9 +231,9 @@ static void close_one_chan(struct chan *chan, int delay_free_irq) | |||
| 231 | spin_unlock_irqrestore(&irqs_to_free_lock, flags); | 231 | spin_unlock_irqrestore(&irqs_to_free_lock, flags); |
| 232 | } | 232 | } |
| 233 | else { | 233 | else { |
| 234 | if (chan->input) | 234 | if (chan->input && chan->enabled) |
| 235 | free_irq(chan->line->driver->read_irq, chan); | 235 | free_irq(chan->line->driver->read_irq, chan); |
| 236 | if (chan->output) | 236 | if (chan->output && chan->enabled) |
| 237 | free_irq(chan->line->driver->write_irq, chan); | 237 | free_irq(chan->line->driver->write_irq, chan); |
| 238 | chan->enabled = 0; | 238 | chan->enabled = 0; |
| 239 | } | 239 | } |
diff --git a/arch/um/drivers/hostaudio_kern.c b/arch/um/drivers/hostaudio_kern.c index 68142df76608..0c46e398cd8f 100644 --- a/arch/um/drivers/hostaudio_kern.c +++ b/arch/um/drivers/hostaudio_kern.c | |||
| @@ -187,7 +187,9 @@ static int hostaudio_open(struct inode *inode, struct file *file) | |||
| 187 | int ret; | 187 | int ret; |
| 188 | 188 | ||
| 189 | #ifdef DEBUG | 189 | #ifdef DEBUG |
| 190 | kparam_block_sysfs_write(dsp); | ||
| 190 | printk(KERN_DEBUG "hostaudio: open called (host: %s)\n", dsp); | 191 | printk(KERN_DEBUG "hostaudio: open called (host: %s)\n", dsp); |
| 192 | kparam_unblock_sysfs_write(dsp); | ||
| 191 | #endif | 193 | #endif |
| 192 | 194 | ||
| 193 | state = kmalloc(sizeof(struct hostaudio_state), GFP_KERNEL); | 195 | state = kmalloc(sizeof(struct hostaudio_state), GFP_KERNEL); |
| @@ -199,9 +201,11 @@ static int hostaudio_open(struct inode *inode, struct file *file) | |||
| 199 | if (file->f_mode & FMODE_WRITE) | 201 | if (file->f_mode & FMODE_WRITE) |
| 200 | w = 1; | 202 | w = 1; |
| 201 | 203 | ||
| 204 | kparam_block_sysfs_write(dsp); | ||
| 202 | lock_kernel(); | 205 | lock_kernel(); |
| 203 | ret = os_open_file(dsp, of_set_rw(OPENFLAGS(), r, w), 0); | 206 | ret = os_open_file(dsp, of_set_rw(OPENFLAGS(), r, w), 0); |
| 204 | unlock_kernel(); | 207 | unlock_kernel(); |
| 208 | kparam_unblock_sysfs_write(dsp); | ||
| 205 | 209 | ||
| 206 | if (ret < 0) { | 210 | if (ret < 0) { |
| 207 | kfree(state); | 211 | kfree(state); |
| @@ -258,13 +262,17 @@ static int hostmixer_open_mixdev(struct inode *inode, struct file *file) | |||
| 258 | if (file->f_mode & FMODE_WRITE) | 262 | if (file->f_mode & FMODE_WRITE) |
| 259 | w = 1; | 263 | w = 1; |
| 260 | 264 | ||
| 265 | kparam_block_sysfs_write(mixer); | ||
| 261 | lock_kernel(); | 266 | lock_kernel(); |
| 262 | ret = os_open_file(mixer, of_set_rw(OPENFLAGS(), r, w), 0); | 267 | ret = os_open_file(mixer, of_set_rw(OPENFLAGS(), r, w), 0); |
| 263 | unlock_kernel(); | 268 | unlock_kernel(); |
| 269 | kparam_unblock_sysfs_write(mixer); | ||
| 264 | 270 | ||
| 265 | if (ret < 0) { | 271 | if (ret < 0) { |
| 272 | kparam_block_sysfs_write(dsp); | ||
| 266 | printk(KERN_ERR "hostaudio_open_mixdev failed to open '%s', " | 273 | printk(KERN_ERR "hostaudio_open_mixdev failed to open '%s', " |
| 267 | "err = %d\n", dsp, -ret); | 274 | "err = %d\n", dsp, -ret); |
| 275 | kparam_unblock_sysfs_write(dsp); | ||
| 268 | kfree(state); | 276 | kfree(state); |
| 269 | return ret; | 277 | return ret; |
| 270 | } | 278 | } |
| @@ -320,8 +328,10 @@ MODULE_LICENSE("GPL"); | |||
| 320 | 328 | ||
| 321 | static int __init hostaudio_init_module(void) | 329 | static int __init hostaudio_init_module(void) |
| 322 | { | 330 | { |
| 331 | __kernel_param_lock(); | ||
| 323 | printk(KERN_INFO "UML Audio Relay (host dsp = %s, host mixer = %s)\n", | 332 | printk(KERN_INFO "UML Audio Relay (host dsp = %s, host mixer = %s)\n", |
| 324 | dsp, mixer); | 333 | dsp, mixer); |
| 334 | __kernel_param_unlock(); | ||
| 325 | 335 | ||
| 326 | module_data.dev_audio = register_sound_dsp(&hostaudio_fops, -1); | 336 | module_data.dev_audio = register_sound_dsp(&hostaudio_fops, -1); |
| 327 | if (module_data.dev_audio < 0) { | 337 | if (module_data.dev_audio < 0) { |
diff --git a/arch/um/drivers/ubd_kern.c b/arch/um/drivers/ubd_kern.c index da992a3ad6b7..1bcd208c459f 100644 --- a/arch/um/drivers/ubd_kern.c +++ b/arch/um/drivers/ubd_kern.c | |||
| @@ -33,6 +33,7 @@ | |||
| 33 | #include "linux/mm.h" | 33 | #include "linux/mm.h" |
| 34 | #include "linux/slab.h" | 34 | #include "linux/slab.h" |
| 35 | #include "linux/vmalloc.h" | 35 | #include "linux/vmalloc.h" |
| 36 | #include "linux/smp_lock.h" | ||
| 36 | #include "linux/blkpg.h" | 37 | #include "linux/blkpg.h" |
| 37 | #include "linux/genhd.h" | 38 | #include "linux/genhd.h" |
| 38 | #include "linux/spinlock.h" | 39 | #include "linux/spinlock.h" |
| @@ -1098,6 +1099,7 @@ static int ubd_open(struct block_device *bdev, fmode_t mode) | |||
| 1098 | struct ubd *ubd_dev = disk->private_data; | 1099 | struct ubd *ubd_dev = disk->private_data; |
| 1099 | int err = 0; | 1100 | int err = 0; |
| 1100 | 1101 | ||
| 1102 | lock_kernel(); | ||
| 1101 | if(ubd_dev->count == 0){ | 1103 | if(ubd_dev->count == 0){ |
| 1102 | err = ubd_open_dev(ubd_dev); | 1104 | err = ubd_open_dev(ubd_dev); |
| 1103 | if(err){ | 1105 | if(err){ |
| @@ -1115,7 +1117,8 @@ static int ubd_open(struct block_device *bdev, fmode_t mode) | |||
| 1115 | if(--ubd_dev->count == 0) ubd_close_dev(ubd_dev); | 1117 | if(--ubd_dev->count == 0) ubd_close_dev(ubd_dev); |
| 1116 | err = -EROFS; | 1118 | err = -EROFS; |
| 1117 | }*/ | 1119 | }*/ |
| 1118 | out: | 1120 | out: |
| 1121 | unlock_kernel(); | ||
| 1119 | return err; | 1122 | return err; |
| 1120 | } | 1123 | } |
| 1121 | 1124 | ||
| @@ -1123,8 +1126,10 @@ static int ubd_release(struct gendisk *disk, fmode_t mode) | |||
| 1123 | { | 1126 | { |
| 1124 | struct ubd *ubd_dev = disk->private_data; | 1127 | struct ubd *ubd_dev = disk->private_data; |
| 1125 | 1128 | ||
| 1129 | lock_kernel(); | ||
| 1126 | if(--ubd_dev->count == 0) | 1130 | if(--ubd_dev->count == 0) |
| 1127 | ubd_close_dev(ubd_dev); | 1131 | ubd_close_dev(ubd_dev); |
| 1132 | unlock_kernel(); | ||
| 1128 | return 0; | 1133 | return 0; |
| 1129 | } | 1134 | } |
| 1130 | 1135 | ||
diff --git a/arch/um/include/asm/dma-mapping.h b/arch/um/include/asm/dma-mapping.h index b948c14a7867..17a2cb5a4178 100644 --- a/arch/um/include/asm/dma-mapping.h +++ b/arch/um/include/asm/dma-mapping.h | |||
| @@ -94,7 +94,6 @@ dma_sync_sg_for_cpu(struct device *dev, struct scatterlist *sg, int nelems, | |||
| 94 | 94 | ||
| 95 | #define dma_alloc_noncoherent(d, s, h, f) dma_alloc_coherent(d, s, h, f) | 95 | #define dma_alloc_noncoherent(d, s, h, f) dma_alloc_coherent(d, s, h, f) |
| 96 | #define dma_free_noncoherent(d, s, v, h) dma_free_coherent(d, s, v, h) | 96 | #define dma_free_noncoherent(d, s, v, h) dma_free_coherent(d, s, v, h) |
| 97 | #define dma_is_consistent(d, h) (1) | ||
| 98 | 97 | ||
| 99 | static inline int | 98 | static inline int |
| 100 | dma_get_cache_alignment(void) | 99 | dma_get_cache_alignment(void) |
diff --git a/arch/um/include/shared/os.h b/arch/um/include/shared/os.h index cd40fddcf99d..c4617baaa4f2 100644 --- a/arch/um/include/shared/os.h +++ b/arch/um/include/shared/os.h | |||
| @@ -161,6 +161,9 @@ extern int os_stat_filesystem(char *path, long *bsize_out, | |||
| 161 | long *spare_out); | 161 | long *spare_out); |
| 162 | extern int os_change_dir(char *dir); | 162 | extern int os_change_dir(char *dir); |
| 163 | extern int os_fchange_dir(int fd); | 163 | extern int os_fchange_dir(int fd); |
| 164 | extern unsigned os_major(unsigned long long dev); | ||
| 165 | extern unsigned os_minor(unsigned long long dev); | ||
| 166 | extern unsigned long long os_makedev(unsigned major, unsigned minor); | ||
| 164 | 167 | ||
| 165 | /* start_up.c */ | 168 | /* start_up.c */ |
| 166 | extern void os_early_checks(void); | 169 | extern void os_early_checks(void); |
diff --git a/arch/um/kernel/exec.c b/arch/um/kernel/exec.c index 97974c1bdd12..59b20d93b6d4 100644 --- a/arch/um/kernel/exec.c +++ b/arch/um/kernel/exec.c | |||
| @@ -44,7 +44,7 @@ void start_thread(struct pt_regs *regs, unsigned long eip, unsigned long esp) | |||
| 44 | PT_REGS_SP(regs) = esp; | 44 | PT_REGS_SP(regs) = esp; |
| 45 | } | 45 | } |
| 46 | 46 | ||
| 47 | static long execve1(char *file, char __user * __user *argv, | 47 | static long execve1(const char *file, char __user * __user *argv, |
| 48 | char __user *__user *env) | 48 | char __user *__user *env) |
| 49 | { | 49 | { |
| 50 | long error; | 50 | long error; |
| @@ -61,7 +61,7 @@ static long execve1(char *file, char __user * __user *argv, | |||
| 61 | return error; | 61 | return error; |
| 62 | } | 62 | } |
| 63 | 63 | ||
| 64 | long um_execve(char *file, char __user *__user *argv, char __user *__user *env) | 64 | long um_execve(const char *file, char __user *__user *argv, char __user *__user *env) |
| 65 | { | 65 | { |
| 66 | long err; | 66 | long err; |
| 67 | 67 | ||
| @@ -71,7 +71,7 @@ long um_execve(char *file, char __user *__user *argv, char __user *__user *env) | |||
| 71 | return err; | 71 | return err; |
| 72 | } | 72 | } |
| 73 | 73 | ||
| 74 | long sys_execve(char __user *file, char __user *__user *argv, | 74 | long sys_execve(const char __user *file, char __user *__user *argv, |
| 75 | char __user *__user *env) | 75 | char __user *__user *env) |
| 76 | { | 76 | { |
| 77 | long error; | 77 | long error; |
diff --git a/arch/um/kernel/internal.h b/arch/um/kernel/internal.h index 3bda43c7a786..1303a105fe91 100644 --- a/arch/um/kernel/internal.h +++ b/arch/um/kernel/internal.h | |||
| @@ -1 +1 @@ | |||
| extern long um_execve(char *file, char __user *__user *argv, char __user *__user *env); | extern long um_execve(const char *file, char __user *__user *argv, char __user *__user *env); | ||
diff --git a/arch/um/kernel/ksyms.c b/arch/um/kernel/ksyms.c index 836fc9b94707..0ae0dfcfbffb 100644 --- a/arch/um/kernel/ksyms.c +++ b/arch/um/kernel/ksyms.c | |||
| @@ -58,6 +58,9 @@ EXPORT_SYMBOL(os_accept_connection); | |||
| 58 | EXPORT_SYMBOL(os_rcv_fd); | 58 | EXPORT_SYMBOL(os_rcv_fd); |
| 59 | EXPORT_SYMBOL(run_helper); | 59 | EXPORT_SYMBOL(run_helper); |
| 60 | EXPORT_SYMBOL(start_thread); | 60 | EXPORT_SYMBOL(start_thread); |
| 61 | EXPORT_SYMBOL(os_major); | ||
| 62 | EXPORT_SYMBOL(os_minor); | ||
| 63 | EXPORT_SYMBOL(os_makedev); | ||
| 61 | 64 | ||
| 62 | EXPORT_SYMBOL(add_sigio_fd); | 65 | EXPORT_SYMBOL(add_sigio_fd); |
| 63 | EXPORT_SYMBOL(ignore_sigio_fd); | 66 | EXPORT_SYMBOL(ignore_sigio_fd); |
diff --git a/arch/um/kernel/ptrace.c b/arch/um/kernel/ptrace.c index 484509948ee9..e0510496596c 100644 --- a/arch/um/kernel/ptrace.c +++ b/arch/um/kernel/ptrace.c | |||
| @@ -7,9 +7,6 @@ | |||
| 7 | #include "linux/ptrace.h" | 7 | #include "linux/ptrace.h" |
| 8 | #include "linux/sched.h" | 8 | #include "linux/sched.h" |
| 9 | #include "asm/uaccess.h" | 9 | #include "asm/uaccess.h" |
| 10 | #ifdef CONFIG_PROC_MM | ||
| 11 | #include "proc_mm.h" | ||
| 12 | #endif | ||
| 13 | #include "skas_ptrace.h" | 10 | #include "skas_ptrace.h" |
| 14 | 11 | ||
| 15 | 12 | ||
| @@ -158,24 +155,6 @@ long arch_ptrace(struct task_struct *child, long request, long addr, long data) | |||
| 158 | break; | 155 | break; |
| 159 | } | 156 | } |
| 160 | #endif | 157 | #endif |
| 161 | #ifdef CONFIG_PROC_MM | ||
| 162 | case PTRACE_SWITCH_MM: { | ||
| 163 | struct mm_struct *old = child->mm; | ||
| 164 | struct mm_struct *new = proc_mm_get_mm(data); | ||
| 165 | |||
| 166 | if (IS_ERR(new)) { | ||
| 167 | ret = PTR_ERR(new); | ||
| 168 | break; | ||
| 169 | } | ||
| 170 | |||
| 171 | atomic_inc(&new->mm_users); | ||
| 172 | child->mm = new; | ||
| 173 | child->active_mm = new; | ||
| 174 | mmput(old); | ||
| 175 | ret = 0; | ||
| 176 | break; | ||
| 177 | } | ||
| 178 | #endif | ||
| 179 | #ifdef PTRACE_ARCH_PRCTL | 158 | #ifdef PTRACE_ARCH_PRCTL |
| 180 | case PTRACE_ARCH_PRCTL: | 159 | case PTRACE_ARCH_PRCTL: |
| 181 | /* XXX Calls ptrace on the host - needs some SMP thinking */ | 160 | /* XXX Calls ptrace on the host - needs some SMP thinking */ |
diff --git a/arch/um/kernel/syscall.c b/arch/um/kernel/syscall.c index 4393173923f5..7427c0b1930c 100644 --- a/arch/um/kernel/syscall.c +++ b/arch/um/kernel/syscall.c | |||
| @@ -58,7 +58,7 @@ int kernel_execve(const char *filename, char *const argv[], char *const envp[]) | |||
| 58 | 58 | ||
| 59 | fs = get_fs(); | 59 | fs = get_fs(); |
| 60 | set_fs(KERNEL_DS); | 60 | set_fs(KERNEL_DS); |
| 61 | ret = um_execve((char *)filename, (char __user *__user *)argv, | 61 | ret = um_execve(filename, (char __user *__user *)argv, |
| 62 | (char __user *__user *) envp); | 62 | (char __user *__user *) envp); |
| 63 | set_fs(fs); | 63 | set_fs(fs); |
| 64 | 64 | ||
diff --git a/arch/um/os-Linux/file.c b/arch/um/os-Linux/file.c index b5afcfd0f861..140e587bc0ad 100644 --- a/arch/um/os-Linux/file.c +++ b/arch/um/os-Linux/file.c | |||
| @@ -561,3 +561,18 @@ int os_lock_file(int fd, int excl) | |||
| 561 | out: | 561 | out: |
| 562 | return err; | 562 | return err; |
| 563 | } | 563 | } |
| 564 | |||
| 565 | unsigned os_major(unsigned long long dev) | ||
| 566 | { | ||
| 567 | return major(dev); | ||
| 568 | } | ||
| 569 | |||
| 570 | unsigned os_minor(unsigned long long dev) | ||
| 571 | { | ||
| 572 | return minor(dev); | ||
| 573 | } | ||
| 574 | |||
| 575 | unsigned long long os_makedev(unsigned major, unsigned minor) | ||
| 576 | { | ||
| 577 | return makedev(major, minor); | ||
| 578 | } | ||
diff --git a/arch/um/os-Linux/user_syms.c b/arch/um/os-Linux/user_syms.c index 89b48a116a89..05f5ea8e83d2 100644 --- a/arch/um/os-Linux/user_syms.c +++ b/arch/um/os-Linux/user_syms.c | |||
| @@ -103,6 +103,10 @@ EXPORT_SYMBOL_PROTO(getuid); | |||
| 103 | EXPORT_SYMBOL_PROTO(fsync); | 103 | EXPORT_SYMBOL_PROTO(fsync); |
| 104 | EXPORT_SYMBOL_PROTO(fdatasync); | 104 | EXPORT_SYMBOL_PROTO(fdatasync); |
| 105 | 105 | ||
| 106 | EXPORT_SYMBOL_PROTO(lstat64); | ||
| 107 | EXPORT_SYMBOL_PROTO(fstat64); | ||
| 108 | EXPORT_SYMBOL_PROTO(mknod); | ||
| 109 | |||
| 106 | /* Export symbols used by GCC for the stack protector. */ | 110 | /* Export symbols used by GCC for the stack protector. */ |
| 107 | extern void __stack_smash_handler(void *) __attribute__((weak)); | 111 | extern void __stack_smash_handler(void *) __attribute__((weak)); |
| 108 | EXPORT_SYMBOL(__stack_smash_handler); | 112 | EXPORT_SYMBOL(__stack_smash_handler); |
