x86/uaccess: Move variable into switch case statement
authorKees Cook <keescook@chromium.org>
Thu, 9 Dec 2021 04:34:56 +0000 (20:34 -0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 27 Jan 2022 09:53:55 +0000 (10:53 +0100)
[ Upstream commit 61646ca83d3889696f2772edaff122dd96a2935e ]

When building with automatic stack variable initialization, GCC 12
complains about variables defined outside of switch case statements.
Move the variable into the case that uses it, which silences the warning:

./arch/x86/include/asm/uaccess.h:317:23: warning: statement will never be executed [-Wswitch-unreachable]
  317 |         unsigned char x_u8__; \
      |                       ^~~~~~

Fixes: 865c50e1d279 ("x86/uaccess: utilize CONFIG_CC_HAS_ASM_GOTO_OUTPUT")
Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Dave Hansen <dave.hansen@linux.intel.com>
Signed-off-by: Borislav Petkov <bp@suse.de>
Link: https://lkml.kernel.org/r/20211209043456.1377875-1-keescook@chromium.org
Signed-off-by: Sasha Levin <sashal@kernel.org>
arch/x86/include/asm/uaccess.h

index 5c95d242f38d708e313f39cc781fa8455fdd16ed..bb1430283c726c1fa5791b56ca88bee298200b94 100644 (file)
@@ -314,11 +314,12 @@ do {                                                                      \
 do {                                                                   \
        __chk_user_ptr(ptr);                                            \
        switch (size) {                                                 \
-       unsigned char x_u8__;                                           \
-       case 1:                                                         \
+       case 1: {                                                       \
+               unsigned char x_u8__;                                   \
                __get_user_asm(x_u8__, ptr, "b", "=q", label);          \
                (x) = x_u8__;                                           \
                break;                                                  \
+       }                                                               \
        case 2:                                                         \
                __get_user_asm(x, ptr, "w", "=r", label);               \
                break;                                                  \