diff options
author | Renlin Li <renlin.li@arm.com> | 2018-01-18 12:08:40 +0000 |
---|---|---|
committer | Renlin Li <renlin.li@arm.com> | 2018-01-24 16:19:47 +0000 |
commit | 322474019df79a1305e83ff7620a72f31a5c7b55 (patch) | |
tree | ae7e6030970c16a017c540609ec31f448c6ad32f /gas | |
parent | cc40406d1d033abc21de1af5a30f2a5fbb692507 (diff) | |
download | gdb-322474019df79a1305e83ff7620a72f31a5c7b55.zip gdb-322474019df79a1305e83ff7620a72f31a5c7b55.tar.gz gdb-322474019df79a1305e83ff7620a72f31a5c7b55.tar.bz2 |
[GAS][AARCH64]Add group relocations to create PC-relative offset.
This is a patch to add the gas support for group relocations to create a
16, 32, 48, or 64 bit PC-relative offset inline.
The following relocations are added along with the test cases:
BFD_RELOC_AARCH64_MOVW_PREL_G0, BFD_RELOC_AARCH64_MOVW_PREL_G0_NC,
BFD_RELOC_AARCH64_MOVW_PREL_G1, BFD_RELOC_AARCH64_MOVW_PREL_G1_NC,
BFD_RELOC_AARCH64_MOVW_PREL_G2, BFD_RELOC_AARCH64_MOVW_PREL_G2_NC,
BFD_RELOC_AARCH64_MOVW_PREL_G3.
bfd/
2018-01-24 Renlin Li <renlin.li@arm.com>
* reloc.c: Add BFD_RELOC_AARCH64_MOVW_PREL_G0,
BFD_RELOC_AARCH64_MOVW_PREL_G0_NC, BFD_RELOC_AARCH64_MOVW_PREL_G1,
BFD_RELOC_AARCH64_MOVW_PREL_G1_NC, BFD_RELOC_AARCH64_MOVW_PREL_G2,
BFD_RELOC_AARCH64_MOVW_PREL_G2_NC, BFD_RELOC_AARCH64_MOVW_PREL_G3.
* bfd-in2.h: Regenerate.
* libbfd.h: Regenerate.
* elfnn-aarch64.c (elfNN_aarch64_howto_table): Add entries for
BFD_RELOC_AARCH64_MOVW_PREL_G0, BFD_RELOC_AARCH64_MOVW_PREL_G0_NC,
BFD_RELOC_AARCH64_MOVW_PREL_G1, BFD_RELOC_AARCH64_MOVW_PREL_G1_NC,
BFD_RELOC_AARCH64_MOVW_PREL_G2, BFD_RELOC_AARCH64_MOVW_PREL_G2_NC,
BFD_RELOC_AARCH64_MOVW_PREL_G3.
gas/
2018-01-24 Renlin Li <renlin.li@arm.com>
* config/tc-aarch64.c (reloc_table): add entries for
BFD_RELOC_AARCH64_MOVW_PREL_G0, BFD_RELOC_AARCH64_MOVW_PREL_G0_NC,
BFD_RELOC_AARCH64_MOVW_PREL_G1, BFD_RELOC_AARCH64_MOVW_PREL_G1_NC,
BFD_RELOC_AARCH64_MOVW_PREL_G2, BFD_RELOC_AARCH64_MOVW_PREL_G2_NC,
BFD_RELOC_AARCH64_MOVW_PREL_G3.
(process_movw_reloc_info): Supports newly added MOVW_PREL relocations.
(md_apply_fix): Likewise
* testsuite/gas/aarch64/prel_g0.s: New.
* testsuite/gas/aarch64/prel_g0.d: New.
* testsuite/gas/aarch64/prel_g0_nc.s: New.
* testsuite/gas/aarch64/prel_g0_nc.d: New.
* testsuite/gas/aarch64/prel_g1.s: New.
* testsuite/gas/aarch64/prel_g1.d: New.
* testsuite/gas/aarch64/prel_g1_nc.s: New.
* testsuite/gas/aarch64/prel_g1_nc.d: New.
* testsuite/gas/aarch64/prel_g2.s: New.
* testsuite/gas/aarch64/prel_g2.d: New.
* testsuite/gas/aarch64/prel_g2_nc.s: New.
* testsuite/gas/aarch64/prel_g2_nc.d: New.
* testsuite/gas/aarch64/prel_g3.s: New.
* testsuite/gas/aarch64/prel_g3.d: New.
Diffstat (limited to 'gas')
-rw-r--r-- | gas/ChangeLog | 24 | ||||
-rw-r--r-- | gas/config/tc-aarch64.c | 84 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g0.d | 13 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g0.s | 7 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g0_nc.d | 15 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g0_nc.s | 8 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g1.d | 13 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g1.s | 7 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g1_nc.d | 15 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g1_nc.s | 8 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g2.d | 15 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g2.s | 8 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g2_nc.d | 15 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g2_nc.s | 8 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g3.d | 15 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/reloc-prel_g3.s | 8 |
16 files changed, 263 insertions, 0 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog index 2ce6f17..6773b02 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,27 @@ +2018-01-24 Renlin Li <renlin.li@arm.com> + + * config/tc-aarch64.c (reloc_table): add entries for + BFD_RELOC_AARCH64_MOVW_PREL_G0, BFD_RELOC_AARCH64_MOVW_PREL_G0_NC, + BFD_RELOC_AARCH64_MOVW_PREL_G1, BFD_RELOC_AARCH64_MOVW_PREL_G1_NC, + BFD_RELOC_AARCH64_MOVW_PREL_G2, BFD_RELOC_AARCH64_MOVW_PREL_G2_NC, + BFD_RELOC_AARCH64_MOVW_PREL_G3. + (process_movw_reloc_info): Supports newly added MOVW_PREL relocations. + (md_apply_fix): Likewise + * testsuite/gas/aarch64/prel_g0.s: New. + * testsuite/gas/aarch64/prel_g0.d: New. + * testsuite/gas/aarch64/prel_g0_nc.s: New. + * testsuite/gas/aarch64/prel_g0_nc.d: New. + * testsuite/gas/aarch64/prel_g1.s: New. + * testsuite/gas/aarch64/prel_g1.d: New. + * testsuite/gas/aarch64/prel_g1_nc.s: New. + * testsuite/gas/aarch64/prel_g1_nc.d: New. + * testsuite/gas/aarch64/prel_g2.s: New. + * testsuite/gas/aarch64/prel_g2.d: New. + * testsuite/gas/aarch64/prel_g2_nc.s: New. + * testsuite/gas/aarch64/prel_g2_nc.d: New. + * testsuite/gas/aarch64/prel_g3.s: New. + * testsuite/gas/aarch64/prel_g3.d: New. + 2018-01-23 Maciej W. Rozycki <macro@mips.com> * configure.ac: Also set `mips_default_abi' to N32_ABI for diff --git a/gas/config/tc-aarch64.c b/gas/config/tc-aarch64.c index 8af3137..3a0cde9 100644 --- a/gas/config/tc-aarch64.c +++ b/gas/config/tc-aarch64.c @@ -2577,6 +2577,69 @@ static struct reloc_table_entry reloc_table[] = { 0, 0}, + /* Most significant bits 0-15 of signed/unsigned address/value: MOVZ */ + {"prel_g0", 1, + 0, /* adr_type */ + 0, + BFD_RELOC_AARCH64_MOVW_PREL_G0, + 0, + 0, + 0}, + + /* Most significant bits 0-15 of signed/unsigned address/value: MOVK */ + {"prel_g0_nc", 1, + 0, /* adr_type */ + 0, + BFD_RELOC_AARCH64_MOVW_PREL_G0_NC, + 0, + 0, + 0}, + + /* Most significant bits 16-31 of signed/unsigned address/value: MOVZ */ + {"prel_g1", 1, + 0, /* adr_type */ + 0, + BFD_RELOC_AARCH64_MOVW_PREL_G1, + 0, + 0, + 0}, + + /* Most significant bits 16-31 of signed/unsigned address/value: MOVK */ + {"prel_g1_nc", 1, + 0, /* adr_type */ + 0, + BFD_RELOC_AARCH64_MOVW_PREL_G1_NC, + 0, + 0, + 0}, + + /* Most significant bits 32-47 of signed/unsigned address/value: MOVZ */ + {"prel_g2", 1, + 0, /* adr_type */ + 0, + BFD_RELOC_AARCH64_MOVW_PREL_G2, + 0, + 0, + 0}, + + /* Most significant bits 32-47 of signed/unsigned address/value: MOVK */ + {"prel_g2_nc", 1, + 0, /* adr_type */ + 0, + BFD_RELOC_AARCH64_MOVW_PREL_G2_NC, + 0, + 0, + 0}, + + /* Most significant bits 48-63 of signed/unsigned address/value: MOVZ */ + {"prel_g3", 1, + 0, /* adr_type */ + 0, + BFD_RELOC_AARCH64_MOVW_PREL_G3, + 0, + 0, + 0}, + /* Get to the page containing GOT entry for a symbol. */ {"got", 1, 0, /* adr_type */ @@ -5079,6 +5142,10 @@ process_movw_reloc_info (void) case BFD_RELOC_AARCH64_MOVW_G0_S: case BFD_RELOC_AARCH64_MOVW_G1_S: case BFD_RELOC_AARCH64_MOVW_G2_S: + case BFD_RELOC_AARCH64_MOVW_PREL_G0: + case BFD_RELOC_AARCH64_MOVW_PREL_G1: + case BFD_RELOC_AARCH64_MOVW_PREL_G2: + case BFD_RELOC_AARCH64_MOVW_PREL_G3: case BFD_RELOC_AARCH64_TLSGD_MOVW_G1: case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0: case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1: @@ -5096,6 +5163,8 @@ process_movw_reloc_info (void) case BFD_RELOC_AARCH64_MOVW_G0_NC: case BFD_RELOC_AARCH64_MOVW_G0_S: case BFD_RELOC_AARCH64_MOVW_GOTOFF_G0_NC: + case BFD_RELOC_AARCH64_MOVW_PREL_G0: + case BFD_RELOC_AARCH64_MOVW_PREL_G0_NC: case BFD_RELOC_AARCH64_TLSDESC_OFF_G0_NC: case BFD_RELOC_AARCH64_TLSGD_MOVW_G0_NC: case BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC: @@ -5109,6 +5178,8 @@ process_movw_reloc_info (void) case BFD_RELOC_AARCH64_MOVW_G1_NC: case BFD_RELOC_AARCH64_MOVW_G1_S: case BFD_RELOC_AARCH64_MOVW_GOTOFF_G1: + case BFD_RELOC_AARCH64_MOVW_PREL_G1: + case BFD_RELOC_AARCH64_MOVW_PREL_G1_NC: case BFD_RELOC_AARCH64_TLSDESC_OFF_G1: case BFD_RELOC_AARCH64_TLSGD_MOVW_G1: case BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G1: @@ -5121,6 +5192,8 @@ process_movw_reloc_info (void) case BFD_RELOC_AARCH64_MOVW_G2: case BFD_RELOC_AARCH64_MOVW_G2_NC: case BFD_RELOC_AARCH64_MOVW_G2_S: + case BFD_RELOC_AARCH64_MOVW_PREL_G2: + case BFD_RELOC_AARCH64_MOVW_PREL_G2_NC: case BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G2: case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G2: if (is32) @@ -5133,6 +5206,7 @@ process_movw_reloc_info (void) shift = 32; break; case BFD_RELOC_AARCH64_MOVW_G3: + case BFD_RELOC_AARCH64_MOVW_PREL_G3: if (is32) { set_fatal_syntax_error @@ -7608,12 +7682,16 @@ md_apply_fix (fixS * fixP, valueT * valP, segT seg) case BFD_RELOC_AARCH64_MOVW_G0_NC: case BFD_RELOC_AARCH64_MOVW_G0_S: case BFD_RELOC_AARCH64_MOVW_GOTOFF_G0_NC: + case BFD_RELOC_AARCH64_MOVW_PREL_G0: + case BFD_RELOC_AARCH64_MOVW_PREL_G0_NC: scale = 0; goto movw_common; case BFD_RELOC_AARCH64_MOVW_G1: case BFD_RELOC_AARCH64_MOVW_G1_NC: case BFD_RELOC_AARCH64_MOVW_G1_S: case BFD_RELOC_AARCH64_MOVW_GOTOFF_G1: + case BFD_RELOC_AARCH64_MOVW_PREL_G1: + case BFD_RELOC_AARCH64_MOVW_PREL_G1_NC: scale = 16; goto movw_common; case BFD_RELOC_AARCH64_TLSDESC_OFF_G0_NC: @@ -7635,9 +7713,12 @@ md_apply_fix (fixS * fixP, valueT * valP, segT seg) case BFD_RELOC_AARCH64_MOVW_G2: case BFD_RELOC_AARCH64_MOVW_G2_NC: case BFD_RELOC_AARCH64_MOVW_G2_S: + case BFD_RELOC_AARCH64_MOVW_PREL_G2: + case BFD_RELOC_AARCH64_MOVW_PREL_G2_NC: scale = 32; goto movw_common; case BFD_RELOC_AARCH64_MOVW_G3: + case BFD_RELOC_AARCH64_MOVW_PREL_G3: scale = 48; movw_common: if (fixP->fx_done || !seg->use_rela_p) @@ -7669,6 +7750,9 @@ md_apply_fix (fixS * fixP, valueT * valP, segT seg) case BFD_RELOC_AARCH64_MOVW_G0_S: case BFD_RELOC_AARCH64_MOVW_G1_S: case BFD_RELOC_AARCH64_MOVW_G2_S: + case BFD_RELOC_AARCH64_MOVW_PREL_G0: + case BFD_RELOC_AARCH64_MOVW_PREL_G1: + case BFD_RELOC_AARCH64_MOVW_PREL_G2: /* NOTE: We can only come here with movz or movn. */ if (signed_overflow (value, scale + 16)) as_bad_where (fixP->fx_file, fixP->fx_line, diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g0.d b/gas/testsuite/gas/aarch64/reloc-prel_g0.d new file mode 100644 index 0000000..9ba990e --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g0.d @@ -0,0 +1,13 @@ +#objdump: -dr + +.*: file format .* + +Disassembly of section \.text: + +0000000000000000 <.*>: + 0: 8a000000 and x0, x0, x0 + 4: 92400000 and x0, x0, #0x1 + 8: d2800004 mov x4, #0x0 // #0 + 8: R_AARCH64_MOVW_PREL_G0 tempy + c: d2800011 mov x17, #0x0 // #0 + c: R_AARCH64_MOVW_PREL_G0 tempy2 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g0.s b/gas/testsuite/gas/aarch64/reloc-prel_g0.s new file mode 100644 index 0000000..4cbb287 --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g0.s @@ -0,0 +1,7 @@ +.comm gempy,4,4 +.text + + and x0,x0,x0 + and x0,x0,#0x1 + movz x4, :prel_g0:tempy + movz x17, :prel_g0:tempy2 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g0_nc.d b/gas/testsuite/gas/aarch64/reloc-prel_g0_nc.d new file mode 100644 index 0000000..4127ce7 --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g0_nc.d @@ -0,0 +1,15 @@ +#objdump: -dr + +.*: file format .* + +Disassembly of section \.text: + +0000000000000000 <.*>: + 0: 8a000000 and x0, x0, x0 + 4: 92400000 and x0, x0, #0x1 + 8: f2800004 movk x4, #0x0 + 8: R_AARCH64_MOVW_PREL_G0_NC tempy + c: f2800007 movk x7, #0x0 + c: R_AARCH64_MOVW_PREL_G0_NC tempy2 + 10: f2800011 movk x17, #0x0 + 10: R_AARCH64_MOVW_PREL_G0_NC tempy3 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g0_nc.s b/gas/testsuite/gas/aarch64/reloc-prel_g0_nc.s new file mode 100644 index 0000000..6b4c2e9 --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g0_nc.s @@ -0,0 +1,8 @@ +.comm gempy,4,4 +.text + + and x0,x0,x0 + and x0,x0,#0x1 + movk x4, :prel_g0_nc:tempy + movk x7, :prel_g0_nc:tempy2 + movk x17, :prel_g0_nc:tempy3 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g1.d b/gas/testsuite/gas/aarch64/reloc-prel_g1.d new file mode 100644 index 0000000..1a161f8 --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g1.d @@ -0,0 +1,13 @@ +#objdump: -dr + +.*: file format .* + +Disassembly of section \.text: + +0000000000000000 <.*>: + 0: 8a000000 and x0, x0, x0 + 4: 92400000 and x0, x0, #0x1 + 8: d2a00004 movz x4, #0x0, lsl #16 + 8: R_AARCH64_MOVW_PREL_G1 tempy + c: d2a00011 movz x17, #0x0, lsl #16 + c: R_AARCH64_MOVW_PREL_G1 tempy2 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g1.s b/gas/testsuite/gas/aarch64/reloc-prel_g1.s new file mode 100644 index 0000000..fd7e216 --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g1.s @@ -0,0 +1,7 @@ +.comm gempy,4,4 +.text + + and x0,x0,x0 + and x0,x0,#0x1 + movz x4, :prel_g1:tempy + movz x17, :prel_g1:tempy2 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g1_nc.d b/gas/testsuite/gas/aarch64/reloc-prel_g1_nc.d new file mode 100644 index 0000000..4c0a1d9 --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g1_nc.d @@ -0,0 +1,15 @@ +#objdump: -dr + +.*: file format .* + +Disassembly of section \.text: + +0000000000000000 <.*>: + 0: 8a000000 and x0, x0, x0 + 4: 92400000 and x0, x0, #0x1 + 8: f2a00004 movk x4, #0x0, lsl #16 + 8: R_AARCH64_MOVW_PREL_G1_NC tempy + c: f2a00007 movk x7, #0x0, lsl #16 + c: R_AARCH64_MOVW_PREL_G1_NC tempy2 + 10: f2a00011 movk x17, #0x0, lsl #16 + 10: R_AARCH64_MOVW_PREL_G1_NC tempy3 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g1_nc.s b/gas/testsuite/gas/aarch64/reloc-prel_g1_nc.s new file mode 100644 index 0000000..6c5b72f --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g1_nc.s @@ -0,0 +1,8 @@ +.comm gempy,4,4 +.text + + and x0,x0,x0 + and x0,x0,#0x1 + movk x4, :prel_g1_nc:tempy + movk x7, :prel_g1_nc:tempy2 + movk x17, :prel_g1_nc:tempy3 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g2.d b/gas/testsuite/gas/aarch64/reloc-prel_g2.d new file mode 100644 index 0000000..80d1870 --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g2.d @@ -0,0 +1,15 @@ +#objdump: -dr + +.*: file format .* + +Disassembly of section \.text: + +0000000000000000 <.*>: + 0: 8a000000 and x0, x0, x0 + 4: 92400000 and x0, x0, #0x1 + 8: d2c00004 movz x4, #0x0, lsl #32 + 8: R_AARCH64_MOVW_PREL_G2 tempy + c: d2c00007 movz x7, #0x0, lsl #32 + c: R_AARCH64_MOVW_PREL_G2 tempy2 + 10: d2c00011 movz x17, #0x0, lsl #32 + 10: R_AARCH64_MOVW_PREL_G2 tempy3 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g2.s b/gas/testsuite/gas/aarch64/reloc-prel_g2.s new file mode 100644 index 0000000..716bf29 --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g2.s @@ -0,0 +1,8 @@ +.comm gempy,4,4 +.text + + and x0,x0,x0 + and x0,x0,#0x1 + movz x4, :prel_g2:tempy + movz x7, :prel_g2:tempy2 + movz x17, :prel_g2:tempy3 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g2_nc.d b/gas/testsuite/gas/aarch64/reloc-prel_g2_nc.d new file mode 100644 index 0000000..dc3c58e --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g2_nc.d @@ -0,0 +1,15 @@ +#objdump: -dr + +.*: file format .* + +Disassembly of section \.text: + +0000000000000000 <.*>: + 0: 8a000000 and x0, x0, x0 + 4: 92400000 and x0, x0, #0x1 + 8: f2c00004 movk x4, #0x0, lsl #32 + 8: R_AARCH64_MOVW_PREL_G2_NC tempy + c: f2c00007 movk x7, #0x0, lsl #32 + c: R_AARCH64_MOVW_PREL_G2_NC tempy2 + 10: f2c00011 movk x17, #0x0, lsl #32 + 10: R_AARCH64_MOVW_PREL_G2_NC tempy3 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g2_nc.s b/gas/testsuite/gas/aarch64/reloc-prel_g2_nc.s new file mode 100644 index 0000000..7327faa --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g2_nc.s @@ -0,0 +1,8 @@ +.comm gempy,4,4 +.text + + and x0,x0,x0 + and x0,x0,#0x1 + movk x4, :prel_g2_nc:tempy + movk x7, :prel_g2_nc:tempy2 + movk x17, :prel_g2_nc:tempy3 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g3.d b/gas/testsuite/gas/aarch64/reloc-prel_g3.d new file mode 100644 index 0000000..4a476ab --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g3.d @@ -0,0 +1,15 @@ +#objdump: -dr + +.*: file format .* + +Disassembly of section \.text: + +0000000000000000 <.*>: + 0: 8a000000 and x0, x0, x0 + 4: 92400000 and x0, x0, #0x1 + 8: d2e00004 movz x4, #0x0, lsl #48 + 8: R_AARCH64_MOVW_PREL_G3 tempy + c: d2e00007 movz x7, #0x0, lsl #48 + c: R_AARCH64_MOVW_PREL_G3 tempy2 + 10: d2e00011 movz x17, #0x0, lsl #48 + 10: R_AARCH64_MOVW_PREL_G3 tempy3 diff --git a/gas/testsuite/gas/aarch64/reloc-prel_g3.s b/gas/testsuite/gas/aarch64/reloc-prel_g3.s new file mode 100644 index 0000000..2850e49 --- /dev/null +++ b/gas/testsuite/gas/aarch64/reloc-prel_g3.s @@ -0,0 +1,8 @@ +.comm gempy,4,4 +.text + + and x0,x0,x0 + and x0,x0,#0x1 + movz x4, :prel_g3:tempy + movz x7, :prel_g3:tempy2 + movz x17, :prel_g3:tempy3 |