291 lines
6.6 KiB
ArmAsm
291 lines
6.6 KiB
ArmAsm
|
# 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 }
|