summaryrefslogtreecommitdiff
path: root/README
diff options
context:
space:
mode:
authorArnd Bergmann <arnd@arndb.de>2021-05-06 00:12:42 +0300
committerPeter Zijlstra <peterz@infradead.org>2021-05-06 16:33:49 +0300
commit1139aeb1c521eb4a050920ce6c64c36c4f2a3ab7 (patch)
tree8c78df882fe9a6daac3e0566edb5e1f8bce7fdce /README
parent635de956a7f5a6ffcb04f29d70630c64c717b56b (diff)
downloadlinux-1139aeb1c521eb4a050920ce6c64c36c4f2a3ab7.tar.xz
smp: Fix smp_call_function_single_async prototype
As of commit 966a967116e6 ("smp: Avoid using two cache lines for struct call_single_data"), the smp code prefers 32-byte aligned call_single_data objects for performance reasons, but the block layer includes an instance of this structure in the main 'struct request' that is more senstive to size than to performance here, see 4ccafe032005 ("block: unalign call_single_data in struct request"). The result is a violation of the calling conventions that clang correctly points out: block/blk-mq.c:630:39: warning: passing 8-byte aligned argument to 32-byte aligned parameter 2 of 'smp_call_function_single_async' may result in an unaligned pointer access [-Walign-mismatch] smp_call_function_single_async(cpu, &rq->csd); It does seem that the usage of the call_single_data without cache line alignment should still be allowed by the smp code, so just change the function prototype so it accepts both, but leave the default alignment unchanged for the other users. This seems better to me than adding a local hack to shut up an otherwise correct warning in the caller. Signed-off-by: Arnd Bergmann <arnd@arndb.de> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Acked-by: Jens Axboe <axboe@kernel.dk> Link: https://lkml.kernel.org/r/20210505211300.3174456-1-arnd@kernel.org
Diffstat (limited to 'README')
0 files changed, 0 insertions, 0 deletions