]> git.baikalelectronics.ru Git - kernel.git/commitdiff
powerpc/32/build: move got1/got2 sections out of text
authorNicholas Piggin <npiggin@gmail.com>
Fri, 16 Sep 2022 04:07:50 +0000 (14:07 +1000)
committerMichael Ellerman <mpe@ellerman.id.au>
Mon, 26 Sep 2022 10:58:17 +0000 (20:58 +1000)
Following the example from the binutils default linker script, move
.got1 and .got2 out of .text, to just after RO_DATA.

Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20220916040755.2398112-3-npiggin@gmail.com
arch/powerpc/kernel/vmlinux.lds.S

index 5fe33a65902930c304dd2e2cc1d95f1e9ce28bf7..a922c348b4f750a889eeabaf856d54ce75c92817 100644 (file)
@@ -126,14 +126,6 @@ SECTIONS
                *(.sfpr);
                MEM_KEEP(init.text)
                MEM_KEEP(exit.text)
-
-#ifdef CONFIG_PPC32
-               *(.got1)
-               __got2_start = .;
-               *(.got2)
-               __got2_end = .;
-#endif /* CONFIG_PPC32 */
-
        } :text
 
        . = ALIGN(PAGE_SIZE);
@@ -143,7 +135,16 @@ SECTIONS
        /* Read-only data */
        RO_DATA(PAGE_SIZE)
 
-#ifdef CONFIG_PPC64
+#ifdef CONFIG_PPC32
+       .got1 : AT(ADDR(.got1) - LOAD_OFFSET) {
+               *(.got1)
+       }
+       .got2 : AT(ADDR(.got2) - LOAD_OFFSET) {
+               __got2_start = .;
+               *(.got2)
+               __got2_end = .;
+       }
+#else /* CONFIG_PPC32 */
        SOFT_MASK_TABLE(8)
        RESTART_TABLE(8)
 
@@ -194,7 +195,7 @@ SECTIONS
                *(__rfi_flush_fixup)
                __stop___rfi_flush_fixup = .;
        }
-#endif /* CONFIG_PPC64 */
+#endif /* CONFIG_PPC32 */
 
 #ifdef CONFIG_PPC_BARRIER_NOSPEC
        . = ALIGN(8);