(committed on Frieder's behalf)
authorepetrich <epetrich@4a8a32a2-be11-0410-ad9d-d568d2c75423>
Tue, 16 Dec 2003 05:02:50 +0000 (05:02 +0000)
committerepetrich <epetrich@4a8a32a2-be11-0410-ad9d-d568d2c75423>
Tue, 16 Dec 2003 05:02:50 +0000 (05:02 +0000)
* src/mcs51/main.c: fixed the fix for bug #737001

git-svn-id: https://sdcc.svn.sourceforge.net/svnroot/sdcc/trunk/sdcc@3059 4a8a32a2-be11-0410-ad9d-d568d2c75423

ChangeLog
src/mcs51/main.c

index 6fe9b2e443ec32f0bd2908f2970c208bf9037f23..9e8acf65d41b2212c2976d90e7632b98b8b676e8 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2003-12-16 Frieder Ferlemann <Frieder.Ferlemann@web.de>
+
+       (committed by Erik Petrich <epetrich@ivorytower.norman.ok.us> on Frieder's behalf)
+       * src/mcs51/main.c: fixed the fix for bug #737001
+
 2003-12-15  Borut Razem <borut.razem@siol.net>
 
        * support/scripts/sdcc.nsi: updated for NSIS 2.0 beta 4
index 20f721fe534220d8605a0fd1556ca03bc5151878..0bf2d1141a723e8dafd6201865d7e172ce89c694 100644 (file)
@@ -157,17 +157,17 @@ _mcs51_genIVT (FILE * of, symbol ** interrupts, int maxInterrupts)
    This clears XSEG, DSEG, BSEG, OSEG, SSEG */
 static void _mcs51_genRAMCLEAR (FILE * of) {
   fprintf (of, ";      _mcs51_genRAMCLEAR() start\n");
-  fprintf (of, "       mov     r1,#l_XSEG\n");
-  fprintf (of, "       mov     a,r1\n");
+  fprintf (of, "       mov     r0,#l_XSEG\n");
+  fprintf (of, "       mov     a,r0\n");
   fprintf (of, "       orl     a,#(l_XSEG >> 8)\n");
   fprintf (of, "       jz      00005$\n");
-  fprintf (of, "       mov     r0,#((l_XSEG + 255) >> 8)\n");
+  fprintf (of, "       mov     r1,#((l_XSEG + 255) >> 8)\n");
   fprintf (of, "       mov     dptr,#s_XSEG\n");
   fprintf (of, "       clr     a\n");
   fprintf (of, "00004$:        movx    @dptr,a\n");
   fprintf (of, "       inc     dptr\n");
-  fprintf (of, "       djnz    r1,00004$\n");
   fprintf (of, "       djnz    r0,00004$\n");
+  fprintf (of, "       djnz    r1,00004$\n");
   /* r0 is zero now. Clearing 256 byte assuming 128 byte devices don't mind */
   fprintf (of, "00005$:        mov     @r0,a\n");   
   fprintf (of, "       djnz    r0,00005$\n");