# 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(#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(#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(#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 }