]> git.gag.com Git - fw/sdcc/commitdiff
* device/lib/_gptrget.c: also push/pop _PSBANK, added # to 0x03
authormaartenbrock <maartenbrock@4a8a32a2-be11-0410-ad9d-d568d2c75423>
Tue, 28 Jun 2005 20:34:12 +0000 (20:34 +0000)
committermaartenbrock <maartenbrock@4a8a32a2-be11-0410-ad9d-d568d2c75423>
Tue, 28 Jun 2005 20:34:12 +0000 (20:34 +0000)
* device/lib/_itoa.c,
* device/lib/_ltoa.c: optimized codesize
* src/SDCCsymt.c (checkSClass): added sanity check for sfr at addresses,
  but don't know how to suppress the double warning.
* src/mcs51/gen.c (genPlusIncr): fixed bug when incrementing volatile int's
* support/Util/SDCCerr.c,
* support/Util/SDCCerr.h: added warning W_SFR_ABSRANGE for sanity check

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

ChangeLog
device/lib/_gptrget.c
device/lib/_itoa.c
device/lib/_ltoa.c
src/SDCCsymt.c
src/mcs51/gen.c
support/Util/SDCCerr.c
support/Util/SDCCerr.h

index 31e62b6d63ba7fc722cd5f0f1dae7127923f76a4..e58d4d90f9ca7752f83ba7b25d37332067b4d771 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,14 @@
+2005-06-28 Maarten Brock <sourceforge.brock AT dse.nl>
+
+       * device/lib/_gptrget.c: also push/pop _PSBANK, added # to 0x03
+       * device/lib/_itoa.c,
+       * device/lib/_ltoa.c: optimized codesize
+       * src/SDCCsymt.c (checkSClass): added sanity check for sfr at addresses,
+         but don't know how to suppress the double warning.
+       * src/mcs51/gen.c (genPlusIncr): fixed bug when incrementing volatile int's
+       * support/Util/SDCCerr.c,
+       * support/Util/SDCCerr.h: added warning W_SFR_ABSRANGE for sanity check
+
 2005-06-27 Maarten Brock <sourceforge.brock AT dse.nl>
 
        * as/mcs51/asexpr.c (expr): disabled warning "not in .flat24 mode",
index 18a2f588a7864d129ffc7d03704a4c4cf83ac96f..beb11aa228ea55d80bf759140a2979d520608d64 100644 (file)
@@ -49,53 +49,55 @@ _gptrget (char *gptr) _naked
     ;
     ;   depending on the pointer type acc. to SDCCsymt.h
     ;
-       jb              _B_7,codeptr$        ; >0x80 code               ; 3
-       jnb             _B_6,xdataptr$       ; <0x40 far                ; 3
+        jb      _B_7,codeptr$        ; >0x80 code       ; 3
+        jnb     _B_6,xdataptr$       ; <0x40 far        ; 3
 
-        mov     dph,r0 ; save r0 independant of regbank        ; 2
-        mov     r0,dpl ; use only low order address            ; 2
+        mov     dph,r0 ; save r0 independant of regbank ; 2
+        mov     r0,dpl ; use only low order address     ; 2
 
-       jb              _B_5,pdataptr$       ; >0x60 pdata              ; 3
+        jb      _B_5,pdataptr$       ; >0x60 pdata      ; 3
     ;
     ;   Pointer to data space
     ;
-        mov     a,@r0                                                                  ; 1
-        mov     r0,dph ; restore r0                                            ; 2
-        mov     dph,#0 ; restore dph                                   ; 2
-        ret                                                                                            ; 1
+        mov     a,@r0                                   ; 1
+        mov     r0,dph ; restore r0                     ; 2
+        mov     dph,#0 ; restore dph                    ; 2
+        ret                                             ; 1
     ;
     ;   pointer to external stack or pdata
     ;
  pdataptr$:
