diff options
Diffstat (limited to 'arch/tile/include/asm')
-rw-r--r-- | arch/tile/include/asm/atomic_32.h | 17 | ||||
-rw-r--r-- | arch/tile/include/asm/compat.h | 55 | ||||
-rw-r--r-- | arch/tile/include/asm/elf.h | 6 | ||||
-rw-r--r-- | arch/tile/include/asm/futex.h | 17 | ||||
-rw-r--r-- | arch/tile/include/asm/page.h | 9 | ||||
-rw-r--r-- | arch/tile/include/asm/pgtable.h | 9 | ||||
-rw-r--r-- | arch/tile/include/asm/pgtable_32.h | 12 | ||||
-rw-r--r-- | arch/tile/include/asm/ptrace.h | 5 | ||||
-rw-r--r-- | arch/tile/include/asm/sections.h | 9 | ||||
-rw-r--r-- | arch/tile/include/asm/signal.h | 1 | ||||
-rw-r--r-- | arch/tile/include/asm/spinlock_32.h | 3 | ||||
-rw-r--r-- | arch/tile/include/asm/stack.h | 6 | ||||
-rw-r--r-- | arch/tile/include/asm/syscalls.h | 72 | ||||
-rw-r--r-- | arch/tile/include/asm/system.h | 30 | ||||
-rw-r--r-- | arch/tile/include/asm/thread_info.h | 8 | ||||
-rw-r--r-- | arch/tile/include/asm/traps.h | 26 | ||||
-rw-r--r-- | arch/tile/include/asm/uaccess.h | 22 | ||||
-rw-r--r-- | arch/tile/include/asm/unistd.h | 9 |
18 files changed, 227 insertions, 89 deletions
diff --git a/arch/tile/include/asm/atomic_32.h b/arch/tile/include/asm/atomic_32.h index e4f8b4f04895..40a5a3a876d9 100644 --- a/arch/tile/include/asm/atomic_32.h +++ b/arch/tile/include/asm/atomic_32.h | |||
@@ -348,6 +348,23 @@ void __init_atomic_per_cpu(void); | |||
348 | /* Support releasing the atomic lock in do_page_fault_ics(). */ | 348 | /* Support releasing the atomic lock in do_page_fault_ics(). */ |
349 | void __atomic_fault_unlock(int *lock_ptr); | 349 | void __atomic_fault_unlock(int *lock_ptr); |
350 | #endif | 350 | #endif |
351 | |||
352 | /* Private helper routines in lib/atomic_asm_32.S */ | ||
353 | extern struct __get_user __atomic_cmpxchg(volatile int *p, | ||
354 | int *lock, int o, int n); | ||
355 | extern struct __get_user __atomic_xchg(volatile int *p, int *lock, int n); | ||
356 | extern struct __get_user __atomic_xchg_add(volatile int *p, int *lock, int n); | ||
357 | extern struct __get_user __atomic_xchg_add_unless(volatile int *p, | ||
358 | int *lock, int o, int n); | ||
359 | extern struct __get_user __atomic_or(volatile int *p, int *lock, int n); | ||
360 | extern struct __get_user __atomic_andn(volatile int *p, int *lock, int n); | ||
361 | extern struct __get_user __atomic_xor(volatile int *p, int *lock, int n); | ||
362 | extern u64 __atomic64_cmpxchg(volatile u64 *p, int *lock, u64 o, u64 n); | ||
363 | extern u64 __atomic64_xchg(volatile u64 *p, int *lock, u64 n); | ||
364 | extern u64 __atomic64_xchg_add(volatile u64 *p, int *lock, u64 n); | ||
365 | extern u64 __atomic64_xchg_add_unless(volatile u64 *p, | ||
366 | int *lock, u64 o, u64 n); | ||
367 | |||
351 | #endif /* !__ASSEMBLY__ */ | 368 | #endif /* !__ASSEMBLY__ */ |
352 | 369 | ||
353 | #endif /* _ASM_TILE_ATOMIC_32_H */ | 370 | #endif /* _ASM_TILE_ATOMIC_32_H */ |
diff --git a/arch/tile/include/asm/compat.h b/arch/tile/include/asm/compat.h index b09292bcc19f..5a34da6cdd79 100644 --- a/arch/tile/include/asm/compat.h +++ b/arch/tile/include/asm/compat.h | |||
@@ -70,48 +70,7 @@ struct compat_timeval { | |||
70 | s32 tv_usec; | 70 | s32 tv_usec; |
71 | }; | 71 | }; |
72 | 72 | ||
73 | struct compat_stat { | 73 | #define compat_stat stat |
74 | unsigned int st_dev; | ||
75 | unsigned int st_ino; | ||
76 | unsigned int st_mode; | ||
77 | unsigned int st_nlink; | ||
78 | unsigned int st_uid; | ||
79 | unsigned int st_gid; | ||
80 | unsigned int st_rdev; | ||
81 | unsigned int __pad1; | ||
82 | int st_size; | ||
83 | int st_blksize; | ||
84 | int __pad2; | ||
85 | int st_blocks; | ||
86 | int st_atime; | ||
87 | unsigned int st_atime_nsec; | ||
88 | int st_mtime; | ||
89 | unsigned int st_mtime_nsec; | ||
90 | int st_ctime; | ||
91 | unsigned int st_ctime_nsec; | ||
92 | unsigned int __unused[2]; | ||
93 | }; | ||
94 | |||
95 | struct compat_stat64 { | ||
96 | unsigned long st_dev; | ||
97 | unsigned long st_ino; | ||
98 | unsigned int st_mode; | ||
99 | unsigned int st_nlink; | ||
100 | unsigned int st_uid; | ||
101 | unsigned int st_gid; | ||
102 | unsigned long st_rdev; | ||
103 | long st_size; | ||
104 | unsigned int st_blksize; | ||
105 | unsigned long st_blocks __attribute__((packed)); | ||
106 | unsigned int st_atime; | ||
107 | unsigned int st_atime_nsec; | ||
108 | unsigned int st_mtime; | ||
109 | unsigned int st_mtime_nsec; | ||
110 | unsigned int st_ctime; | ||
111 | unsigned int st_ctime_nsec; | ||
112 | unsigned int __unused8; | ||
113 | }; | ||
114 | |||
115 | #define compat_statfs statfs | 74 | #define compat_statfs statfs |
116 | 75 | ||
117 | struct compat_sysctl { | 76 | struct compat_sysctl { |
@@ -233,7 +192,7 @@ static inline compat_uptr_t ptr_to_compat(void __user *uptr) | |||
233 | /* Sign-extend when storing a kernel pointer to a user's ptregs. */ | 192 | /* Sign-extend when storing a kernel pointer to a user's ptregs. */ |
234 | static inline unsigned long ptr_to_compat_reg(void __user *uptr) | 193 | static inline unsigned long ptr_to_compat_reg(void __user *uptr) |
235 | { | 194 | { |
236 | return (long)(int)(long)uptr; | 195 | return (long)(int)(long __force)uptr; |
237 | } | 196 | } |
238 | 197 | ||
239 | static inline void __user *compat_alloc_user_space(long len) | 198 | static inline void __user *compat_alloc_user_space(long len) |
@@ -278,17 +237,8 @@ long compat_sys_sync_file_range2(int fd, unsigned int flags, | |||
278 | long compat_sys_fallocate(int fd, int mode, | 237 | long compat_sys_fallocate(int fd, int mode, |
279 | u32 offset_lo, u32 offset_hi, | 238 | u32 offset_lo, u32 offset_hi, |
280 | u32 len_lo, u32 len_hi); | 239 | u32 len_lo, u32 len_hi); |
281 | long compat_sys_stat64(char __user *filename, | ||
282 | struct compat_stat64 __user *statbuf); | ||
283 | long compat_sys_lstat64(char __user *filename, | ||
284 | struct compat_stat64 __user *statbuf); | ||
285 | long compat_sys_fstat64(unsigned int fd, struct compat_stat64 __user *statbuf); | ||
286 | long compat_sys_fstatat64(int dfd, char __user *filename, | ||
287 | struct compat_stat64 __user *statbuf, int flag); | ||
288 | long compat_sys_sched_rr_get_interval(compat_pid_t pid, | 240 | long compat_sys_sched_rr_get_interval(compat_pid_t pid, |
289 | struct compat_timespec __user *interval); | 241 | struct compat_timespec __user *interval); |
290 | ssize_t compat_sys_sendfile(int out_fd, int in_fd, compat_off_t __user *offset, | ||
291 | size_t count); | ||
292 | 242 | ||
293 | /* Versions of compat functions that differ from generic Linux. */ | 243 | /* Versions of compat functions that differ from generic Linux. */ |
294 | struct compat_msgbuf; | 244 | struct compat_msgbuf; |
@@ -302,7 +252,6 @@ long tile_compat_sys_ptrace(compat_long_t request, compat_long_t pid, | |||
302 | compat_long_t addr, compat_long_t data); | 252 | compat_long_t addr, compat_long_t data); |
303 | 253 | ||
304 | /* Tilera Linux syscalls that don't have "compat" versions. */ | 254 | /* Tilera Linux syscalls that don't have "compat" versions. */ |
305 | #define compat_sys_raise_fpe sys_raise_fpe | ||
306 | #define compat_sys_flush_cache sys_flush_cache | 255 | #define compat_sys_flush_cache sys_flush_cache |
307 | 256 | ||
308 | #endif /* _ASM_TILE_COMPAT_H */ | 257 | #endif /* _ASM_TILE_COMPAT_H */ |
diff --git a/arch/tile/include/asm/elf.h b/arch/tile/include/asm/elf.h index 1bca0debdb0f..623a6bb741c1 100644 --- a/arch/tile/include/asm/elf.h +++ b/arch/tile/include/asm/elf.h | |||
@@ -59,8 +59,7 @@ enum { ELF_ARCH = CHIP_ELF_TYPE() }; | |||
59 | */ | 59 | */ |
60 | #define elf_check_arch(x) \ | 60 | #define elf_check_arch(x) \ |
61 | ((x)->e_ident[EI_CLASS] == ELF_CLASS && \ | 61 | ((x)->e_ident[EI_CLASS] == ELF_CLASS && \ |
62 | ((x)->e_machine == CHIP_ELF_TYPE() || \ | 62 | (x)->e_machine == CHIP_ELF_TYPE()) |
63 | (x)->e_machine == CHIP_COMPAT_ELF_TYPE())) | ||
64 | 63 | ||
65 | /* The module loader only handles a few relocation types. */ | 64 | /* The module loader only handles a few relocation types. */ |
66 | #ifndef __tilegx__ | 65 | #ifndef __tilegx__ |
@@ -139,8 +138,7 @@ extern int arch_setup_additional_pages(struct linux_binprm *bprm, | |||
139 | */ | 138 | */ |
140 | #define compat_elf_check_arch(x) \ | 139 | #define compat_elf_check_arch(x) \ |
141 | ((x)->e_ident[EI_CLASS] == ELFCLASS32 && \ | 140 | ((x)->e_ident[EI_CLASS] == ELFCLASS32 && \ |
142 | ((x)->e_machine == CHIP_ELF_TYPE() || \ | 141 | (x)->e_machine == CHIP_ELF_TYPE()) |
143 | (x)->e_machine == CHIP_COMPAT_ELF_TYPE())) | ||
144 | 142 | ||
145 | #define compat_start_thread(regs, ip, usp) do { \ | 143 | #define compat_start_thread(regs, ip, usp) do { \ |
146 | regs->pc = ptr_to_compat_reg((void *)(ip)); \ | 144 | regs->pc = ptr_to_compat_reg((void *)(ip)); \ |
diff --git a/arch/tile/include/asm/futex.h b/arch/tile/include/asm/futex.h index 9eaeb3c08786..fe0d10dcae57 100644 --- a/arch/tile/include/asm/futex.h +++ b/arch/tile/include/asm/futex.h | |||
@@ -29,14 +29,14 @@ | |||
29 | #include <linux/uaccess.h> | 29 | #include <linux/uaccess.h> |
30 | #include <linux/errno.h> | 30 | #include <linux/errno.h> |
31 | 31 | ||
32 | extern struct __get_user futex_set(int *v, int i); | 32 | extern struct __get_user futex_set(int __user *v, int i); |
33 | extern struct __get_user futex_add(int *v, int n); | 33 | extern struct __get_user futex_add(int __user *v, int n); |
34 | extern struct __get_user futex_or(int *v, int n); | 34 | extern struct __get_user futex_or(int __user *v, int n); |
35 | extern struct __get_user futex_andn(int *v, int n); | 35 | extern struct __get_user futex_andn(int __user *v, int n); |
36 | extern struct __get_user futex_cmpxchg(int *v, int o, int n); | 36 | extern struct __get_user futex_cmpxchg(int __user *v, int o, int n); |
37 | 37 | ||
38 | #ifndef __tilegx__ | 38 | #ifndef __tilegx__ |
39 | extern struct __get_user futex_xor(int *v, int n); | 39 | extern struct __get_user futex_xor(int __user *v, int n); |
40 | #else | 40 | #else |
41 | static inline struct __get_user futex_xor(int __user *uaddr, int n) | 41 | static inline struct __get_user futex_xor(int __user *uaddr, int n) |
42 | { | 42 | { |
@@ -131,6 +131,11 @@ static inline int futex_atomic_cmpxchg_inatomic(int __user *uaddr, int oldval, | |||
131 | return asm_ret.err ? asm_ret.err : asm_ret.val; | 131 | return asm_ret.err ? asm_ret.err : asm_ret.val; |
132 | } | 132 | } |
133 | 133 | ||
134 | #ifndef __tilegx__ | ||
135 | /* Return failure from the atomic wrappers. */ | ||
136 | struct __get_user __atomic_bad_address(int __user *addr); | ||
137 | #endif | ||
138 | |||
134 | #endif /* !__ASSEMBLY__ */ | 139 | #endif /* !__ASSEMBLY__ */ |
135 | 140 | ||
136 | #endif /* _ASM_TILE_FUTEX_H */ | 141 | #endif /* _ASM_TILE_FUTEX_H */ |
diff --git a/arch/tile/include/asm/page.h b/arch/tile/include/asm/page.h index c8301c43d6d9..f894a9016da6 100644 --- a/arch/tile/include/asm/page.h +++ b/arch/tile/include/asm/page.h | |||
@@ -16,8 +16,6 @@ | |||
16 | #define _ASM_TILE_PAGE_H | 16 | #define _ASM_TILE_PAGE_H |
17 | 17 | ||
18 | #include <linux/const.h> | 18 | #include <linux/const.h> |
19 | #include <hv/hypervisor.h> | ||
20 | #include <arch/chip.h> | ||
21 | 19 | ||
22 | /* PAGE_SHIFT and HPAGE_SHIFT determine the page sizes. */ | 20 | /* PAGE_SHIFT and HPAGE_SHIFT determine the page sizes. */ |
23 | #define PAGE_SHIFT 16 | 21 | #define PAGE_SHIFT 16 |
@@ -29,6 +27,11 @@ | |||
29 | #define PAGE_MASK (~(PAGE_SIZE - 1)) | 27 | #define PAGE_MASK (~(PAGE_SIZE - 1)) |
30 | #define HPAGE_MASK (~(HPAGE_SIZE - 1)) | 28 | #define HPAGE_MASK (~(HPAGE_SIZE - 1)) |
31 | 29 | ||
30 | #ifdef __KERNEL__ | ||
31 | |||
32 | #include <hv/hypervisor.h> | ||
33 | #include <arch/chip.h> | ||
34 | |||
32 | /* | 35 | /* |
33 | * The {,H}PAGE_SHIFT values must match the HV_LOG2_PAGE_SIZE_xxx | 36 | * The {,H}PAGE_SHIFT values must match the HV_LOG2_PAGE_SIZE_xxx |
34 | * definitions in <hv/hypervisor.h>. We validate this at build time | 37 | * definitions in <hv/hypervisor.h>. We validate this at build time |
@@ -331,4 +334,6 @@ extern pte_t *virt_to_pte(struct mm_struct *mm, unsigned long addr); | |||
331 | #include <asm-generic/memory_model.h> | 334 | #include <asm-generic/memory_model.h> |
332 | #include <asm-generic/getorder.h> | 335 | #include <asm-generic/getorder.h> |
333 | 336 | ||
337 | #endif /* __KERNEL__ */ | ||
338 | |||
334 | #endif /* _ASM_TILE_PAGE_H */ | 339 | #endif /* _ASM_TILE_PAGE_H */ |
diff --git a/arch/tile/include/asm/pgtable.h b/arch/tile/include/asm/pgtable.h index beb1504e9c10..b3367379d537 100644 --- a/arch/tile/include/asm/pgtable.h +++ b/arch/tile/include/asm/pgtable.h | |||
@@ -229,9 +229,9 @@ static inline void __pte_clear(pte_t *ptep) | |||
229 | #define pte_donemigrate(x) hv_pte_set_present(hv_pte_clear_migrating(x)) | 229 | #define pte_donemigrate(x) hv_pte_set_present(hv_pte_clear_migrating(x)) |
230 | 230 | ||
231 | #define pte_ERROR(e) \ | 231 | #define pte_ERROR(e) \ |
232 | printk("%s:%d: bad pte 0x%016llx.\n", __FILE__, __LINE__, pte_val(e)) | 232 | pr_err("%s:%d: bad pte 0x%016llx.\n", __FILE__, __LINE__, pte_val(e)) |
233 | #define pgd_ERROR(e) \ | 233 | #define pgd_ERROR(e) \ |
234 | printk("%s:%d: bad pgd 0x%016llx.\n", __FILE__, __LINE__, pgd_val(e)) | 234 | pr_err("%s:%d: bad pgd 0x%016llx.\n", __FILE__, __LINE__, pgd_val(e)) |
235 | 235 | ||
236 | /* | 236 | /* |
237 | * set_pte_order() sets the given PTE and also sanity-checks the | 237 | * set_pte_order() sets the given PTE and also sanity-checks the |
@@ -470,6 +470,11 @@ static inline int pmd_huge_page(pmd_t pmd) | |||
470 | 470 | ||
471 | #include <asm-generic/pgtable.h> | 471 | #include <asm-generic/pgtable.h> |
472 | 472 | ||
473 | /* Support /proc/NN/pgtable API. */ | ||
474 | struct seq_file; | ||
475 | int arch_proc_pgtable_show(struct seq_file *m, struct mm_struct *mm, | ||
476 | unsigned long vaddr, pte_t *ptep, void **datap); | ||
477 | |||
473 | #endif /* !__ASSEMBLY__ */ | 478 | #endif /* !__ASSEMBLY__ */ |
474 | 479 | ||
475 | #endif /* _ASM_TILE_PGTABLE_H */ | 480 | #endif /* _ASM_TILE_PGTABLE_H */ |
diff --git a/arch/tile/include/asm/pgtable_32.h b/arch/tile/include/asm/pgtable_32.h index b935fb2ad4f3..53ec34884744 100644 --- a/arch/tile/include/asm/pgtable_32.h +++ b/arch/tile/include/asm/pgtable_32.h | |||
@@ -89,15 +89,27 @@ static inline int pgd_addr_invalid(unsigned long addr) | |||
89 | /* | 89 | /* |
90 | * Provide versions of these routines that can be used safely when | 90 | * Provide versions of these routines that can be used safely when |
91 | * the hypervisor may be asynchronously modifying dirty/accessed bits. | 91 | * the hypervisor may be asynchronously modifying dirty/accessed bits. |
92 | * ptep_get_and_clear() matches the generic one but we provide it to | ||
93 | * be parallel with the 64-bit code. | ||
92 | */ | 94 | */ |
93 | #define __HAVE_ARCH_PTEP_TEST_AND_CLEAR_YOUNG | 95 | #define __HAVE_ARCH_PTEP_TEST_AND_CLEAR_YOUNG |
94 | #define __HAVE_ARCH_PTEP_SET_WRPROTECT | 96 | #define __HAVE_ARCH_PTEP_SET_WRPROTECT |
97 | #define __HAVE_ARCH_PTEP_GET_AND_CLEAR | ||
95 | 98 | ||
96 | extern int ptep_test_and_clear_young(struct vm_area_struct *, | 99 | extern int ptep_test_and_clear_young(struct vm_area_struct *, |
97 | unsigned long addr, pte_t *); | 100 | unsigned long addr, pte_t *); |
98 | extern void ptep_set_wrprotect(struct mm_struct *, | 101 | extern void ptep_set_wrprotect(struct mm_struct *, |
99 | unsigned long addr, pte_t *); | 102 | unsigned long addr, pte_t *); |
100 | 103 | ||
104 | #define __HAVE_ARCH_PTEP_GET_AND_CLEAR | ||
105 | static inline pte_t ptep_get_and_clear(struct mm_struct *mm, | ||
106 | unsigned long addr, pte_t *ptep) | ||
107 | { | ||
108 | pte_t pte = *ptep; | ||
109 | pte_clear(_mm, addr, ptep); | ||
110 | return pte; | ||
111 | } | ||
112 | |||
101 | /* Create a pmd from a PTFN. */ | 113 | /* Create a pmd from a PTFN. */ |
102 | static inline pmd_t ptfn_pmd(unsigned long ptfn, pgprot_t prot) | 114 | static inline pmd_t ptfn_pmd(unsigned long ptfn, pgprot_t prot) |
103 | { | 115 | { |
diff --git a/arch/tile/include/asm/ptrace.h b/arch/tile/include/asm/ptrace.h index 4d1d9953016a..acdae814e016 100644 --- a/arch/tile/include/asm/ptrace.h +++ b/arch/tile/include/asm/ptrace.h | |||
@@ -112,6 +112,9 @@ struct pt_regs { | |||
112 | /* Fill in a struct pt_regs with the current kernel registers. */ | 112 | /* Fill in a struct pt_regs with the current kernel registers. */ |
113 | struct pt_regs *get_pt_regs(struct pt_regs *); | 113 | struct pt_regs *get_pt_regs(struct pt_regs *); |
114 | 114 | ||
115 | /* Trace the current syscall. */ | ||
116 | extern void do_syscall_trace(void); | ||
117 | |||
115 | extern void show_regs(struct pt_regs *); | 118 | extern void show_regs(struct pt_regs *); |
116 | 119 | ||
117 | #define arch_has_single_step() (1) | 120 | #define arch_has_single_step() (1) |
@@ -123,7 +126,7 @@ extern void show_regs(struct pt_regs *); | |||
123 | */ | 126 | */ |
124 | struct single_step_state { | 127 | struct single_step_state { |
125 | /* the page to which we will write hacked-up bundles */ | 128 | /* the page to which we will write hacked-up bundles */ |
126 | void *buffer; | 129 | void __user *buffer; |
127 | 130 | ||
128 | union { | 131 | union { |
129 | int flags; | 132 | int flags; |
diff --git a/arch/tile/include/asm/sections.h b/arch/tile/include/asm/sections.h index 6c111491f0ed..d062d463fca9 100644 --- a/arch/tile/include/asm/sections.h +++ b/arch/tile/include/asm/sections.h | |||
@@ -25,7 +25,14 @@ extern char _sinitdata[], _einitdata[]; | |||
25 | /* Write-once data is writable only till the end of initialization. */ | 25 | /* Write-once data is writable only till the end of initialization. */ |
26 | extern char __w1data_begin[], __w1data_end[]; | 26 | extern char __w1data_begin[], __w1data_end[]; |
27 | 27 | ||
28 | extern char __feedback_section_start[], __feedback_section_end[]; | 28 | |
29 | /* Not exactly sections, but PC comparison points in the code. */ | ||
30 | extern char __rt_sigreturn[], __rt_sigreturn_end[]; | ||
31 | #ifndef __tilegx__ | ||
32 | extern char sys_cmpxchg[], __sys_cmpxchg_end[]; | ||
33 | extern char __sys_cmpxchg_grab_lock[]; | ||
34 | extern char __start_atomic_asm_code[], __end_atomic_asm_code[]; | ||
35 | #endif | ||
29 | 36 | ||
30 | /* Handle the discontiguity between _sdata and _stext. */ | 37 | /* Handle the discontiguity between _sdata and _stext. */ |
31 | static inline int arch_is_kernel_data(unsigned long addr) | 38 | static inline int arch_is_kernel_data(unsigned long addr) |
diff --git a/arch/tile/include/asm/signal.h b/arch/tile/include/asm/signal.h index d20d326d201b..eb0253f32202 100644 --- a/arch/tile/include/asm/signal.h +++ b/arch/tile/include/asm/signal.h | |||
@@ -26,6 +26,7 @@ | |||
26 | #if defined(__KERNEL__) && !defined(__ASSEMBLY__) | 26 | #if defined(__KERNEL__) && !defined(__ASSEMBLY__) |
27 | int restore_sigcontext(struct pt_regs *, struct sigcontext __user *, long *); | 27 | int restore_sigcontext(struct pt_regs *, struct sigcontext __user *, long *); |
28 | int setup_sigcontext(struct sigcontext __user *, struct pt_regs *); | 28 | int setup_sigcontext(struct sigcontext __user *, struct pt_regs *); |
29 | void do_signal(struct pt_regs *regs); | ||
29 | #endif | 30 | #endif |
30 | 31 | ||
31 | #endif /* _ASM_TILE_SIGNAL_H */ | 32 | #endif /* _ASM_TILE_SIGNAL_H */ |
diff --git a/arch/tile/include/asm/spinlock_32.h b/arch/tile/include/asm/spinlock_32.h index f3a8473c68da..88efdde8dd2b 100644 --- a/arch/tile/include/asm/spinlock_32.h +++ b/arch/tile/include/asm/spinlock_32.h | |||
@@ -134,9 +134,8 @@ static inline int arch_read_trylock(arch_rwlock_t *rwlock) | |||
134 | { | 134 | { |
135 | int locked; | 135 | int locked; |
136 | u32 val = __insn_tns((int *)&rwlock->lock); | 136 | u32 val = __insn_tns((int *)&rwlock->lock); |
137 | if (unlikely(val & 1)) { | 137 | if (unlikely(val & 1)) |
138 | return arch_read_trylock_slow(rwlock); | 138 | return arch_read_trylock_slow(rwlock); |
139 | } | ||
140 | locked = (val << _RD_COUNT_WIDTH) == 0; | 139 | locked = (val << _RD_COUNT_WIDTH) == 0; |
141 | rwlock->lock = val + (locked << _RD_COUNT_SHIFT); | 140 | rwlock->lock = val + (locked << _RD_COUNT_SHIFT); |
142 | return locked; | 141 | return locked; |
diff --git a/arch/tile/include/asm/stack.h b/arch/tile/include/asm/stack.h index 864913bcfbc9..f908473c322d 100644 --- a/arch/tile/include/asm/stack.h +++ b/arch/tile/include/asm/stack.h | |||
@@ -48,6 +48,10 @@ extern void KBacktraceIterator_init(struct KBacktraceIterator *kbt, | |||
48 | /* Initialize iterator based on current stack. */ | 48 | /* Initialize iterator based on current stack. */ |
49 | extern void KBacktraceIterator_init_current(struct KBacktraceIterator *kbt); | 49 | extern void KBacktraceIterator_init_current(struct KBacktraceIterator *kbt); |
50 | 50 | ||
51 | /* Helper method for above. */ | ||
52 | extern void _KBacktraceIterator_init_current(struct KBacktraceIterator *kbt, | ||
53 | ulong pc, ulong lr, ulong sp, ulong r52); | ||
54 | |||
51 | /* No more frames? */ | 55 | /* No more frames? */ |
52 | extern int KBacktraceIterator_end(struct KBacktraceIterator *kbt); | 56 | extern int KBacktraceIterator_end(struct KBacktraceIterator *kbt); |
53 | 57 | ||
@@ -64,5 +68,7 @@ extern void tile_show_stack(struct KBacktraceIterator *, int headers); | |||
64 | /* Dump stack of current process, with registers to seed the backtrace. */ | 68 | /* Dump stack of current process, with registers to seed the backtrace. */ |
65 | extern void dump_stack_regs(struct pt_regs *); | 69 | extern void dump_stack_regs(struct pt_regs *); |
66 | 70 | ||
71 | /* Helper method for assembly dump_stack(). */ | ||
72 | extern void _dump_stack(int dummy, ulong pc, ulong lr, ulong sp, ulong r52); | ||
67 | 73 | ||
68 | #endif /* _ASM_TILE_STACK_H */ | 74 | #endif /* _ASM_TILE_STACK_H */ |
diff --git a/arch/tile/include/asm/syscalls.h b/arch/tile/include/asm/syscalls.h index 9f2b8e2f69d5..af165a74537f 100644 --- a/arch/tile/include/asm/syscalls.h +++ b/arch/tile/include/asm/syscalls.h | |||
@@ -22,7 +22,19 @@ | |||
22 | #include <linux/linkage.h> | 22 | #include <linux/linkage.h> |
23 | #include <linux/signal.h> | 23 | #include <linux/signal.h> |
24 | #include <linux/types.h> | 24 | #include <linux/types.h> |
25 | #include <asm-generic/syscalls.h> | 25 | #include <linux/compat.h> |
26 | |||
27 | /* The array of function pointers for syscalls. */ | ||
28 | extern void *sys_call_table[]; | ||
29 | #ifdef CONFIG_COMPAT | ||
30 | extern void *compat_sys_call_table[]; | ||
31 | #endif | ||
32 | |||
33 | /* | ||
34 | * Note that by convention, any syscall which requires the current | ||
35 | * register set takes an additional "struct pt_regs *" pointer; the | ||
36 | * sys_xxx() function just adds the pointer and tail-calls to _sys_xxx(). | ||
37 | */ | ||
26 | 38 | ||
27 | /* kernel/sys.c */ | 39 | /* kernel/sys.c */ |
28 | ssize_t sys32_readahead(int fd, u32 offset_lo, u32 offset_hi, u32 count); | 40 | ssize_t sys32_readahead(int fd, u32 offset_lo, u32 offset_hi, u32 count); |
@@ -31,10 +43,66 @@ long sys32_fadvise64(int fd, u32 offset_lo, u32 offset_hi, | |||
31 | int sys32_fadvise64_64(int fd, u32 offset_lo, u32 offset_hi, | 43 | int sys32_fadvise64_64(int fd, u32 offset_lo, u32 offset_hi, |
32 | u32 len_lo, u32 len_hi, int advice); | 44 | u32 len_lo, u32 len_hi, int advice); |
33 | long sys_flush_cache(void); | 45 | long sys_flush_cache(void); |
46 | long sys_mmap2(unsigned long addr, unsigned long len, | ||
47 | unsigned long prot, unsigned long flags, | ||
48 | unsigned long fd, unsigned long pgoff); | ||
49 | #ifdef __tilegx__ | ||
50 | long sys_mmap(unsigned long addr, unsigned long len, | ||
51 | unsigned long prot, unsigned long flags, | ||
52 | unsigned long fd, off_t pgoff); | ||
53 | #endif | ||
54 | |||
55 | /* kernel/process.c */ | ||
56 | long sys_clone(unsigned long clone_flags, unsigned long newsp, | ||
57 | void __user *parent_tid, void __user *child_tid); | ||
58 | long _sys_clone(unsigned long clone_flags, unsigned long newsp, | ||
59 | void __user *parent_tid, void __user *child_tid, | ||
60 | struct pt_regs *regs); | ||
61 | long sys_fork(void); | ||
62 | long _sys_fork(struct pt_regs *regs); | ||
63 | long sys_vfork(void); | ||
64 | long _sys_vfork(struct pt_regs *regs); | ||
65 | long sys_execve(char __user *filename, char __user * __user *argv, | ||
66 | char __user * __user *envp); | ||
67 | long _sys_execve(char __user *filename, char __user * __user *argv, | ||
68 | char __user * __user *envp, struct pt_regs *regs); | ||
69 | |||
70 | /* kernel/signal.c */ | ||
71 | long sys_sigaltstack(const stack_t __user *, stack_t __user *); | ||
72 | long _sys_sigaltstack(const stack_t __user *, stack_t __user *, | ||
73 | struct pt_regs *); | ||
74 | long sys_rt_sigreturn(void); | ||
75 | long _sys_rt_sigreturn(struct pt_regs *regs); | ||
76 | |||
77 | /* platform-independent functions */ | ||
78 | long sys_rt_sigsuspend(sigset_t __user *unewset, size_t sigsetsize); | ||
79 | long sys_rt_sigaction(int sig, const struct sigaction __user *act, | ||
80 | struct sigaction __user *oact, size_t sigsetsize); | ||
34 | 81 | ||
35 | #ifndef __tilegx__ | 82 | #ifndef __tilegx__ |
36 | /* mm/fault.c */ | 83 | /* mm/fault.c */ |
37 | int sys_cmpxchg_badaddr(unsigned long address, struct pt_regs *); | 84 | int sys_cmpxchg_badaddr(unsigned long address); |
85 | int _sys_cmpxchg_badaddr(unsigned long address, struct pt_regs *); | ||
86 | #endif | ||
87 | |||
88 | #ifdef CONFIG_COMPAT | ||
89 | long compat_sys_execve(char __user *path, compat_uptr_t __user *argv, | ||
90 | compat_uptr_t __user *envp); | ||
91 | long _compat_sys_execve(char __user *path, compat_uptr_t __user *argv, | ||
92 | compat_uptr_t __user *envp, struct pt_regs *regs); | ||
93 | long compat_sys_sigaltstack(const struct compat_sigaltstack __user *uss_ptr, | ||
94 | struct compat_sigaltstack __user *uoss_ptr); | ||
95 | long _compat_sys_sigaltstack(const struct compat_sigaltstack __user *uss_ptr, | ||
96 | struct compat_sigaltstack __user *uoss_ptr, | ||
97 | struct pt_regs *regs); | ||
98 | long compat_sys_rt_sigreturn(void); | ||
99 | long _compat_sys_rt_sigreturn(struct pt_regs *regs); | ||
100 | |||
101 | /* These four are not defined for 64-bit, but serve as "compat" syscalls. */ | ||
102 | long sys_fcntl64(unsigned int fd, unsigned int cmd, unsigned long arg); | ||
103 | long sys_fstat64(unsigned long fd, struct stat64 __user *statbuf); | ||
104 | long sys_truncate64(const char __user *path, loff_t length); | ||
105 | long sys_ftruncate64(unsigned int fd, loff_t length); | ||
38 | #endif | 106 | #endif |
39 | 107 | ||
40 | #endif /* _ASM_TILE_SYSCALLS_H */ | 108 | #endif /* _ASM_TILE_SYSCALLS_H */ |
diff --git a/arch/tile/include/asm/system.h b/arch/tile/include/asm/system.h index d6ca7f816c87..0935094f370a 100644 --- a/arch/tile/include/asm/system.h +++ b/arch/tile/include/asm/system.h | |||
@@ -160,6 +160,14 @@ struct task_struct; | |||
160 | extern struct task_struct *_switch_to(struct task_struct *prev, | 160 | extern struct task_struct *_switch_to(struct task_struct *prev, |
161 | struct task_struct *next); | 161 | struct task_struct *next); |
162 | 162 | ||
163 | /* Helper function for _switch_to(). */ | ||
164 | extern struct task_struct *__switch_to(struct task_struct *prev, | ||
165 | struct task_struct *next, | ||
166 | unsigned long new_system_save_1_0); | ||
167 | |||
168 | /* Address that switched-away from tasks are at. */ | ||
169 | extern unsigned long get_switch_to_pc(void); | ||
170 | |||
163 | /* | 171 | /* |
164 | * On SMP systems, when the scheduler does migration-cost autodetection, | 172 | * On SMP systems, when the scheduler does migration-cost autodetection, |
165 | * it needs a way to flush as much of the CPU's caches as possible: | 173 | * it needs a way to flush as much of the CPU's caches as possible: |
@@ -187,10 +195,26 @@ extern int unaligned_printk; | |||
187 | /* Number of unaligned fixups performed */ | 195 | /* Number of unaligned fixups performed */ |
188 | extern unsigned int unaligned_fixup_count; | 196 | extern unsigned int unaligned_fixup_count; |
189 | 197 | ||
198 | /* Init-time routine to do tile-specific per-cpu setup. */ | ||
199 | void setup_cpu(int boot); | ||
200 | |||
190 | /* User-level DMA management functions */ | 201 | /* User-level DMA management functions */ |
191 | void grant_dma_mpls(void); | 202 | void grant_dma_mpls(void); |
192 | void restrict_dma_mpls(void); | 203 | void restrict_dma_mpls(void); |
193 | 204 | ||
205 | #ifdef CONFIG_HARDWALL | ||
206 | /* User-level network management functions */ | ||
207 | void reset_network_state(void); | ||
208 | void grant_network_mpls(void); | ||
209 | void restrict_network_mpls(void); | ||
210 | int hardwall_deactivate(struct task_struct *task); | ||
211 | |||
212 | /* Hook hardwall code into changes in affinity. */ | ||
213 | #define arch_set_cpus_allowed(p, new_mask) do { \ | ||
214 | if (p->thread.hardwall && !cpumask_equal(&p->cpus_allowed, new_mask)) \ | ||
215 | hardwall_deactivate(p); \ | ||
216 | } while (0) | ||
217 | #endif | ||
194 | 218 | ||
195 | /* Invoke the simulator "syscall" mechanism (see arch/tile/kernel/entry.S). */ | 219 | /* Invoke the simulator "syscall" mechanism (see arch/tile/kernel/entry.S). */ |
196 | extern int _sim_syscall(int syscall_num, ...); | 220 | extern int _sim_syscall(int syscall_num, ...); |
@@ -215,6 +239,12 @@ extern int _sim_syscall(int syscall_num, ...); | |||
215 | homecache_migrate_kthread(); \ | 239 | homecache_migrate_kthread(); \ |
216 | } while (0) | 240 | } while (0) |
217 | 241 | ||
242 | /* Support function for forking a new task. */ | ||
243 | void ret_from_fork(void); | ||
244 | |||
245 | /* Called from ret_from_fork() when a new process starts up. */ | ||
246 | struct task_struct *sim_notify_fork(struct task_struct *prev); | ||
247 | |||
218 | #endif /* !__ASSEMBLY__ */ | 248 | #endif /* !__ASSEMBLY__ */ |
219 | 249 | ||
220 | #endif /* _ASM_TILE_SYSTEM_H */ | 250 | #endif /* _ASM_TILE_SYSTEM_H */ |
diff --git a/arch/tile/include/asm/thread_info.h b/arch/tile/include/asm/thread_info.h index 9024bf3530aa..beec8729564a 100644 --- a/arch/tile/include/asm/thread_info.h +++ b/arch/tile/include/asm/thread_info.h | |||
@@ -55,7 +55,7 @@ struct thread_info { | |||
55 | .restart_block = { \ | 55 | .restart_block = { \ |
56 | .fn = do_no_restart_syscall, \ | 56 | .fn = do_no_restart_syscall, \ |
57 | }, \ | 57 | }, \ |
58 | .step_state = 0, \ | 58 | .step_state = NULL, \ |
59 | } | 59 | } |
60 | 60 | ||
61 | #define init_thread_info (init_thread_union.thread_info) | 61 | #define init_thread_info (init_thread_union.thread_info) |
@@ -86,6 +86,12 @@ register unsigned long stack_pointer __asm__("sp"); | |||
86 | extern struct thread_info *alloc_thread_info(struct task_struct *task); | 86 | extern struct thread_info *alloc_thread_info(struct task_struct *task); |
87 | extern void free_thread_info(struct thread_info *info); | 87 | extern void free_thread_info(struct thread_info *info); |
88 | 88 | ||
89 | /* Sit on a nap instruction until interrupted. */ | ||
90 | extern void smp_nap(void); | ||
91 | |||
92 | /* Enable interrupts racelessly and nap forever: helper for cpu_idle(). */ | ||
93 | extern void _cpu_idle(void); | ||
94 | |||
89 | /* Switch boot idle thread to a freshly-allocated stack and free old stack. */ | 95 | /* Switch boot idle thread to a freshly-allocated stack and free old stack. */ |
90 | extern void cpu_idle_on_new_stack(struct thread_info *old_ti, | 96 | extern void cpu_idle_on_new_stack(struct thread_info *old_ti, |
91 | unsigned long new_sp, | 97 | unsigned long new_sp, |
diff --git a/arch/tile/include/asm/traps.h b/arch/tile/include/asm/traps.h index eab33d4a917d..432a9c15c8a2 100644 --- a/arch/tile/include/asm/traps.h +++ b/arch/tile/include/asm/traps.h | |||
@@ -18,9 +18,28 @@ | |||
18 | /* mm/fault.c */ | 18 | /* mm/fault.c */ |
19 | void do_page_fault(struct pt_regs *, int fault_num, | 19 | void do_page_fault(struct pt_regs *, int fault_num, |
20 | unsigned long address, unsigned long write); | 20 | unsigned long address, unsigned long write); |
21 | void do_async_page_fault(struct pt_regs *); | ||
22 | |||
23 | #ifndef __tilegx__ | ||
24 | /* | ||
25 | * We return this structure in registers to avoid having to write | ||
26 | * additional save/restore code in the intvec.S caller. | ||
27 | */ | ||
28 | struct intvec_state { | ||
29 | void *handler; | ||
30 | unsigned long vecnum; | ||
31 | unsigned long fault_num; | ||
32 | unsigned long info; | ||
33 | unsigned long retval; | ||
34 | }; | ||
35 | struct intvec_state do_page_fault_ics(struct pt_regs *regs, int fault_num, | ||
36 | unsigned long address, | ||
37 | unsigned long info); | ||
38 | #endif | ||
21 | 39 | ||
22 | /* kernel/traps.c */ | 40 | /* kernel/traps.c */ |
23 | void do_trap(struct pt_regs *, int fault_num, unsigned long reason); | 41 | void do_trap(struct pt_regs *, int fault_num, unsigned long reason); |
42 | void kernel_double_fault(int dummy, ulong pc, ulong lr, ulong sp, ulong r52); | ||
24 | 43 | ||
25 | /* kernel/time.c */ | 44 | /* kernel/time.c */ |
26 | void do_timer_interrupt(struct pt_regs *, int fault_num); | 45 | void do_timer_interrupt(struct pt_regs *, int fault_num); |
@@ -31,6 +50,13 @@ void hv_message_intr(struct pt_regs *, int intnum); | |||
31 | /* kernel/irq.c */ | 50 | /* kernel/irq.c */ |
32 | void tile_dev_intr(struct pt_regs *, int intnum); | 51 | void tile_dev_intr(struct pt_regs *, int intnum); |
33 | 52 | ||
53 | #ifdef CONFIG_HARDWALL | ||
54 | /* kernel/hardwall.c */ | ||
55 | void do_hardwall_trap(struct pt_regs *, int fault_num); | ||
56 | #endif | ||
57 | |||
58 | /* kernel/ptrace.c */ | ||
59 | void do_breakpoint(struct pt_regs *, int fault_num); | ||
34 | 60 | ||
35 | 61 | ||
36 | #endif /* _ASM_TILE_SYSCALLS_H */ | 62 | #endif /* _ASM_TILE_SYSCALLS_H */ |
diff --git a/arch/tile/include/asm/uaccess.h b/arch/tile/include/asm/uaccess.h index f3058afd5a88..ed17a80ec0ed 100644 --- a/arch/tile/include/asm/uaccess.h +++ b/arch/tile/include/asm/uaccess.h | |||
@@ -89,8 +89,10 @@ int __range_ok(unsigned long addr, unsigned long size); | |||
89 | * checks that the pointer is in the user space range - after calling | 89 | * checks that the pointer is in the user space range - after calling |
90 | * this function, memory access functions may still return -EFAULT. | 90 | * this function, memory access functions may still return -EFAULT. |
91 | */ | 91 | */ |
92 | #define access_ok(type, addr, size) \ | 92 | #define access_ok(type, addr, size) ({ \ |
93 | (likely(__range_ok((unsigned long)addr, size) == 0)) | 93 | __chk_user_ptr(addr); \ |
94 | likely(__range_ok((unsigned long)(addr), (size)) == 0); \ | ||
95 | }) | ||
94 | 96 | ||
95 | /* | 97 | /* |
96 | * The exception table consists of pairs of addresses: the first is the | 98 | * The exception table consists of pairs of addresses: the first is the |
@@ -134,14 +136,14 @@ struct __get_user { | |||
134 | * such extended assembler routines, though we will have to use a | 136 | * such extended assembler routines, though we will have to use a |
135 | * different return code in that case (1, 2, or 4, rather than -EFAULT). | 137 | * different return code in that case (1, 2, or 4, rather than -EFAULT). |
136 | */ | 138 | */ |
137 | extern struct __get_user __get_user_1(const void *); | 139 | extern struct __get_user __get_user_1(const void __user *); |
138 | extern struct __get_user __get_user_2(const void *); | 140 | extern struct __get_user __get_user_2(const void __user *); |
139 | extern struct __get_user __get_user_4(const void *); | 141 | extern struct __get_user __get_user_4(const void __user *); |
140 | extern struct __get_user __get_user_8(const void *); | 142 | extern struct __get_user __get_user_8(const void __user *); |
141 | extern int __put_user_1(long, void *); | 143 | extern int __put_user_1(long, void __user *); |
142 | extern int __put_user_2(long, void *); | 144 | extern int __put_user_2(long, void __user *); |
143 | extern int __put_user_4(long, void *); | 145 | extern int __put_user_4(long, void __user *); |
144 | extern int __put_user_8(long long, void *); | 146 | extern int __put_user_8(long long, void __user *); |
145 | 147 | ||
146 | /* Unimplemented routines to cause linker failures */ | 148 | /* Unimplemented routines to cause linker failures */ |
147 | extern struct __get_user __get_user_bad(void); | 149 | extern struct __get_user __get_user_bad(void); |
diff --git a/arch/tile/include/asm/unistd.h b/arch/tile/include/asm/unistd.h index 03b3d5d665dd..f2e3ff485333 100644 --- a/arch/tile/include/asm/unistd.h +++ b/arch/tile/include/asm/unistd.h | |||
@@ -15,7 +15,6 @@ | |||
15 | #if !defined(_ASM_TILE_UNISTD_H) || defined(__SYSCALL) | 15 | #if !defined(_ASM_TILE_UNISTD_H) || defined(__SYSCALL) |
16 | #define _ASM_TILE_UNISTD_H | 16 | #define _ASM_TILE_UNISTD_H |
17 | 17 | ||
18 | |||
19 | #ifndef __LP64__ | 18 | #ifndef __LP64__ |
20 | /* Use the flavor of this syscall that matches the 32-bit API better. */ | 19 | /* Use the flavor of this syscall that matches the 32-bit API better. */ |
21 | #define __ARCH_WANT_SYNC_FILE_RANGE2 | 20 | #define __ARCH_WANT_SYNC_FILE_RANGE2 |
@@ -24,6 +23,10 @@ | |||
24 | /* Use the standard ABI for syscalls. */ | 23 | /* Use the standard ABI for syscalls. */ |
25 | #include <asm-generic/unistd.h> | 24 | #include <asm-generic/unistd.h> |
26 | 25 | ||
26 | /* Additional Tilera-specific syscalls. */ | ||
27 | #define __NR_flush_cache (__NR_arch_specific_syscall + 1) | ||
28 | __SYSCALL(__NR_flush_cache, sys_flush_cache) | ||
29 | |||
27 | #ifndef __tilegx__ | 30 | #ifndef __tilegx__ |
28 | /* "Fast" syscalls provide atomic support for 32-bit chips. */ | 31 | /* "Fast" syscalls provide atomic support for 32-bit chips. */ |
29 | #define __NR_FAST_cmpxchg -1 | 32 | #define __NR_FAST_cmpxchg -1 |
@@ -33,10 +36,6 @@ | |||
33 | __SYSCALL(__NR_cmpxchg_badaddr, sys_cmpxchg_badaddr) | 36 | __SYSCALL(__NR_cmpxchg_badaddr, sys_cmpxchg_badaddr) |
34 | #endif | 37 | #endif |
35 | 38 | ||
36 | /* Additional Tilera-specific syscalls. */ | ||
37 | #define __NR_flush_cache (__NR_arch_specific_syscall + 1) | ||
38 | __SYSCALL(__NR_flush_cache, sys_flush_cache) | ||
39 | |||
40 | #ifdef __KERNEL__ | 39 | #ifdef __KERNEL__ |
41 | /* In compat mode, we use sys_llseek() for compat_sys_llseek(). */ | 40 | /* In compat mode, we use sys_llseek() for compat_sys_llseek(). */ |
42 | #ifdef CONFIG_COMPAT | 41 | #ifdef CONFIG_COMPAT |