|
@@ -370,6 +370,14 @@ do { \
|
|
__pu_err; \
|
|
__pu_err; \
|
|
})
|
|
})
|
|
|
|
|
|
|
|
+#ifdef CONFIG_CPU_SPECTRE
|
|
|
|
+/*
|
|
|
|
+ * When mitigating Spectre variant 1.1, all accessors need to include
|
|
|
|
+ * verification of the address space.
|
|
|
|
+ */
|
|
|
|
+#define __put_user(x, ptr) put_user(x, ptr)
|
|
|
|
+
|
|
|
|
+#else
|
|
#define __put_user(x, ptr) \
|
|
#define __put_user(x, ptr) \
|
|
({ \
|
|
({ \
|
|
long __pu_err = 0; \
|
|
long __pu_err = 0; \
|
|
@@ -377,12 +385,6 @@ do { \
|
|
__pu_err; \
|
|
__pu_err; \
|
|
})
|
|
})
|
|
|
|
|
|
-#define __put_user_error(x, ptr, err) \
|
|
|
|
-({ \
|
|
|
|
- __put_user_switch((x), (ptr), (err), __put_user_nocheck); \
|
|
|
|
- (void) 0; \
|
|
|
|
-})
|
|
|
|
-
|
|
|
|
#define __put_user_nocheck(x, __pu_ptr, __err, __size) \
|
|
#define __put_user_nocheck(x, __pu_ptr, __err, __size) \
|
|
do { \
|
|
do { \
|
|
unsigned long __pu_addr = (unsigned long)__pu_ptr; \
|
|
unsigned long __pu_addr = (unsigned long)__pu_ptr; \
|
|
@@ -462,6 +464,7 @@ do { \
|
|
: "r" (x), "i" (-EFAULT) \
|
|
: "r" (x), "i" (-EFAULT) \
|
|
: "cc")
|
|
: "cc")
|
|
|
|
|
|
|
|
+#endif /* !CONFIG_CPU_SPECTRE */
|
|
|
|
|
|
#ifdef CONFIG_MMU
|
|
#ifdef CONFIG_MMU
|
|
extern unsigned long __must_check
|
|
extern unsigned long __must_check
|