-        movx    a,@r0                                                                  ; 1
-        mov     r0,dph ; restore r0                                            ; 2
-        mov     dph,#0 ; restore dph                                   ; 2
-        ret                                                                                            ; 1
-       ;
-       ;   pointer to code area
-       ;
+        movx    a,@r0                                   ; 1
+        mov     r0,dph ; restore r0                     ; 2
+        mov     dph,#0 ; restore dph                    ; 2
+        ret                                             ; 1
+    ;
+    ;   pointer to code area
+    ;
  codeptr$:
-       ; implementation for SiLabs C8051F12x
-               mov             a,b                                                                             ; 2
-               anl             a,0x03                                                                  ; 2
-               swap    a                                                                               ; 1
-               anl             _PSBANK,#0x0F                                                   ; 3
-               orl             _PSBANK,a                                                               ; 2
-
-        clr     a                                                                              ; 1
-        movc    a,@a+dptr                                                              ; 1
-        ret                                                                                            ; 1
+    ; implementation for SiLabs C8051F12x
+        mov     a,b                                     ; 2
+        anl     a,#0x03                                 ; 2
+        swap    a                                       ; 1
+        push    _PSBANK                                 ; 2
+        anl     _PSBANK,#0x0F                           ; 3
+        orl     _PSBANK,a                               ; 2
+
+        clr     a                                       ; 1
+        movc    a,@a+dptr                               ; 1
+        pop     _PSBANK                                 ; 2
+        ret                                             ; 1
     ;
     ;   pointer to xternal data
     ;
  xdataptr$:
-       ; implementation for xram a16-a21 tied to P3
-               mov             _P3,b                                                                   ; 3
+    ; implementation for xram a16-a21 tied to P3
+        mov     _P3,b                                   ; 3
 
-        movx    a,@dptr                                                                        ; 1
-        ret                                                                                            ; 1
-                                                                                                       ;===
-                                                                                                       ;43 bytes
+        movx    a,@dptr                                 ; 1
+        ret                                             ; 1
+                                                        ;===
+                                                        ;47 bytes
      _endasm ;
 }
 
@@ -113,47 +115,47 @@ _gptrget (char *gptr) _naked
     ;
     ;   depending on the pointer type acc. to SDCCsymt.h
     ;
-       mov             b,dph                                                                   ; 3
-       jb              _B_7,codeptr$        ; >0x80 code               ; 3
-       jnb             _B_6,xdataptr$       ; <0x40 far                ; 3
+        mov     b,dph                                   ; 3
+        jb      _B_7,codeptr$        ; >0x80 code       ; 3
+        jnb     _B_6,xdataptr$       ; <0x40 far        ; 3
 
-        mov     b,r0   ; save r0 independant of regbank        ; 2
-        mov     r0,dpl ; use only low order address            ; 2
+        mov     b,r0   ; save r0 independant of regbank ; 2
+        mov     r0,dpl ; use only low order address     ; 2
 
-       jb              _B_5,pdataptr$       ; >0x60 pdata              ; 3
+        jb      _B_5,pdataptr$       ; >0x60 pdata      ; 3
     ;
     ;   Pointer to data space
     ;
-        mov     a,@r0                                                                  ; 1
-        mov     r0,b   ; restore r0                                            ; 2
-        ret                                                                                            ; 1
+        mov     a,@r0                                   ; 1
+        mov     r0,b   ; restore r0                     ; 2
+        ret                                             ; 1
     ;
     ;   pointer to xternal stack or pdata
     ;
  pdataptr$:
-        movx    a,@r0                                                                  ; 1
-        mov     r0,b   ; restore r0                                            ; 2
-        ret                                                                                            ; 1
-       ;
-       ;   pointer to code area, max 15 bits
-       ;
+        movx    a,@r0                                   ; 1
+        mov     r0,b   ; restore r0                     ; 2
+        ret                                             ; 1
+    ;
+    ;   pointer to code area, max 15 bits
+    ;
  codeptr$:
