mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-12-09 04:21:49 +08:00
5499c7c71c
PR 20744 bfd/ * elf32-ppc.c (ppc_elf_howto_raw): Correct dst_mask on all VLE 16D relocations. (ppc_elf_vle_split16): Correct field mask and shift for 16D relocs. (ppc_elf_relocate_section): Correct calculation for VLE SDAREL relocs. ld/ * testsuite/ld-powerpc/vle-reloc-2.s: Use r6 for last insn of each group. * testsuite/ld-powerpc/vle-reloc-2.d: Update for above change and sdarel reloc fix.
93 lines
2.2 KiB
ArmAsm
93 lines
2.2 KiB
ArmAsm
.section .text
|
|
sub1:
|
|
se_blr
|
|
|
|
sub2:
|
|
se_blr
|
|
|
|
.section .text
|
|
vle_reloc_2:
|
|
e_or2i 1, low@l
|
|
e_or2i 2, high@h
|
|
e_or2i 3, high_adjust@ha
|
|
e_or2i 4, low_sdarel@sdarel@l
|
|
e_or2i 5, high_sdarel@sdarel@h
|
|
e_or2i 6, high_adjust_sdarel@sdarel@ha
|
|
|
|
e_and2i. 1, low@l
|
|
e_and2i. 2, high@h
|
|
e_and2i. 3, high_adjust@ha
|
|
e_and2i. 4, low_sdarel@sdarel@l
|
|
e_and2i. 5, high_sdarel@sdarel@h
|
|
e_and2i. 6, high_adjust_sdarel@sdarel@ha
|
|
|
|
e_or2is 1, low@l
|
|
e_or2is 2, high@h
|
|
e_or2is 3, high_adjust@ha
|
|
e_or2is 4, low_sdarel@sdarel@l
|
|
e_or2is 5, high_sdarel@sdarel@h
|
|
e_or2is 6, high_adjust_sdarel@sdarel@ha
|
|
|
|
e_lis 1, low@l
|
|
e_lis 2, high@h
|
|
e_lis 3, high_adjust@ha
|
|
e_lis 4, low_sdarel@sdarel@l
|
|
e_lis 5, high_sdarel@sdarel@h
|
|
e_lis 6, high_adjust_sdarel@sdarel@ha
|
|
|
|
e_and2is. 1, low@l
|
|
e_and2is. 2, high@h
|
|
e_and2is. 3, high_adjust@ha
|
|
e_and2is. 4, low_sdarel@sdarel@l
|
|
e_and2is. 5, high_sdarel@sdarel@h
|
|
e_and2is. 6, high_adjust_sdarel@sdarel@ha
|
|
|
|
e_cmp16i 1, low@l
|
|
e_cmp16i 2, high@h
|
|
e_cmp16i 3, high_adjust@ha
|
|
e_cmp16i 4, low_sdarel@sdarel@l
|
|
e_cmp16i 5, high_sdarel@sdarel@h
|
|
e_cmp16i 6, high_adjust_sdarel@sdarel@ha
|
|
|
|
e_cmpl16i 1, low@l
|
|
e_cmpl16i 2, high@h
|
|
e_cmpl16i 3, high_adjust@ha
|
|
e_cmpl16i 4, low_sdarel@sdarel@l
|
|
e_cmpl16i 5, high_sdarel@sdarel@h
|
|
e_cmpl16i 6, high_adjust_sdarel@sdarel@ha
|
|
|
|
e_cmph16i 1, low@l
|
|
e_cmph16i 2, high@h
|
|
e_cmph16i 3, high_adjust@ha
|
|
e_cmph16i 4, low_sdarel@sdarel@l
|
|
e_cmph16i 5, high_sdarel@sdarel@h
|
|
e_cmph16i 6, high_adjust_sdarel@sdarel@ha
|
|
|
|
e_cmphl16i 1, low@l
|
|
e_cmphl16i 2, high@h
|
|
e_cmphl16i 3, high_adjust@ha
|
|
e_cmphl16i 4, low_sdarel@sdarel@l
|
|
e_cmphl16i 5, high_sdarel@sdarel@h
|
|
e_cmphl16i 6, high_adjust_sdarel@sdarel@ha
|
|
|
|
e_add2i. 1, low@l
|
|
e_add2i. 2, high@h
|
|
e_add2i. 3, high_adjust@ha
|
|
e_add2i. 4, low_sdarel@sdarel@l
|
|
e_add2i. 5, high_sdarel@sdarel@h
|
|
e_add2i. 6, high_adjust_sdarel@sdarel@ha
|
|
|
|
e_add2is 1, low@l
|
|
e_add2is 2, high@h
|
|
e_add2is 3, high_adjust@ha
|
|
e_add2is 4, low_sdarel@sdarel@l
|
|
e_add2is 5, high_sdarel@sdarel@h
|
|
e_add2is 6, high_adjust_sdarel@sdarel@ha
|
|
|
|
e_mull2i 1, low@l
|
|
e_mull2i 2, high@h
|
|
e_mull2i 3, high_adjust@ha
|
|
e_mull2i 4, low_sdarel@sdarel@l
|
|
e_mull2i 5, high_sdarel@sdarel@h
|
|
e_mull2i 6, high_adjust_sdarel@sdarel@ha
|