aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/validation/optim/cmp-zext-uimm2.c
diff options
Diffstat (limited to 'validation/optim/cmp-zext-uimm2.c')
-rw-r--r--validation/optim/cmp-zext-uimm2.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/validation/optim/cmp-zext-uimm2.c b/validation/optim/cmp-zext-uimm2.c
new file mode 100644
index 00000000..64f30b9a
--- /dev/null
+++ b/validation/optim/cmp-zext-uimm2.c
@@ -0,0 +1,30 @@
+#define zext(X) ((unsigned long long) (X))
+
+int zext_ltu_q(unsigned x) { return (zext(x) < 0x100000001UL) == 1; }
+int zext_ltu_p(unsigned x) { return (zext(x) < 0x100000000UL) == 1; }
+int zext_ltu_0(unsigned x) { return (zext(x) < 0x0ffffffffUL) == (x < 0xffffffff); }
+int zext_ltu_m(unsigned x) { return (zext(x) < 0x0fffffffeUL) == (x < 0xfffffffe); }
+
+int zext_leu_q(unsigned x) { return (zext(x) <= 0x100000001UL) == 1; }
+int zext_leu_p(unsigned x) { return (zext(x) <= 0x100000000UL) == 1; }
+int zext_leu_0(unsigned x) { return (zext(x) <= 0x0ffffffffUL) == 1; }
+int zext_leu_m(unsigned x) { return (zext(x) <= 0x0fffffffeUL) == (x <= 0xfffffffe); }
+
+int zext_geu_q(unsigned x) { return (zext(x) >= 0x100000001UL) == 0; }
+int zext_geu_p(unsigned x) { return (zext(x) >= 0x100000000UL) == 0; }
+int zext_geu_0(unsigned x) { return (zext(x) >= 0x0ffffffffUL) == (x >= 0xffffffff); }
+int zext_geu_m(unsigned x) { return (zext(x) >= 0x0fffffffeUL) == (x >= 0xfffffffe); }
+
+int zext_gtu_q(unsigned x) { return (zext(x) > 0x100000001UL) == 0; }
+int zext_gtu_p(unsigned x) { return (zext(x) > 0x100000000UL) == 0; }
+int zext_gtu_0(unsigned x) { return (zext(x) > 0x0ffffffffUL) == 0; }
+int zext_gtu_m(unsigned x) { return (zext(x) > 0x0fffffffeUL) == (x > 0xfffffffe); }
+
+/*
+ * check-name: cmp-zext-uimm2
+ * check-command: test-linearize -Wno-decl $file
+ * check-known-to-fail
+ *
+ * check-output-ignore
+ * check-output-returns: 1
+ */