Get subtractions the right way round.
authorDavid Given <dg@cowlark.com>
Tue, 15 Nov 2016 19:25:11 +0000 (20:25 +0100)
committerDavid Given <dg@cowlark.com>
Tue, 15 Nov 2016 19:25:11 +0000 (20:25 +0100)
mach/powerpc/mcg/table
plat/qemuppc/tests/intsub.c [new file with mode: 0644]

index a6f416b..03daee9 100644 (file)
@@ -609,7 +609,7 @@ PATTERNS
     ALUCC(ADD.I, "addi")
 
        out:(int)reg = SUB.I(left:(int)reg, right:(int)reg)
-               emit "subf %out, %left, %right"
+               emit "subf %out, %right, %left"
                cost 4;
 
        out:(int)reg = SUB.I(left:(int)reg, right:CONST.I)
diff --git a/plat/qemuppc/tests/intsub.c b/plat/qemuppc/tests/intsub.c
new file mode 100644 (file)
index 0000000..72ba0ff
--- /dev/null
@@ -0,0 +1,31 @@
+#include "test.h"
+
+/* Constants in globals to defeat constant folding. */
+int two = 2;
+int one = 1;
+int zero = 0;
+int minusone = -1;
+
+/* Bypasses the CRT, so there's no stdio or BSS initialisation. */
+void _m_a_i_n(void)
+{
+    ASSERT((two - one) == 1);
+    ASSERT((one - two) == -1);
+
+    ASSERT((two - 1) == 1);
+    ASSERT((one - 2) == -1);
+
+    ASSERT((2   - one) == 1);
+    ASSERT((1   - two) == -1);
+
+    ASSERT(((unsigned int)two - (unsigned int)one) == 1);
+    ASSERT(((unsigned int)one - (unsigned int)two) == 0xffffffff);
+
+    ASSERT(((unsigned int)two - (unsigned int)1) == 1);
+    ASSERT(((unsigned int)one - (unsigned int)2) == 0xffffffff);
+
+    ASSERT(((unsigned int)2   - (unsigned int)one) == 1);
+    ASSERT(((unsigned int)1   - (unsigned int)two) == 0xffffffff);
+
+    finished();
+}
\ No newline at end of file