Skip to content
  1. Apr 01, 2015
  2. Mar 30, 2015
  3. Mar 26, 2015
  4. Mar 24, 2015
    • Michael Kuperstein's avatar
      Revert "Use std::bitset for SubtargetFeatures" · 29704e7f
      Michael Kuperstein authored
      This reverts commit r233055.
      
      It still causes buildbot failures (gcc running out of memory on several platforms, and a self-host failure on arm), although less than the previous time.
      
      llvm-svn: 233068
      29704e7f
    • Michael Kuperstein's avatar
      Use std::bitset for SubtargetFeatures · 774b441b
      Michael Kuperstein authored
      Previously, subtarget features were a bitfield with the underlying type being uint64_t. 
      Since several targets (X86 and ARM, in particular) have hit or were very close to hitting this bound, switching the features to use a bitset.
      No functional change.
      
      The first time this was committed (r229831), it caused several buildbot failures. 
      At least some of the ARM ones were due to gcc/binutils issues, and should now be fixed.
      
      Differential Revision: http://reviews.llvm.org/D8542
      
      llvm-svn: 233055
      774b441b
  5. Mar 17, 2015
    • Renato Golin's avatar
      [ARM] Add support for ARMV6K subtarget (LLVM) · 12350607
      Renato Golin authored
      ARMv6K is another layer between ARMV6 and ARMV6T2. This is the LLVM
      side of the changes.
      
      ARMV6 family LLVM implementation.
      
      +-------------------------------------+
      | ARMV6                               |
      +----------------+--------------------+
      | ARMV6M (thumb) | ARMV6K (arm,thumb) | <- From ARMV6K and ARMV6M processors
      +----------------+--------------------+    have support for hint instructions
      | ARMV6T2 (arm,thumb,thumb2)          |    (SEV/WFE/WFI/NOP/YIELD). They can
      +-------------------------------------+    be either real or default to NOP.
      | ARMV7 (arm,thumb,thumb2)            |    The two processors also use
      +-------------------------------------+    different encoding for them.
      
      Patch by Vinicius Tinti.
      
      llvm-svn: 232468
      12350607
  6. Feb 19, 2015
  7. Feb 14, 2015
    • Duncan P. N. Exon Smith's avatar
      ARM: Canonicalize access to function attributes, NFC · 2cff9e19
      Duncan P. N. Exon Smith authored
      Canonicalize access to function attributes to use the simpler API.
      
      getAttributes().getAttribute(AttributeSet::FunctionIndex, Kind)
        => getFnAttribute(Kind)
      
      getAttributes().hasAttribute(AttributeSet::FunctionIndex, Kind)
        => hasFnAttribute(Kind)
      
      llvm-svn: 229220
      2cff9e19
  8. Jan 29, 2015
  9. Jan 26, 2015
    • Eric Christopher's avatar
      Move DataLayout back to the TargetMachine from TargetSubtargetInfo · 8b770651
      Eric Christopher authored
      derived classes.
      
      Since global data alignment, layout, and mangling is often based on the
      DataLayout, move it to the TargetMachine. This ensures that global
      data is going to be layed out and mangled consistently if the subtarget
      changes on a per function basis. Prior to this all targets(*) have
      had subtarget dependent code moved out and onto the TargetMachine.
      
      *One target hasn't been migrated as part of this change: R600. The
      R600 port has, as a subtarget feature, the size of pointers and
      this affects global data layout. I've currently hacked in a FIXME
      to enable progress, but the port needs to be updated to either pass
      the 64-bitness to the TargetMachine, or fix the DataLayout to
      avoid subtarget dependent features.
      
      llvm-svn: 227113
      8b770651
  10. Jan 14, 2015
    • Chandler Carruth's avatar
      [cleanup] Re-sort all the #include lines in LLVM using · d9903888
      Chandler Carruth authored
      utils/sort_includes.py.
      
      I clearly haven't done this in a while, so more changed than usual. This
      even uncovered a missing include from the InstrProf library that I've
      added. No functionality changed here, just mechanical cleanup of the
      include order.
      
      llvm-svn: 225974
      d9903888
  11. Dec 18, 2014
    • Eric Christopher's avatar
      Add a new string member to the TargetOptions struct for the name · 661f2d1c
      Eric Christopher authored
      of the abi we should be using. For targets that don't use the
      option there's no change, otherwise this allows external users
      to set the ABI via string and avoid some of the -backend-option
      pain in clang.
      
      Use this option to move the ABI for the ARM port from the
      Subtarget to the TargetMachine and update the testcases
      accordingly since it's no longer valid to set via -mattr.
      
      llvm-svn: 224492
      661f2d1c
    • Eric Christopher's avatar
      Model ARM backend ABI selection after the front end code doing the · 1971c350
      Eric Christopher authored
      same. This will change the "bare metal" ABI from APCS to AAPCS.
      
      The only difference between the front and back end code is that
      the code for Triple::GNU was added for environment. That will migrate
      to the front end shortly.
      
      Tests updated with the ABI they were originally testing in the case
      of bare metal (e.g. -mtriple armv7) or with a -gnu for arm-linux
      triples.
      
      llvm-svn: 224489
      1971c350
  12. Dec 11, 2014
    • Tim Northover's avatar
      ARM: convert isTargetIOS checks to isTargetDarwin. · e2c33715
      Tim Northover authored
      The distinction is mostly useful in the front-end. By the time we get here,
      there are very few situations where we actually want different behaviour for
      Darwin and IOS (in fact Darwin mostly just exists in a few tests). So this
      should reduce any surprising weirdness for anyone using it.
      
      No functional change on anything anyone actually cares about.
      
      llvm-svn: 224035
      e2c33715
  13. Nov 01, 2014
    • Rafael Espindola's avatar
      Remove redundant calls to isMaterializable. · 246c4fb5
      Rafael Espindola authored
      This removes calls to isMaterializable in the following cases:
      
      * It was redundant with a call to isDeclaration now that isDeclaration returns
        the correct answer for materializable functions.
      * It was followed by a call to Materialize. Just call Materialize and check EC.
      
      llvm-svn: 221050
      246c4fb5
  14. Oct 15, 2014
    • Tim Northover's avatar
      ARM: drop check for triple that's no longer used. · e9ff4c29
      Tim Northover authored
      Early attempts to support AAPCS bare metal MachO targets based the decision on
      the CPU being compiled for. This was not a particularly great idea and we've
      got a better option now, but this check remained.
      
      No functional change for any target we care about.
      
      llvm-svn: 219767
      e9ff4c29
    • Tim Northover's avatar
      ARM: remove ARM/Thumb distinction for preferred alignment. · cf6ce0c8
      Tim Northover authored
      Thumb1 has legitimate reasons for preferring 32-bit alignment of types
      i1/i8/i16, since the 16-bit encoding of "add rD, sp, #imm" requires #imm to be
      a multiple of 4. However, this is a trade-off betweem code size and RAM usage;
      the DataLayout string is not the best place to represent it even if desired.
      
      So this patch removes the extra Thumb requirements, hopefully making ARM and
      Thumb completely compatible in this respect.
      
      llvm-svn: 219734
      cf6ce0c8
  15. Oct 14, 2014
    • Tim Northover's avatar
      ARM: set preferred aggregate alignment to 32 universally. · aa09ac6e
      Tim Northover authored
      Before, ARM and Thumb mode code had different preferred alignments, which could
      lead to some rather unexpected results. There's justification for reducing it
      from the default 64-bits (wasted space), but I don't think there is for going
      below 32-bits.
      
      There's no actual ABI change here, just to reassure people.
      
      llvm-svn: 219719
      aa09ac6e
  16. Oct 09, 2014
  17. Oct 08, 2014
  18. Oct 03, 2014
  19. Sep 17, 2014
    • Richard Trieu's avatar
      | -> || · 1fbe1a8b
      Richard Trieu authored
      No functional change.
      
      llvm-svn: 217934
      1fbe1a8b
  20. Sep 03, 2014
  21. Sep 02, 2014
  22. Aug 21, 2014
  23. Aug 19, 2014
  24. Aug 08, 2014
  25. 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
  26. Jul 16, 2014
    • Chris Bieneman's avatar
      [RegisterCoalescer] Moving the RegisterCoalescer subtarget hook onto the... · df4b763b
      Chris Bieneman authored
      [RegisterCoalescer] Moving the RegisterCoalescer subtarget hook onto the TargetRegisterInfo instead of the TargetSubtargetInfo.
      
      llvm-svn: 213188
      df4b763b
    • Chris Bieneman's avatar
      Added documentation for SizeMultiplier in the ARM subtarget hook for register... · 80a866a3
      Chris Bieneman authored
      Added documentation for SizeMultiplier in the ARM subtarget hook for register coalescing. Also fixed some 80 col violations.
      
      No functional code changes.
      
      llvm-svn: 213169
      80a866a3
    • Sanjay Patel's avatar
      Move Post RA Scheduling flag bit into SchedMachineModel · a2f658d6
      Sanjay Patel authored
      Refactoring; no functional changes intended
      
          Removed PostRAScheduler bits from subtargets (X86, ARM).
          Added PostRAScheduler bit to MCSchedModel class.
          This bit is set by a CPU's scheduling model (if it exists).
          Removed enablePostRAScheduler() function from TargetSubtargetInfo and subclasses.
          Fixed the existing enablePostMachineScheduler() method to use the MCSchedModel (was just returning false!).
          Added methods to TargetSubtargetInfo to allow overrides for AntiDepBreakMode, CriticalPathRCs, and OptLevel for PostRAScheduling.
          Added enablePostRAScheduler() function to PostRAScheduler class which queries the subtarget for the above values.
          Preserved existing scheduler behavior for ARM, MIPS, PPC, and X86: 
             a. ARM overrides the CPU's postRA settings by enabling postRA for any non-Thumb or Thumb2 subtarget. 
             b. MIPS overrides the CPU's postRA settings by enabling postRA for everything. 
             c. PPC overrides the CPU's postRA settings by enabling postRA for everything. 
             d. X86 is the only target that actually has postRA specified via sched model info.
      
      Differential Revision: http://reviews.llvm.org/D4217
      
      llvm-svn: 213101
      a2f658d6
  27. Jul 15, 2014
    • Chris Bieneman's avatar
      [RegisterCoalescer] Add new subtarget hook allowing targets to opt-out of coalescing. · 03695ab5
      Chris Bieneman authored
      The coalescer is very aggressive at propagating constraints on the register classes, and the register allocator doesn’t know how to split sub-registers later to recover. This patch provides an escape valve for targets that encounter this problem to limit coalescing.
      
      This patch also implements such for ARM to lower register pressure when using lots of large register classes. This works around PR18825.
      
      llvm-svn: 213078
      03695ab5
  28. Jul 04, 2014
    • Eric Christopher's avatar
      Move function dependent resetting of a subtarget variable out of the · c1058df6
      Eric Christopher authored
      subtarget. This involved having the movt predicate take the current
      function - since we care about size in instruction selection for
      whether or not to use movw/movt take the function so we can check
      the attributes. This required adding the current MachineFunction to
      FastISel and propagating through.
      
      llvm-svn: 212309
      c1058df6
  29. Jun 26, 2014
  30. Jun 19, 2014
Loading