diff options
author | Sebastian Andrzej Siewior <bigeasy@linutronix.de> | 2019-04-24 04:52:53 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2019-04-24 06:17:08 -0400 |
commit | d4645d30b50d1691c26ff0f8fa4e718b08f8d3bb (patch) | |
tree | 23feedb73bf7aab415e01e5fd278d7459dd3cdba | |
parent | de7b77e5bb9451417ca57f1b6501da654587c048 (diff) |
smpboot: Place the __percpu annotation correctly
The test robot reported a wrong assignment of a per-CPU variable which
it detected by using sparse and sent a report. The assignment itself is
correct. The annotation for sparse was wrong and hence the report.
The first pointer is a "normal" pointer and points to the per-CPU memory
area. That means that the __percpu annotation has to be moved.
Move the __percpu annotation to pointer which points to the per-CPU
area. This change affects only the sparse tool (and is ignored by the
compiler).
Reported-by: kbuild test robot <lkp@intel.com>
Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Paul E. McKenney <paulmck@linux.ibm.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Fixes: f97f8f06a49fe ("smpboot: Provide infrastructure for percpu hotplug threads")
Link: http://lkml.kernel.org/r/20190424085253.12178-1-bigeasy@linutronix.de
Signed-off-by: Ingo Molnar <mingo@kernel.org>
-rw-r--r-- | include/linux/smpboot.h | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/include/linux/smpboot.h b/include/linux/smpboot.h index d0884b525001..9d1bc65d226c 100644 --- a/include/linux/smpboot.h +++ b/include/linux/smpboot.h | |||
@@ -29,7 +29,7 @@ struct smpboot_thread_data; | |||
29 | * @thread_comm: The base name of the thread | 29 | * @thread_comm: The base name of the thread |
30 | */ | 30 | */ |
31 | struct smp_hotplug_thread { | 31 | struct smp_hotplug_thread { |
32 | struct task_struct __percpu **store; | 32 | struct task_struct * __percpu *store; |
33 | struct list_head list; | 33 | struct list_head list; |
34 | int (*thread_should_run)(unsigned int cpu); | 34 | int (*thread_should_run)(unsigned int cpu); |
35 | void (*thread_fn)(unsigned int cpu); | 35 | void (*thread_fn)(unsigned int cpu); |