[GHC] #10518: unregisterised GHC generates incorrect 0xUL literals for certain onstants

GHC ghc-devs at haskell.org
Sat Jun 13 22:06:17 UTC 2015


#10518: unregisterised GHC generates incorrect 0xUL literals for certain onstants
-------------------------------------+-------------------------------------
              Reporter:  slyfox      |             Owner:  slyfox
                  Type:  bug         |            Status:  new
              Priority:  normal      |         Milestone:
             Component:  Compiler    |           Version:  7.10.1
              Keywords:              |  Operating System:  Unknown/Multiple
          Architecture:              |   Type of failure:  None/Unknown
  Unknown/Multiple                   |        Blocked By:
             Test Case:              |   Related Tickets:
              Blocking:              |
Differential Revisions:              |
-------------------------------------+-------------------------------------
 jakzale reports:
 21:47:27 < int-e> Oh, nice. Yes, indeed pprHexVal (2^32) W32 (function
 from cmm/PprC.hs) would result in 0xU.
 21:50:29 < jakzale> int-e: yes, truncInt takes module 2^32, then go
 returns empty string (I guess)

 Here comes the test:
 {{{
 $ cat a.cmm

 foo() {
     bits64 a;
     a = 0x10000000000000000; // overflows 64 bits
     return (a);
 }

 $ inplace/bin/ghc-stage2 -c a.cmm
 /tmp/ghc8580_0/ghc_2.hc: In function 'foo':

 /tmp/ghc8580_0/ghc_2.hc:8:7: error:
      error: invalid suffix "xUL" on integer constant
      _c0 = 0xUL;
            ^
 }}}
 I've broke it with commit:43f1b2ecd1960fa7377cf55a2b97c66059a701ef
 when introduced truncation that can generate more zeroes.

--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/10518>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler


More information about the ghc-tickets mailing list