core: fix typo in percpu read_mostly section
This fixes a typo that named the read_mostly section of percpu as
readmostly. It works fine with SMP because the linker script specifies
.data..percpu..readmostly. However, UP kernel builds don't have percpu
sections defined and the non-percpu version of the section is called
data..read_mostly, so .data..readmostly will float around and may break
things unexpectedly.
Looking at the original change that introduced data..percpu..readmostly
(commit c957ef2c59
), it looks like this
was the original intention.
Tested: Built UP kernel and confirmed the sections got merged.
- Before the patch:
$ objdump -h vmlinux.o | grep '\.data\.\.read.*mostly'
38 .data..read_mostly 00004418 0000000000000000 0000000000000000 00431ac0 2**6
50 .data..readmostly 00000014 0000000000000000 0000000000000000 00444000 2**3
- After the patch:
$ objdump -h vmlinux.o | grep '\.data\.\.read.*mostly'
38 .data..read_mostly 00004438 0000000000000000 0000000000000000 00431ac0 2**6
Signed-off-by: Zhengyu He <hzy@google.com>
Signed-off-by: Filipe Brandenburger <filbranden@google.com>
Signed-off-by: Tejun Heo <tj@kernel.org>
This commit is contained in:
parent
ebe06187bf
commit
330d282216
2 changed files with 3 additions and 3 deletions
|
@ -693,7 +693,7 @@
|
||||||
. = ALIGN(PAGE_SIZE); \
|
. = ALIGN(PAGE_SIZE); \
|
||||||
*(.data..percpu..page_aligned) \
|
*(.data..percpu..page_aligned) \
|
||||||
. = ALIGN(cacheline); \
|
. = ALIGN(cacheline); \
|
||||||
*(.data..percpu..readmostly) \
|
*(.data..percpu..read_mostly) \
|
||||||
. = ALIGN(cacheline); \
|
. = ALIGN(cacheline); \
|
||||||
*(.data..percpu) \
|
*(.data..percpu) \
|
||||||
*(.data..percpu..shared_aligned) \
|
*(.data..percpu..shared_aligned) \
|
||||||
|
|
|
@ -146,10 +146,10 @@
|
||||||
* Declaration/definition used for per-CPU variables that must be read mostly.
|
* Declaration/definition used for per-CPU variables that must be read mostly.
|
||||||
*/
|
*/
|
||||||
#define DECLARE_PER_CPU_READ_MOSTLY(type, name) \
|
#define DECLARE_PER_CPU_READ_MOSTLY(type, name) \
|
||||||
DECLARE_PER_CPU_SECTION(type, name, "..readmostly")
|
DECLARE_PER_CPU_SECTION(type, name, "..read_mostly")
|
||||||
|
|
||||||
#define DEFINE_PER_CPU_READ_MOSTLY(type, name) \
|
#define DEFINE_PER_CPU_READ_MOSTLY(type, name) \
|
||||||
DEFINE_PER_CPU_SECTION(type, name, "..readmostly")
|
DEFINE_PER_CPU_SECTION(type, name, "..read_mostly")
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Intermodule exports for per-CPU variables. sparse forgets about
|
* Intermodule exports for per-CPU variables. sparse forgets about
|
||||||
|
|
Loading…
Reference in a new issue