diff options
author | Jaymes Wilks <mjwilks@us.ibm.com> | 2019-02-04 14:06:56 -0600 |
---|---|---|
committer | Daniel M. Crowell <dcrowell@us.ibm.com> | 2019-03-11 17:07:52 -0500 |
commit | f5475890894b4d542f622cee27604de15b41bb4b (patch) | |
tree | c7462a5d51689fab8dfbe66dd87c6263e8e44959 /src/runtime | |
parent | 676c584aaa7046d45d0c9ac3851699566d905bac (diff) | |
download | talos-hostboot-f5475890894b4d542f622cee27604de15b41bb4b.tar.gz talos-hostboot-f5475890894b4d542f622cee27604de15b41bb4b.zip |
Support thread local storage
Generally adds support to declare variables as thread_local
- Add support in HBRT start assembly to skip adjusting TLS relocations
- Add support in linker to generate tagged TLS entries
- Update linker to process TLS relocations correctly
- Update TLS code to ignore top half of module ID
- Update module images to hold a "module ID"
- Update custome linker to update module ID during binary link
- Update TLS code to track TLS sections via module ID
Change-Id: I1589550d7787beb08827ca24a728397dedf0373b
RTC: 147599
Reviewed-on: http://rchgit01.rchland.ibm.com/gerrit1/71709
Reviewed-by: Ilya Smirnov <ismirno@us.ibm.com>
Reviewed-by: Michael Baiocchi <mbaiocch@us.ibm.com>
Tested-by: Jenkins Server <pfd-jenkins+hostboot@us.ibm.com>
Tested-by: FSP CI Jenkins <fsp-CI-jenkins+hostboot@us.ibm.com>
Tested-by: Jenkins OP Build CI <op-jenkins+hostboot@us.ibm.com>
Tested-by: Jenkins OP HW <op-hw-jenkins+hostboot@us.ibm.com>
Reviewed-by: Daniel M. Crowell <dcrowell@us.ibm.com>
Diffstat (limited to 'src/runtime')
-rw-r--r-- | src/runtime/rt_start.S | 35 |
1 files changed, 34 insertions, 1 deletions
diff --git a/src/runtime/rt_start.S b/src/runtime/rt_start.S index ba1a975d7..aaf4ee59e 100644 --- a/src/runtime/rt_start.S +++ b/src/runtime/rt_start.S @@ -5,7 +5,7 @@ # # OpenPOWER HostBoot Project # -# Contributors Listed Below - COPYRIGHT 2013,2017 +# Contributors Listed Below - COPYRIGHT 2013,2019 # [+] International Business Machines Corp. # [+] Joel Stanley # @@ -52,13 +52,46 @@ _init: cmpwi cr0, r8, 0 # Perform relocations (if any). beq 2f + + # TLS workaround + # Load ASCII 'T','L','S' + 0x00 into bits 32:63 of r6, which will be used + # to compare against bits 0-31 of each relocation entry. A match signifies + # that this and the next relocation entry are the TLS module and offset + # relocations respectively. Skip both relocations before continuing the + # processing. These first two directives create the reference pattern to + # compare against. Also skip a relocation entry if its value is 0. + rldicl r6,r6,0,63 # Clear r6 to zero + addis r6, 0, 0x544C # Load ASCII "TL" into bits 32:47 of r6 + ori r6, r6, 0x5300 # Load ASCII "S" + 0x00 into bits 48:63 of r6 + mtctr r8 1: ldu r8, 8(r10) # Get relocation destination add r8, r8, r4 ld r7, 0(r8) # Get relocation address + + + # TLS workaround (continued for next 8 instructions) + rldicl r5,r5,0,63 # Clear r5 to zero + cmp cr0, 0, r5, r7 # Compare the relocation address (r7) to zero (r5) + beq cr0, 3f # If the relocation address is zero, do + # not adjust it and instead jump to the loop + # decrement/branch instruction + + rldicl r5,r7,32,32 # Rotate bits 0-31 of the relocation address + # into 32-63 and clear bits 0-31, saving result + # to r5, to set up the next comparison + cmp cr0, 0, r6, r5 # Compare bits 32-63, which should both contain + # ASCII TLS+0x00 if this is a TLS module + bne cr0, 4f # If not a TLS module relocation, keep going; + ldu r8, 8(r10) # otherwise, skip the TLS module relocation + bdnz 3f # and decrement the loop counter to match. Jump + # to a 2nd skip/decrement pair to effectively skip + # the next TLS module relocation as well +4: add r7, r7, r4 std r7, 0(r8) # Update relocation address. +3: bdnz 1b # Decrement CTR and continue loop. 2: addi r10, r4, 0x2008 # Find pointer to main TOC. |