shithub: scc

Download patch

ref: 20b5535ad47415dae9f55e048cb0958be03bb9a1
parent: c40ecd533a2317a3db0b29c3ecdc6ffd0d8baeb4
author: Roberto E. Vargas Caballero <k0ga@shike2.com>
date: Sun Sep 6 08:14:42 EDT 2015

Fix problems with identities about &

The ones function was generating more problems, that the
problems it was fixing. At this moment there is a know bug,
because we are not expanding the most significant bit, so
some cases can be missed.

--- a/cc1/fold.c
+++ b/cc1/fold.c
@@ -135,6 +135,16 @@
 	return 1;
 }
 
+static TUINT
+ones(int n)
+{
+	TUINT v;
+
+	for (v = 1; n--; v |= 1)
+		v <<= 1;
+	return v;
+}
+
 static bool
 foldint(int op, Symbol *res, TINT l, TINT r)
 {
@@ -360,22 +370,12 @@
 		aux = l;
 		l = r;
 		r = aux;
-		*rp = r;
-		*lp = l;
 		break;
 	}
+	*rp = r;
+	*lp = l;
 }
 
-static TUINT
-ones(int n)
-{
-	TUINT v;
-
-	for (v = 1; n--; v |= 1)
-		v <<= 1;
-	return v;
-}
-
 static Node *
 identity(int *op, Node *lp, Node *rp)
 {
@@ -462,7 +462,7 @@
 		return NULL;
 	case OBAND:
 		/* i & ~0 => i */
-		if (cmpnode(rp, ones(lp->type->size * 8)))
+		if (cmpnode(rp, ~0))
 			goto free_right;
 		return NULL;
 	case OMOD: