aboutsummaryrefslogtreecommitdiff
path: root/test/MC/Hexagon/bug20416.s
diff options
context:
space:
mode:
Diffstat (limited to 'test/MC/Hexagon/bug20416.s')
-rw-r--r--test/MC/Hexagon/bug20416.s13
1 files changed, 13 insertions, 0 deletions
diff --git a/test/MC/Hexagon/bug20416.s b/test/MC/Hexagon/bug20416.s
new file mode 100644
index 00000000000..e4fb194bbf1
--- /dev/null
+++ b/test/MC/Hexagon/bug20416.s
@@ -0,0 +1,13 @@
+# RUN: not llvm-mc -mv60 -mhvx -filetype=asm %s 2>%t; FileCheck %s --check-prefix=CHECK-V60-ERROR <%t
+# RUN: llvm-mc -mv62 -mhvx -filetype=asm %s | FileCheck %s
+
+// for this a v60+/hvx instruction sequence, make sure fails with v60
+// but passes with v62. this is because this instruction uses different
+// itinerary between v60 and v62
+{
+ v0.h=vsat(v5.w,v9.w)
+ v16.h=vsat(v6.w,v26.w)
+}
+# CHECK-V60-ERROR: rror: invalid instruction packet: slot error
+# CHECK: v0.h = vsat(v5.w,v9.w)
+# CHECK: v16.h = vsat(v6.w,v26.w)