[ARM/FDPIC v6 12/24] [ARM] FDPIC: Restore r9 after we call __aeabi_read_tp
We call __aeabi_read_tp() to get the thread pointer. Since this is a function call, we have to restore the FDPIC register afterwards. 2019-09-10 Christophe Lyon <christophe.lyon@st.com> Mickaël Guêné <mickael.guene@st.com> gcc/ * config/arm/arm.c (arm_load_tp): Add FDPIC support. * config/arm/arm.md (FDPIC_REGNUM): New constant. (load_tp_soft_fdpic): New pattern. (load_tp_soft): Disable in FDPIC mode. Co-Authored-By: Mickaël Guêné <mickael.guene@st.com> From-SVN: r275574
This commit is contained in:
parent
ae1152e5a0
commit
bb33a88e3d
3 changed files with 35 additions and 4 deletions
|
@ -1,7 +1,14 @@
|
|||
2019-09-10 Christophe Lyon <christophe.lyon@st.com>
|
||||
Mickaël Guêné <mickael.guene@st.com>
|
||||
|
||||
gcc/
|
||||
* config/arm/arm.c (arm_load_tp): Add FDPIC support.
|
||||
* config/arm/arm.md (FDPIC_REGNUM): New constant.
|
||||
(load_tp_soft_fdpic): New pattern.
|
||||
(load_tp_soft): Disable in FDPIC mode.
|
||||
|
||||
2019-09-10 Christophe Lyon <christophe.lyon@st.com>
|
||||
Mickaël Guêné <mickael.guene@st.com>
|
||||
|
||||
* config/arm/arm.c (tls_reloc): Add TLS_GD32_FDPIC,
|
||||
TLS_LDM32_FDPIC and TLS_IE32_FDPIC.
|
||||
(arm_call_tls_get_addr): Add FDPIC support.
|
||||
|
@ -11,7 +18,6 @@
|
|||
2019-09-10 Christophe Lyon <christophe.lyon@st.com>
|
||||
Mickaël Guêné <mickael.guene@st.com>
|
||||
|
||||
gcc/
|
||||
* config/arm/arm.c (arm_asm_trampoline_template): Add FDPIC
|
||||
support.
|
||||
(arm_trampoline_init): Likewise.
|
||||
|
|
|
@ -8685,7 +8685,18 @@ arm_load_tp (rtx target)
|
|||
|
||||
rtx tmp;
|
||||
|
||||
emit_insn (gen_load_tp_soft ());
|
||||
if (TARGET_FDPIC)
|
||||
{
|
||||
rtx fdpic_reg = gen_rtx_REG (Pmode, FDPIC_REGNUM);
|
||||
rtx initial_fdpic_reg = get_hard_reg_initial_val (Pmode, FDPIC_REGNUM);
|
||||
|
||||
emit_insn (gen_load_tp_soft_fdpic ());
|
||||
|
||||
/* Restore r9. */
|
||||
emit_insn (gen_restore_pic_register_after_call(fdpic_reg, initial_fdpic_reg));
|
||||
}
|
||||
else
|
||||
emit_insn (gen_load_tp_soft ());
|
||||
|
||||
tmp = gen_rtx_REG (SImode, R0_REGNUM);
|
||||
emit_move_insn (target, tmp);
|
||||
|
|
|
@ -31,6 +31,7 @@
|
|||
[(R0_REGNUM 0) ; First CORE register
|
||||
(R1_REGNUM 1) ; Second CORE register
|
||||
(R4_REGNUM 4) ; Fifth CORE register
|
||||
(FDPIC_REGNUM 9) ; FDPIC register
|
||||
(IP_REGNUM 12) ; Scratch register
|
||||
(SP_REGNUM 13) ; Stack pointer
|
||||
(LR_REGNUM 14) ; Return address register
|
||||
|
@ -11164,13 +11165,26 @@
|
|||
(set_attr "type" "mrs")]
|
||||
)
|
||||
|
||||
;; Doesn't clobber R1-R3. Must use r0 for the first operand.
|
||||
(define_insn "load_tp_soft_fdpic"
|
||||
[(set (reg:SI 0) (unspec:SI [(const_int 0)] UNSPEC_TLS))
|
||||
(clobber (reg:SI FDPIC_REGNUM))
|
||||
(clobber (reg:SI LR_REGNUM))
|
||||
(clobber (reg:SI IP_REGNUM))
|
||||
(clobber (reg:CC CC_REGNUM))]
|
||||
"TARGET_SOFT_TP && TARGET_FDPIC"
|
||||
"bl\\t__aeabi_read_tp\\t@ load_tp_soft"
|
||||
[(set_attr "conds" "clob")
|
||||
(set_attr "type" "branch")]
|
||||
)
|
||||
|
||||
;; Doesn't clobber R1-R3. Must use r0 for the first operand.
|
||||
(define_insn "load_tp_soft"
|
||||
[(set (reg:SI 0) (unspec:SI [(const_int 0)] UNSPEC_TLS))
|
||||
(clobber (reg:SI LR_REGNUM))
|
||||
(clobber (reg:SI IP_REGNUM))
|
||||
(clobber (reg:CC CC_REGNUM))]
|
||||
"TARGET_SOFT_TP"
|
||||
"TARGET_SOFT_TP && !TARGET_FDPIC"
|
||||
"bl\\t__aeabi_read_tp\\t@ load_tp_soft"
|
||||
[(set_attr "conds" "clob")
|
||||
(set_attr "type" "branch")]
|
||||
|
|
Loading…
Add table
Reference in a new issue