]> git.baikalelectronics.ru Git - kernel.git/commitdiff
powerpc/booke: Avoid link stack corruption in several places
authorChristophe Leroy <christophe.leroy@csgroup.eu>
Tue, 24 Aug 2021 07:56:26 +0000 (07:56 +0000)
committerMichael Ellerman <mpe@ellerman.id.au>
Wed, 25 Aug 2021 03:35:47 +0000 (13:35 +1000)
Use bcl 20,31,+4 instead of bl in order to preserve link stack.

See commit cf139ca31085 ("powerpc/vdso: Avoid link stack corruption
in __get_datapage()") for details.

Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/e9fbc285eceb720e6c0e032ef47fe8b05f669b48.1629791751.git.christophe.leroy@csgroup.eu
arch/powerpc/include/asm/ppc_asm.h
arch/powerpc/kernel/exceptions-64e.S
arch/powerpc/kernel/fsl_booke_entry_mapping.S
arch/powerpc/kernel/head_44x.S
arch/powerpc/kernel/head_fsl_booke.S
arch/powerpc/mm/nohash/tlb_low.S

index ffe712307e1189f62f52af803ab9125bcf13cf19..1c538a9a11e09327a174b13ae5dffb3fdd0c1fc1 100644 (file)
@@ -260,7 +260,7 @@ n:
 
 /* Be careful, this will clobber the lr register. */
 #define LOAD_REG_ADDR_PIC(reg, name)           \
-       bl      0f;                             \
+       bcl     20,31,$+4;                      \
 0:     mflr    reg;                            \
        addis   reg,reg,(name - 0b)@ha;         \
        addi    reg,reg,(name - 0b)@l;
index 1401787b0b937f3edd429c5730309708814c8b3d..7e0943d9f9b0104b5c6270c886032269541dc64c 100644 (file)
@@ -1127,7 +1127,7 @@ found_iprot:
  * r3 = MAS0_TLBSEL (for the iprot array)
  * r4 = SPRN_TLBnCFG
  */
-       bl      invstr                          /* Find our address */
+       bcl     20,31,$+4                       /* Find our address */
 invstr:        mflr    r6                              /* Make it accessible */
        mfmsr   r7
        rlwinm  r5,r7,27,31,31                  /* extract MSR[IS] */
@@ -1196,7 +1196,7 @@ skpinv:   addi    r6,r6,1                         /* Increment */
        mfmsr   r6
        xori    r6,r6,MSR_IS
        mtspr   SPRN_SRR1,r6
-       bl      1f              /* Find our address */
+       bcl     20,31,$+4       /* Find our address */
 1:     mflr    r6
        addi    r6,r6,(2f - 1b)
        mtspr   SPRN_SRR0,r6
@@ -1256,7 +1256,7 @@ skpinv:   addi    r6,r6,1                         /* Increment */
  * r4 = MAS0 w/TLBSEL & ESEL for the temp mapping
  */
        /* Now we branch the new virtual address mapped by this entry */
-       bl      1f              /* Find our address */
+       bcl     20,31,$+4       /* Find our address */
 1:     mflr    r6
        addi    r6,r6,(2f - 1b)
        tovirt(r6,r6)
index 8bccce6544b5eadc5845020b2c22958899f92cfe..dedc17fac8f806248425d7b668fe0dd6c5e56f36 100644 (file)
@@ -1,7 +1,7 @@
 /* SPDX-License-Identifier: GPL-2.0 */
 
 /* 1. Find the index of the entry we're executing in */
-       bl      invstr                          /* Find our address */
+       bcl     20,31,$+4                               /* Find our address */
 invstr:        mflr    r6                              /* Make it accessible */
        mfmsr   r7
        rlwinm  r4,r7,27,31,31                  /* extract MSR[IS] */
@@ -85,7 +85,7 @@ skpinv:       addi    r6,r6,1                         /* Increment */
        addi    r6,r6,10
        slw     r6,r8,r6        /* convert to mask */
 
-       bl      1f              /* Find our address */
+       bcl     20,31,$+4       /* Find our address */
 1:     mflr    r7
 
        mfspr   r8,SPRN_MAS3
@@ -117,7 +117,7 @@ skpinv:     addi    r6,r6,1                         /* Increment */
 
        xori    r6,r4,1
        slwi    r6,r6,5         /* setup new context with other address space */
-       bl      1f              /* Find our address */
+       bcl     20,31,$+4       /* Find our address */
 1:     mflr    r9
        rlwimi  r7,r9,0,20,31
        addi    r7,r7,(2f - 1b)
@@ -207,7 +207,7 @@ next_tlb_setup:
 
        lis     r7,MSR_KERNEL@h
        ori     r7,r7,MSR_KERNEL@l
-       bl      1f                      /* Find our address */
+       bcl     20,31,$+4               /* Find our address */
 1:     mflr    r9
        rlwimi  r6,r9,0,20,31
        addi    r6,r6,(2f - 1b)
index ddc978a2d3819384ae0935bb41bcb18a94351e88..02d2928d1e01064fa463db64fb7d66883609e8f7 100644 (file)
@@ -70,7 +70,7 @@ _ENTRY(_start);
  * address.
  * r21 will be loaded with the physical runtime address of _stext
  */
-       bl      0f                              /* Get our runtime address */
+       bcl     20,31,$+4                       /* Get our runtime address */
 0:     mflr    r21                             /* Make it accessible */
        addis   r21,r21,(_stext - 0b)@ha
        addi    r21,r21,(_stext - 0b)@l         /* Get our current runtime base */
@@ -853,7 +853,7 @@ _GLOBAL(init_cpu_state)
 wmmucr:        mtspr   SPRN_MMUCR,r3                   /* Put MMUCR */
        sync
 
-       bl      invstr                          /* Find our address */
+       bcl     20,31,$+4                       /* Find our address */
 invstr:        mflr    r5                              /* Make it accessible */
        tlbsx   r23,0,r5                        /* Find entry we are in */
        li      r4,0                            /* Start at TLB entry 0 */
@@ -1045,7 +1045,7 @@ head_start_47x:
        sync
 
        /* Find the entry we are running from */
-       bl      1f
+       bcl     20,31,$+4
 1:     mflr    r23
        tlbsx   r23,0,r23
        tlbre   r24,r23,0
index 0f9642f36b4900dee70507359451f93f57a7d4f2..dbf3b89e543c5df3036bdfd3b5d8fc05b78c0f83 100644 (file)
@@ -79,7 +79,7 @@ _ENTRY(_start);
        mr      r23,r3
        mr      r25,r4
 
-       bl      0f
+       bcl     20,31,$+4
 0:     mflr    r8
        addis   r3,r8,(is_second_reloc - 0b)@ha
        lwz     r19,(is_second_reloc - 0b)@l(r3)
@@ -1132,7 +1132,7 @@ _GLOBAL(switch_to_as1)
        bne     1b
 
        /* Get the tlb entry used by the current running code */
-       bl      0f
+       bcl     20,31,$+4
 0:     mflr    r4
        tlbsx   0,r4
 
@@ -1166,7 +1166,7 @@ _GLOBAL(switch_to_as1)
 _GLOBAL(restore_to_as0)
        mflr    r0
 
-       bl      0f
+       bcl     20,31,$+4
 0:     mflr    r9
        addi    r9,r9,1f - 0b
 
index 4613bf8e9aae66d80aa5fdfc50d03b30f4f590f5..5add4a51e51fcab0cdc35aa35814b2033879a1dc 100644 (file)
@@ -199,7 +199,7 @@ END_FTR_SECTION_IFSET(CPU_FTR_476_DD2)
  * Touch enough instruction cache lines to ensure cache hits
  */
 1:     mflr    r9
-       bl      2f
+       bcl     20,31,$+4
 2:     mflr    r6
        li      r7,32
        PPC_ICBT(0,R6,R7)               /* touch next cache line */
@@ -414,7 +414,7 @@ _GLOBAL(loadcam_multi)
         * Set up temporary TLB entry that is the same as what we're
         * running from, but in AS=1.
         */
-       bl      1f
+       bcl     20,31,$+4
 1:     mflr    r6
        tlbsx   0,r8
        mfspr   r6,SPRN_MAS1