diff options
author | Dmitry Safonov <dima@arista.com> | 2018-10-12 09:42:53 -0400 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2018-11-01 08:02:21 -0400 |
commit | 98f76206b33504b934209d16196477dfa519a807 (patch) | |
tree | 3e2dea288531e70e4c881d9e9ca2eeba926afb76 | |
parent | a846446b1914d1e3d996d657754f43fde89bab51 (diff) |
compat: Cleanup in_compat_syscall() callers
Now that in_compat_syscall() is consistent on all architectures and does
not longer report true on native i686, the workarounds (ifdeffery and
helpers) can be removed.
Signed-off-by: Dmitry Safonov <dima@arista.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: Dmitry Safonov <0x7f454c46@gmail.com>
Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Cc: Andy Lutomirsky <luto@kernel.org>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Herbert Xu <herbert@gondor.apana.org.au>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: John Stultz <john.stultz@linaro.org>
Cc: "Kirill A. Shutemov" <kirill.shutemov@linux.intel.com>
Cc: Oleg Nesterov <oleg@redhat.com>
Cc: Steffen Klassert <steffen.klassert@secunet.com>
Cc: Stephen Boyd <sboyd@kernel.org>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: linux-efi@vger.kernel.org
Cc: netdev@vger.kernel.org
Link: https://lkml.kernel.org/r/20181012134253.23266-3-dima@arista.com
-rw-r--r-- | drivers/firmware/efi/efivars.c | 16 | ||||
-rw-r--r-- | kernel/time/time.c | 2 | ||||
-rw-r--r-- | net/xfrm/xfrm_state.c | 2 | ||||
-rw-r--r-- | net/xfrm/xfrm_user.c | 2 |
4 files changed, 5 insertions, 17 deletions
diff --git a/drivers/firmware/efi/efivars.c b/drivers/firmware/efi/efivars.c index 3e626fd9bd4e..8061667a6765 100644 --- a/drivers/firmware/efi/efivars.c +++ b/drivers/firmware/efi/efivars.c | |||
@@ -229,14 +229,6 @@ sanity_check(struct efi_variable *var, efi_char16_t *name, efi_guid_t vendor, | |||
229 | return 0; | 229 | return 0; |
230 | } | 230 | } |
231 | 231 | ||
232 | static inline bool is_compat(void) | ||
233 | { | ||
234 | if (IS_ENABLED(CONFIG_COMPAT) && in_compat_syscall()) | ||
235 | return true; | ||
236 | |||
237 | return false; | ||
238 | } | ||
239 | |||
240 | static void | 232 | static void |
241 | copy_out_compat(struct efi_variable *dst, struct compat_efi_variable *src) | 233 | copy_out_compat(struct efi_variable *dst, struct compat_efi_variable *src) |
242 | { | 234 | { |
@@ -263,7 +255,7 @@ efivar_store_raw(struct efivar_entry *entry, const char *buf, size_t count) | |||
263 | u8 *data; | 255 | u8 *data; |
264 | int err; | 256 | int err; |
265 | 257 | ||
266 | if (is_compat()) { | 258 | if (in_compat_syscall()) { |
267 | struct compat_efi_variable *compat; | 259 | struct compat_efi_variable *compat; |
268 | 260 | ||
269 | if (count != sizeof(*compat)) | 261 | if (count != sizeof(*compat)) |
@@ -324,7 +316,7 @@ efivar_show_raw(struct efivar_entry *entry, char *buf) | |||
324 | &entry->var.DataSize, entry->var.Data)) | 316 | &entry->var.DataSize, entry->var.Data)) |
325 | return -EIO; | 317 | return -EIO; |
326 | 318 | ||
327 | if (is_compat()) { | 319 | if (in_compat_syscall()) { |
328 | compat = (struct compat_efi_variable *)buf; | 320 | compat = (struct compat_efi_variable *)buf; |
329 | 321 | ||
330 | size = sizeof(*compat); | 322 | size = sizeof(*compat); |
@@ -418,7 +410,7 @@ static ssize_t efivar_create(struct file *filp, struct kobject *kobj, | |||
418 | struct compat_efi_variable *compat = (struct compat_efi_variable *)buf; | 410 | struct compat_efi_variable *compat = (struct compat_efi_variable *)buf; |
419 | struct efi_variable *new_var = (struct efi_variable *)buf; | 411 | struct efi_variable *new_var = (struct efi_variable *)buf; |
420 | struct efivar_entry *new_entry; | 412 | struct efivar_entry *new_entry; |
421 | bool need_compat = is_compat(); | 413 | bool need_compat = in_compat_syscall(); |
422 | efi_char16_t *name; | 414 | efi_char16_t *name; |
423 | unsigned long size; | 415 | unsigned long size; |
424 | u32 attributes; | 416 | u32 attributes; |
@@ -495,7 +487,7 @@ static ssize_t efivar_delete(struct file *filp, struct kobject *kobj, | |||
495 | if (!capable(CAP_SYS_ADMIN)) | 487 | if (!capable(CAP_SYS_ADMIN)) |
496 | return -EACCES; | 488 | return -EACCES; |
497 | 489 | ||
498 | if (is_compat()) { | 490 | if (in_compat_syscall()) { |
499 | if (count != sizeof(*compat)) | 491 | if (count != sizeof(*compat)) |
500 | return -EINVAL; | 492 | return -EINVAL; |
501 | 493 | ||
diff --git a/kernel/time/time.c b/kernel/time/time.c index e3a7f7fd3abc..ad204cf6d001 100644 --- a/kernel/time/time.c +++ b/kernel/time/time.c | |||
@@ -842,7 +842,7 @@ int get_timespec64(struct timespec64 *ts, | |||
842 | ts->tv_sec = kts.tv_sec; | 842 | ts->tv_sec = kts.tv_sec; |
843 | 843 | ||
844 | /* Zero out the padding for 32 bit systems or in compat mode */ | 844 | /* Zero out the padding for 32 bit systems or in compat mode */ |
845 | if (IS_ENABLED(CONFIG_64BIT_TIME) && (!IS_ENABLED(CONFIG_64BIT) || in_compat_syscall())) | 845 | if (IS_ENABLED(CONFIG_64BIT_TIME) && in_compat_syscall()) |
846 | kts.tv_nsec &= 0xFFFFFFFFUL; | 846 | kts.tv_nsec &= 0xFFFFFFFFUL; |
847 | 847 | ||
848 | ts->tv_nsec = kts.tv_nsec; | 848 | ts->tv_nsec = kts.tv_nsec; |
diff --git a/net/xfrm/xfrm_state.c b/net/xfrm/xfrm_state.c index b669262682c9..dc4a9f1fb941 100644 --- a/net/xfrm/xfrm_state.c +++ b/net/xfrm/xfrm_state.c | |||
@@ -2077,10 +2077,8 @@ int xfrm_user_policy(struct sock *sk, int optname, u8 __user *optval, int optlen | |||
2077 | struct xfrm_mgr *km; | 2077 | struct xfrm_mgr *km; |
2078 | struct xfrm_policy *pol = NULL; | 2078 | struct xfrm_policy *pol = NULL; |
2079 | 2079 | ||
2080 | #ifdef CONFIG_COMPAT | ||
2081 | if (in_compat_syscall()) | 2080 | if (in_compat_syscall()) |
2082 | return -EOPNOTSUPP; | 2081 | return -EOPNOTSUPP; |
2083 | #endif | ||
2084 | 2082 | ||
2085 | if (!optval && !optlen) { | 2083 | if (!optval && !optlen) { |
2086 | xfrm_sk_policy_insert(sk, XFRM_POLICY_IN, NULL); | 2084 | xfrm_sk_policy_insert(sk, XFRM_POLICY_IN, NULL); |
diff --git a/net/xfrm/xfrm_user.c b/net/xfrm/xfrm_user.c index ca7a207b81a9..c9a84e22f5d5 100644 --- a/net/xfrm/xfrm_user.c +++ b/net/xfrm/xfrm_user.c | |||
@@ -2621,10 +2621,8 @@ static int xfrm_user_rcv_msg(struct sk_buff *skb, struct nlmsghdr *nlh, | |||
2621 | const struct xfrm_link *link; | 2621 | const struct xfrm_link *link; |
2622 | int type, err; | 2622 | int type, err; |
2623 | 2623 | ||
2624 | #ifdef CONFIG_COMPAT | ||
2625 | if (in_compat_syscall()) | 2624 | if (in_compat_syscall()) |
2626 | return -EOPNOTSUPP; | 2625 | return -EOPNOTSUPP; |
2627 | #endif | ||
2628 | 2626 | ||
2629 | type = nlh->nlmsg_type; | 2627 | type = nlh->nlmsg_type; |
2630 | if (type > XFRM_MSG_MAX) | 2628 | if (type > XFRM_MSG_MAX) |