提交 aff77951 编写于 作者: V Vladis Dronov 提交者: Michael Ellerman

powerpc: fix function annotations to avoid section mismatch warnings with gcc-10

Certain warnings are emitted for powerpc code when building with a gcc-10
toolset:

    WARNING: modpost: vmlinux.o(.text.unlikely+0x377c): Section mismatch in
    reference from the function remove_pmd_table() to the function
    .meminit.text:split_kernel_mapping()
    The function remove_pmd_table() references
    the function __meminit split_kernel_mapping().
    This is often because remove_pmd_table lacks a __meminit
    annotation or the annotation of split_kernel_mapping is wrong.

Add the appropriate __init and __meminit annotations to make modpost not
complain. In all the cases there are just a single callsite from another
__init or __meminit function:

__meminit remove_pagetable() -> remove_pud_table() -> remove_pmd_table()
__init prom_init() -> setup_secure_guest()
__init xive_spapr_init() -> xive_spapr_disabled()
Signed-off-by: NVladis Dronov <vdronov@redhat.com>
Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20200729133741.62789-1-vdronov@redhat.com
上级 2e6bd221
...@@ -3270,7 +3270,7 @@ static int enter_secure_mode(unsigned long kbase, unsigned long fdt) ...@@ -3270,7 +3270,7 @@ static int enter_secure_mode(unsigned long kbase, unsigned long fdt)
/* /*
* Call the Ultravisor to transfer us to secure memory if we have an ESM blob. * Call the Ultravisor to transfer us to secure memory if we have an ESM blob.
*/ */
static void setup_secure_guest(unsigned long kbase, unsigned long fdt) static void __init setup_secure_guest(unsigned long kbase, unsigned long fdt)
{ {
int ret; int ret;
...@@ -3300,7 +3300,7 @@ static void setup_secure_guest(unsigned long kbase, unsigned long fdt) ...@@ -3300,7 +3300,7 @@ static void setup_secure_guest(unsigned long kbase, unsigned long fdt)
} }
} }
#else #else
static void setup_secure_guest(unsigned long kbase, unsigned long fdt) static void __init setup_secure_guest(unsigned long kbase, unsigned long fdt)
{ {
} }
#endif /* CONFIG_PPC_SVM */ #endif /* CONFIG_PPC_SVM */
......
...@@ -823,7 +823,7 @@ static void remove_pte_table(pte_t *pte_start, unsigned long addr, ...@@ -823,7 +823,7 @@ static void remove_pte_table(pte_t *pte_start, unsigned long addr,
} }
} }
static void remove_pmd_table(pmd_t *pmd_start, unsigned long addr, static void __meminit remove_pmd_table(pmd_t *pmd_start, unsigned long addr,
unsigned long end) unsigned long end)
{ {
unsigned long next; unsigned long next;
...@@ -853,7 +853,7 @@ static void remove_pmd_table(pmd_t *pmd_start, unsigned long addr, ...@@ -853,7 +853,7 @@ static void remove_pmd_table(pmd_t *pmd_start, unsigned long addr,
} }
} }
static void remove_pud_table(pud_t *pud_start, unsigned long addr, static void __meminit remove_pud_table(pud_t *pud_start, unsigned long addr,
unsigned long end) unsigned long end)
{ {
unsigned long next; unsigned long next;
......
...@@ -768,7 +768,7 @@ static const u8 *get_vec5_feature(unsigned int index) ...@@ -768,7 +768,7 @@ static const u8 *get_vec5_feature(unsigned int index)
return vec5 + index; return vec5 + index;
} }
static bool xive_spapr_disabled(void) static bool __init xive_spapr_disabled(void)
{ {
const u8 *vec5_xive; const u8 *vec5_xive;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册