]> git.sur5r.net Git - cc65/commitdiff
Masking a bit field is unnecessary if there was no shift operation or if the
authoruz <uz@b7a2c559-68d2-44c3-8de9-860c34a00d81>
Fri, 20 Jan 2012 15:54:43 +0000 (15:54 +0000)
committeruz <uz@b7a2c559-68d2-44c3-8de9-860c34a00d81>
Fri, 20 Jan 2012 15:54:43 +0000 (15:54 +0000)
shift operation shifted just zeroes into the value.

git-svn-id: svn://svn.cc65.org/cc65/trunk@5412 b7a2c559-68d2-44c3-8de9-860c34a00d81

src/cc65/loadexpr.c

index 4802dbb2b61fdd9fcd88e88faa4a095b4b32cf3f..99c5684d16f4242245b53b969377fb915ca31a24 100644 (file)
@@ -162,8 +162,11 @@ void LoadExpr (unsigned Flags, struct ExprDesc* Expr)
             unsigned F = CF_INT | CF_UNSIGNED | CF_CONST | (Flags & CF_TEST);
             /* Shift right by the bit offset */
             g_asr (F, Expr->BitOffs);
-            /* And by the width */
-            g_and (F, (0x0001U << Expr->BitWidth) - 1U);
+            /* And by the width if the field doesn't end on an int boundary */
+            if (Expr->BitOffs + Expr->BitWidth != CHAR_BITS &&
+                Expr->BitOffs + Expr->BitWidth != INT_BITS) {
+                g_and (F, (0x0001U << Expr->BitWidth) - 1U);
+            }
         }
 
         /* Expression was tested */