diff options
author | Yufeng Zhang <yufeng.zhang@arm.com> | 2012-10-15 14:52:06 +0000 |
---|---|---|
committer | Yufeng Zhang <yufeng.zhang@arm.com> | 2012-10-15 14:52:06 +0000 |
commit | 9de794e14842cdc778c4ee490e613c7163c5a976 (patch) | |
tree | 1b81633e536e6e41fa9a0b12acf5bbef9c83bf59 | |
parent | f05682d46014082c3afe2bff6d04a1d203bce119 (diff) | |
download | fsf-binutils-gdb-9de794e14842cdc778c4ee490e613c7163c5a976.zip fsf-binutils-gdb-9de794e14842cdc778c4ee490e613c7163c5a976.tar.gz fsf-binutils-gdb-9de794e14842cdc778c4ee490e613c7163c5a976.tar.bz2 |
Added missing alignment check to load/store uimm12 immediate offset.
opcodes/
* aarch64-opc.c (operand_general_constraint_met_p): Change to check
the alignment of addr.offset.imm instead of that of shifter.amount for
operand type AARCH64_OPND_ADDR_UIMM12.
gas/testsuite/
* gas/aarch64/illegal-2.s: Add test case.
* gas/aarch64/illegal-2.l: Likewise.
-rw-r--r-- | gas/testsuite/gas/aarch64/illegal-2.l | 1 | ||||
-rw-r--r-- | gas/testsuite/gas/aarch64/illegal-2.s | 2 | ||||
-rw-r--r-- | opcodes/aarch64-opc.c | 2 |
3 files changed, 4 insertions, 1 deletions
diff --git a/gas/testsuite/gas/aarch64/illegal-2.l b/gas/testsuite/gas/aarch64/illegal-2.l index 2ba6894..372596b 100644 --- a/gas/testsuite/gas/aarch64/illegal-2.l +++ b/gas/testsuite/gas/aarch64/illegal-2.l @@ -6,3 +6,4 @@ [^:]*:16: Error: .*$ [^:]*:19: Error: .*$ [^:]*:20: Error: .*$ +[^:]*:24: Error: .*$ diff --git a/gas/testsuite/gas/aarch64/illegal-2.s b/gas/testsuite/gas/aarch64/illegal-2.s index 3aa7283..7711e14 100644 --- a/gas/testsuite/gas/aarch64/illegal-2.s +++ b/gas/testsuite/gas/aarch64/illegal-2.s @@ -20,3 +20,5 @@ mov wsp, #0x33030000 .set u16, 0xfff0 + + ldr x0, [x0, #257] diff --git a/opcodes/aarch64-opc.c b/opcodes/aarch64-opc.c index 2d66a25..8c70938 100644 --- a/opcodes/aarch64-opc.c +++ b/opcodes/aarch64-opc.c @@ -1426,7 +1426,7 @@ operand_general_constraint_met_p (const aarch64_opnd_info *opnds, int idx, 0, 4095 * size); return 0; } - if (!value_aligned_p (opnd->shifter.amount, size)) + if (!value_aligned_p (opnd->addr.offset.imm, size)) { set_unaligned_error (mismatch_detail, idx, size); return 0; |