-       ; 0x8000 <= dptr <= 0xFFFF
-       ; no need to AND dph and restore from B if hardware wraps code memory
-        anl     dph,#0x7F                                                              ; 3
-        clr     a                                                                              ; 1
-        movc    a,@a+dptr                                                              ; 1
-        mov     dph,b                                                                  ; 3
-        ret                                                                                            ; 1
+    ; 0x8000 <= dptr <= 0xFFFF
+    ; no need to AND dph and restore from B if hardware wraps code memory
+        anl     dph,#0x7F                               ; 3
+        clr     a                                       ; 1
+        movc    a,@a+dptr                               ; 1
+        mov     dph,b                                   ; 3
+        ret                                             ; 1
     ;
     ;   pointer to xternal data, max 14 bits
     ;
  xdataptr$:
-       ; 0 <= dptr <= 0x3FFF
-        movx    a,@dptr                                                                        ; 1
-        ret                                                                                            ; 1
-                                                                                                       ;===
-                                                                                                       ;35 bytes
+    ; 0 <= dptr <= 0x3FFF
+        movx    a,@dptr                                 ; 1
+        ret                                             ; 1
+                                                        ;===
+                                                        ;35 bytes
      _endasm ;
 }
 
@@ -171,43 +173,43 @@ _gptrget (char *gptr) _naked
     ;
     ;   depending on the pointer type acc. to SDCCsymt.h
     ;
-       jb              _B_7,codeptr$        ; >0x80 code               ; 3
-       jnb             _B_6,xdataptr$       ; <0x40 far                ; 3
+        jb      _B_7,codeptr$        ; >0x80 code       ; 3
+        jnb     _B_6,xdataptr$       ; <0x40 far        ; 3
 
-        mov     dph,r0 ; save r0 independant of regbank        ; 2
-        mov     r0,dpl ; use only low order address            ; 2
+        mov     dph,r0 ; save r0 independant of regbank ; 2
+        mov     r0,dpl ; use only low order address     ; 2
 
-       jb              _B_5,pdataptr$       ; >0x60 pdata              ; 3
+        jb      _B_5,pdataptr$       ; >0x60 pdata      ; 3
     ;
     ;   Pointer to data space
     ;
-        mov     a,@r0                                                                  ; 1
-        mov     r0,dph ; restore r0                                            ; 2
-        mov     dph,#0 ; restore dph                                   ; 2
-        ret                                                                                            ; 1
+        mov     a,@r0                                   ; 1
+        mov     r0,dph ; restore r0                     ; 2
+        mov     dph,#0 ; restore dph                    ; 2
+        ret                                             ; 1
     ;
     ;   pointer to xternal stack or pdata
     ;
  pdataptr$:
-        movx    a,@r0                                                                  ; 1
-        mov     r0,dph ; restore r0                                            ; 2
-        mov     dph,#0 ; restore dph                                   ; 2
-        ret                                                                                            ; 1
-       ;
-       ;   pointer to code area, max 16 bits
-       ;
+        movx    a,@r0                                   ; 1
+        mov     r0,dph ; restore r0                     ; 2
+        mov     dph,#0 ; restore dph                    ; 2
+        ret                                             ; 1
+    ;
+    ;   pointer to code area, max 16 bits
+    ;
  codeptr$:
-        clr     a                                                                              ; 1
-        movc    a,@a+dptr                                                              ; 1
-        ret                                                                                            ; 1
+        clr     a                                       ; 1
+        movc    a,@a+dptr                               ; 1
+        ret                                             ; 1
     ;
     ;   pointer to xternal data, max 16 bits
     ;
  xdataptr$:
-        movx    a,@dptr                                                                        ; 1
-        ret                                                                                            ; 1
-                                                                                                       ;===
-                                                                                                       ;30 bytes
+        movx    a,@dptr                                 ; 1
+        ret                                             ; 1
+                                                        ;===
+                                                        ;30 bytes
      _endasm ;
 }
 
@@ -224,47 +226,47 @@ _gptrget (char *gptr) _naked
     ;
     ;   depending on the pointer type acc. to SDCCsymt.h
     ;
