]> git.sur5r.net Git - cc65/commitdiff
Fixed a bug
authorcuz <cuz@b7a2c559-68d2-44c3-8de9-860c34a00d81>
Mon, 10 Dec 2001 18:01:53 +0000 (18:01 +0000)
committercuz <cuz@b7a2c559-68d2-44c3-8de9-860c34a00d81>
Mon, 10 Dec 2001 18:01:53 +0000 (18:01 +0000)
git-svn-id: svn://svn.cc65.org/cc65/trunk@1137 b7a2c559-68d2-44c3-8de9-860c34a00d81

src/cc65/coptcmp.c

index a88e7047d1fdfe58e9e9c96babd797bbbe6c1c3d..c185ecc27ad9432bf3b5afb1b8374723ed661190 100644 (file)
@@ -670,17 +670,16 @@ unsigned OptCmp4 (CodeSeg* S)
                /* Change the code to just use the A register. Move the load
                 * of the low byte after the first branch if possible:
                 *
-                *      ldy     #o-1
+                *      ldy     #o
                 *      lda     (sp),y
                 *      cmp     #a
                 *      bne     L1
-                *      ldy     #o
+                *      ldy     #o-1
                 *      lda     (sp),y
                 *      cmp     #b
                 *      jne/jeq ...
                 */
-               sprintf (Buf, "$%02X", (int)(L[0]->Num-1));
-               X = NewCodeEntry (OP65_LDY, AM65_IMM, Buf, 0, L[0]->LI);
+               X = NewCodeEntry (OP65_LDY, AM65_IMM, L[0]->Arg, 0, L[0]->LI);
                CS_InsertEntry (S, X, I+3);
 
                X = NewCodeEntry (OP65_LDA, AM65_ZP_INDY, "sp", 0, L[1]->LI);
@@ -689,7 +688,8 @@ unsigned OptCmp4 (CodeSeg* S)
                X = NewCodeEntry (OP65_CMP, L[2]->AM, L[2]->Arg, 0, L[2]->LI);
                CS_InsertEntry (S, X, I+5);
 
-               X = NewCodeEntry (OP65_LDY, AM65_IMM, L[0]->Arg, 0, L[0]->LI);
+               sprintf (Buf, "$%02X", (int)(L[0]->Num-1));
+               X = NewCodeEntry (OP65_LDY, AM65_IMM, Buf, 0, L[0]->LI);
                CS_InsertEntry (S, X, I+7);
 
                X = NewCodeEntry (OP65_LDA, AM65_ZP_INDY, "sp", 0, L[1]->LI);