summaryrefslogtreecommitdiff
path: root/net/sunrpc/timer.c
diff options
context:
space:
mode:
authorGuenter Roeck <linux@roeck-us.net>2021-11-02 07:24:20 -0700
committerAlexander Grund <flamefire89@gmail.com>2024-03-07 18:17:12 +0100
commit3d129c2c52ce9bb9af94364957b7a75758351c2b (patch)
treebf845e7bd3a9cd9488df20cdb1f9b54eafbea837 /net/sunrpc/timer.c
parent603fe30acf57a20d48ceec9fccb78715f5d589c9 (diff)
string: uninline memcpy_and_pad
commit 5c4e0a21fae877a7ef89be6dcc6263ec672372b8 upstream. When building m68k:allmodconfig, recent versions of gcc generate the following error if the length of UTS_RELEASE is less than 8 bytes. In function 'memcpy_and_pad', inlined from 'nvmet_execute_disc_identify' at drivers/nvme/target/discovery.c:268:2: arch/m68k/include/asm/string.h:72:25: error: '__builtin_memcpy' reading 8 bytes from a region of size 7 Discussions around the problem suggest that this only happens if an architecture does not provide strlen(), if -ffreestanding is provided as compiler option, and if CONFIG_FORTIFY_SOURCE=n. All of this is the case for m68k. The exact reasons are unknown, but seem to be related to the ability of the compiler to evaluate the return value of strlen() and the resulting execution flow in memcpy_and_pad(). It would be possible to work around the problem by using sizeof(UTS_RELEASE) instead of strlen(UTS_RELEASE), but that would only postpone the problem until the function is called in a similar way. Uninline memcpy_and_pad() instead to solve the problem for good. Suggested-by: Linus Torvalds <torvalds@linux-foundation.org> Reviewed-by: Geert Uytterhoeven <geert@linux-m68k.org> Acked-by: Andy Shevchenko <andriy.shevchenko@intel.com> Change-Id: I21516b6de0b5f3d8af30ebbbfcac2d4a495658ac Signed-off-by: Guenter Roeck <linux@roeck-us.net> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Alexander Grund <theflamefire89@gmail.com>
Diffstat (limited to 'net/sunrpc/timer.c')
0 files changed, 0 insertions, 0 deletions