-        mov     a,b                                                                            ; 2
-        jz      00001$  ; 0 near                                               ; 2
-        dec     a                                                                              ; 1
-        jz      00002$  ; 1 far                                                        ; 2
-        dec     a                                                                              ; 1
-        jz      00003$  ; 2 code                                               ; 2
-        dec     a                                                                              ; 1
-        jz      00004$  ; 3 pdata                                              ; 2
-        dec     a       ; 4 skip generic pointer               ; 1
-        dec     a                                                                              ; 1
-        jz      00001$  ; 5 idata                                              ; 2
+        mov     a,b                                     ; 2
+        jz      00001$  ; 0 near                        ; 2
+        dec     a                                       ; 1
+        jz      00002$  ; 1 far                         ; 2
+        dec     a                                       ; 1
+        jz      00003$  ; 2 code                        ; 2
+        dec     a                                       ; 1
+        jz      00004$  ; 3 pdata                       ; 2
+        dec     a       ; 4 skip generic pointer        ; 1
+        dec     a                                       ; 1
+        jz      00001$  ; 5 idata                       ; 2
     ;
     ;   any other value for type
     ;   return xFF
-        mov     a,#0xff                                                                        ; 2
-        ret                                                                                            ; 1
+        mov     a,#0xff                                 ; 2
+        ret                                             ; 1
     ;
     ;   Pointer to data space
     ;
  00001$:
-        push    ar0                                                                            ; 2
+        push    ar0                                     ; 2
         ;
-        mov     r0,dpl     ; use only low order address        ; 2
-        mov     a,@r0                                                                  ; 1
+        mov     r0,dpl     ; use only low order address ; 2
+        mov     a,@r0                                   ; 1
         ;
-        pop     ar0                                                                            ; 2
+        pop     ar0                                     ; 2
         ;
-        ret                                                                                            ; 1
+        ret                                             ; 1
     ;
     ;   pointer to xternal data
     ;
  00002$:
-        movx    a,@dptr                                                                        ; 1
-        ret                                                                                            ; 1
+        movx    a,@dptr                                 ; 1
+        ret                                             ; 1
 ;
 ;   pointer to code area
 ;
  00003$:
         ; clr     a  is already 0
-        movc    a,@a+dptr                                                              ; 1
-        ret                                                                                            ; 1
+        movc    a,@a+dptr                               ; 1
+        ret                                             ; 1
 ;
 ;   pointer to xternal stack or pdata
 ;
@@ -273,14 +275,14 @@ _gptrget (char *gptr) _naked
         mov     dph,__XPAGE     ; __XPAGE (usually p2) holds high byte for pdata access
         movx    a,@dptr
 #else
-        push    ar0                                                                            ; 2
-        mov     r0,dpl                                                                 ; 2
-        movx    a,@r0                                                                  ; 1
-        pop     ar0                                                                            ; 2
+        push    ar0                                     ; 2
+        mov     r0,dpl                                  ; 2
+        movx    a,@r0                                   ; 1
+        pop     ar0                                     ; 2
 #endif
-        ret                                                                                            ; 1
-                                                                                                       ;===
-                                                                                                       ;40 bytes
+        ret                                             ; 1
+                                                        ;===
+                                                        ;40 bytes
      _endasm ;
 }
 #endif
@@ -301,13 +303,13 @@ _gptrgetWord (unsigned *gptr)
     ;
     ;   depending on the pointer type acc. to SDCCsymt.h
     ;
-       jb              _B_7,00003$           ; >0x80 code
-       jnb             _B_6,00002$           ; <0x40 far
+        jb      _B_7,00003$           ; >0x80 code
+        jnb     _B_6,00002$           ; <0x40 far
 
         mov     dph,r0 ; save r0 independant of regbank
         mov     r0,dpl ; use only low order address
 
-       jb              _B_5,00004$           ; >0x60 pdata
+        jb      _B_5,00004$           ; >0x60 pdata
     ;
     ;   Pointer to data space
     ;
index b282dac69839e99f6d298b54f12859bf5e4248a2..f89ba9e497c05a84b3a9ed6fadbd861d57ebcc57 100755 (executable)
@@ -40,10 +40,7 @@ void _itoa(int value, char* string, unsigned char radix)
 {
   if (value < 0 && radix == 10) {
     *string++ = '-';
-    _uitoa(-value, string, radix);
-  }
-  else {
-    _uitoa(value, string, radix);
+    value = -value;
   }
+  _uitoa(value, string, radix);
 }
