Skip to content
  1. Jan 17, 2016
  2. Jan 15, 2016
  3. Jan 11, 2016
  4. Dec 18, 2015
    • Rafael Espindola's avatar
      Drop materializeAllPermanently. · c4a03483
      Rafael Espindola authored
      This inlines materializeAll into the only caller
      (materializeAllPermanently) and renames materializeAllPermanently to
      just materializeAll.
      
      llvm-svn: 256024
      c4a03483
  5. Jul 15, 2015
  6. Jun 09, 2015
  7. May 12, 2015
    • Eric Christopher's avatar
      Migrate existing backends that care about software floating point · 824f42f2
      Eric Christopher authored
      to use the information in the module rather than TargetOptions.
      
      We've had and clang has used the use-soft-float attribute for some
      time now so have the backends set a subtarget feature based on
      a particular function now that subtargets are created based on
      functions and function attributes.
      
      For the one middle end soft float check go ahead and create
      an overloadable TargetLowering::useSoftFloat function that
      just checks the TargetSubtargetInfo in all cases.
      
      Also remove the command line option that hard codes whether or
      not soft-float is set by using the attribute for all of the
      target specific test cases - for the generic just go ahead and
      add the attribute in the one case that showed up.
      
      llvm-svn: 237079
      824f42f2
  8. Apr 19, 2015
  9. Apr 11, 2015
  10. Mar 25, 2015
    • Lang Hames's avatar
      [Orc][lli] Add a very simple Orc-based lazy JIT to lli. · 9528bbaa
      Lang Hames authored
      This ensures that we're building and testing the CompileOnDemand layer, at least
      in a basic way.
      
      Currently x86-64 only, and with limited to no library calls enabled (depending
      on host platform). Patches welcome. ;)
      
      To enable access to the lazy JIT, this patch replaces the '-use-orcmcjit' lli
      option with a new option:
      '-jit-kind={ mcjit | orc-mcjit | orc-lazy }'.
      
      All regression tests are updated to use the new option, and one trivial test of
      the new lazy JIT is added.
      
      llvm-svn: 233182
      9528bbaa
  11. Mar 23, 2015
  12. Feb 26, 2015
  13. Jan 23, 2015
    • Lang Hames's avatar
      [Orc] New JIT APIs. · 93de2a12
      Lang Hames authored
      This patch adds a new set of JIT APIs to LLVM. The aim of these new APIs is to
      cleanly support a wider range of JIT use cases in LLVM, and encourage the
      development and contribution of re-usable infrastructure for LLVM JIT use-cases.
      
      These APIs are intended to live alongside the MCJIT APIs, and should not affect
      existing clients.
      
      Included in this patch:
      
      1) New headers in include/llvm/ExecutionEngine/Orc that provide a set of
         components for building JIT infrastructure.
         Implementation code for these headers lives in lib/ExecutionEngine/Orc.
      
      2) A prototype re-implementation of MCJIT (OrcMCJITReplacement) built out of the
         new components.
      
      3) Minor changes to RTDyldMemoryManager needed to support the new components.
         These changes should not impact existing clients.
      
      4) A new flag for lli, -use-orcmcjit, which will cause lli to use the
         OrcMCJITReplacement class as its underlying execution engine, rather than
         MCJIT itself.
      
      Tests to follow shortly.
      
      Special thanks to Michael Ilseman, Pete Cooper, David Blaikie, Eric Christopher,
      Justin Bogner, and Jim Grosbach for extensive feedback and discussion.
      
      llvm-svn: 226940
      93de2a12
  14. Jan 22, 2015
    • Chris Bieneman's avatar
      Assigning and copying command line option objects shouldn't be allowed. · e71fb5ce
      Chris Bieneman authored
      Summary:
      The default copy and assignment operators for these objects probably don't actually do what the clients intend, so they should be deleted.
      
      Places using the assignment operator to set the value of an option should cast to the option's data type first to call into the override for operator=. Places using the copy constructor just need to be changed to not copy (i.e. passing by const reference instead of value).
      
      Reviewers: dexonsmith, chandlerc
      
      Subscribers: llvm-commits
      
      Differential Revision: http://reviews.llvm.org/D7114
      
      llvm-svn: 226762
      e71fb5ce
  15. Dec 03, 2014
  16. Nov 29, 2014
  17. Sep 23, 2014
  18. Sep 03, 2014
  19. Aug 27, 2014
  20. Aug 26, 2014
  21. Aug 25, 2014
    • Rafael Espindola's avatar
      Modernize raw_fd_ostream's constructor a bit. · 3fd1e993
      Rafael Espindola authored
      Take a StringRef instead of a "const char *".
      Take a "std::error_code &" instead of a "std::string &" for error.
      
      A create static method would be even better, but this patch is already a bit too
      big.
      
      llvm-svn: 216393
      3fd1e993
  22. Aug 20, 2014
  23. Aug 19, 2014
    • Rafael Espindola's avatar
      Don't own the buffer in object::Binary. · 48af1c2a
      Rafael Espindola authored
      Owning the buffer is somewhat inflexible. Some Binaries have sub Binaries
      (like Archive) and we had to create dummy buffers just to handle that. It is
      also a bad fit for IRObjectFile where the Module wants to own the buffer too.
      
      Keeping this ownership would make supporting IR inside native objects
      particularly painful.
      
      This patch focuses in lib/Object. If something elsewhere used to own an Binary,
      now it also owns a MemoryBuffer.
      
      This patch introduces a few new types.
      
      * MemoryBufferRef. This is just a pair of StringRefs for the data and name.
        This is to MemoryBuffer as StringRef is to std::string.
      * OwningBinary. A combination of Binary and a MemoryBuffer. This is needed
        for convenience functions that take a filename and return both the
        buffer and the Binary using that buffer.
      
      The C api now uses OwningBinary to avoid any change in semantics. I will start
      a new thread to see if we want to change it and how.
      
      llvm-svn: 216002
      48af1c2a
    • Rafael Espindola's avatar
      2a8a2795
  24. Aug 13, 2014
  25. Aug 08, 2014
  26. Aug 07, 2014
    • Rafael Espindola's avatar
      Nuke the old JIT. · f8b27c41
      Rafael Espindola authored
      I am sure we will be finding bits and pieces of dead code for years to
      come, but this is a good start.
      
      Thanks to Lang Hames for making MCJIT a good replacement!
      
      llvm-svn: 215111
      f8b27c41
  27. Aug 01, 2014
  28. Jul 31, 2014
  29. Jul 06, 2014
  30. Jun 24, 2014
  31. Jun 13, 2014
  32. Jun 12, 2014
  33. Apr 29, 2014
    • David Blaikie's avatar
      PR19553: Memory leak in RuntimeDyldELF::createObjectImageFromFile · 7a1e775a
      David Blaikie authored
      This starts in MCJIT::getSymbolAddress where the
      unique_ptr<object::Binary> is release()d and (after a cast) passed to a
      single caller, MCJIT::addObjectFile.
      
      addObjectFile calls RuntimeDyld::loadObject.
      RuntimeDld::loadObject calls RuntimeDyldELF::createObjectFromFile
      
      And the pointer is never owned at this point. I say this point, because
      the alternative codepath, RuntimeDyldMachO::createObjectFile certainly
      does take ownership, so this seemed like a good hint that this was a/the
      right place to take ownership.
      
      llvm-svn: 207580
      7a1e775a
  34. Apr 25, 2014
  35. Apr 22, 2014
Loading