aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2016-10-12 02:38:39 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2016-10-12 02:38:39 -0400
commit4cdf8dbe2d4b3891a9abd9f9ec32acbe58de0cf6 (patch)
tree006204597d8aab019a8831da3f38556ca9dcaab1
parent6b25e21fa6f26d0f0d45f161d169029411c84286 (diff)
parentaa7eb9ad32f84ce91a92f5c0196ae7adb5611ac4 (diff)
Merge branch 'work.uaccess2' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
Pull uaccess.h prepwork from Al Viro: "Preparations to tree-wide switch to use of linux/uaccess.h (which, obviously, will allow to start unifying stuff for real). The last step there, ie PATT='^[[:blank:]]*#[[:blank:]]*include[[:blank:]]*<asm/uaccess.h>' sed -i -e "s!$PATT!#include <linux/uaccess.h>!" \ `git grep -l "$PATT"|grep -v ^include/linux/uaccess.h` is not taken here - I would prefer to do it once just before or just after -rc1. However, everything should be ready for it" * 'work.uaccess2' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: remove a stray reference to asm/uaccess.h in docs sparc64: separate extable_64.h, switch elf_64.h to it score: separate extable.h, switch module.h to it mips: separate extable.h, switch module.h to it x86: separate extable.h, switch sections.h to it remove stray include of asm/uaccess.h from cacheflush.h mn10300: remove a bogus processor.h->uaccess.h include xtensa: split uaccess.h into C and asm sides bonding: quit messing with IOCTL kill __kernel_ds_p off mn10300: finish verify_area() off frv: move HAVE_ARCH_UNMAPPED_AREA to pgtable.h exceptions: detritus removal
-rw-r--r--Documentation/DocBook/kernel-hacking.tmpl2
-rw-r--r--arch/arm/mm/fault.h1
-rw-r--r--arch/frv/include/asm/pgtable.h1
-rw-r--r--arch/frv/include/asm/segment.h1
-rw-r--r--arch/frv/include/asm/uaccess.h2
-rw-r--r--arch/m68k/include/asm/uaccess_no.h3
-rw-r--r--arch/microblaze/include/asm/uaccess.h3
-rw-r--r--arch/mips/include/asm/extable.h13
-rw-r--r--arch/mips/include/asm/module.h2
-rw-r--r--arch/mips/include/asm/uaccess.h9
-rw-r--r--arch/mips/lasat/picvue_proc.c1
-rw-r--r--arch/mn10300/include/asm/processor.h1
-rw-r--r--arch/mn10300/include/asm/uaccess.h7
-rw-r--r--arch/mn10300/kernel/signal.c6
-rw-r--r--arch/openrisc/include/asm/uaccess.h4
-rw-r--r--arch/score/include/asm/extable.h11
-rw-r--r--arch/score/include/asm/module.h2
-rw-r--r--arch/score/include/asm/uaccess.h8
-rw-r--r--arch/sh/include/asm/uaccess.h2
-rw-r--r--arch/sparc/include/asm/elf_64.h2
-rw-r--r--arch/sparc/include/asm/extable_64.h20
-rw-r--r--arch/sparc/include/asm/uaccess_64.h18
-rw-r--r--arch/x86/include/asm/cacheflush.h1
-rw-r--r--arch/x86/include/asm/extable.h35
-rw-r--r--arch/x86/include/asm/sections.h2
-rw-r--r--arch/x86/include/asm/uaccess.h32
-rw-r--r--arch/x86/mm/fault.c2
-rw-r--r--arch/xtensa/include/asm/asm-uaccess.h160
-rw-r--r--arch/xtensa/include/asm/uaccess.h153
-rw-r--r--arch/xtensa/kernel/coprocessor.S2
-rw-r--r--arch/xtensa/kernel/entry.S2
-rw-r--r--drivers/char/tb0219.c1
-rw-r--r--drivers/net/bonding/bond_main.c4
-rw-r--r--drivers/platform/x86/dell-smo8800.c1
-rw-r--r--drivers/video/fbdev/au1200fb.c1
-rw-r--r--drivers/watchdog/ath79_wdt.c1
-rw-r--r--include/asm-generic/uaccess.h4
-rw-r--r--include/net/bonding.h12
38 files changed, 262 insertions, 270 deletions
diff --git a/Documentation/DocBook/kernel-hacking.tmpl b/Documentation/DocBook/kernel-hacking.tmpl
index 589b40cc5eb5..2a272275c81b 100644
--- a/Documentation/DocBook/kernel-hacking.tmpl
+++ b/Documentation/DocBook/kernel-hacking.tmpl
@@ -483,7 +483,7 @@ printk(KERN_INFO "my ip: %pI4\n", &amp;ipaddress);
483 <function>get_user()</function> 483 <function>get_user()</function>
484 / 484 /
485 <function>put_user()</function> 485 <function>put_user()</function>
486 <filename class="headerfile">include/asm/uaccess.h</filename> 486 <filename class="headerfile">include/linux/uaccess.h</filename>
487 </title> 487 </title>
488 488
489 <para> 489 <para>
diff --git a/arch/arm/mm/fault.h b/arch/arm/mm/fault.h
index 05ec5e0df32d..67532f242271 100644
--- a/arch/arm/mm/fault.h
+++ b/arch/arm/mm/fault.h
@@ -23,7 +23,6 @@ static inline int fsr_fs(unsigned int fsr)
23#endif 23#endif
24 24
25void do_bad_area(unsigned long addr, unsigned int fsr, struct pt_regs *regs); 25void do_bad_area(unsigned long addr, unsigned int fsr, struct pt_regs *regs);
26unsigned long search_exception_table(unsigned long addr);
27void early_abt_enable(void); 26void early_abt_enable(void);
28 27
29#endif /* __ARCH_ARM_FAULT_H */ 28#endif /* __ARCH_ARM_FAULT_H */
diff --git a/arch/frv/include/asm/pgtable.h b/arch/frv/include/asm/pgtable.h
index 07d7a7ef8bd5..a0513d463a1f 100644
--- a/arch/frv/include/asm/pgtable.h
+++ b/arch/frv/include/asm/pgtable.h
@@ -522,5 +522,6 @@ extern void __init pgtable_cache_init(void);
522#ifndef __ASSEMBLY__ 522#ifndef __ASSEMBLY__
523extern void __init paging_init(void); 523extern void __init paging_init(void);
524#endif /* !__ASSEMBLY__ */ 524#endif /* !__ASSEMBLY__ */
525#define HAVE_ARCH_UNMAPPED_AREA
525 526
526#endif /* _ASM_PGTABLE_H */ 527#endif /* _ASM_PGTABLE_H */
diff --git a/arch/frv/include/asm/segment.h b/arch/frv/include/asm/segment.h
index 4377c89a57f5..2305142d4cf8 100644
--- a/arch/frv/include/asm/segment.h
+++ b/arch/frv/include/asm/segment.h
@@ -32,7 +32,6 @@ typedef struct {
32#define get_ds() (KERNEL_DS) 32#define get_ds() (KERNEL_DS)
33#define get_fs() (__current_thread_info->addr_limit) 33#define get_fs() (__current_thread_info->addr_limit)
34#define segment_eq(a, b) ((a).seg == (b).seg) 34#define segment_eq(a, b) ((a).seg == (b).seg)
35#define __kernel_ds_p() segment_eq(get_fs(), KERNEL_DS)
36#define get_addr_limit() (get_fs().seg) 35#define get_addr_limit() (get_fs().seg)
37 36
38#define set_fs(_x) \ 37#define set_fs(_x) \
diff --git a/arch/frv/include/asm/uaccess.h b/arch/frv/include/asm/uaccess.h
index 87d9e34c5df8..c0f4057eab60 100644
--- a/arch/frv/include/asm/uaccess.h
+++ b/arch/frv/include/asm/uaccess.h
@@ -20,8 +20,6 @@
20#include <asm/segment.h> 20#include <asm/segment.h>
21#include <asm/sections.h> 21#include <asm/sections.h>
22 22
23#define HAVE_ARCH_UNMAPPED_AREA /* we decide where to put mmaps */
24
25#define __ptr(x) ((unsigned long __force *)(x)) 23#define __ptr(x) ((unsigned long __force *)(x))
26 24
27#define VERIFY_READ 0 25#define VERIFY_READ 0
diff --git a/arch/m68k/include/asm/uaccess_no.h b/arch/m68k/include/asm/uaccess_no.h
index 1bdf15263754..36deeb36503b 100644
--- a/arch/m68k/include/asm/uaccess_no.h
+++ b/arch/m68k/include/asm/uaccess_no.h
@@ -44,9 +44,6 @@ struct exception_table_entry
44 unsigned long insn, fixup; 44 unsigned long insn, fixup;
45}; 45};
46 46
47/* Returns 0 if exception not found and fixup otherwise. */
48extern unsigned long search_exception_table(unsigned long);
49
50 47
51/* 48/*
52 * These are the main single-value transfer routines. They automatically 49 * These are the main single-value transfer routines. They automatically
diff --git a/arch/microblaze/include/asm/uaccess.h b/arch/microblaze/include/asm/uaccess.h
index 826676778094..253a67e275ad 100644
--- a/arch/microblaze/include/asm/uaccess.h
+++ b/arch/microblaze/include/asm/uaccess.h
@@ -71,9 +71,6 @@ struct exception_table_entry {
71 unsigned long insn, fixup; 71 unsigned long insn, fixup;
72}; 72};
73 73
74/* Returns 0 if exception not found and fixup otherwise. */
75extern unsigned long search_exception_table(unsigned long);
76
77#ifndef CONFIG_MMU 74#ifndef CONFIG_MMU
78 75
79/* Check against bounds of physical memory */ 76/* Check against bounds of physical memory */
diff --git a/arch/mips/include/asm/extable.h b/arch/mips/include/asm/extable.h
new file mode 100644
index 000000000000..dce7a627a925
--- /dev/null
+++ b/arch/mips/include/asm/extable.h
@@ -0,0 +1,13 @@
1#ifndef _ASM_EXTABLE_H
2#define _ASM_EXTABLE_H
3
4struct exception_table_entry
5{
6 unsigned long insn;
7 unsigned long nextinsn;
8};
9
10struct pt_regs;
11extern int fixup_exception(struct pt_regs *regs);
12
13#endif
diff --git a/arch/mips/include/asm/module.h b/arch/mips/include/asm/module.h
index 0aaf9a01ea50..702c273e67a9 100644
--- a/arch/mips/include/asm/module.h
+++ b/arch/mips/include/asm/module.h
@@ -3,7 +3,7 @@
3 3
4#include <linux/list.h> 4#include <linux/list.h>
5#include <linux/elf.h> 5#include <linux/elf.h>
6#include <asm/uaccess.h> 6#include <asm/extable.h>
7 7
8struct mod_arch_specific { 8struct mod_arch_specific {
9 /* Data Bus Error exception tables */ 9 /* Data Bus Error exception tables */
diff --git a/arch/mips/include/asm/uaccess.h b/arch/mips/include/asm/uaccess.h
index 21a2aaba20d5..4daf839cd8a8 100644
--- a/arch/mips/include/asm/uaccess.h
+++ b/arch/mips/include/asm/uaccess.h
@@ -16,6 +16,7 @@
16#include <linux/thread_info.h> 16#include <linux/thread_info.h>
17#include <linux/string.h> 17#include <linux/string.h>
18#include <asm/asm-eva.h> 18#include <asm/asm-eva.h>
19#include <asm/extable.h>
19 20
20/* 21/*
21 * The fs value determines whether argument validity checking should be 22 * The fs value determines whether argument validity checking should be
@@ -1485,12 +1486,4 @@ static inline long strnlen_user(const char __user *s, long n)
1485 return res; 1486 return res;
1486} 1487}
1487 1488
1488struct exception_table_entry
1489{
1490 unsigned long insn;
1491 unsigned long nextinsn;
1492};
1493
1494extern int fixup_exception(struct pt_regs *regs);
1495
1496#endif /* _ASM_UACCESS_H */ 1489#endif /* _ASM_UACCESS_H */
diff --git a/arch/mips/lasat/picvue_proc.c b/arch/mips/lasat/picvue_proc.c
index 27533c109f92..dd292dcec684 100644
--- a/arch/mips/lasat/picvue_proc.c
+++ b/arch/mips/lasat/picvue_proc.c
@@ -16,6 +16,7 @@
16 16
17#include <linux/timer.h> 17#include <linux/timer.h>
18#include <linux/mutex.h> 18#include <linux/mutex.h>
19#include <linux/uaccess.h>
19 20
20#include "picvue.h" 21#include "picvue.h"
21 22
diff --git a/arch/mn10300/include/asm/processor.h b/arch/mn10300/include/asm/processor.h
index 769d5ed8e992..b10ba121c849 100644
--- a/arch/mn10300/include/asm/processor.h
+++ b/arch/mn10300/include/asm/processor.h
@@ -18,7 +18,6 @@
18#include <asm/page.h> 18#include <asm/page.h>
19#include <asm/ptrace.h> 19#include <asm/ptrace.h>
20#include <asm/cpu-regs.h> 20#include <asm/cpu-regs.h>
21#include <asm/uaccess.h>
22#include <asm/current.h> 21#include <asm/current.h>
23 22
24/* Forward declaration, a strange C thing */ 23/* Forward declaration, a strange C thing */
diff --git a/arch/mn10300/include/asm/uaccess.h b/arch/mn10300/include/asm/uaccess.h
index d012e877a95a..2eedf6f46a57 100644
--- a/arch/mn10300/include/asm/uaccess.h
+++ b/arch/mn10300/include/asm/uaccess.h
@@ -38,7 +38,6 @@
38#define get_ds() (KERNEL_DS) 38#define get_ds() (KERNEL_DS)
39#define get_fs() (current_thread_info()->addr_limit) 39#define get_fs() (current_thread_info()->addr_limit)
40#define set_fs(x) (current_thread_info()->addr_limit = (x)) 40#define set_fs(x) (current_thread_info()->addr_limit = (x))
41#define __kernel_ds_p() (current_thread_info()->addr_limit.seg == 0x9FFFFFFF)
42 41
43#define segment_eq(a, b) ((a).seg == (b).seg) 42#define segment_eq(a, b) ((a).seg == (b).seg)
44 43
@@ -72,12 +71,6 @@ static inline int ___range_ok(unsigned long addr, unsigned int size)
72#define access_ok(type, addr, size) (__range_ok((addr), (size)) == 0) 71#define access_ok(type, addr, size) (__range_ok((addr), (size)) == 0)
73#define __access_ok(addr, size) (__range_ok((addr), (size)) == 0) 72#define __access_ok(addr, size) (__range_ok((addr), (size)) == 0)
74 73
75static inline int verify_area(int type, const void *addr, unsigned long size)
76{
77 return access_ok(type, addr, size) ? 0 : -EFAULT;
78}
79
80
81/* 74/*
82 * The exception table consists of pairs of addresses: the first is the 75 * The exception table consists of pairs of addresses: the first is the
83 * address of an instruction that is allowed to fault, and the second is 76 * address of an instruction that is allowed to fault, and the second is
diff --git a/arch/mn10300/kernel/signal.c b/arch/mn10300/kernel/signal.c
index dfd0301cf200..cd8cb1d1176b 100644
--- a/arch/mn10300/kernel/signal.c
+++ b/arch/mn10300/kernel/signal.c
@@ -75,7 +75,7 @@ static int restore_sigcontext(struct pt_regs *regs,
75 struct fpucontext *buf; 75 struct fpucontext *buf;
76 err |= __get_user(buf, &sc->fpucontext); 76 err |= __get_user(buf, &sc->fpucontext);
77 if (buf) { 77 if (buf) {
78 if (verify_area(VERIFY_READ, buf, sizeof(*buf))) 78 if (!access_ok(VERIFY_READ, buf, sizeof(*buf)))
79 goto badframe; 79 goto badframe;
80 err |= fpu_restore_sigcontext(buf); 80 err |= fpu_restore_sigcontext(buf);
81 } 81 }
@@ -98,7 +98,7 @@ asmlinkage long sys_sigreturn(void)
98 long d0; 98 long d0;
99 99
100 frame = (struct sigframe __user *) current_frame()->sp; 100 frame = (struct sigframe __user *) current_frame()->sp;
101 if (verify_area(VERIFY_READ, frame, sizeof(*frame))) 101 if (!access_ok(VERIFY_READ, frame, sizeof(*frame)))
102 goto badframe; 102 goto badframe;
103 if (__get_user(set.sig[0], &frame->sc.oldmask)) 103 if (__get_user(set.sig[0], &frame->sc.oldmask))
104 goto badframe; 104 goto badframe;
@@ -130,7 +130,7 @@ asmlinkage long sys_rt_sigreturn(void)
130 long d0; 130 long d0;
131 131
132 frame = (struct rt_sigframe __user *) current_frame()->sp; 132 frame = (struct rt_sigframe __user *) current_frame()->sp;
133 if (verify_area(VERIFY_READ, frame, sizeof(*frame))) 133 if (!access_ok(VERIFY_READ, frame, sizeof(*frame)))
134 goto badframe; 134 goto badframe;
135 if (__copy_from_user(&set, &frame->uc.uc_sigmask, sizeof(set))) 135 if (__copy_from_user(&set, &frame->uc.uc_sigmask, sizeof(set)))
136 goto badframe; 136 goto badframe;
diff --git a/arch/openrisc/include/asm/uaccess.h b/arch/openrisc/include/asm/uaccess.h
index 5cc6b4f1b795..140faa16685a 100644
--- a/arch/openrisc/include/asm/uaccess.h
+++ b/arch/openrisc/include/asm/uaccess.h
@@ -82,10 +82,6 @@ struct exception_table_entry {
82 unsigned long insn, fixup; 82 unsigned long insn, fixup;
83}; 83};
84 84
85/* Returns 0 if exception not found and fixup otherwise. */
86extern unsigned long search_exception_table(unsigned long);
87extern void sort_exception_table(void);
88
89/* 85/*
90 * These are the main single-value transfer routines. They automatically 86 * These are the main single-value transfer routines. They automatically
91 * use the right size if we just have the right pointer type. 87 * use the right size if we just have the right pointer type.
diff --git a/arch/score/include/asm/extable.h b/arch/score/include/asm/extable.h
new file mode 100644
index 000000000000..c4423ccf830d
--- /dev/null
+++ b/arch/score/include/asm/extable.h
@@ -0,0 +1,11 @@
1#ifndef _ASM_SCORE_EXTABLE_H
2#define _ASM_SCORE_EXTABLE_H
3
4struct exception_table_entry {
5 unsigned long insn;
6 unsigned long fixup;
7};
8
9struct pt_regs;
10extern int fixup_exception(struct pt_regs *regs);
11#endif
diff --git a/arch/score/include/asm/module.h b/arch/score/include/asm/module.h
index abf395bbfaba..6dc1f2935eef 100644
--- a/arch/score/include/asm/module.h
+++ b/arch/score/include/asm/module.h
@@ -2,7 +2,7 @@
2#define _ASM_SCORE_MODULE_H 2#define _ASM_SCORE_MODULE_H
3 3
4#include <linux/list.h> 4#include <linux/list.h>
5#include <asm/uaccess.h> 5#include <asm/extable.h>
6#include <asm-generic/module.h> 6#include <asm-generic/module.h>
7 7
8struct mod_arch_specific { 8struct mod_arch_specific {
diff --git a/arch/score/include/asm/uaccess.h b/arch/score/include/asm/uaccess.h
index 01aec8ccde83..db58ab98ec4b 100644
--- a/arch/score/include/asm/uaccess.h
+++ b/arch/score/include/asm/uaccess.h
@@ -4,6 +4,7 @@
4#include <linux/kernel.h> 4#include <linux/kernel.h>
5#include <linux/errno.h> 5#include <linux/errno.h>
6#include <linux/thread_info.h> 6#include <linux/thread_info.h>
7#include <asm/extable.h>
7 8
8#define VERIFY_READ 0 9#define VERIFY_READ 0
9#define VERIFY_WRITE 1 10#define VERIFY_WRITE 1
@@ -420,12 +421,5 @@ static inline long strnlen_user(const char __user *str, long len)
420 return __strnlen_user(str, len); 421 return __strnlen_user(str, len);
421} 422}
422 423
423struct exception_table_entry {
424 unsigned long insn;
425 unsigned long fixup;
426};
427
428extern int fixup_exception(struct pt_regs *regs);
429
430#endif /* __SCORE_UACCESS_H */ 424#endif /* __SCORE_UACCESS_H */
431 425
diff --git a/arch/sh/include/asm/uaccess.h b/arch/sh/include/asm/uaccess.h
index 92ade79ac427..a38d0c7b818f 100644
--- a/arch/sh/include/asm/uaccess.h
+++ b/arch/sh/include/asm/uaccess.h
@@ -192,8 +192,6 @@ struct exception_table_entry {
192#endif 192#endif
193 193
194int fixup_exception(struct pt_regs *regs); 194int fixup_exception(struct pt_regs *regs);
195/* Returns 0 if exception not found and fixup.unit otherwise. */
196unsigned long search_exception_table(unsigned long addr);
197const struct exception_table_entry *search_exception_tables(unsigned long addr); 195const struct exception_table_entry *search_exception_tables(unsigned long addr);
198 196
199extern void *set_exception_table_vec(unsigned int vec, void *handler); 197extern void *set_exception_table_vec(unsigned int vec, void *handler);
diff --git a/arch/sparc/include/asm/elf_64.h b/arch/sparc/include/asm/elf_64.h
index 93310837c2df..3f2d403873bd 100644
--- a/arch/sparc/include/asm/elf_64.h
+++ b/arch/sparc/include/asm/elf_64.h
@@ -7,7 +7,7 @@
7 7
8#include <asm/ptrace.h> 8#include <asm/ptrace.h>
9#include <asm/processor.h> 9#include <asm/processor.h>
10#include <asm/uaccess.h> 10#include <asm/extable_64.h>
11#include <asm/spitfire.h> 11#include <asm/spitfire.h>
12 12
13/* 13/*
diff --git a/arch/sparc/include/asm/extable_64.h b/arch/sparc/include/asm/extable_64.h
new file mode 100644
index 000000000000..1121cb056ffb
--- /dev/null
+++ b/arch/sparc/include/asm/extable_64.h
@@ -0,0 +1,20 @@
1#ifndef __ASM_EXTABLE64_H
2#define __ASM_EXTABLE64_H
3/*
4 * The exception table consists of pairs of addresses: the first is the
5 * address of an instruction that is allowed to fault, and the second is
6 * the address at which the program should continue. No registers are
7 * modified, so it is entirely up to the continuation code to figure out
8 * what to do.
9 *
10 * All the routines below use bits of fixup code that are out of line
11 * with the main instruction path. This means when everything is well,
12 * we don't even have to jump over them. Further, they do not intrude
13 * on our cache or tlb entries.
14 */
15
16struct exception_table_entry {
17 unsigned int insn, fixup;
18};
19
20#endif
diff --git a/arch/sparc/include/asm/uaccess_64.h b/arch/sparc/include/asm/uaccess_64.h
index 37a315d0ddd4..b68acc563235 100644
--- a/arch/sparc/include/asm/uaccess_64.h
+++ b/arch/sparc/include/asm/uaccess_64.h
@@ -13,6 +13,7 @@
13#include <asm/asi.h> 13#include <asm/asi.h>
14#include <asm/spitfire.h> 14#include <asm/spitfire.h>
15#include <asm-generic/uaccess-unaligned.h> 15#include <asm-generic/uaccess-unaligned.h>
16#include <asm/extable_64.h>
16#endif 17#endif
17 18
18#ifndef __ASSEMBLY__ 19#ifndef __ASSEMBLY__
@@ -81,23 +82,6 @@ static inline int access_ok(int type, const void __user * addr, unsigned long si
81 return 1; 82 return 1;
82} 83}
83 84
84/*
85 * The exception table consists of pairs of addresses: the first is the
86 * address of an instruction that is allowed to fault, and the second is
87 * the address at which the program should continue. No registers are
88 * modified, so it is entirely up to the continuation code to figure out
89 * what to do.
90 *
91 * All the routines below use bits of fixup code that are out of line
92 * with the main instruction path. This means when everything is well,
93 * we don't even have to jump over them. Further, they do not intrude
94 * on our cache or tlb entries.
95 */
96
97struct exception_table_entry {
98 unsigned int insn, fixup;
99};
100
101void __ret_efault(void); 85void __ret_efault(void);
102void __retl_efault(void); 86void __retl_efault(void);
103 87
diff --git a/arch/x86/include/asm/cacheflush.h b/arch/x86/include/asm/cacheflush.h
index 61518cf79437..872877d930de 100644
--- a/arch/x86/include/asm/cacheflush.h
+++ b/arch/x86/include/asm/cacheflush.h
@@ -4,7 +4,6 @@
4/* Caches aren't brain-dead on the intel. */ 4/* Caches aren't brain-dead on the intel. */
5#include <asm-generic/cacheflush.h> 5#include <asm-generic/cacheflush.h>
6#include <asm/special_insns.h> 6#include <asm/special_insns.h>
7#include <asm/uaccess.h>
8 7
9/* 8/*
10 * The set_memory_* API can be used to change various attributes of a virtual 9 * The set_memory_* API can be used to change various attributes of a virtual
diff --git a/arch/x86/include/asm/extable.h b/arch/x86/include/asm/extable.h
new file mode 100644
index 000000000000..b8ad261d11dc
--- /dev/null
+++ b/arch/x86/include/asm/extable.h
@@ -0,0 +1,35 @@
1#ifndef _ASM_X86_EXTABLE_H
2#define _ASM_X86_EXTABLE_H
3/*
4 * The exception table consists of triples of addresses relative to the
5 * exception table entry itself. The first address is of an instruction
6 * that is allowed to fault, the second is the target at which the program
7 * should continue. The third is a handler function to deal with the fault
8 * caused by the instruction in the first field.
9 *
10 * All the routines below use bits of fixup code that are out of line
11 * with the main instruction path. This means when everything is well,
12 * we don't even have to jump over them. Further, they do not intrude
13 * on our cache or tlb entries.
14 */
15
16struct exception_table_entry {
17 int insn, fixup, handler;
18};
19struct pt_regs;
20
21#define ARCH_HAS_RELATIVE_EXTABLE
22
23#define swap_ex_entry_fixup(a, b, tmp, delta) \
24 do { \
25 (a)->fixup = (b)->fixup + (delta); \
26 (b)->fixup = (tmp).fixup - (delta); \
27 (a)->handler = (b)->handler + (delta); \
28 (b)->handler = (tmp).handler - (delta); \
29 } while (0)
30
31extern int fixup_exception(struct pt_regs *regs, int trapnr);
32extern bool ex_has_fault_handler(unsigned long ip);
33extern void early_fixup_exception(struct pt_regs *regs, int trapnr);
34
35#endif
diff --git a/arch/x86/include/asm/sections.h b/arch/x86/include/asm/sections.h
index 13b6cdd0af57..2f75f30cb2f6 100644
--- a/arch/x86/include/asm/sections.h
+++ b/arch/x86/include/asm/sections.h
@@ -2,7 +2,7 @@
2#define _ASM_X86_SECTIONS_H 2#define _ASM_X86_SECTIONS_H
3 3
4#include <asm-generic/sections.h> 4#include <asm-generic/sections.h>
5#include <asm/uaccess.h> 5#include <asm/extable.h>
6 6
7extern char __brk_base[], __brk_limit[]; 7extern char __brk_base[], __brk_limit[];
8extern struct exception_table_entry __stop___ex_table[]; 8extern struct exception_table_entry __stop___ex_table[];
diff --git a/arch/x86/include/asm/uaccess.h b/arch/x86/include/asm/uaccess.h
index 2131c4ce7d8a..faf3687f1035 100644
--- a/arch/x86/include/asm/uaccess.h
+++ b/arch/x86/include/asm/uaccess.h
@@ -11,6 +11,7 @@
11#include <asm/asm.h> 11#include <asm/asm.h>
12#include <asm/page.h> 12#include <asm/page.h>
13#include <asm/smap.h> 13#include <asm/smap.h>
14#include <asm/extable.h>
14 15
15#define VERIFY_READ 0 16#define VERIFY_READ 0
16#define VERIFY_WRITE 1 17#define VERIFY_WRITE 1
@@ -91,37 +92,6 @@ static inline bool __chk_range_not_ok(unsigned long addr, unsigned long size, un
91 likely(!__range_not_ok(addr, size, user_addr_max())) 92 likely(!__range_not_ok(addr, size, user_addr_max()))
92 93
93/* 94/*
94 * The exception table consists of triples of addresses relative to the
95 * exception table entry itself. The first address is of an instruction
96 * that is allowed to fault, the second is the target at which the program
97 * should continue. The third is a handler function to deal with the fault
98 * caused by the instruction in the first field.
99 *
100 * All the routines below use bits of fixup code that are out of line
101 * with the main instruction path. This means when everything is well,
102 * we don't even have to jump over them. Further, they do not intrude
103 * on our cache or tlb entries.
104 */
105
106struct exception_table_entry {
107 int insn, fixup, handler;
108};
109
110#define ARCH_HAS_RELATIVE_EXTABLE
111
112#define swap_ex_entry_fixup(a, b, tmp, delta) \
113 do { \
114 (a)->fixup = (b)->fixup + (delta); \
115 (b)->fixup = (tmp).fixup - (delta); \
116 (a)->handler = (b)->handler + (delta); \
117 (b)->handler = (tmp).handler - (delta); \
118 } while (0)
119
120extern int fixup_exception(struct pt_regs *regs, int trapnr);
121extern bool ex_has_fault_handler(unsigned long ip);
122extern void early_fixup_exception(struct pt_regs *regs, int trapnr);
123
124/*
125 * These are the main single-value transfer routines. They automatically 95 * These are the main single-value transfer routines. They automatically
126 * use the right size if we just have the right pointer type. 96 * use the right size if we just have the right pointer type.
127 * 97 *
diff --git a/arch/x86/mm/fault.c b/arch/x86/mm/fault.c
index 4dc13340653e..9f72ca3b2669 100644
--- a/arch/x86/mm/fault.c
+++ b/arch/x86/mm/fault.c
@@ -5,7 +5,7 @@
5 */ 5 */
6#include <linux/sched.h> /* test_thread_flag(), ... */ 6#include <linux/sched.h> /* test_thread_flag(), ... */
7#include <linux/kdebug.h> /* oops_begin/end, ... */ 7#include <linux/kdebug.h> /* oops_begin/end, ... */
8#include <linux/extable.h> /* search_exception_table */ 8#include <linux/extable.h> /* search_exception_tables */
9#include <linux/bootmem.h> /* max_low_pfn */ 9#include <linux/bootmem.h> /* max_low_pfn */
10#include <linux/kprobes.h> /* NOKPROBE_SYMBOL, ... */ 10#include <linux/kprobes.h> /* NOKPROBE_SYMBOL, ... */
11#include <linux/mmiotrace.h> /* kmmio_handler, ... */ 11#include <linux/mmiotrace.h> /* kmmio_handler, ... */
diff --git a/arch/xtensa/include/asm/asm-uaccess.h b/arch/xtensa/include/asm/asm-uaccess.h
new file mode 100644
index 000000000000..a7a110039786
--- /dev/null
+++ b/arch/xtensa/include/asm/asm-uaccess.h
@@ -0,0 +1,160 @@
1/*
2 * include/asm-xtensa/uaccess.h
3 *
4 * User space memory access functions
5 *
6 * These routines provide basic accessing functions to the user memory
7 * space for the kernel. This header file provides functions such as:
8 *
9 * This file is subject to the terms and conditions of the GNU General Public
10 * License. See the file "COPYING" in the main directory of this archive
11 * for more details.
12 *
13 * Copyright (C) 2001 - 2005 Tensilica Inc.
14 */
15
16#ifndef _XTENSA_ASM_UACCESS_H
17#define _XTENSA_ASM_UACCESS_H
18
19#include <linux/errno.h>
20#include <asm/types.h>
21
22#define VERIFY_READ 0
23#define VERIFY_WRITE 1
24
25#include <asm/current.h>
26#include <asm/asm-offsets.h>
27#include <asm/processor.h>
28
29/*
30 * These assembly macros mirror the C macros in asm/uaccess.h. They
31 * should always have identical functionality. See
32 * arch/xtensa/kernel/sys.S for usage.
33 */
34
35#define KERNEL_DS 0
36#define USER_DS 1
37
38#define get_ds (KERNEL_DS)
39
40/*
41 * get_fs reads current->thread.current_ds into a register.
42 * On Entry:
43 * <ad> anything
44 * <sp> stack
45 * On Exit:
46 * <ad> contains current->thread.current_ds
47 */
48 .macro get_fs ad, sp
49 GET_CURRENT(\ad,\sp)
50#if THREAD_CURRENT_DS > 1020
51 addi \ad, \ad, TASK_THREAD
52 l32i \ad, \ad, THREAD_CURRENT_DS - TASK_THREAD
53#else
54 l32i \ad, \ad, THREAD_CURRENT_DS
55#endif
56 .endm
57
58/*
59 * set_fs sets current->thread.current_ds to some value.
60 * On Entry:
61 * <at> anything (temp register)
62 * <av> value to write
63 * <sp> stack
64 * On Exit:
65 * <at> destroyed (actually, current)
66 * <av> preserved, value to write
67 */
68 .macro set_fs at, av, sp
69 GET_CURRENT(\at,\sp)
70 s32i \av, \at, THREAD_CURRENT_DS
71 .endm
72
73/*
74 * kernel_ok determines whether we should bypass addr/size checking.
75 * See the equivalent C-macro version below for clarity.
76 * On success, kernel_ok branches to a label indicated by parameter
77 * <success>. This implies that the macro falls through to the next
78 * insruction on an error.
79 *
80 * Note that while this macro can be used independently, we designed
81 * in for optimal use in the access_ok macro below (i.e., we fall
82 * through on error).
83 *
84 * On Entry:
85 * <at> anything (temp register)
86 * <success> label to branch to on success; implies
87 * fall-through macro on error
88 * <sp> stack pointer
89 * On Exit:
90 * <at> destroyed (actually, current->thread.current_ds)
91 */
92
93#if ((KERNEL_DS != 0) || (USER_DS == 0))
94# error Assembly macro kernel_ok fails
95#endif
96 .macro kernel_ok at, sp, success
97 get_fs \at, \sp
98 beqz \at, \success
99 .endm
100
101/*
102 * user_ok determines whether the access to user-space memory is allowed.
103 * See the equivalent C-macro version below for clarity.
104 *
105 * On error, user_ok branches to a label indicated by parameter
106 * <error>. This implies that the macro falls through to the next
107 * instruction on success.
108 *
109 * Note that while this macro can be used independently, we designed
110 * in for optimal use in the access_ok macro below (i.e., we fall
111 * through on success).
112 *
113 * On Entry:
114 * <aa> register containing memory address
115 * <as> register containing memory size
116 * <at> temp register
117 * <error> label to branch to on error; implies fall-through
118 * macro on success
119 * On Exit:
120 * <aa> preserved
121 * <as> preserved
122 * <at> destroyed (actually, (TASK_SIZE + 1 - size))
123 */
124 .macro user_ok aa, as, at, error
125 movi \at, __XTENSA_UL_CONST(TASK_SIZE)
126 bgeu \as, \at, \error
127 sub \at, \at, \as
128 bgeu \aa, \at, \error
129 .endm
130
131/*
132 * access_ok determines whether a memory access is allowed. See the
133 * equivalent C-macro version below for clarity.
134 *
135 * On error, access_ok branches to a label indicated by parameter
136 * <error>. This implies that the macro falls through to the next
137 * instruction on success.
138 *
139 * Note that we assume success is the common case, and we optimize the
140 * branch fall-through case on success.
141 *
142 * On Entry:
143 * <aa> register containing memory address
144 * <as> register containing memory size
145 * <at> temp register
146 * <sp>
147 * <error> label to branch to on error; implies fall-through
148 * macro on success
149 * On Exit:
150 * <aa> preserved
151 * <as> preserved
152 * <at> destroyed
153 */
154 .macro access_ok aa, as, at, sp, error
155 kernel_ok \at, \sp, .Laccess_ok_\@
156 user_ok \aa, \as, \at, \error
157.Laccess_ok_\@:
158 .endm
159
160#endif /* _XTENSA_ASM_UACCESS_H */
diff --git a/arch/xtensa/include/asm/uaccess.h b/arch/xtensa/include/asm/uaccess.h
index 147b26ed9c91..848a3d736bcb 100644
--- a/arch/xtensa/include/asm/uaccess.h
+++ b/arch/xtensa/include/asm/uaccess.h
@@ -17,153 +17,12 @@
17#define _XTENSA_UACCESS_H 17#define _XTENSA_UACCESS_H
18 18
19#include <linux/errno.h> 19#include <linux/errno.h>
20#ifndef __ASSEMBLY__
21#include <linux/prefetch.h> 20#include <linux/prefetch.h>
22#endif
23#include <asm/types.h> 21#include <asm/types.h>
24 22
25#define VERIFY_READ 0 23#define VERIFY_READ 0
26#define VERIFY_WRITE 1 24#define VERIFY_WRITE 1
27 25
28#ifdef __ASSEMBLY__
29
30#include <asm/current.h>
31#include <asm/asm-offsets.h>
32#include <asm/processor.h>
33
34/*
35 * These assembly macros mirror the C macros that follow below. They
36 * should always have identical functionality. See
37 * arch/xtensa/kernel/sys.S for usage.
38 */
39
40#define KERNEL_DS 0
41#define USER_DS 1
42
43#define get_ds (KERNEL_DS)
44
45/*
46 * get_fs reads current->thread.current_ds into a register.
47 * On Entry:
48 * <ad> anything
49 * <sp> stack
50 * On Exit:
51 * <ad> contains current->thread.current_ds
52 */
53 .macro get_fs ad, sp
54 GET_CURRENT(\ad,\sp)
55#if THREAD_CURRENT_DS > 1020
56 addi \ad, \ad, TASK_THREAD
57 l32i \ad, \ad, THREAD_CURRENT_DS - TASK_THREAD
58#else
59 l32i \ad, \ad, THREAD_CURRENT_DS
60#endif
61 .endm
62
63/*
64 * set_fs sets current->thread.current_ds to some value.
65 * On Entry:
66 * <at> anything (temp register)
67 * <av> value to write
68 * <sp> stack
69 * On Exit:
70 * <at> destroyed (actually, current)
71 * <av> preserved, value to write
72 */
73 .macro set_fs at, av, sp
74 GET_CURRENT(\at,\sp)
75 s32i \av, \at, THREAD_CURRENT_DS
76 .endm
77
78/*
79 * kernel_ok determines whether we should bypass addr/size checking.
80 * See the equivalent C-macro version below for clarity.
81 * On success, kernel_ok branches to a label indicated by parameter
82 * <success>. This implies that the macro falls through to the next
83 * insruction on an error.
84 *
85 * Note that while this macro can be used independently, we designed
86 * in for optimal use in the access_ok macro below (i.e., we fall
87 * through on error).
88 *
89 * On Entry:
90 * <at> anything (temp register)
91 * <success> label to branch to on success; implies
92 * fall-through macro on error
93 * <sp> stack pointer
94 * On Exit:
95 * <at> destroyed (actually, current->thread.current_ds)
96 */
97
98#if ((KERNEL_DS != 0) || (USER_DS == 0))
99# error Assembly macro kernel_ok fails
100#endif
101 .macro kernel_ok at, sp, success
102 get_fs \at, \sp
103 beqz \at, \success
104 .endm
105
106/*
107 * user_ok determines whether the access to user-space memory is allowed.
108 * See the equivalent C-macro version below for clarity.
109 *
110 * On error, user_ok branches to a label indicated by parameter
111 * <error>. This implies that the macro falls through to the next
112 * instruction on success.
113 *
114 * Note that while this macro can be used independently, we designed
115 * in for optimal use in the access_ok macro below (i.e., we fall
116 * through on success).
117 *
118 * On Entry:
119 * <aa> register containing memory address
120 * <as> register containing memory size
121 * <at> temp register
122 * <error> label to branch to on error; implies fall-through
123 * macro on success
124 * On Exit:
125 * <aa> preserved
126 * <as> preserved
127 * <at> destroyed (actually, (TASK_SIZE + 1 - size))
128 */
129 .macro user_ok aa, as, at, error
130 movi \at, __XTENSA_UL_CONST(TASK_SIZE)
131 bgeu \as, \at, \error
132 sub \at, \at, \as
133 bgeu \aa, \at, \error
134 .endm
135
136/*
137 * access_ok determines whether a memory access is allowed. See the
138 * equivalent C-macro version below for clarity.
139 *
140 * On error, access_ok branches to a label indicated by parameter
141 * <error>. This implies that the macro falls through to the next
142 * instruction on success.
143 *
144 * Note that we assume success is the common case, and we optimize the
145 * branch fall-through case on success.
146 *
147 * On Entry:
148 * <aa> register containing memory address
149 * <as> register containing memory size
150 * <at> temp register
151 * <sp>
152 * <error> label to branch to on error; implies fall-through
153 * macro on success
154 * On Exit:
155 * <aa> preserved
156 * <as> preserved
157 * <at> destroyed
158 */
159 .macro access_ok aa, as, at, sp, error
160 kernel_ok \at, \sp, .Laccess_ok_\@
161 user_ok \aa, \as, \at, \error
162.Laccess_ok_\@:
163 .endm
164
165#else /* __ASSEMBLY__ not defined */
166
167#include <linux/sched.h> 26#include <linux/sched.h>
168 27
169/* 28/*
@@ -495,16 +354,4 @@ struct exception_table_entry
495 unsigned long insn, fixup; 354 unsigned long insn, fixup;
496}; 355};
497 356
498/* Returns 0 if exception not found and fixup.unit otherwise. */
499
500extern unsigned long search_exception_table(unsigned long addr);
501extern void sort_exception_table(void);
502
503/* Returns the new pc */
504#define fixup_exception(map_reg, fixup_unit, pc) \
505({ \
506 fixup_unit; \
507})
508
509#endif /* __ASSEMBLY__ */
510#endif /* _XTENSA_UACCESS_H */ 357#endif /* _XTENSA_UACCESS_H */
diff --git a/arch/xtensa/kernel/coprocessor.S b/arch/xtensa/kernel/coprocessor.S
index a482df5df2b2..6911e384f608 100644
--- a/arch/xtensa/kernel/coprocessor.S
+++ b/arch/xtensa/kernel/coprocessor.S
@@ -17,7 +17,7 @@
17#include <asm/processor.h> 17#include <asm/processor.h>
18#include <asm/coprocessor.h> 18#include <asm/coprocessor.h>
19#include <asm/thread_info.h> 19#include <asm/thread_info.h>
20#include <asm/uaccess.h> 20#include <asm/asm-uaccess.h>
21#include <asm/unistd.h> 21#include <asm/unistd.h>
22#include <asm/ptrace.h> 22#include <asm/ptrace.h>
23#include <asm/current.h> 23#include <asm/current.h>
diff --git a/arch/xtensa/kernel/entry.S b/arch/xtensa/kernel/entry.S
index fa04d9d368a7..f5ef3cc0497c 100644
--- a/arch/xtensa/kernel/entry.S
+++ b/arch/xtensa/kernel/entry.S
@@ -17,7 +17,7 @@
17#include <asm/processor.h> 17#include <asm/processor.h>
18#include <asm/coprocessor.h> 18#include <asm/coprocessor.h>
19#include <asm/thread_info.h> 19#include <asm/thread_info.h>
20#include <asm/uaccess.h> 20#include <asm/asm-uaccess.h>
21#include <asm/unistd.h> 21#include <asm/unistd.h>
22#include <asm/ptrace.h> 22#include <asm/ptrace.h>
23#include <asm/current.h> 23#include <asm/current.h>
diff --git a/drivers/char/tb0219.c b/drivers/char/tb0219.c
index 480a777db577..7c19d9b22785 100644
--- a/drivers/char/tb0219.c
+++ b/drivers/char/tb0219.c
@@ -21,6 +21,7 @@
21#include <linux/fs.h> 21#include <linux/fs.h>
22#include <linux/init.h> 22#include <linux/init.h>
23#include <linux/module.h> 23#include <linux/module.h>
24#include <linux/uaccess.h>
24 25
25#include <asm/io.h> 26#include <asm/io.h>
26#include <asm/reboot.h> 27#include <asm/reboot.h>
diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c
index 3f31ca32f52b..5fa36ebc0640 100644
--- a/drivers/net/bonding/bond_main.c
+++ b/drivers/net/bonding/bond_main.c
@@ -471,9 +471,9 @@ static int bond_check_dev_link(struct bonding *bond,
471 /* Yes, the mii is overlaid on the ifreq.ifr_ifru */ 471 /* Yes, the mii is overlaid on the ifreq.ifr_ifru */
472 strncpy(ifr.ifr_name, slave_dev->name, IFNAMSIZ); 472 strncpy(ifr.ifr_name, slave_dev->name, IFNAMSIZ);
473 mii = if_mii(&ifr); 473 mii = if_mii(&ifr);
474 if (IOCTL(slave_dev, &ifr, SIOCGMIIPHY) == 0) { 474 if (ioctl(slave_dev, &ifr, SIOCGMIIPHY) == 0) {
475 mii->reg_num = MII_BMSR; 475 mii->reg_num = MII_BMSR;
476 if (IOCTL(slave_dev, &ifr, SIOCGMIIREG) == 0) 476 if (ioctl(slave_dev, &ifr, SIOCGMIIREG) == 0)
477 return mii->val_out & BMSR_LSTATUS; 477 return mii->val_out & BMSR_LSTATUS;
478 } 478 }
479 } 479 }
diff --git a/drivers/platform/x86/dell-smo8800.c b/drivers/platform/x86/dell-smo8800.c
index 0aec4fd4c48e..37e646034ef8 100644
--- a/drivers/platform/x86/dell-smo8800.c
+++ b/drivers/platform/x86/dell-smo8800.c
@@ -24,6 +24,7 @@
24#include <linux/acpi.h> 24#include <linux/acpi.h>
25#include <linux/interrupt.h> 25#include <linux/interrupt.h>
26#include <linux/miscdevice.h> 26#include <linux/miscdevice.h>
27#include <linux/uaccess.h>
27 28
28struct smo8800_device { 29struct smo8800_device {
29 u32 irq; /* acpi device irq */ 30 u32 irq; /* acpi device irq */
diff --git a/drivers/video/fbdev/au1200fb.c b/drivers/video/fbdev/au1200fb.c
index f9507b1894df..6c2b2ca4a909 100644
--- a/drivers/video/fbdev/au1200fb.c
+++ b/drivers/video/fbdev/au1200fb.c
@@ -43,6 +43,7 @@
43#include <linux/ctype.h> 43#include <linux/ctype.h>
44#include <linux/dma-mapping.h> 44#include <linux/dma-mapping.h>
45#include <linux/slab.h> 45#include <linux/slab.h>
46#include <linux/uaccess.h>
46 47
47#include <asm/mach-au1x00/au1000.h> 48#include <asm/mach-au1x00/au1000.h>
48#include <asm/mach-au1x00/au1200fb.h> /* platform_data */ 49#include <asm/mach-au1x00/au1200fb.h> /* platform_data */
diff --git a/drivers/watchdog/ath79_wdt.c b/drivers/watchdog/ath79_wdt.c
index 835d310081e1..e2209bf5fa8a 100644
--- a/drivers/watchdog/ath79_wdt.c
+++ b/drivers/watchdog/ath79_wdt.c
@@ -35,6 +35,7 @@
35#include <linux/err.h> 35#include <linux/err.h>
36#include <linux/of.h> 36#include <linux/of.h>
37#include <linux/of_platform.h> 37#include <linux/of_platform.h>
38#include <linux/uaccess.h>
38 39
39#define DRIVER_NAME "ath79-wdt" 40#define DRIVER_NAME "ath79-wdt"
40 41
diff --git a/include/asm-generic/uaccess.h b/include/asm-generic/uaccess.h
index 6df9b0749671..cc6bb319e464 100644
--- a/include/asm-generic/uaccess.h
+++ b/include/asm-generic/uaccess.h
@@ -69,10 +69,6 @@ struct exception_table_entry
69 unsigned long insn, fixup; 69 unsigned long insn, fixup;
70}; 70};
71 71
72/* Returns 0 if exception not found and fixup otherwise. */
73extern unsigned long search_exception_table(unsigned long);
74
75
76/* 72/*
77 * architectures with an MMU should override these two 73 * architectures with an MMU should override these two
78 */ 74 */
diff --git a/include/net/bonding.h b/include/net/bonding.h
index 6360c259da6d..f32f7ef8a23a 100644
--- a/include/net/bonding.h
+++ b/include/net/bonding.h
@@ -37,18 +37,6 @@
37#ifndef __long_aligned 37#ifndef __long_aligned
38#define __long_aligned __attribute__((aligned((sizeof(long))))) 38#define __long_aligned __attribute__((aligned((sizeof(long)))))
39#endif 39#endif
40/*
41 * Less bad way to call ioctl from within the kernel; this needs to be
42 * done some other way to get the call out of interrupt context.
43 * Needs "ioctl" variable to be supplied by calling context.
44 */
45#define IOCTL(dev, arg, cmd) ({ \
46 int res = 0; \
47 mm_segment_t fs = get_fs(); \
48 set_fs(get_ds()); \
49 res = ioctl(dev, arg, cmd); \
50 set_fs(fs); \
51 res; })
52 40
53#define BOND_MODE(bond) ((bond)->params.mode) 41#define BOND_MODE(bond) ((bond)->params.mode)
54 42