| // RUN: llvm-mc -triple=aarch64-none-linux-gnu < %s | FileCheck %s |
| // RUN: not llvm-mc -mattr=+no-neg-immediates -triple=aarch64-none-linux-gnu < %s 2>&1 | FileCheck %s --check-prefix=CHECK-NO-NEG-IMM |
| |
| add w0, w2, #4096 |
| sub w0, w2, #4096 |
| // CHECK: add w0, w2, #1, lsl #12 |
| // CHECK: sub w0, w2, #1, lsl #12 |
| |
| add w0, w2, #-4096 |
| sub w0, w2, #-4096 |
| // CHECK: sub w0, w2, #1, lsl #12 |
| // CHECK: add w0, w2, #1, lsl #12 |
| |
| // CHECK: sub w0, w2, #2, lsl #12 |
| // CHECK: sub w0, w2, #2, lsl #12 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| sub w0, w2, #2, lsl 12 |
| add w0, w2, #-2, lsl 12 |
| // CHECK: sub x1, x3, #2, lsl #12 |
| // CHECK: sub x1, x3, #2, lsl #12 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| sub x1, x3, #2, lsl 12 |
| add x1, x3, #-2, lsl 12 |
| // CHECK: sub x1, x3, #4 |
| // CHECK: sub x1, x3, #4 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| sub x1, x3, #4 |
| add x1, x3, #-4 |
| // CHECK: sub x1, x3, #4095 |
| // CHECK: sub x1, x3, #4095 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| sub x1, x3, #4095, lsl 0 |
| add x1, x3, #-4095, lsl 0 |
| // CHECK: sub x3, x4, #0 |
| sub x3, x4, #0 |
| |
| // CHECK: add w0, w2, #2, lsl #12 |
| // CHECK: add w0, w2, #2, lsl #12 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| add w0, w2, #2, lsl 12 |
| sub w0, w2, #-2, lsl 12 |
| // CHECK: add x1, x3, #2, lsl #12 |
| // CHECK: add x1, x3, #2, lsl #12 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| add x1, x3, #2, lsl 12 |
| sub x1, x3, #-2, lsl 12 |
| // CHECK: add x1, x3, #4 |
| // CHECK: add x1, x3, #4 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| add x1, x3, #4 |
| sub x1, x3, #-4 |
| // CHECK: add x1, x3, #4095 |
| // CHECK: add x1, x3, #4095 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| add x1, x3, #4095, lsl 0 |
| sub x1, x3, #-4095, lsl 0 |
| // CHECK: add x2, x5, #0 |
| add x2, x5, #0 |
| |
| // CHECK: subs w0, w2, #2, lsl #12 |
| // CHECK: subs w0, w2, #2, lsl #12 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| subs w0, w2, #2, lsl 12 |
| adds w0, w2, #-2, lsl 12 |
| // CHECK: subs x1, x3, #2, lsl #12 |
| // CHECK: subs x1, x3, #2, lsl #12 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| subs x1, x3, #2, lsl 12 |
| adds x1, x3, #-2, lsl 12 |
| // CHECK: subs x1, x3, #4 |
| // CHECK: subs x1, x3, #4 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| subs x1, x3, #4 |
| adds x1, x3, #-4 |
| // CHECK: subs x1, x3, #4095 |
| // CHECK: subs x1, x3, #4095 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| subs x1, x3, #4095, lsl 0 |
| adds x1, x3, #-4095, lsl 0 |
| // CHECK: subs x3, x4, #0 |
| subs x3, x4, #0 |
| |
| // CHECK: adds w0, w2, #2, lsl #12 |
| // CHECK: adds w0, w2, #2, lsl #12 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| adds w0, w2, #2, lsl 12 |
| subs w0, w2, #-2, lsl 12 |
| // CHECK: adds x1, x3, #2, lsl #12 |
| // CHECK: adds x1, x3, #2, lsl #12 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| adds x1, x3, #2, lsl 12 |
| subs x1, x3, #-2, lsl 12 |
| // CHECK: adds x1, x3, #4 |
| // CHECK: adds x1, x3, #4 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| adds x1, x3, #4 |
| subs x1, x3, #-4 |
| // CHECK: adds x1, x3, #4095 |
| // CHECK: adds x1, x3, #4095 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| adds x1, x3, #4095, lsl 0 |
| subs x1, x3, #-4095, lsl 0 |
| // CHECK: adds x2, x5, #0 |
| adds x2, x5, #0 |
| |
| // CHECK: {{adds xzr,|cmn}} x5, #5 |
| // CHECK: {{adds xzr,|cmn}} x5, #5 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| cmn x5, #5 |
| cmp x5, #-5 |
| // CHECK: {{subs xzr,|cmp}} x6, #4095 |
| // CHECK: {{subs xzr,|cmp}} x6, #4095 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| cmp x6, #4095 |
| cmn x6, #-4095 |
| // CHECK: {{adds wzr,|cmn}} w7, #5 |
| // CHECK: {{adds wzr,|cmn}} w7, #5 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| cmn w7, #5 |
| cmp w7, #-5 |
| // CHECK: {{subs wzr,|cmp}} w8, #4095 |
| // CHECK: {{subs wzr,|cmp}} w8, #4095 |
| // CHECK-NO-NEG-IMM: instruction requires: NegativeImmediates |
| cmp w8, #4095 |
| cmn w8, #-4095 |