1. 19 Jun, 2000 1 commit
  2. 18 Jun, 2000 5 commits
    • panne's avatar
      [project @ 2000-06-18 21:12:31 by panne] · 2e8a6c42
      panne authored
      Added Eq and Ord instances for ArrayException
    • simonmar's avatar
      [project @ 2000-06-18 17:09:33 by simonmar] · 6771cedb
      simonmar authored
      mention cvs-ghc@haskell.org
    • simonmar's avatar
      [project @ 2000-06-18 16:26:52 by simonmar] · ec86294b
      simonmar authored
      Add FreeBSD-compatible catalog.  This one works on my FreeBSD 4.0 box
      with the following packages installed:
      alternatively, installing the 'docproj' meta-package gets everything
      you need.
    • chak's avatar
      [project @ 2000-06-18 12:13:56 by chak] · 4b719913
      chak authored
      Script that automates building GHC from .hc files.
      ?? Shall I edit the corresponding section in building.sgml to advise the use
      ?? of this script (thus replacing the outdated description of the manual
      ?? steps - which is wrong anyway).
    • simonpj's avatar
      [project @ 2000-06-18 08:37:17 by simonpj] · 91ef36b9
      simonpj authored
      *** MERGE WITH 4.07 ***
      * Fix the ambiguity check in TcMonotype.lhs so that
        it is not carried out for types read from interface 
        files.  Some workers may get ambiguous types but that
        does not matter, and should not make compilation fail.
        More detail in the comments with TcMonoType.tc_type_kind
        (the HsForAll case)
      * Don't create specialisations for type applications 
        where there's a matching rule.  The rule should
        clearly take precedence.  (Bug reported by Sven.)
        I havn't tested this fix.
      * Run the occurrence analyser after tidyCore, so that
        occurrence info (notably dead-var info) is correct
        for the code generators.  This should fix Erik's problem,
        but again I've not tested the fix.  The extra call 
        is in Main.lhs
      * Fix CoreToStg so that it can handle an StgLam in mkStgCase.
        This only shows up in a wierd case, documented in 
  3. 17 Jun, 2000 1 commit
    • chak's avatar
      [project @ 2000-06-17 07:52:30 by chak] · aa104ab9
      chak authored
      * SGML_DOC can now hold a _list_ of sgml documentations to build
      * both building.sgml and ffi-art.sgml are now build in docs/
  4. 16 Jun, 2000 2 commits
  5. 15 Jun, 2000 9 commits
    • panne's avatar
      [project @ 2000-06-15 20:22:53 by panne] · cc0a715a
      panne authored
      Quick workaround for Reuben's M$ configuration problems
    • simonmar's avatar
      [project @ 2000-06-15 15:56:51 by simonmar] · 9f60c2c4
      simonmar authored
      sigh, fix the ordering of the phases so that splitting works again.
    • daan's avatar
      [project @ 2000-06-15 13:23:51 by daan] · 3d124552
      daan authored
      Added new primitives and bytecodes that support
      code generation for XMLambda. All additions are
      surrounded by #ifdef XMLAMBDA.
      Most important additions:
      - Rows (n-tuples) which are implemented on top of Frozen Mutarrays
      - Inj (variant sums), which is implemented using a new constructor
      called Inj which contains both the value and an unboxed int
      which represents the index.
    • daan's avatar
      [project @ 2000-06-15 13:18:08 by daan] · b619d74d
      daan authored
      Added definition of int64 to make it compilable with both gcc and VisualC++
      Added functions to the bytecode assembler that
      support code generation for Xmlambda. All additions for
      Xmlambda are surrounded by #ifdef XMLAMBDA.
    • daan's avatar
      [project @ 2000-06-15 13:16:16 by daan] · d188050a
      daan authored
      Added definition of int64 to make it compilable with both gcc and VisualC++
    • simonmar's avatar
      [project @ 2000-06-15 11:50:14 by simonmar] · 93c0c44f
      simonmar authored
      urk! the arity of a record selector Id didn't take into account any
      dictionary arguments due to the context on the datatype...
      (fixes bug on H/OpenGL reported by Sven)
    • sewardj's avatar
      [project @ 2000-06-15 11:17:41 by sewardj] · 0779a545
      sewardj authored
      Emit slightly better x86 floating point code for comparisons, +, -,
      * and /, in the common case where one of the source fake FP regs
      is the same as the destination reg.
    • rrt's avatar
      [project @ 2000-06-15 09:24:49 by rrt] · 8c0949c9
      rrt authored
      Fixed typo: .hs left out of .SUFFIXES list.
    • sewardj's avatar
      [project @ 2000-06-15 08:38:25 by sewardj] · 665229e5
      sewardj authored
      Major thing: new register allocator.  Brief description follows.
      Should correctly handle code with loops in, even though we don't
      generate any such at the moment.  A lot of comments.  The previous
      machinery for spilling is retained, as is the idea of a fast-and-easy
      initial allocation attempt intended to deal with the majority of code
      blocks (about 60% on x86) very cheaply.  Many comments explaining
      in detail how it works :-)
      The Stix inliner is now on by default.  Integer code seems to run
      within about 1% of that -fvia-C.  x86 fp code is significantly worse,
      up to about 30% slower, depending on the amount of fp activity.
      Minor thing: lazyfication of the top-level NCG plumbing, so that the
      NCG doesn't require any greater residency than compiling to C, just a
      bit more time.  Created lazyThenUs and lazyMapUs for this purpose.
      The new allocator is somewhat, although not catastophically, slower
      than the old one.  Fixing of the long-standing NCG space leak more
      than makes up for it; overall hsc run-time is down about 5%, due to
      significantly reduced GC time.
      Instructions are numbered sequentially, starting at zero.
      A flow edge (FE) is a pair of insn numbers (MkFE Int Int) denoting
      a possible flow of control from the first insn to the second.
      The input to the register allocator is a list of instructions, which
      mention Regs.  A Reg can be a RealReg -- a real machine reg -- or a
      VirtualReg, which carries a unique.  After allocation, all the
      VirtualReg references will have been converted into RealRegs, and
      possibly some spill code will have been inserted.
      The heart of the register allocator works in four phases.
      1.  (find_flow_edges) Calculate all the FEs for the code list.
          Return them not as a [FE], but implicitly, as a pair of
          Array Int [Int], being the successor and predecessor maps
          for instructions.
      2.  (calc_liveness) Returns a FiniteMap FE RegSet.  For each
          FE, indicates the set of registers live on that FE.  Note
          that the set includes both RealRegs and VirtualRegs.  The
          former appear because the code could mention fixed register
          usages, and we need to take them into account from the start.
      3.  (calc_live_range_sets) Invert the above mapping, giving a
          FiniteMap Reg FeSet, indicating, for each virtual and real
          reg mentioned in the code, which FEs it is live on.
      4.  (calc_vreg_to_rreg_mapping) For virtual reg, try and find
          an allocatable real register for it.  Each real register has
          a "current commitment", indicating the set of FEs it is
          currently live on.  A virtual reg v can be assigned to
          real reg r iff v's live-fe-set does not intersect with r's
          current commitment fe-set.  If the assignment is made,
          v's live-fe-set is union'd into r's current commitment fe-set.
          There is also the minor restriction that v and r must be of
          the same register class (integer or floating).
          Once this mapping is established, we simply apply it to the
          input insns, and that's it.
          If no suitable real register can be found, the vreg is mapped
          to itself, and we deem allocation to have failed.  The partially
          allocated code is returned.  The higher echelons of the allocator
          (doGeneralAlloc and runRegAlloc) then cooperate to insert spill
          code and re-run allocation, until a successful allocation is found.
  6. 14 Jun, 2000 13 commits
  7. 13 Jun, 2000 9 commits
    • simonmar's avatar
      [project @ 2000-06-13 16:10:00 by simonmar] · 0a423b55
      simonmar authored
      forgot one file
    • simonmar's avatar
      [project @ 2000-06-13 16:07:20 by simonmar] · 877aad48
      simonmar authored
      New Driver
      Most things work now, so I'm committing this for a shake down.
      Doubtless there'll be some breakage but things should be back to
      normal by the end of the week.
      NOTE: GHC 4.06 won't work to build this driver at the moment, due to a
      bug in its parser.  I'll commit a workaround shortly.
      There are several improvements here:
      	- the driver is written in Haskell, so is allegedly
      	  more maintainable than the previous one.  It's a bit shorter,
      	  at any rate.
      	- the package system has been generalised, so that eg.
      	  the RTS is a package, as is GMP and the prelude.  Packages
      	  are now configured via a configuration file, package.conf.
      	  Two versions of package.conf are automatically generated by
      	  PackageSrc.hs, one for ghc-inplace and one for the installed ghc.
      	- So that we only have to build the driver once, there's some
      	  special hackery to deal with locations of utilities, and
      	  other configuration stuff:
      	  ghc now has a -B option, which is used in a similar way
      	  to gcc's.  eg.
      		ghc -B/home/blah/fptools
      	  will run ghc in-place in the specified fptools tree, using
      	  /home/blah/fptools/ghc/utils/mkdependHS to find mkdependHS
      	  for example.  ghc-inplace is now a small shell script that
      	  simply invokes the above.  Whereas
      		ghc -B/usr/local/lib/ghc-4.07
      	  also works, for an installed copy of ghc in
      	- the mangler, object splitter and GC stats gatherer are separate
      	  scripts in subdirectories of ghc/driver.  ghc-asm.lprl and
      	  ghc-split.lprl have been copied in the CVS repository to maintain
      	  the history (fingers crossed; I've never done this before)
      Other notes:
      	- Java support isn't there yet.  Andy: don't update for the time
      	  being until I can sort this.
      	- Windows support is also broken, but will be fixed in due course.
    • sof's avatar
      [project @ 2000-06-13 15:35:29 by sof] · eab8ac17
      sof authored
      x86: Relativise register table offsets for Hp, R1, R2 and SpA
    • sof's avatar
      [project @ 2000-06-13 15:35:29 by sof] · 8da2e6d8
      sof authored
      x86: Catch fast entry points fallthroughs via %esi and %edi
    • sof's avatar
      [project @ 2000-06-13 15:35:29 by sof] · 56f7d139
      sof authored
      m68k-*-nextstep3 updates
    • sof's avatar
      [project @ 2000-06-13 15:35:29 by sof] · 64d3966d
      sof authored
      When doing -monly-x-regs, fix up entry and exit from PerformGC_wrapper
    • sof's avatar
      [project @ 2000-06-13 15:35:29 by sof] · 8ef57b89
      sof authored
      Tweaked __fexp regexps
    • sof's avatar
      [project @ 2000-06-13 15:35:29 by sof] · fe4c050b
      sof authored
      PPC updates
    • sof's avatar
      [project @ 2000-06-13 15:35:29 by sof] · 90840304
      sof authored
      On mingw32, which is the only 'platform' where we support producing
      DLLs, prefix each static closure with a zero word. This is needed so
      that we can distinguish between pointers to (reversed!) info tables
      and static closures just by checking whether there's a zero word just
      above the pointed-to entity. Wish there was a better way..