diff options
Diffstat (limited to 'arch/mips/kernel')
-rw-r--r-- | arch/mips/kernel/cpu-probe.c | 6 | ||||
-rw-r--r-- | arch/mips/kernel/gdb-low.S | 2 | ||||
-rw-r--r-- | arch/mips/kernel/irq.c | 10 | ||||
-rw-r--r-- | arch/mips/kernel/linux32.c | 180 | ||||
-rw-r--r-- | arch/mips/kernel/proc.c | 1 | ||||
-rw-r--r-- | arch/mips/kernel/process.c | 16 | ||||
-rw-r--r-- | arch/mips/kernel/setup.c | 11 | ||||
-rw-r--r-- | arch/mips/kernel/signal-common.h | 10 | ||||
-rw-r--r-- | arch/mips/kernel/signal.c | 6 | ||||
-rw-r--r-- | arch/mips/kernel/signal32.c | 46 | ||||
-rw-r--r-- | arch/mips/kernel/signal_n32.c | 5 | ||||
-rw-r--r-- | arch/mips/kernel/smp.c | 4 | ||||
-rw-r--r-- | arch/mips/kernel/syscall.c | 7 | ||||
-rw-r--r-- | arch/mips/kernel/traps.c | 2 |
14 files changed, 142 insertions, 164 deletions
diff --git a/arch/mips/kernel/cpu-probe.c b/arch/mips/kernel/cpu-probe.c index 292f8b243a5e..58b3b14873cb 100644 --- a/arch/mips/kernel/cpu-probe.c +++ b/arch/mips/kernel/cpu-probe.c | |||
@@ -291,7 +291,7 @@ static inline void cpu_probe_legacy(struct cpuinfo_mips *c) | |||
291 | * for documentation. Commented out because it shares | 291 | * for documentation. Commented out because it shares |
292 | * it's c0_prid id number with the TX3900. | 292 | * it's c0_prid id number with the TX3900. |
293 | */ | 293 | */ |
294 | c->cputype = CPU_R4650; | 294 | c->cputype = CPU_R4650; |
295 | c->isa_level = MIPS_CPU_ISA_III; | 295 | c->isa_level = MIPS_CPU_ISA_III; |
296 | c->options = R4K_OPTS | MIPS_CPU_FPU | MIPS_CPU_LLSC; | 296 | c->options = R4K_OPTS | MIPS_CPU_FPU | MIPS_CPU_LLSC; |
297 | c->tlbsize = 48; | 297 | c->tlbsize = 48; |
@@ -604,7 +604,7 @@ static inline void cpu_probe_alchemy(struct cpuinfo_mips *c) | |||
604 | case PRID_IMP_AU1_REV2: | 604 | case PRID_IMP_AU1_REV2: |
605 | switch ((c->processor_id >> 24) & 0xff) { | 605 | switch ((c->processor_id >> 24) & 0xff) { |
606 | case 0: | 606 | case 0: |
607 | c->cputype = CPU_AU1000; | 607 | c->cputype = CPU_AU1000; |
608 | break; | 608 | break; |
609 | case 1: | 609 | case 1: |
610 | c->cputype = CPU_AU1500; | 610 | c->cputype = CPU_AU1500; |
@@ -705,7 +705,7 @@ __init void cpu_probe(void) | |||
705 | break; | 705 | break; |
706 | case PRID_COMP_PHILIPS: | 706 | case PRID_COMP_PHILIPS: |
707 | cpu_probe_philips(c); | 707 | cpu_probe_philips(c); |
708 | break; | 708 | break; |
709 | default: | 709 | default: |
710 | c->cputype = CPU_UNKNOWN; | 710 | c->cputype = CPU_UNKNOWN; |
711 | } | 711 | } |
diff --git a/arch/mips/kernel/gdb-low.S b/arch/mips/kernel/gdb-low.S index 83b8986f9401..235ad9f6bd35 100644 --- a/arch/mips/kernel/gdb-low.S +++ b/arch/mips/kernel/gdb-low.S | |||
@@ -41,7 +41,7 @@ | |||
41 | */ | 41 | */ |
42 | .align 5 | 42 | .align 5 |
43 | NESTED(trap_low, GDB_FR_SIZE, sp) | 43 | NESTED(trap_low, GDB_FR_SIZE, sp) |
44 | .set noat | 44 | .set noat |
45 | .set noreorder | 45 | .set noreorder |
46 | 46 | ||
47 | mfc0 k0, CP0_STATUS | 47 | mfc0 k0, CP0_STATUS |
diff --git a/arch/mips/kernel/irq.c b/arch/mips/kernel/irq.c index 7d93992e462c..3dd76b3d2967 100644 --- a/arch/mips/kernel/irq.c +++ b/arch/mips/kernel/irq.c | |||
@@ -68,9 +68,8 @@ int show_interrupts(struct seq_file *p, void *v) | |||
68 | 68 | ||
69 | if (i == 0) { | 69 | if (i == 0) { |
70 | seq_printf(p, " "); | 70 | seq_printf(p, " "); |
71 | for (j=0; j<NR_CPUS; j++) | 71 | for_each_online_cpu(j) |
72 | if (cpu_online(j)) | 72 | seq_printf(p, "CPU%d ",j); |
73 | seq_printf(p, "CPU%d ",j); | ||
74 | seq_putc(p, '\n'); | 73 | seq_putc(p, '\n'); |
75 | } | 74 | } |
76 | 75 | ||
@@ -83,9 +82,8 @@ int show_interrupts(struct seq_file *p, void *v) | |||
83 | #ifndef CONFIG_SMP | 82 | #ifndef CONFIG_SMP |
84 | seq_printf(p, "%10u ", kstat_irqs(i)); | 83 | seq_printf(p, "%10u ", kstat_irqs(i)); |
85 | #else | 84 | #else |
86 | for (j = 0; j < NR_CPUS; j++) | 85 | for_each_online_cpu(j) |
87 | if (cpu_online(j)) | 86 | seq_printf(p, "%10u ", kstat_cpu(j).irqs[i]); |
88 | seq_printf(p, "%10u ", kstat_cpu(j).irqs[i]); | ||
89 | #endif | 87 | #endif |
90 | seq_printf(p, " %14s", irq_desc[i].handler->typename); | 88 | seq_printf(p, " %14s", irq_desc[i].handler->typename); |
91 | seq_printf(p, " %s", action->name); | 89 | seq_printf(p, " %s", action->name); |
diff --git a/arch/mips/kernel/linux32.c b/arch/mips/kernel/linux32.c index e00e5f6e7fdd..013bc93688e8 100644 --- a/arch/mips/kernel/linux32.c +++ b/arch/mips/kernel/linux32.c | |||
@@ -69,7 +69,7 @@ | |||
69 | * Revalidate the inode. This is required for proper NFS attribute caching. | 69 | * Revalidate the inode. This is required for proper NFS attribute caching. |
70 | */ | 70 | */ |
71 | 71 | ||
72 | int cp_compat_stat(struct kstat *stat, struct compat_stat *statbuf) | 72 | int cp_compat_stat(struct kstat *stat, struct compat_stat __user *statbuf) |
73 | { | 73 | { |
74 | struct compat_stat tmp; | 74 | struct compat_stat tmp; |
75 | 75 | ||
@@ -106,6 +106,10 @@ sys32_mmap2(unsigned long addr, unsigned long len, unsigned long prot, | |||
106 | unsigned long error; | 106 | unsigned long error; |
107 | 107 | ||
108 | error = -EINVAL; | 108 | error = -EINVAL; |
109 | if (pgoff & (~PAGE_MASK >> 12)) | ||
110 | goto out; | ||
111 | pgoff >>= PAGE_SHIFT-12; | ||
112 | |||
109 | if (!(flags & MAP_ANONYMOUS)) { | 113 | if (!(flags & MAP_ANONYMOUS)) { |
110 | error = -EBADF; | 114 | error = -EBADF; |
111 | file = fget(fd); | 115 | file = fget(fd); |
@@ -125,7 +129,7 @@ out: | |||
125 | } | 129 | } |
126 | 130 | ||
127 | 131 | ||
128 | asmlinkage int sys_truncate64(const char *path, unsigned int high, | 132 | asmlinkage int sys_truncate64(const char __user *path, unsigned int high, |
129 | unsigned int low) | 133 | unsigned int low) |
130 | { | 134 | { |
131 | if ((int)high < 0) | 135 | if ((int)high < 0) |
@@ -161,12 +165,6 @@ out: | |||
161 | return error; | 165 | return error; |
162 | } | 166 | } |
163 | 167 | ||
164 | asmlinkage int | ||
165 | sys32_waitpid(compat_pid_t pid, unsigned int *stat_addr, int options) | ||
166 | { | ||
167 | return compat_sys_wait4(pid, stat_addr, options, NULL); | ||
168 | } | ||
169 | |||
170 | asmlinkage long | 168 | asmlinkage long |
171 | sysn32_waitid(int which, compat_pid_t pid, | 169 | sysn32_waitid(int which, compat_pid_t pid, |
172 | siginfo_t __user *uinfo, int options, | 170 | siginfo_t __user *uinfo, int options, |
@@ -175,6 +173,7 @@ sysn32_waitid(int which, compat_pid_t pid, | |||
175 | struct rusage ru; | 173 | struct rusage ru; |
176 | long ret; | 174 | long ret; |
177 | mm_segment_t old_fs = get_fs(); | 175 | mm_segment_t old_fs = get_fs(); |
176 | int si_signo; | ||
178 | 177 | ||
179 | if (!access_ok(VERIFY_WRITE, uinfo, sizeof(*uinfo))) | 178 | if (!access_ok(VERIFY_WRITE, uinfo, sizeof(*uinfo))) |
180 | return -EFAULT; | 179 | return -EFAULT; |
@@ -184,7 +183,9 @@ sysn32_waitid(int which, compat_pid_t pid, | |||
184 | uru ? (struct rusage __user *) &ru : NULL); | 183 | uru ? (struct rusage __user *) &ru : NULL); |
185 | set_fs (old_fs); | 184 | set_fs (old_fs); |
186 | 185 | ||
187 | if (ret < 0 || uinfo->si_signo == 0) | 186 | if (__get_user(si_signo, &uinfo->si_signo)) |
187 | return -EFAULT; | ||
188 | if (ret < 0 || si_signo == 0) | ||
188 | return ret; | 189 | return ret; |
189 | 190 | ||
190 | if (uru) | 191 | if (uru) |
@@ -208,14 +209,14 @@ struct sysinfo32 { | |||
208 | char _f[8]; | 209 | char _f[8]; |
209 | }; | 210 | }; |
210 | 211 | ||
211 | asmlinkage int sys32_sysinfo(struct sysinfo32 *info) | 212 | asmlinkage int sys32_sysinfo(struct sysinfo32 __user *info) |
212 | { | 213 | { |
213 | struct sysinfo s; | 214 | struct sysinfo s; |
214 | int ret, err; | 215 | int ret, err; |
215 | mm_segment_t old_fs = get_fs (); | 216 | mm_segment_t old_fs = get_fs (); |
216 | 217 | ||
217 | set_fs (KERNEL_DS); | 218 | set_fs (KERNEL_DS); |
218 | ret = sys_sysinfo(&s); | 219 | ret = sys_sysinfo((struct sysinfo __user *)&s); |
219 | set_fs (old_fs); | 220 | set_fs (old_fs); |
220 | err = put_user (s.uptime, &info->uptime); | 221 | err = put_user (s.uptime, &info->uptime); |
221 | err |= __put_user (s.loads[0], &info->loads[0]); | 222 | err |= __put_user (s.loads[0], &info->loads[0]); |
@@ -245,11 +246,11 @@ struct rlimit32 { | |||
245 | }; | 246 | }; |
246 | 247 | ||
247 | #ifdef __MIPSEB__ | 248 | #ifdef __MIPSEB__ |
248 | asmlinkage long sys32_truncate64(const char * path, unsigned long __dummy, | 249 | asmlinkage long sys32_truncate64(const char __user * path, unsigned long __dummy, |
249 | int length_hi, int length_lo) | 250 | int length_hi, int length_lo) |
250 | #endif | 251 | #endif |
251 | #ifdef __MIPSEL__ | 252 | #ifdef __MIPSEL__ |
252 | asmlinkage long sys32_truncate64(const char * path, unsigned long __dummy, | 253 | asmlinkage long sys32_truncate64(const char __user * path, unsigned long __dummy, |
253 | int length_lo, int length_hi) | 254 | int length_lo, int length_hi) |
254 | #endif | 255 | #endif |
255 | { | 256 | { |
@@ -277,7 +278,7 @@ asmlinkage long sys32_ftruncate64(unsigned int fd, unsigned long __dummy, | |||
277 | } | 278 | } |
278 | 279 | ||
279 | static inline long | 280 | static inline long |
280 | get_tv32(struct timeval *o, struct compat_timeval *i) | 281 | get_tv32(struct timeval *o, struct compat_timeval __user *i) |
281 | { | 282 | { |
282 | return (!access_ok(VERIFY_READ, i, sizeof(*i)) || | 283 | return (!access_ok(VERIFY_READ, i, sizeof(*i)) || |
283 | (__get_user(o->tv_sec, &i->tv_sec) | | 284 | (__get_user(o->tv_sec, &i->tv_sec) | |
@@ -285,7 +286,7 @@ get_tv32(struct timeval *o, struct compat_timeval *i) | |||
285 | } | 286 | } |
286 | 287 | ||
287 | static inline long | 288 | static inline long |
288 | put_tv32(struct compat_timeval *o, struct timeval *i) | 289 | put_tv32(struct compat_timeval __user *o, struct timeval *i) |
289 | { | 290 | { |
290 | return (!access_ok(VERIFY_WRITE, o, sizeof(*o)) || | 291 | return (!access_ok(VERIFY_WRITE, o, sizeof(*o)) || |
291 | (__put_user(i->tv_sec, &o->tv_sec) | | 292 | (__put_user(i->tv_sec, &o->tv_sec) | |
@@ -295,7 +296,7 @@ put_tv32(struct compat_timeval *o, struct timeval *i) | |||
295 | extern struct timezone sys_tz; | 296 | extern struct timezone sys_tz; |
296 | 297 | ||
297 | asmlinkage int | 298 | asmlinkage int |
298 | sys32_gettimeofday(struct compat_timeval *tv, struct timezone *tz) | 299 | sys32_gettimeofday(struct compat_timeval __user *tv, struct timezone __user *tz) |
299 | { | 300 | { |
300 | if (tv) { | 301 | if (tv) { |
301 | struct timeval ktv; | 302 | struct timeval ktv; |
@@ -310,7 +311,7 @@ sys32_gettimeofday(struct compat_timeval *tv, struct timezone *tz) | |||
310 | return 0; | 311 | return 0; |
311 | } | 312 | } |
312 | 313 | ||
313 | static inline long get_ts32(struct timespec *o, struct compat_timeval *i) | 314 | static inline long get_ts32(struct timespec *o, struct compat_timeval __user *i) |
314 | { | 315 | { |
315 | long usec; | 316 | long usec; |
316 | 317 | ||
@@ -325,7 +326,7 @@ static inline long get_ts32(struct timespec *o, struct compat_timeval *i) | |||
325 | } | 326 | } |
326 | 327 | ||
327 | asmlinkage int | 328 | asmlinkage int |
328 | sys32_settimeofday(struct compat_timeval *tv, struct timezone *tz) | 329 | sys32_settimeofday(struct compat_timeval __user *tv, struct timezone __user *tz) |
329 | { | 330 | { |
330 | struct timespec kts; | 331 | struct timespec kts; |
331 | struct timezone ktz; | 332 | struct timezone ktz; |
@@ -343,7 +344,7 @@ sys32_settimeofday(struct compat_timeval *tv, struct timezone *tz) | |||
343 | } | 344 | } |
344 | 345 | ||
345 | asmlinkage int sys32_llseek(unsigned int fd, unsigned int offset_high, | 346 | asmlinkage int sys32_llseek(unsigned int fd, unsigned int offset_high, |
346 | unsigned int offset_low, loff_t * result, | 347 | unsigned int offset_low, loff_t __user * result, |
347 | unsigned int origin) | 348 | unsigned int origin) |
348 | { | 349 | { |
349 | return sys_llseek(fd, offset_high, offset_low, result, origin); | 350 | return sys_llseek(fd, offset_high, offset_low, result, origin); |
@@ -353,12 +354,12 @@ asmlinkage int sys32_llseek(unsigned int fd, unsigned int offset_high, | |||
353 | lseek back to original location. They fail just like lseek does on | 354 | lseek back to original location. They fail just like lseek does on |
354 | non-seekable files. */ | 355 | non-seekable files. */ |
355 | 356 | ||
356 | asmlinkage ssize_t sys32_pread(unsigned int fd, char * buf, | 357 | asmlinkage ssize_t sys32_pread(unsigned int fd, char __user * buf, |
357 | size_t count, u32 unused, u64 a4, u64 a5) | 358 | size_t count, u32 unused, u64 a4, u64 a5) |
358 | { | 359 | { |
359 | ssize_t ret; | 360 | ssize_t ret; |
360 | struct file * file; | 361 | struct file * file; |
361 | ssize_t (*read)(struct file *, char *, size_t, loff_t *); | 362 | ssize_t (*read)(struct file *, char __user *, size_t, loff_t *); |
362 | loff_t pos; | 363 | loff_t pos; |
363 | 364 | ||
364 | ret = -EBADF; | 365 | ret = -EBADF; |
@@ -388,12 +389,12 @@ bad_file: | |||
388 | return ret; | 389 | return ret; |
389 | } | 390 | } |
390 | 391 | ||
391 | asmlinkage ssize_t sys32_pwrite(unsigned int fd, const char * buf, | 392 | asmlinkage ssize_t sys32_pwrite(unsigned int fd, const char __user * buf, |
392 | size_t count, u32 unused, u64 a4, u64 a5) | 393 | size_t count, u32 unused, u64 a4, u64 a5) |
393 | { | 394 | { |
394 | ssize_t ret; | 395 | ssize_t ret; |
395 | struct file * file; | 396 | struct file * file; |
396 | ssize_t (*write)(struct file *, const char *, size_t, loff_t *); | 397 | ssize_t (*write)(struct file *, const char __user *, size_t, loff_t *); |
397 | loff_t pos; | 398 | loff_t pos; |
398 | 399 | ||
399 | ret = -EBADF; | 400 | ret = -EBADF; |
@@ -426,14 +427,14 @@ bad_file: | |||
426 | } | 427 | } |
427 | 428 | ||
428 | asmlinkage int sys32_sched_rr_get_interval(compat_pid_t pid, | 429 | asmlinkage int sys32_sched_rr_get_interval(compat_pid_t pid, |
429 | struct compat_timespec *interval) | 430 | struct compat_timespec __user *interval) |
430 | { | 431 | { |
431 | struct timespec t; | 432 | struct timespec t; |
432 | int ret; | 433 | int ret; |
433 | mm_segment_t old_fs = get_fs (); | 434 | mm_segment_t old_fs = get_fs (); |
434 | 435 | ||
435 | set_fs (KERNEL_DS); | 436 | set_fs (KERNEL_DS); |
436 | ret = sys_sched_rr_get_interval(pid, &t); | 437 | ret = sys_sched_rr_get_interval(pid, (struct timespec __user *)&t); |
437 | set_fs (old_fs); | 438 | set_fs (old_fs); |
438 | if (put_user (t.tv_sec, &interval->tv_sec) || | 439 | if (put_user (t.tv_sec, &interval->tv_sec) || |
439 | __put_user (t.tv_nsec, &interval->tv_nsec)) | 440 | __put_user (t.tv_nsec, &interval->tv_nsec)) |
@@ -551,7 +552,7 @@ struct ipc_kludge32 { | |||
551 | }; | 552 | }; |
552 | 553 | ||
553 | static int | 554 | static int |
554 | do_sys32_semctl(int first, int second, int third, void *uptr) | 555 | do_sys32_semctl(int first, int second, int third, void __user *uptr) |
555 | { | 556 | { |
556 | union semun fourth; | 557 | union semun fourth; |
557 | u32 pad; | 558 | u32 pad; |
@@ -562,12 +563,12 @@ do_sys32_semctl(int first, int second, int third, void *uptr) | |||
562 | if (!uptr) | 563 | if (!uptr) |
563 | return -EINVAL; | 564 | return -EINVAL; |
564 | err = -EFAULT; | 565 | err = -EFAULT; |
565 | if (get_user (pad, (u32 *)uptr)) | 566 | if (get_user (pad, (u32 __user *)uptr)) |
566 | return err; | 567 | return err; |
567 | if ((third & ~IPC_64) == SETVAL) | 568 | if ((third & ~IPC_64) == SETVAL) |
568 | fourth.val = (int)pad; | 569 | fourth.val = (int)pad; |
569 | else | 570 | else |
570 | fourth.__pad = (void *)A(pad); | 571 | fourth.__pad = (void __user *)A(pad); |
571 | switch (third & ~IPC_64) { | 572 | switch (third & ~IPC_64) { |
572 | case IPC_INFO: | 573 | case IPC_INFO: |
573 | case IPC_RMID: | 574 | case IPC_RMID: |
@@ -585,14 +586,14 @@ do_sys32_semctl(int first, int second, int third, void *uptr) | |||
585 | 586 | ||
586 | case IPC_STAT: | 587 | case IPC_STAT: |
587 | case SEM_STAT: | 588 | case SEM_STAT: |
588 | fourth.__pad = &s; | 589 | fourth.__pad = (struct semid64_ds __user *)&s; |
589 | old_fs = get_fs(); | 590 | old_fs = get_fs(); |
590 | set_fs(KERNEL_DS); | 591 | set_fs(KERNEL_DS); |
591 | err = sys_semctl(first, second, third | IPC_64, fourth); | 592 | err = sys_semctl(first, second, third | IPC_64, fourth); |
592 | set_fs(old_fs); | 593 | set_fs(old_fs); |
593 | 594 | ||
594 | if (third & IPC_64) { | 595 | if (third & IPC_64) { |
595 | struct semid64_ds32 *usp64 = (struct semid64_ds32 *) A(pad); | 596 | struct semid64_ds32 __user *usp64 = (struct semid64_ds32 __user *) A(pad); |
596 | 597 | ||
597 | if (!access_ok(VERIFY_WRITE, usp64, sizeof(*usp64))) { | 598 | if (!access_ok(VERIFY_WRITE, usp64, sizeof(*usp64))) { |
598 | err = -EFAULT; | 599 | err = -EFAULT; |
@@ -609,7 +610,7 @@ do_sys32_semctl(int first, int second, int third, void *uptr) | |||
609 | err2 |= __put_user(s.sem_ctime, &usp64->sem_ctime); | 610 | err2 |= __put_user(s.sem_ctime, &usp64->sem_ctime); |
610 | err2 |= __put_user(s.sem_nsems, &usp64->sem_nsems); | 611 | err2 |= __put_user(s.sem_nsems, &usp64->sem_nsems); |
611 | } else { | 612 | } else { |
612 | struct semid_ds32 *usp32 = (struct semid_ds32 *) A(pad); | 613 | struct semid_ds32 __user *usp32 = (struct semid_ds32 __user *) A(pad); |
613 | 614 | ||
614 | if (!access_ok(VERIFY_WRITE, usp32, sizeof(*usp32))) { | 615 | if (!access_ok(VERIFY_WRITE, usp32, sizeof(*usp32))) { |
615 | err = -EFAULT; | 616 | err = -EFAULT; |
@@ -639,9 +640,9 @@ do_sys32_semctl(int first, int second, int third, void *uptr) | |||
639 | } | 640 | } |
640 | 641 | ||
641 | static int | 642 | static int |
642 | do_sys32_msgsnd (int first, int second, int third, void *uptr) | 643 | do_sys32_msgsnd (int first, int second, int third, void __user *uptr) |
643 | { | 644 | { |
644 | struct msgbuf32 *up = (struct msgbuf32 *)uptr; | 645 | struct msgbuf32 __user *up = (struct msgbuf32 __user *)uptr; |
645 | struct msgbuf *p; | 646 | struct msgbuf *p; |
646 | mm_segment_t old_fs; | 647 | mm_segment_t old_fs; |
647 | int err; | 648 | int err; |
@@ -660,7 +661,7 @@ do_sys32_msgsnd (int first, int second, int third, void *uptr) | |||
660 | goto out; | 661 | goto out; |
661 | old_fs = get_fs (); | 662 | old_fs = get_fs (); |
662 | set_fs (KERNEL_DS); | 663 | set_fs (KERNEL_DS); |
663 | err = sys_msgsnd (first, p, second, third); | 664 | err = sys_msgsnd (first, (struct msgbuf __user *)p, second, third); |
664 | set_fs (old_fs); | 665 | set_fs (old_fs); |
665 | out: | 666 | out: |
666 | kfree (p); | 667 | kfree (p); |
@@ -670,15 +671,15 @@ out: | |||
670 | 671 | ||
671 | static int | 672 | static int |
672 | do_sys32_msgrcv (int first, int second, int msgtyp, int third, | 673 | do_sys32_msgrcv (int first, int second, int msgtyp, int third, |
673 | int version, void *uptr) | 674 | int version, void __user *uptr) |
674 | { | 675 | { |
675 | struct msgbuf32 *up; | 676 | struct msgbuf32 __user *up; |
676 | struct msgbuf *p; | 677 | struct msgbuf *p; |
677 | mm_segment_t old_fs; | 678 | mm_segment_t old_fs; |
678 | int err; | 679 | int err; |
679 | 680 | ||
680 | if (!version) { | 681 | if (!version) { |
681 | struct ipc_kludge32 *uipck = (struct ipc_kludge32 *)uptr; | 682 | struct ipc_kludge32 __user *uipck = (struct ipc_kludge32 __user *)uptr; |
682 | struct ipc_kludge32 ipck; | 683 | struct ipc_kludge32 ipck; |
683 | 684 | ||
684 | err = -EINVAL; | 685 | err = -EINVAL; |
@@ -687,7 +688,7 @@ do_sys32_msgrcv (int first, int second, int msgtyp, int third, | |||
687 | err = -EFAULT; | 688 | err = -EFAULT; |
688 | if (copy_from_user (&ipck, uipck, sizeof (struct ipc_kludge32))) | 689 | if (copy_from_user (&ipck, uipck, sizeof (struct ipc_kludge32))) |
689 | goto out; | 690 | goto out; |
690 | uptr = (void *)AA(ipck.msgp); | 691 | uptr = (void __user *)AA(ipck.msgp); |
691 | msgtyp = ipck.msgtyp; | 692 | msgtyp = ipck.msgtyp; |
692 | } | 693 | } |
693 | 694 | ||
@@ -699,11 +700,11 @@ do_sys32_msgrcv (int first, int second, int msgtyp, int third, | |||
699 | goto out; | 700 | goto out; |
700 | old_fs = get_fs (); | 701 | old_fs = get_fs (); |
701 | set_fs (KERNEL_DS); | 702 | set_fs (KERNEL_DS); |
702 | err = sys_msgrcv (first, p, second + 4, msgtyp, third); | 703 | err = sys_msgrcv (first, (struct msgbuf __user *)p, second + 4, msgtyp, third); |
703 | set_fs (old_fs); | 704 | set_fs (old_fs); |
704 | if (err < 0) | 705 | if (err < 0) |
705 | goto free_then_out; | 706 | goto free_then_out; |
706 | up = (struct msgbuf32 *)uptr; | 707 | up = (struct msgbuf32 __user *)uptr; |
707 | if (put_user (p->mtype, &up->mtype) || | 708 | if (put_user (p->mtype, &up->mtype) || |
708 | __copy_to_user (&up->mtext, p->mtext, err)) | 709 | __copy_to_user (&up->mtext, p->mtext, err)) |
709 | err = -EFAULT; | 710 | err = -EFAULT; |
@@ -714,19 +715,19 @@ out: | |||
714 | } | 715 | } |
715 | 716 | ||
716 | static int | 717 | static int |
717 | do_sys32_msgctl (int first, int second, void *uptr) | 718 | do_sys32_msgctl (int first, int second, void __user *uptr) |
718 | { | 719 | { |
719 | int err = -EINVAL, err2; | 720 | int err = -EINVAL, err2; |
720 | struct msqid64_ds m; | 721 | struct msqid64_ds m; |
721 | struct msqid_ds32 *up32 = (struct msqid_ds32 *)uptr; | 722 | struct msqid_ds32 __user *up32 = (struct msqid_ds32 __user *)uptr; |
722 | struct msqid64_ds32 *up64 = (struct msqid64_ds32 *)uptr; | 723 | struct msqid64_ds32 __user *up64 = (struct msqid64_ds32 __user *)uptr; |
723 | mm_segment_t old_fs; | 724 | mm_segment_t old_fs; |
724 | 725 | ||
725 | switch (second & ~IPC_64) { | 726 | switch (second & ~IPC_64) { |
726 | case IPC_INFO: | 727 | case IPC_INFO: |
727 | case IPC_RMID: | 728 | case IPC_RMID: |
728 | case MSG_INFO: | 729 | case MSG_INFO: |
729 | err = sys_msgctl (first, second, (struct msqid_ds *)uptr); | 730 | err = sys_msgctl (first, second, (struct msqid_ds __user *)uptr); |
730 | break; | 731 | break; |
731 | 732 | ||
732 | case IPC_SET: | 733 | case IPC_SET: |
@@ -753,7 +754,7 @@ do_sys32_msgctl (int first, int second, void *uptr) | |||
753 | break; | 754 | break; |
754 | old_fs = get_fs(); | 755 | old_fs = get_fs(); |
755 | set_fs(KERNEL_DS); | 756 | set_fs(KERNEL_DS); |
756 | err = sys_msgctl(first, second | IPC_64, (struct msqid_ds *)&m); | 757 | err = sys_msgctl(first, second | IPC_64, (struct msqid_ds __user *)&m); |
757 | set_fs(old_fs); | 758 | set_fs(old_fs); |
758 | break; | 759 | break; |
759 | 760 | ||
@@ -761,7 +762,7 @@ do_sys32_msgctl (int first, int second, void *uptr) | |||
761 | case MSG_STAT: | 762 | case MSG_STAT: |
762 | old_fs = get_fs(); | 763 | old_fs = get_fs(); |
763 | set_fs(KERNEL_DS); | 764 | set_fs(KERNEL_DS); |
764 | err = sys_msgctl(first, second | IPC_64, (struct msqid_ds *)&m); | 765 | err = sys_msgctl(first, second | IPC_64, (struct msqid_ds __user *)&m); |
765 | set_fs(old_fs); | 766 | set_fs(old_fs); |
766 | if (second & IPC_64) { | 767 | if (second & IPC_64) { |
767 | if (!access_ok(VERIFY_WRITE, up64, sizeof(*up64))) { | 768 | if (!access_ok(VERIFY_WRITE, up64, sizeof(*up64))) { |
@@ -815,10 +816,10 @@ do_sys32_msgctl (int first, int second, void *uptr) | |||
815 | } | 816 | } |
816 | 817 | ||
817 | static int | 818 | static int |
818 | do_sys32_shmat (int first, int second, int third, int version, void *uptr) | 819 | do_sys32_shmat (int first, int second, int third, int version, void __user *uptr) |
819 | { | 820 | { |
820 | unsigned long raddr; | 821 | unsigned long raddr; |
821 | u32 *uaddr = (u32 *)A((u32)third); | 822 | u32 __user *uaddr = (u32 __user *)A((u32)third); |
822 | int err = -EINVAL; | 823 | int err = -EINVAL; |
823 | 824 | ||
824 | if (version == 1) | 825 | if (version == 1) |
@@ -837,11 +838,11 @@ struct shm_info32 { | |||
837 | }; | 838 | }; |
838 | 839 | ||
839 | static int | 840 | static int |
840 | do_sys32_shmctl (int first, int second, void *uptr) | 841 | do_sys32_shmctl (int first, int second, void __user *uptr) |
841 | { | 842 | { |
842 | struct shmid64_ds32 *up64 = (struct shmid64_ds32 *)uptr; | 843 | struct shmid64_ds32 __user *up64 = (struct shmid64_ds32 __user *)uptr; |
843 | struct shmid_ds32 *up32 = (struct shmid_ds32 *)uptr; | 844 | struct shmid_ds32 __user *up32 = (struct shmid_ds32 __user *)uptr; |
844 | struct shm_info32 *uip = (struct shm_info32 *)uptr; | 845 | struct shm_info32 __user *uip = (struct shm_info32 __user *)uptr; |
845 | int err = -EFAULT, err2; | 846 | int err = -EFAULT, err2; |
846 | struct shmid64_ds s64; | 847 | struct shmid64_ds s64; |
847 | mm_segment_t old_fs; | 848 | mm_segment_t old_fs; |
@@ -854,7 +855,7 @@ do_sys32_shmctl (int first, int second, void *uptr) | |||
854 | case IPC_RMID: | 855 | case IPC_RMID: |
855 | case SHM_LOCK: | 856 | case SHM_LOCK: |
856 | case SHM_UNLOCK: | 857 | case SHM_UNLOCK: |
857 | err = sys_shmctl(first, second, (struct shmid_ds *)uptr); | 858 | err = sys_shmctl(first, second, (struct shmid_ds __user *)uptr); |
858 | break; | 859 | break; |
859 | case IPC_SET: | 860 | case IPC_SET: |
860 | if (second & IPC_64) { | 861 | if (second & IPC_64) { |
@@ -870,7 +871,7 @@ do_sys32_shmctl (int first, int second, void *uptr) | |||
870 | break; | 871 | break; |
871 | old_fs = get_fs(); | 872 | old_fs = get_fs(); |
872 | set_fs(KERNEL_DS); | 873 | set_fs(KERNEL_DS); |
873 | err = sys_shmctl(first, second & ~IPC_64, &s); | 874 | err = sys_shmctl(first, second & ~IPC_64, (struct shmid_ds __user *)&s); |
874 | set_fs(old_fs); | 875 | set_fs(old_fs); |
875 | break; | 876 | break; |
876 | 877 | ||
@@ -878,7 +879,7 @@ do_sys32_shmctl (int first, int second, void *uptr) | |||
878 | case SHM_STAT: | 879 | case SHM_STAT: |
879 | old_fs = get_fs(); | 880 | old_fs = get_fs(); |
880 | set_fs(KERNEL_DS); | 881 | set_fs(KERNEL_DS); |
881 | err = sys_shmctl(first, second | IPC_64, (void *) &s64); | 882 | err = sys_shmctl(first, second | IPC_64, (void __user *) &s64); |
882 | set_fs(old_fs); | 883 | set_fs(old_fs); |
883 | if (err < 0) | 884 | if (err < 0) |
884 | break; | 885 | break; |
@@ -928,7 +929,7 @@ do_sys32_shmctl (int first, int second, void *uptr) | |||
928 | case SHM_INFO: | 929 | case SHM_INFO: |
929 | old_fs = get_fs(); | 930 | old_fs = get_fs(); |
930 | set_fs(KERNEL_DS); | 931 | set_fs(KERNEL_DS); |
931 | err = sys_shmctl(first, second, (void *)&si); | 932 | err = sys_shmctl(first, second, (void __user *)&si); |
932 | set_fs(old_fs); | 933 | set_fs(old_fs); |
933 | if (err < 0) | 934 | if (err < 0) |
934 | break; | 935 | break; |
@@ -950,11 +951,11 @@ do_sys32_shmctl (int first, int second, void *uptr) | |||
950 | return err; | 951 | return err; |
951 | } | 952 | } |
952 | 953 | ||
953 | static int sys32_semtimedop(int semid, struct sembuf *tsems, int nsems, | 954 | static int sys32_semtimedop(int semid, struct sembuf __user *tsems, int nsems, |
954 | const struct compat_timespec *timeout32) | 955 | const struct compat_timespec __user *timeout32) |
955 | { | 956 | { |
956 | struct compat_timespec t32; | 957 | struct compat_timespec t32; |
957 | struct timespec *t64 = compat_alloc_user_space(sizeof(*t64)); | 958 | struct timespec __user *t64 = compat_alloc_user_space(sizeof(*t64)); |
958 | 959 | ||
959 | if (copy_from_user(&t32, timeout32, sizeof(t32))) | 960 | if (copy_from_user(&t32, timeout32, sizeof(t32))) |
960 | return -EFAULT; | 961 | return -EFAULT; |
@@ -977,11 +978,11 @@ sys32_ipc (u32 call, int first, int second, int third, u32 ptr, u32 fifth) | |||
977 | switch (call) { | 978 | switch (call) { |
978 | case SEMOP: | 979 | case SEMOP: |
979 | /* struct sembuf is the same on 32 and 64bit :)) */ | 980 | /* struct sembuf is the same on 32 and 64bit :)) */ |
980 | err = sys_semtimedop (first, (struct sembuf *)AA(ptr), second, | 981 | err = sys_semtimedop (first, (struct sembuf __user *)AA(ptr), second, |
981 | NULL); | 982 | NULL); |
982 | break; | 983 | break; |
983 | case SEMTIMEDOP: | 984 | case SEMTIMEDOP: |
984 | err = sys32_semtimedop (first, (struct sembuf *)AA(ptr), second, | 985 | err = sys32_semtimedop (first, (struct sembuf __user *)AA(ptr), second, |
985 | (const struct compat_timespec __user *)AA(fifth)); | 986 | (const struct compat_timespec __user *)AA(fifth)); |
986 | break; | 987 | break; |
987 | case SEMGET: | 988 | case SEMGET: |
@@ -989,36 +990,36 @@ sys32_ipc (u32 call, int first, int second, int third, u32 ptr, u32 fifth) | |||
989 | break; | 990 | break; |
990 | case SEMCTL: | 991 | case SEMCTL: |
991 | err = do_sys32_semctl (first, second, third, | 992 | err = do_sys32_semctl (first, second, third, |
992 | (void *)AA(ptr)); | 993 | (void __user *)AA(ptr)); |
993 | break; | 994 | break; |
994 | 995 | ||
995 | case MSGSND: | 996 | case MSGSND: |
996 | err = do_sys32_msgsnd (first, second, third, | 997 | err = do_sys32_msgsnd (first, second, third, |
997 | (void *)AA(ptr)); | 998 | (void __user *)AA(ptr)); |
998 | break; | 999 | break; |
999 | case MSGRCV: | 1000 | case MSGRCV: |
1000 | err = do_sys32_msgrcv (first, second, fifth, third, | 1001 | err = do_sys32_msgrcv (first, second, fifth, third, |
1001 | version, (void *)AA(ptr)); | 1002 | version, (void __user *)AA(ptr)); |
1002 | break; | 1003 | break; |
1003 | case MSGGET: | 1004 | case MSGGET: |
1004 | err = sys_msgget ((key_t) first, second); | 1005 | err = sys_msgget ((key_t) first, second); |
1005 | break; | 1006 | break; |
1006 | case MSGCTL: | 1007 | case MSGCTL: |
1007 | err = do_sys32_msgctl (first, second, (void *)AA(ptr)); | 1008 | err = do_sys32_msgctl (first, second, (void __user *)AA(ptr)); |
1008 | break; | 1009 | break; |
1009 | 1010 | ||
1010 | case SHMAT: | 1011 | case SHMAT: |
1011 | err = do_sys32_shmat (first, second, third, | 1012 | err = do_sys32_shmat (first, second, third, |
1012 | version, (void *)AA(ptr)); | 1013 | version, (void __user *)AA(ptr)); |
1013 | break; | 1014 | break; |
1014 | case SHMDT: | 1015 | case SHMDT: |
1015 | err = sys_shmdt ((char *)A(ptr)); | 1016 | err = sys_shmdt ((char __user *)A(ptr)); |
1016 | break; | 1017 | break; |
1017 | case SHMGET: | 1018 | case SHMGET: |
1018 | err = sys_shmget (first, (unsigned)second, third); | 1019 | err = sys_shmget (first, (unsigned)second, third); |
1019 | break; | 1020 | break; |
1020 | case SHMCTL: | 1021 | case SHMCTL: |
1021 | err = do_sys32_shmctl (first, second, (void *)AA(ptr)); | 1022 | err = do_sys32_shmctl (first, second, (void __user *)AA(ptr)); |
1022 | break; | 1023 | break; |
1023 | default: | 1024 | default: |
1024 | err = -EINVAL; | 1025 | err = -EINVAL; |
@@ -1029,7 +1030,7 @@ sys32_ipc (u32 call, int first, int second, int third, u32 ptr, u32 fifth) | |||
1029 | } | 1030 | } |
1030 | 1031 | ||
1031 | asmlinkage long sys32_shmat(int shmid, char __user *shmaddr, | 1032 | asmlinkage long sys32_shmat(int shmid, char __user *shmaddr, |
1032 | int shmflg, int32_t *addr) | 1033 | int shmflg, int32_t __user *addr) |
1033 | { | 1034 | { |
1034 | unsigned long raddr; | 1035 | unsigned long raddr; |
1035 | int err; | 1036 | int err; |
@@ -1054,12 +1055,13 @@ struct sysctl_args32 | |||
1054 | 1055 | ||
1055 | #ifdef CONFIG_SYSCTL | 1056 | #ifdef CONFIG_SYSCTL |
1056 | 1057 | ||
1057 | asmlinkage long sys32_sysctl(struct sysctl_args32 *args) | 1058 | asmlinkage long sys32_sysctl(struct sysctl_args32 __user *args) |
1058 | { | 1059 | { |
1059 | struct sysctl_args32 tmp; | 1060 | struct sysctl_args32 tmp; |
1060 | int error; | 1061 | int error; |
1061 | size_t oldlen, *oldlenp = NULL; | 1062 | size_t oldlen; |
1062 | unsigned long addr = (((long)&args->__unused[0]) + 7) & ~7; | 1063 | size_t __user *oldlenp = NULL; |
1064 | unsigned long addr = (((unsigned long)&args->__unused[0]) + 7) & ~7; | ||
1063 | 1065 | ||
1064 | if (copy_from_user(&tmp, args, sizeof(tmp))) | 1066 | if (copy_from_user(&tmp, args, sizeof(tmp))) |
1065 | return -EFAULT; | 1067 | return -EFAULT; |
@@ -1071,20 +1073,20 @@ asmlinkage long sys32_sysctl(struct sysctl_args32 *args) | |||
1071 | basically copy the whole sysctl.c here, and | 1073 | basically copy the whole sysctl.c here, and |
1072 | glibc's __sysctl uses rw memory for the structure | 1074 | glibc's __sysctl uses rw memory for the structure |
1073 | anyway. */ | 1075 | anyway. */ |
1074 | if (get_user(oldlen, (u32 *)A(tmp.oldlenp)) || | 1076 | if (get_user(oldlen, (u32 __user *)A(tmp.oldlenp)) || |
1075 | put_user(oldlen, (size_t *)addr)) | 1077 | put_user(oldlen, (size_t __user *)addr)) |
1076 | return -EFAULT; | 1078 | return -EFAULT; |
1077 | oldlenp = (size_t *)addr; | 1079 | oldlenp = (size_t __user *)addr; |
1078 | } | 1080 | } |
1079 | 1081 | ||
1080 | lock_kernel(); | 1082 | lock_kernel(); |
1081 | error = do_sysctl((int *)A(tmp.name), tmp.nlen, (void *)A(tmp.oldval), | 1083 | error = do_sysctl((int __user *)A(tmp.name), tmp.nlen, (void __user *)A(tmp.oldval), |
1082 | oldlenp, (void *)A(tmp.newval), tmp.newlen); | 1084 | oldlenp, (void __user *)A(tmp.newval), tmp.newlen); |
1083 | unlock_kernel(); | 1085 | unlock_kernel(); |
1084 | if (oldlenp) { | 1086 | if (oldlenp) { |
1085 | if (!error) { | 1087 | if (!error) { |
1086 | if (get_user(oldlen, (size_t *)addr) || | 1088 | if (get_user(oldlen, (size_t __user *)addr) || |
1087 | put_user(oldlen, (u32 *)A(tmp.oldlenp))) | 1089 | put_user(oldlen, (u32 __user *)A(tmp.oldlenp))) |
1088 | error = -EFAULT; | 1090 | error = -EFAULT; |
1089 | } | 1091 | } |
1090 | copy_to_user(args->__unused, tmp.__unused, sizeof(tmp.__unused)); | 1092 | copy_to_user(args->__unused, tmp.__unused, sizeof(tmp.__unused)); |
@@ -1094,7 +1096,7 @@ asmlinkage long sys32_sysctl(struct sysctl_args32 *args) | |||
1094 | 1096 | ||
1095 | #endif /* CONFIG_SYSCTL */ | 1097 | #endif /* CONFIG_SYSCTL */ |
1096 | 1098 | ||
1097 | asmlinkage long sys32_newuname(struct new_utsname * name) | 1099 | asmlinkage long sys32_newuname(struct new_utsname __user * name) |
1098 | { | 1100 | { |
1099 | int ret = 0; | 1101 | int ret = 0; |
1100 | 1102 | ||
@@ -1129,9 +1131,9 @@ struct ustat32 { | |||
1129 | char f_fpack[6]; | 1131 | char f_fpack[6]; |
1130 | }; | 1132 | }; |
1131 | 1133 | ||
1132 | extern asmlinkage long sys_ustat(dev_t dev, struct ustat * ubuf); | 1134 | extern asmlinkage long sys_ustat(dev_t dev, struct ustat __user * ubuf); |
1133 | 1135 | ||
1134 | asmlinkage int sys32_ustat(dev_t dev, struct ustat32 * ubuf32) | 1136 | asmlinkage int sys32_ustat(dev_t dev, struct ustat32 __user * ubuf32) |
1135 | { | 1137 | { |
1136 | int err; | 1138 | int err; |
1137 | struct ustat tmp; | 1139 | struct ustat tmp; |
@@ -1139,7 +1141,7 @@ asmlinkage int sys32_ustat(dev_t dev, struct ustat32 * ubuf32) | |||
1139 | mm_segment_t old_fs = get_fs(); | 1141 | mm_segment_t old_fs = get_fs(); |
1140 | 1142 | ||
1141 | set_fs(KERNEL_DS); | 1143 | set_fs(KERNEL_DS); |
1142 | err = sys_ustat(dev, &tmp); | 1144 | err = sys_ustat(dev, (struct ustat __user *)&tmp); |
1143 | set_fs (old_fs); | 1145 | set_fs (old_fs); |
1144 | 1146 | ||
1145 | if (err) | 1147 | if (err) |
@@ -1172,7 +1174,7 @@ struct timex32 { | |||
1172 | 1174 | ||
1173 | extern int do_adjtimex(struct timex *); | 1175 | extern int do_adjtimex(struct timex *); |
1174 | 1176 | ||
1175 | asmlinkage int sys32_adjtimex(struct timex32 *utp) | 1177 | asmlinkage int sys32_adjtimex(struct timex32 __user *utp) |
1176 | { | 1178 | { |
1177 | struct timex txc; | 1179 | struct timex txc; |
1178 | int ret; | 1180 | int ret; |
@@ -1228,7 +1230,7 @@ asmlinkage int sys32_adjtimex(struct timex32 *utp) | |||
1228 | return ret; | 1230 | return ret; |
1229 | } | 1231 | } |
1230 | 1232 | ||
1231 | asmlinkage int sys32_sendfile(int out_fd, int in_fd, compat_off_t *offset, | 1233 | asmlinkage int sys32_sendfile(int out_fd, int in_fd, compat_off_t __user *offset, |
1232 | s32 count) | 1234 | s32 count) |
1233 | { | 1235 | { |
1234 | mm_segment_t old_fs = get_fs(); | 1236 | mm_segment_t old_fs = get_fs(); |
@@ -1239,7 +1241,7 @@ asmlinkage int sys32_sendfile(int out_fd, int in_fd, compat_off_t *offset, | |||
1239 | return -EFAULT; | 1241 | return -EFAULT; |
1240 | 1242 | ||
1241 | set_fs(KERNEL_DS); | 1243 | set_fs(KERNEL_DS); |
1242 | ret = sys_sendfile(out_fd, in_fd, offset ? &of : NULL, count); | 1244 | ret = sys_sendfile(out_fd, in_fd, offset ? (off_t __user *)&of : NULL, count); |
1243 | set_fs(old_fs); | 1245 | set_fs(old_fs); |
1244 | 1246 | ||
1245 | if (offset && put_user(of, offset)) | 1247 | if (offset && put_user(of, offset)) |
@@ -1269,7 +1271,7 @@ static unsigned char socketcall_nargs[18]={AL(0),AL(3),AL(3),AL(3),AL(2),AL(3), | |||
1269 | * it is set by the callees. | 1271 | * it is set by the callees. |
1270 | */ | 1272 | */ |
1271 | 1273 | ||
1272 | asmlinkage long sys32_socketcall(int call, unsigned int *args32) | 1274 | asmlinkage long sys32_socketcall(int call, unsigned int __user *args32) |
1273 | { | 1275 | { |
1274 | unsigned int a[6]; | 1276 | unsigned int a[6]; |
1275 | unsigned int a0,a1; | 1277 | unsigned int a0,a1; |
@@ -1291,7 +1293,7 @@ asmlinkage long sys32_socketcall(int call, unsigned int *args32) | |||
1291 | struct sockaddr __user *addr, int __user *addr_len); | 1293 | struct sockaddr __user *addr, int __user *addr_len); |
1292 | extern asmlinkage long sys_shutdown(int fd, int how); | 1294 | extern asmlinkage long sys_shutdown(int fd, int how); |
1293 | extern asmlinkage long sys_setsockopt(int fd, int level, int optname, char __user *optval, int optlen); | 1295 | extern asmlinkage long sys_setsockopt(int fd, int level, int optname, char __user *optval, int optlen); |
1294 | extern asmlinkage long sys_getsockopt(int fd, int level, int optname, char __user *optval, int *optlen); | 1296 | extern asmlinkage long sys_getsockopt(int fd, int level, int optname, char __user *optval, int __user *optlen); |
1295 | extern asmlinkage long sys_sendmsg(int fd, struct msghdr __user *msg, unsigned flags); | 1297 | extern asmlinkage long sys_sendmsg(int fd, struct msghdr __user *msg, unsigned flags); |
1296 | extern asmlinkage long sys_recvmsg(int fd, struct msghdr __user *msg, unsigned int flags); | 1298 | extern asmlinkage long sys_recvmsg(int fd, struct msghdr __user *msg, unsigned int flags); |
1297 | 1299 | ||
@@ -1411,7 +1413,7 @@ _sys32_clone(nabi_no_regargs struct pt_regs regs) | |||
1411 | newsp = regs.regs[5]; | 1413 | newsp = regs.regs[5]; |
1412 | if (!newsp) | 1414 | if (!newsp) |
1413 | newsp = regs.regs[29]; | 1415 | newsp = regs.regs[29]; |
1414 | parent_tidptr = (int *) regs.regs[6]; | 1416 | parent_tidptr = (int __user *) regs.regs[6]; |
1415 | 1417 | ||
1416 | /* Use __dummy4 instead of getting it off the stack, so that | 1418 | /* Use __dummy4 instead of getting it off the stack, so that |
1417 | syscall() works. */ | 1419 | syscall() works. */ |
diff --git a/arch/mips/kernel/proc.c b/arch/mips/kernel/proc.c index 86fe15b273cd..84ab959f924a 100644 --- a/arch/mips/kernel/proc.c +++ b/arch/mips/kernel/proc.c | |||
@@ -135,6 +135,7 @@ static int show_cpuinfo(struct seq_file *m, void *v) | |||
135 | cpu_has_vce ? "%u" : "not available"); | 135 | cpu_has_vce ? "%u" : "not available"); |
136 | seq_printf(m, fmt, 'D', vced_count); | 136 | seq_printf(m, fmt, 'D', vced_count); |
137 | seq_printf(m, fmt, 'I', vcei_count); | 137 | seq_printf(m, fmt, 'I', vcei_count); |
138 | seq_printf(m, "\n"); | ||
138 | 139 | ||
139 | return 0; | 140 | return 0; |
140 | } | 141 | } |
diff --git a/arch/mips/kernel/process.c b/arch/mips/kernel/process.c index 092679c2dca9..a8f435d82940 100644 --- a/arch/mips/kernel/process.c +++ b/arch/mips/kernel/process.c | |||
@@ -60,17 +60,9 @@ ATTRIB_NORET void cpu_idle(void) | |||
60 | } | 60 | } |
61 | } | 61 | } |
62 | 62 | ||
63 | extern void do_signal(struct pt_regs *regs); | ||
64 | extern void do_signal32(struct pt_regs *regs); | ||
65 | |||
66 | /* | 63 | /* |
67 | * Native o32 and N64 ABI without DSP ASE | 64 | * Native o32 and N64 ABI without DSP ASE |
68 | */ | 65 | */ |
69 | extern int setup_frame(struct k_sigaction * ka, struct pt_regs *regs, | ||
70 | int signr, sigset_t *set); | ||
71 | extern int setup_rt_frame(struct k_sigaction * ka, struct pt_regs *regs, | ||
72 | int signr, sigset_t *set, siginfo_t *info); | ||
73 | |||
74 | struct mips_abi mips_abi = { | 66 | struct mips_abi mips_abi = { |
75 | .do_signal = do_signal, | 67 | .do_signal = do_signal, |
76 | #ifdef CONFIG_TRAD_SIGNALS | 68 | #ifdef CONFIG_TRAD_SIGNALS |
@@ -83,11 +75,6 @@ struct mips_abi mips_abi = { | |||
83 | /* | 75 | /* |
84 | * o32 compatibility on 64-bit kernels, without DSP ASE | 76 | * o32 compatibility on 64-bit kernels, without DSP ASE |
85 | */ | 77 | */ |
86 | extern int setup_frame_32(struct k_sigaction * ka, struct pt_regs *regs, | ||
87 | int signr, sigset_t *set); | ||
88 | extern int setup_rt_frame_32(struct k_sigaction * ka, struct pt_regs *regs, | ||
89 | int signr, sigset_t *set, siginfo_t *info); | ||
90 | |||
91 | struct mips_abi mips_abi_32 = { | 78 | struct mips_abi mips_abi_32 = { |
92 | .do_signal = do_signal32, | 79 | .do_signal = do_signal32, |
93 | .setup_frame = setup_frame_32, | 80 | .setup_frame = setup_frame_32, |
@@ -99,9 +86,6 @@ struct mips_abi mips_abi_32 = { | |||
99 | /* | 86 | /* |
100 | * N32 on 64-bit kernels, without DSP ASE | 87 | * N32 on 64-bit kernels, without DSP ASE |
101 | */ | 88 | */ |
102 | extern int setup_rt_frame_n32(struct k_sigaction * ka, struct pt_regs *regs, | ||
103 | int signr, sigset_t *set, siginfo_t *info); | ||
104 | |||
105 | struct mips_abi mips_abi_n32 = { | 89 | struct mips_abi mips_abi_n32 = { |
106 | .do_signal = do_signal, | 90 | .do_signal = do_signal, |
107 | .setup_rt_frame = setup_rt_frame_n32 | 91 | .setup_rt_frame = setup_rt_frame_n32 |
diff --git a/arch/mips/kernel/setup.c b/arch/mips/kernel/setup.c index d9293c558e41..0cb3b6097e0e 100644 --- a/arch/mips/kernel/setup.c +++ b/arch/mips/kernel/setup.c | |||
@@ -447,21 +447,10 @@ static inline void resource_init(void) | |||
447 | { | 447 | { |
448 | int i; | 448 | int i; |
449 | 449 | ||
450 | #if defined(CONFIG_64BIT) && !defined(CONFIG_BUILD_ELF64) | ||
451 | /* | ||
452 | * The 64bit code in 32bit object format trick can't represent | ||
453 | * 64bit wide relocations for linker script symbols. | ||
454 | */ | ||
455 | code_resource.start = CPHYSADDR(&_text); | ||
456 | code_resource.end = CPHYSADDR(&_etext) - 1; | ||
457 | data_resource.start = CPHYSADDR(&_etext); | ||
458 | data_resource.end = CPHYSADDR(&_edata) - 1; | ||
459 | #else | ||
460 | code_resource.start = virt_to_phys(&_text); | 450 | code_resource.start = virt_to_phys(&_text); |
461 | code_resource.end = virt_to_phys(&_etext) - 1; | 451 | code_resource.end = virt_to_phys(&_etext) - 1; |
462 | data_resource.start = virt_to_phys(&_etext); | 452 | data_resource.start = virt_to_phys(&_etext); |
463 | data_resource.end = virt_to_phys(&_edata) - 1; | 453 | data_resource.end = virt_to_phys(&_edata) - 1; |
464 | #endif | ||
465 | 454 | ||
466 | /* | 455 | /* |
467 | * Request address space for all standard RAM. | 456 | * Request address space for all standard RAM. |
diff --git a/arch/mips/kernel/signal-common.h b/arch/mips/kernel/signal-common.h index 36bfc2588aa3..3ca786215d48 100644 --- a/arch/mips/kernel/signal-common.h +++ b/arch/mips/kernel/signal-common.h | |||
@@ -166,11 +166,11 @@ get_sigframe(struct k_sigaction *ka, struct pt_regs *regs, size_t frame_size) | |||
166 | sp = regs->regs[29]; | 166 | sp = regs->regs[29]; |
167 | 167 | ||
168 | /* | 168 | /* |
169 | * FPU emulator may have it's own trampoline active just | 169 | * FPU emulator may have it's own trampoline active just |
170 | * above the user stack, 16-bytes before the next lowest | 170 | * above the user stack, 16-bytes before the next lowest |
171 | * 16 byte boundary. Try to avoid trashing it. | 171 | * 16 byte boundary. Try to avoid trashing it. |
172 | */ | 172 | */ |
173 | sp -= 32; | 173 | sp -= 32; |
174 | 174 | ||
175 | /* This is the X/Open sanctioned signal stack switching. */ | 175 | /* This is the X/Open sanctioned signal stack switching. */ |
176 | if ((ka->sa.sa_flags & SA_ONSTACK) && (sas_ss_flags (sp) == 0)) | 176 | if ((ka->sa.sa_flags & SA_ONSTACK) && (sas_ss_flags (sp) == 0)) |
diff --git a/arch/mips/kernel/signal.c b/arch/mips/kernel/signal.c index c974cc9b30eb..402efd27c79e 100644 --- a/arch/mips/kernel/signal.c +++ b/arch/mips/kernel/signal.c | |||
@@ -100,8 +100,8 @@ _sys_rt_sigsuspend(nabi_no_regargs struct pt_regs regs) | |||
100 | } | 100 | } |
101 | 101 | ||
102 | #ifdef CONFIG_TRAD_SIGNALS | 102 | #ifdef CONFIG_TRAD_SIGNALS |
103 | asmlinkage int sys_sigaction(int sig, const struct sigaction *act, | 103 | asmlinkage int sys_sigaction(int sig, const struct sigaction __user *act, |
104 | struct sigaction *oact) | 104 | struct sigaction __user *oact) |
105 | { | 105 | { |
106 | struct k_sigaction new_ka, old_ka; | 106 | struct k_sigaction new_ka, old_ka; |
107 | int ret; | 107 | int ret; |
@@ -331,7 +331,7 @@ int setup_rt_frame(struct k_sigaction * ka, struct pt_regs *regs, | |||
331 | /* Create the ucontext. */ | 331 | /* Create the ucontext. */ |
332 | err |= __put_user(0, &frame->rs_uc.uc_flags); | 332 | err |= __put_user(0, &frame->rs_uc.uc_flags); |
333 | err |= __put_user(NULL, &frame->rs_uc.uc_link); | 333 | err |= __put_user(NULL, &frame->rs_uc.uc_link); |
334 | err |= __put_user((void *)current->sas_ss_sp, | 334 | err |= __put_user((void __user *)current->sas_ss_sp, |
335 | &frame->rs_uc.uc_stack.ss_sp); | 335 | &frame->rs_uc.uc_stack.ss_sp); |
336 | err |= __put_user(sas_ss_flags(regs->regs[29]), | 336 | err |= __put_user(sas_ss_flags(regs->regs[29]), |
337 | &frame->rs_uc.uc_stack.ss_flags); | 337 | &frame->rs_uc.uc_stack.ss_flags); |
diff --git a/arch/mips/kernel/signal32.c b/arch/mips/kernel/signal32.c index 237cd8a2cd32..f32a22997c3d 100644 --- a/arch/mips/kernel/signal32.c +++ b/arch/mips/kernel/signal32.c | |||
@@ -163,7 +163,7 @@ static inline int put_sigset(const sigset_t *kbuf, compat_sigset_t __user *ubuf) | |||
163 | return err; | 163 | return err; |
164 | } | 164 | } |
165 | 165 | ||
166 | static inline int get_sigset(sigset_t *kbuf, const compat_sigset_t *ubuf) | 166 | static inline int get_sigset(sigset_t *kbuf, const compat_sigset_t __user *ubuf) |
167 | { | 167 | { |
168 | int err = 0; | 168 | int err = 0; |
169 | unsigned long sig[4]; | 169 | unsigned long sig[4]; |
@@ -195,10 +195,10 @@ save_static_function(sys32_sigsuspend); | |||
195 | __attribute_used__ noinline static int | 195 | __attribute_used__ noinline static int |
196 | _sys32_sigsuspend(nabi_no_regargs struct pt_regs regs) | 196 | _sys32_sigsuspend(nabi_no_regargs struct pt_regs regs) |
197 | { | 197 | { |
198 | compat_sigset_t *uset; | 198 | compat_sigset_t __user *uset; |
199 | sigset_t newset; | 199 | sigset_t newset; |
200 | 200 | ||
201 | uset = (compat_sigset_t *) regs.regs[4]; | 201 | uset = (compat_sigset_t __user *) regs.regs[4]; |
202 | if (get_sigset(&newset, uset)) | 202 | if (get_sigset(&newset, uset)) |
203 | return -EFAULT; | 203 | return -EFAULT; |
204 | sigdelsetmask(&newset, ~_BLOCKABLE); | 204 | sigdelsetmask(&newset, ~_BLOCKABLE); |
@@ -219,7 +219,7 @@ save_static_function(sys32_rt_sigsuspend); | |||
219 | __attribute_used__ noinline static int | 219 | __attribute_used__ noinline static int |
220 | _sys32_rt_sigsuspend(nabi_no_regargs struct pt_regs regs) | 220 | _sys32_rt_sigsuspend(nabi_no_regargs struct pt_regs regs) |
221 | { | 221 | { |
222 | compat_sigset_t *uset; | 222 | compat_sigset_t __user *uset; |
223 | sigset_t newset; | 223 | sigset_t newset; |
224 | size_t sigsetsize; | 224 | size_t sigsetsize; |
225 | 225 | ||
@@ -228,7 +228,7 @@ _sys32_rt_sigsuspend(nabi_no_regargs struct pt_regs regs) | |||
228 | if (sigsetsize != sizeof(compat_sigset_t)) | 228 | if (sigsetsize != sizeof(compat_sigset_t)) |
229 | return -EINVAL; | 229 | return -EINVAL; |
230 | 230 | ||
231 | uset = (compat_sigset_t *) regs.regs[4]; | 231 | uset = (compat_sigset_t __user *) regs.regs[4]; |
232 | if (get_sigset(&newset, uset)) | 232 | if (get_sigset(&newset, uset)) |
233 | return -EFAULT; | 233 | return -EFAULT; |
234 | sigdelsetmask(&newset, ~_BLOCKABLE); | 234 | sigdelsetmask(&newset, ~_BLOCKABLE); |
@@ -236,7 +236,7 @@ _sys32_rt_sigsuspend(nabi_no_regargs struct pt_regs regs) | |||
236 | spin_lock_irq(¤t->sighand->siglock); | 236 | spin_lock_irq(¤t->sighand->siglock); |
237 | current->saved_sigmask = current->blocked; | 237 | current->saved_sigmask = current->blocked; |
238 | current->blocked = newset; | 238 | current->blocked = newset; |
239 | recalc_sigpending(); | 239 | recalc_sigpending(); |
240 | spin_unlock_irq(¤t->sighand->siglock); | 240 | spin_unlock_irq(¤t->sighand->siglock); |
241 | 241 | ||
242 | current->state = TASK_INTERRUPTIBLE; | 242 | current->state = TASK_INTERRUPTIBLE; |
@@ -245,8 +245,8 @@ _sys32_rt_sigsuspend(nabi_no_regargs struct pt_regs regs) | |||
245 | return -ERESTARTNOHAND; | 245 | return -ERESTARTNOHAND; |
246 | } | 246 | } |
247 | 247 | ||
248 | asmlinkage int sys32_sigaction(int sig, const struct sigaction32 *act, | 248 | asmlinkage int sys32_sigaction(int sig, const struct sigaction32 __user *act, |
249 | struct sigaction32 *oact) | 249 | struct sigaction32 __user *oact) |
250 | { | 250 | { |
251 | struct k_sigaction new_ka, old_ka; | 251 | struct k_sigaction new_ka, old_ka; |
252 | int ret; | 252 | int ret; |
@@ -272,15 +272,15 @@ asmlinkage int sys32_sigaction(int sig, const struct sigaction32 *act, | |||
272 | 272 | ||
273 | if (!ret && oact) { | 273 | if (!ret && oact) { |
274 | if (!access_ok(VERIFY_WRITE, oact, sizeof(*oact))) | 274 | if (!access_ok(VERIFY_WRITE, oact, sizeof(*oact))) |
275 | return -EFAULT; | 275 | return -EFAULT; |
276 | err |= __put_user(old_ka.sa.sa_flags, &oact->sa_flags); | 276 | err |= __put_user(old_ka.sa.sa_flags, &oact->sa_flags); |
277 | err |= __put_user((u32)(u64)old_ka.sa.sa_handler, | 277 | err |= __put_user((u32)(u64)old_ka.sa.sa_handler, |
278 | &oact->sa_handler); | 278 | &oact->sa_handler); |
279 | err |= __put_user(old_ka.sa.sa_mask.sig[0], oact->sa_mask.sig); | 279 | err |= __put_user(old_ka.sa.sa_mask.sig[0], oact->sa_mask.sig); |
280 | err |= __put_user(0, &oact->sa_mask.sig[1]); | 280 | err |= __put_user(0, &oact->sa_mask.sig[1]); |
281 | err |= __put_user(0, &oact->sa_mask.sig[2]); | 281 | err |= __put_user(0, &oact->sa_mask.sig[2]); |
282 | err |= __put_user(0, &oact->sa_mask.sig[3]); | 282 | err |= __put_user(0, &oact->sa_mask.sig[3]); |
283 | if (err) | 283 | if (err) |
284 | return -EFAULT; | 284 | return -EFAULT; |
285 | } | 285 | } |
286 | 286 | ||
@@ -301,7 +301,7 @@ asmlinkage int sys32_sigaltstack(nabi_no_regargs struct pt_regs regs) | |||
301 | if (!access_ok(VERIFY_READ, uss, sizeof(*uss))) | 301 | if (!access_ok(VERIFY_READ, uss, sizeof(*uss))) |
302 | return -EFAULT; | 302 | return -EFAULT; |
303 | err |= __get_user(sp, &uss->ss_sp); | 303 | err |= __get_user(sp, &uss->ss_sp); |
304 | kss.ss_sp = (void *) (long) sp; | 304 | kss.ss_sp = (void __user *) (long) sp; |
305 | err |= __get_user(kss.ss_size, &uss->ss_size); | 305 | err |= __get_user(kss.ss_size, &uss->ss_size); |
306 | err |= __get_user(kss.ss_flags, &uss->ss_flags); | 306 | err |= __get_user(kss.ss_flags, &uss->ss_flags); |
307 | if (err) | 307 | if (err) |
@@ -316,7 +316,7 @@ asmlinkage int sys32_sigaltstack(nabi_no_regargs struct pt_regs regs) | |||
316 | if (!ret && uoss) { | 316 | if (!ret && uoss) { |
317 | if (!access_ok(VERIFY_WRITE, uoss, sizeof(*uoss))) | 317 | if (!access_ok(VERIFY_WRITE, uoss, sizeof(*uoss))) |
318 | return -EFAULT; | 318 | return -EFAULT; |
319 | sp = (int) (long) koss.ss_sp; | 319 | sp = (int) (unsigned long) koss.ss_sp; |
320 | err |= __put_user(sp, &uoss->ss_sp); | 320 | err |= __put_user(sp, &uoss->ss_sp); |
321 | err |= __put_user(koss.ss_size, &uoss->ss_size); | 321 | err |= __put_user(koss.ss_size, &uoss->ss_size); |
322 | err |= __put_user(koss.ss_flags, &uoss->ss_flags); | 322 | err |= __put_user(koss.ss_flags, &uoss->ss_flags); |
@@ -527,7 +527,7 @@ _sys32_rt_sigreturn(nabi_no_regargs struct pt_regs regs) | |||
527 | /* The ucontext contains a stack32_t, so we must convert! */ | 527 | /* The ucontext contains a stack32_t, so we must convert! */ |
528 | if (__get_user(sp, &frame->rs_uc.uc_stack.ss_sp)) | 528 | if (__get_user(sp, &frame->rs_uc.uc_stack.ss_sp)) |
529 | goto badframe; | 529 | goto badframe; |
530 | st.ss_sp = (void *)(long) sp; | 530 | st.ss_sp = (void __user *)(long) sp; |
531 | if (__get_user(st.ss_size, &frame->rs_uc.uc_stack.ss_size)) | 531 | if (__get_user(st.ss_size, &frame->rs_uc.uc_stack.ss_size)) |
532 | goto badframe; | 532 | goto badframe; |
533 | if (__get_user(st.ss_flags, &frame->rs_uc.uc_stack.ss_flags)) | 533 | if (__get_user(st.ss_flags, &frame->rs_uc.uc_stack.ss_flags)) |
@@ -624,11 +624,11 @@ static inline void __user *get_sigframe(struct k_sigaction *ka, | |||
624 | sp = regs->regs[29]; | 624 | sp = regs->regs[29]; |
625 | 625 | ||
626 | /* | 626 | /* |
627 | * FPU emulator may have it's own trampoline active just | 627 | * FPU emulator may have it's own trampoline active just |
628 | * above the user stack, 16-bytes before the next lowest | 628 | * above the user stack, 16-bytes before the next lowest |
629 | * 16 byte boundary. Try to avoid trashing it. | 629 | * 16 byte boundary. Try to avoid trashing it. |
630 | */ | 630 | */ |
631 | sp -= 32; | 631 | sp -= 32; |
632 | 632 | ||
633 | /* This is the X/Open sanctioned signal stack switching. */ | 633 | /* This is the X/Open sanctioned signal stack switching. */ |
634 | if ((ka->sa.sa_flags & SA_ONSTACK) && (sas_ss_flags (sp) == 0)) | 634 | if ((ka->sa.sa_flags & SA_ONSTACK) && (sas_ss_flags (sp) == 0)) |
@@ -868,7 +868,7 @@ no_signal: | |||
868 | } | 868 | } |
869 | } | 869 | } |
870 | 870 | ||
871 | asmlinkage int sys32_rt_sigaction(int sig, const struct sigaction32 *act, | 871 | asmlinkage int sys32_rt_sigaction(int sig, const struct sigaction32 __user *act, |
872 | struct sigaction32 __user *oact, | 872 | struct sigaction32 __user *oact, |
873 | unsigned int sigsetsize) | 873 | unsigned int sigsetsize) |
874 | { | 874 | { |
@@ -912,7 +912,7 @@ out: | |||
912 | return ret; | 912 | return ret; |
913 | } | 913 | } |
914 | 914 | ||
915 | asmlinkage int sys32_rt_sigprocmask(int how, compat_sigset_t *set, | 915 | asmlinkage int sys32_rt_sigprocmask(int how, compat_sigset_t __user *set, |
916 | compat_sigset_t __user *oset, unsigned int sigsetsize) | 916 | compat_sigset_t __user *oset, unsigned int sigsetsize) |
917 | { | 917 | { |
918 | sigset_t old_set, new_set; | 918 | sigset_t old_set, new_set; |
diff --git a/arch/mips/kernel/signal_n32.c b/arch/mips/kernel/signal_n32.c index 3e168c08a3a8..477c5334ec1b 100644 --- a/arch/mips/kernel/signal_n32.c +++ b/arch/mips/kernel/signal_n32.c | |||
@@ -87,7 +87,8 @@ save_static_function(sysn32_rt_sigsuspend); | |||
87 | __attribute_used__ noinline static int | 87 | __attribute_used__ noinline static int |
88 | _sysn32_rt_sigsuspend(nabi_no_regargs struct pt_regs regs) | 88 | _sysn32_rt_sigsuspend(nabi_no_regargs struct pt_regs regs) |
89 | { | 89 | { |
90 | compat_sigset_t __user *unewset, uset; | 90 | compat_sigset_t __user *unewset; |
91 | compat_sigset_t uset; | ||
91 | size_t sigsetsize; | 92 | size_t sigsetsize; |
92 | sigset_t newset; | 93 | sigset_t newset; |
93 | 94 | ||
@@ -141,7 +142,7 @@ _sysn32_rt_sigreturn(nabi_no_regargs struct pt_regs regs) | |||
141 | /* The ucontext contains a stack32_t, so we must convert! */ | 142 | /* The ucontext contains a stack32_t, so we must convert! */ |
142 | if (__get_user(sp, &frame->rs_uc.uc_stack.ss_sp)) | 143 | if (__get_user(sp, &frame->rs_uc.uc_stack.ss_sp)) |
143 | goto badframe; | 144 | goto badframe; |
144 | st.ss_sp = (void *)(long) sp; | 145 | st.ss_sp = (void __user *)(long) sp; |
145 | if (__get_user(st.ss_size, &frame->rs_uc.uc_stack.ss_size)) | 146 | if (__get_user(st.ss_size, &frame->rs_uc.uc_stack.ss_size)) |
146 | goto badframe; | 147 | goto badframe; |
147 | if (__get_user(st.ss_flags, &frame->rs_uc.uc_stack.ss_flags)) | 148 | if (__get_user(st.ss_flags, &frame->rs_uc.uc_stack.ss_flags)) |
diff --git a/arch/mips/kernel/smp.c b/arch/mips/kernel/smp.c index 06ed90752424..78d171bfa331 100644 --- a/arch/mips/kernel/smp.c +++ b/arch/mips/kernel/smp.c | |||
@@ -167,8 +167,8 @@ int smp_call_function (void (*func) (void *info), void *info, int retry, | |||
167 | mb(); | 167 | mb(); |
168 | 168 | ||
169 | /* Send a message to all other CPUs and wait for them to respond */ | 169 | /* Send a message to all other CPUs and wait for them to respond */ |
170 | for (i = 0; i < NR_CPUS; i++) | 170 | for_each_online_cpu(i) |
171 | if (cpu_online(i) && i != cpu) | 171 | if (i != cpu) |
172 | core_send_ipi(i, SMP_CALL_FUNCTION); | 172 | core_send_ipi(i, SMP_CALL_FUNCTION); |
173 | 173 | ||
174 | /* Wait for response */ | 174 | /* Wait for response */ |
diff --git a/arch/mips/kernel/syscall.c b/arch/mips/kernel/syscall.c index 1da2eeb3ef9e..2aeaa2fd4b32 100644 --- a/arch/mips/kernel/syscall.c +++ b/arch/mips/kernel/syscall.c | |||
@@ -162,7 +162,10 @@ asmlinkage unsigned long | |||
162 | sys_mmap2(unsigned long addr, unsigned long len, unsigned long prot, | 162 | sys_mmap2(unsigned long addr, unsigned long len, unsigned long prot, |
163 | unsigned long flags, unsigned long fd, unsigned long pgoff) | 163 | unsigned long flags, unsigned long fd, unsigned long pgoff) |
164 | { | 164 | { |
165 | return do_mmap2(addr, len, prot, flags, fd, pgoff); | 165 | if (pgoff & (~PAGE_MASK >> 12)) |
166 | return -EINVAL; | ||
167 | |||
168 | return do_mmap2(addr, len, prot, flags, fd, pgoff >> (PAGE_SHIFT-12)); | ||
166 | } | 169 | } |
167 | 170 | ||
168 | save_static_function(sys_fork); | 171 | save_static_function(sys_fork); |
@@ -345,7 +348,7 @@ asmlinkage int sys_ipc (uint call, int first, int second, | |||
345 | union semun fourth; | 348 | union semun fourth; |
346 | if (!ptr) | 349 | if (!ptr) |
347 | return -EINVAL; | 350 | return -EINVAL; |
348 | if (get_user(fourth.__pad, (void *__user *) ptr)) | 351 | if (get_user(fourth.__pad, (void __user *__user *) ptr)) |
349 | return -EFAULT; | 352 | return -EFAULT; |
350 | return sys_semctl (first, second, third, fourth); | 353 | return sys_semctl (first, second, third, fourth); |
351 | } | 354 | } |
diff --git a/arch/mips/kernel/traps.c b/arch/mips/kernel/traps.c index 005debbfbe84..bed0eb6cf55d 100644 --- a/arch/mips/kernel/traps.c +++ b/arch/mips/kernel/traps.c | |||
@@ -576,7 +576,7 @@ asmlinkage void do_fpe(struct pt_regs *regs, unsigned long fcr31) | |||
576 | } | 576 | } |
577 | #endif | 577 | #endif |
578 | /* | 578 | /* |
579 | * Unimplemented operation exception. If we've got the full | 579 | * Unimplemented operation exception. If we've got the full |
580 | * software emulator on-board, let's use it... | 580 | * software emulator on-board, let's use it... |
581 | * | 581 | * |
582 | * Force FPU to dump state into task/thread context. We're | 582 | * Force FPU to dump state into task/thread context. We're |