| # RUN: llvm-mc -triple=hexagon -filetype=obj -o - %s | llvm-objdump -d - | FileCheck %s |
| # Hexagon Programmer's Reference Manual 11.7.2 NV/ST |
| |
| # Store new-value byte |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 82 f5 b1 3b |
| { r31 = r31 |
| memb(r17 + r21<<#3) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 11 c2 a0 48 |
| { r31 = r31 |
| memb(gp+#17) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 15 c2 b1 a1 |
| { r31 = r31 |
| memb(r17+#21) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 02 e2 b1 a9 |
| { r31 = r31 |
| memb(r17 ++ I:circ(m1)) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 28 e2 b1 a9 |
| { r31 = r31 |
| memb(r17 ++ #5:circ(m1)) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 28 c2 b1 ab |
| { r31 = r31 |
| memb(r17++#5) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 00 e2 b1 ad |
| { r31 = r31 |
| memb(r17++m1) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 00 e2 b1 af |
| { r31 = r31 |
| memb(r17 ++ m1:brev) = r31.new } |
| |
| # Store new-value byte conditionally |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: e2 f5 b1 34 |
| { r31 = r31 |
| if (p3) memb(r17+r21<<#3) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: e2 f5 b1 35 |
| { r31 = r31 |
| if (!p3) memb(r17+r21<<#3) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: e2 f5 b1 36 |
| { p3 = r5 |
| r31 = r31 |
| if (p3.new) memb(r17+r21<<#3) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: e2 f5 b1 37 |
| { p3 = r5 |
| r31 = r31 |
| if (!p3.new) memb(r17+r21<<#3) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: ab c2 b1 40 |
| { r31 = r31 |
| if (p3) memb(r17+#21) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: ab c2 b1 44 |
| { r31 = r31 |
| if (!p3) memb(r17+#21) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: ab c2 b1 42 |
| { p3 = r5 |
| r31 = r31 |
| if (p3.new) memb(r17+#21) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: ab c2 b1 46 |
| { p3 = r5 |
| r31 = r31 |
| if (!p3.new) memb(r17+#21) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 2b e2 b1 ab |
| { r31 = r31 |
| if (p3) memb(r17++#5) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 2f e2 b1 ab |
| { r31 = r31 |
| if (!p3) memb(r17++#5) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: ab e2 b1 ab |
| { p3 = r5 |
| r31 = r31 |
| if (p3.new) memb(r17++#5) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: af e2 b1 ab |
| { p3 = r5 |
| r31 = r31 |
| if (!p3.new) memb(r17++#5) = r31.new } |
| |
| # Store new-value halfword |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 8a f5 b1 3b |
| { r31 = r31 |
| memh(r17 + r21<<#3) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 15 ca a0 48 |
| { r31 = r31 |
| memh(gp+#42) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 15 ca b1 a1 |
| { r31 = r31 |
| memh(r17+#42) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 02 ea b1 a9 |
| { r31 = r31 |
| memh(r17 ++ I:circ(m1)) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 28 ea b1 a9 |
| { r31 = r31 |
| memh(r17 ++ #10:circ(m1)) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 28 ca b1 ab |
| { r31 = r31 |
| memh(r17++#10) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 00 ea b1 ad |
| { r31 = r31 |
| memh(r17++m1) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 00 ea b1 af |
| { r31 = r31 |
| memh(r17 ++ m1:brev) = r31.new } |
| |
| # Store new-value halfword conditionally |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: ea f5 b1 34 |
| { r31 = r31 |
| if (p3) memh(r17+r21<<#3) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: ea f5 b1 35 |
| { r31 = r31 |
| if (!p3) memh(r17+r21<<#3) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: ea f5 b1 36 |
| { p3 = r5 |
| r31 = r31 |
| if (p3.new) memh(r17+r21<<#3) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: ea f5 b1 37 |
| { p3 = r5 |
| r31 = r31 |
| if (!p3.new) memh(r17+r21<<#3) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: ab ca b1 40 |
| { r31 = r31 |
| if (p3) memh(r17+#42) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: ab ca b1 44 |
| { r31 = r31 |
| if (!p3) memh(r17+#42) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: ab ca b1 42 |
| { p3 = r5 |
| r31 = r31 |
| if (p3.new) memh(r17+#42) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: ab ca b1 46 |
| { p3 = r5 |
| r31 = r31 |
| if (!p3.new) memh(r17+#42) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 2b ea b1 ab |
| { r31 = r31 |
| if (p3) memh(r17++#10) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 2f ea b1 ab |
| { r31 = r31 |
| if (!p3) memh(r17++#10) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: ab ea b1 ab |
| { p3 = r5 |
| r31 = r31 |
| if (p3.new) memh(r17++#10) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: af ea b1 ab |
| { p3 = r5 |
| r31 = r31 |
| if (!p3.new) memh(r17++#10) = r31.new } |
| |
| # Store new-value word |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 92 f5 b1 3b |
| { r31 = r31 |
| memw(r17 + r21<<#3) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 15 d2 a0 48 |
| { r31 = r31 |
| memw(gp+#84) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 15 d2 b1 a1 |
| { r31 = r31 |
| memw(r17+#84) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 02 f2 b1 a9 |
| { r31 = r31 |
| memw(r17 ++ I:circ(m1)) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 28 f2 b1 a9 |
| { r31 = r31 |
| memw(r17 ++ #20:circ(m1)) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 28 d2 b1 ab |
| { r31 = r31 |
| memw(r17++#20) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 00 f2 b1 ad |
| { r31 = r31 |
| memw(r17++m1) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 00 f2 b1 af |
| { r31 = r31 |
| memw(r17 ++ m1:brev) = r31.new } |
| |
| # Store new-value word conditionally |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: f2 f5 b1 34 |
| { r31 = r31 |
| if (p3) memw(r17+r21<<#3) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: f2 f5 b1 35 |
| { r31 = r31 |
| if (!p3) memw(r17+r21<<#3) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: f2 f5 b1 36 |
| { p3 = r5 |
| r31 = r31 |
| if (p3.new) memw(r17+r21<<#3) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: f2 f5 b1 37 |
| { p3 = r5 |
| r31 = r31 |
| if (!p3.new) memw(r17+r21<<#3) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: ab d2 b1 40 |
| { r31 = r31 |
| if (p3) memw(r17+#84) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: ab d2 b1 44 |
| { r31 = r31 |
| if (!p3) memw(r17+#84) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: ab d2 b1 42 |
| { p3 = r5 |
| r31 = r31 |
| if (p3.new) memw(r17+#84) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: ab d2 b1 46 |
| { p3 = r5 |
| r31 = r31 |
| if (!p3.new) memw(r17+#84) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 2b f2 b1 ab |
| { r31 = r31 |
| if (p3) memw(r17++#20) = r31.new } |
| # CHECK: 1f 40 7f 70 |
| # CHECK-NEXT: 2f f2 b1 ab |
| { r31 = r31 |
| if (!p3) memw(r17++#20) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: ab f2 b1 ab |
| { p3 = r5 |
| r31 = r31 |
| if (p3.new) memw(r17++#20) = r31.new } |
| # CHECK: 03 40 45 85 |
| # CHECK-NEXT: 1f 40 7f 70 |
| # CHECK-NEXT: af f2 b1 ab |
| { p3 = r5 |
| r31 = r31 |
| if (!p3.new) memw(r17++#20) = r31.new } |