1. 22 May, 2014 1 commit
    • Add Om1 lowering with no optimizations. · 5bc2b1d1
      Jim Stichnoth authored
      This adds infrastructure for low-level x86-32 instructions, and the target lowering patterns.
      
      Practically no optimizations are performed.  Optimizations to be introduced later include liveness analysis, dead-code elimination, global linear-scan register allocation, linear-scan based stack slot coalescing, and compare/branch fusing.  One optimization that is present is simple coalescing of stack slots for variables that are only live within a single basic block.
      
      There are also some fairly comprehensive cross tests.  This testing infrastructure translates bitcode using both Subzero and llc, and a testing harness calls both versions with a variety of "interesting" inputs and compares the results.  Specifically, Arithmetic, Icmp, Fcmp, and Cast instructions are tested this way, across all PNaCl primitive types.
      
      BUG=
      R=jvoung@chromium.org
      
      Review URL: https://codereview.chromium.org/265703002
  2. 19 May, 2014 1 commit
  3. 29 Apr, 2014 1 commit
    • Initial skeleton of Subzero. · f7c9a141
      Jim Stichnoth authored
      This includes just enough code to build the high-level ICE IR and dump it back out again.  There is a script szdiff.py that does a fuzzy diff of the input and output for verification.  See the comment in szdiff.py for a description of the fuzziness.
      
      Building llvm2ice requires LLVM headers, libs, and tools (e.g. FileCheck) to be present.  These default to something like llvm_i686_linux_work/Release+Asserts/ based on the checked-out and built pnacl-llvm code; I'll try to figure out how to more automatically detect the build configuration.
      
      "make check" runs the lit tests.
      
      This CL has under 2000 lines of "interesting" Ice*.{h,cpp} code, plus 600 lines of llvm2ice.cpp driver code, and the rest is tests.
      
      Here is the high-level mapping of source files to functionality:
      
      IceDefs.h, IceTypes.h, IceTypes.cpp:
      Commonly used types and utilities.
      
      IceCfg.h, IceCfg.cpp:
      Operations at the function level.
      
      IceCfgNode.h, IceCfgNode.cpp:
      Operations on basic blocks (nodes).
      
      IceInst.h, IceInst.cpp:
      Operations on instructions.
      
      IceOperand.h, IceOperand.cpp:
      Operations on operands, such as stack locations, physical registers, and constants.
      
      BUG= none
      R=jfb@chromium.org
      
      Review URL: https://codereview.chromium.org/205613002
  4. 19 Mar, 2014 2 commits