-
index 0ba0c3db61d093e1e56c63aa0d5a8987bc9b9815..0ee8be26875fa03921304c921cae74714d5da666 100755 (executable)
@@ -39,10 +39,7 @@ void _ltoa(long value, char* string, unsigned char radix)
 {
   if (value < 0 && radix == 10) {
     *string++ = '-';
-    _ultoa(-value, string, radix);
-  }
-  else {
-    _ultoa(value, string, radix);
+    value = -value;
   }
+  _ultoa(value, string, radix);
 }
-
index 1eff67706192a7f57ea258d767fc8a27c892d82f..fe796ebb42610ae515a405b50d78189337eb7596 100644 (file)
@@ -1373,6 +1373,26 @@ checkSClass (symbol * sym, int isProto)
     if (IS_ABSOLUTE (sym->etype))
       SPEC_VOLATILE (sym->etype) = 1;
   
+  if (TARGET_IS_MCS51 &&
+      IS_ABSOLUTE (sym->etype) &&
+      SPEC_SCLS (sym->etype) == S_SFR)
+    {
+      int n, size;
+      unsigned addr;
+
+      if (SPEC_NOUN (sym->etype) == V_CHAR)
+        size = 8;
+      else if (SPEC_LONG (sym->etype) == 0)
+        size = 16;
+      else
+        size = 32;
+
+      addr = SPEC_ADDR (sym->etype);
+      for (n=0; n<size; n+=8)
+        if (((addr >> n) & 0xFF) < 0x80)
+          werror (W_SFR_ABSRANGE, sym->name);
+    }
+
   /* If code memory is read only, then pointers to code memory */
   /* implicitly point to constants -- make this explicit       */
   t = sym->type;
index e2252b7e5bd8d835668edfdce20c9c7a1ed86a1d..ebf6a53260d276eff09e108bd6c9ded094015164 100644 (file)
@@ -3496,6 +3496,7 @@ genPlusIncr (iCode * ic)
   /* if increment >=16 bits in register or direct space */
   if ((AOP_TYPE(IC_LEFT(ic)) == AOP_REG || AOP_TYPE(IC_LEFT(ic)) == AOP_DIR ) &&
       sameRegs (AOP (IC_LEFT (ic)), AOP (IC_RESULT (ic))) &&
+      !isOperandVolatile (IC_RESULT (ic), FALSE) &&
       (size > 1) &&
       (icount == 1))
     {
index 19594964615349fed2eb895faefb3d53725f83d0..93cd49653647a2fef57690b2dace6080e12a76d9 100644 (file)
@@ -415,7 +415,9 @@ struct
 { W_COMPLEMENT, ERROR_LEVEL_WARNING,
    "using ~ on bit/bool/unsigned char variables can give unexpected results due to promotion to int" },
 { E_SHADOWREGS_NO_ISR, ERROR_LEVEL_ERROR,
-   "ISR function attribute 'shadowregs' following non-ISR function `%s'" },
+   "ISR function attribute 'shadowregs' following non-ISR function '%s'" },
+{ W_SFR_ABSRANGE, ERROR_LEVEL_WARNING,
+   "absolute address for sfr '%s' probably out of range." },
 };
 
 /*
index dc2614db01c5068e2550fd52bc36598e27697915..df65977642f7d82e2c0d3b8cb90d201ac8f3a455 100644 (file)
@@ -197,6 +197,7 @@ SDCCERR - SDCC Standard error handler
 #define W_POSSBUG2                    179 /* possible bug, new format */
 #define W_COMPLEMENT                  180 /* ~bit can give unexpected results */
 #define E_SHADOWREGS_NO_ISR           181 /* shadowregs keyword following non-ISR function */
+#define W_SFR_ABSRANGE                182 /* sfr at address out of range */
 
 #define MAX_ERROR_WARNING             256 /* size of disable warnings array */