Skip to content
  1. Jan 20, 2014
    • Daniel Jasper's avatar
      clang-format: Properly format custom options in protocol buffer definitions. · 929b1db2
      Daniel Jasper authored
      Before:
        option(my_option) = "abc";
      
      After:
        option (my_option) = "abc";
      
      llvm-svn: 199672
      929b1db2
    • Aaron Ballman's avatar
      Formatting cleanups; no functional changes. · 3f5f3e79
      Aaron Ballman authored
      llvm-svn: 199671
      3f5f3e79
    • Rafael Espindola's avatar
      Add a triple. Should fix the 64 bit bots. · 4f5f0b78
      Rafael Espindola authored
      llvm-svn: 199670
      4f5f0b78
    • Rafael Espindola's avatar
      Make the test more strict. · a69024aa
      Rafael Espindola authored
      llvm-svn: 199669
      a69024aa
    • NAKAMURA Takumi's avatar
      Whitespace. · 6515aef0
      NAKAMURA Takumi authored
      llvm-svn: 199667
      6515aef0
    • Aaron Ballman's avatar
      Fixing a typo (turned out to be harmless since the default priority values are... · f28e4993
      Aaron Ballman authored
      Fixing a typo (turned out to be harmless since the default priority values are the same between the two attributes).
      
      llvm-svn: 199666
      f28e4993
    • Rafael Espindola's avatar
    • Aaron Ballman's avatar
      Since the diagnostics engine understands Attr objects, this code is no longer... · 05a63787
      Aaron Ballman authored
      Since the diagnostics engine understands Attr objects, this code is no longer required -- we can just pass in the attribute directly.
      
      llvm-svn: 199664
      05a63787
    • Aaron Ballman's avatar
      Making some minor improvements to r199626. · fc1951c5
      Aaron Ballman authored
      llvm-svn: 199663
      fc1951c5
    • Aaron Ballman's avatar
      HasFunctionProto is a more strict version of FunctionLike. Since attribute... · 9e013515
      Aaron Ballman authored
      HasFunctionProto is a more strict version of FunctionLike. Since attribute subjects are inclusive (passing a single subject test means no subject-related diagnostic will fire), these two subjects should not be combined.
      
      llvm-svn: 199662
      9e013515
    • Hal Finkel's avatar
      Fix misched-aa-colored.ll to require asserts (trying again) · 9ff54e1f
      Hal Finkel authored
      Perhaps it needs to be in caps.
      
      llvm-svn: 199661
      9ff54e1f
    • Daniel Jasper's avatar
      clang-format: Leave 2 empty lines in Google's JavaScript style. · a55544a6
      Daniel Jasper authored
      As per the style guide, two lines are required between top-level
      elements.
      
      llvm-svn: 199660
      a55544a6
    • Hal Finkel's avatar
      Fix misched-aa-colored.ll to require asserts. · a6bcadeb
      Hal Finkel authored
      -misched=shuffle is NDEBUG only. Maybe we should change that.
      
      llvm-svn: 199659
      a6bcadeb
    • Hal Finkel's avatar
      Update IR when merging slots in stack coloring · cd9569c1
      Hal Finkel authored
      The way that stack coloring updated MMOs when merging stack slots, while
      correct, is suboptimal, and is incompatible with the use of AA during
      instruction scheduling. The solution, which involves the use of const_cast (and
      more importantly, updating the IR from within an MI-level pass), obviously
      requires some explanation:
      
      When the stack coloring pass was originally committed, the code in
      ScheduleDAGInstrs::buildSchedGraph tracked possible alias sets by using
      GetUnderlyingObject, and all load/store and store/store memory control
      dependencies where added between SUs at the object level (where only one
      object, that returned by GetUnderlyingObject, was used to identify the object
      associated with each MMO). When stack coloring merged stack slots, it would
      replace MMOs derived from the remapped alloca with the alloca with which the
      remapped alloca was being replaced. Because ScheduleDAGInstrs only used single
      objects, and tracked alias sets at the object level, this was a fine solution.
      
      In r169744, (Andy and) I updated the code in ScheduleDAGInstrs to use
      GetUnderlyingObjects, and track alias sets using, potentially, multiple
      underlying objects for each MMO. This was done, primarily, to provide the
      ability to look through PHIs, and provide better scheduling for
      induction-variable-dependent loads and stores inside loops. At this point, the
      MMO-updating code in stack coloring became suboptimal, because it would clear
      the MMOs for (i.e. completely pessimize) all instructions for which r169744
      might help in scheduling. Updating the IR directly is the simplest fix for this
      (and the one with, by far, the least compile-time impact), but others are
      possible (we could give each MMO a small vector of potential values, or make
      use of a remapping table, constructed from MFI, inside ScheduleDAGInstrs).
      
      Unfortunately, replacing all MMO values derived from the remapped alloca with
      the base replacement alloca fundamentally breaks our ability to use AA during
      instruction scheduling (which is critical to performance on some targets). The
      reason is that the original MMO might have had an offset (either constant or
      dynamic) from the base remapped alloca, and that offset is not present in the
      updated MMO. One possible way around this would be to use
      GetPointerBaseWithConstantOffset, and update not only the MMO's value, but also
      its offset based on the original offset. Unfortunately, this solution would
      only handle constant offsets, and for safety (because AA is not completely
      restricted to deducing relationships with constant offsets), we would need to
      clear all MMOs without constant offsets over the entire function. This would be
      an even worse pessimization than the current single-object restriction. Any
      other solution would involve passing around a vector of remapped allocas, and
      teaching AA to use it, introducing additional complexity and overhead into AA.
      
      Instead, when remapping an alloca, we replace all IR uses of that alloca as
      well (optionally inserting a bitcast as necessary). This is even more efficient
      that the old MMO-updating code in the stack coloring pass (because it removes
      the need to call GetUnderlyingObject on all MMO values), removes the
      single-object pessimization in the default configuration, and enables the
      correct use of AA during instruction scheduling (all without any additional
      overhead).
      
      LLVM now no longer miscompiles itself on x86_64 when using -enable-misched
      -enable-aa-sched-mi -misched-bottomup=0 -misched-topdown=0 -misched=shuffle!
      Fixed PR18497.
      
      Because the alloca replacement is now done at the IR level, unless the MMO
      directly refers to the remapped alloca, the change cannot be seen at the MI
      level. As a result, there is no good way to fix test/CodeGen/X86/pr14090.ll.
      
      llvm-svn: 199658
      cd9569c1
    • Hal Finkel's avatar
      Track multiple stores per object when using AA in ScheduleDAGInstrs · a228a818
      Hal Finkel authored
      When using AA to break false chain dependencies, we need to track multiple
      stores per object in ScheduleDAGInstrs. Historically, we tracked potential alias
      chains at the object level, and so all loads of an object would retain
      dependencies on any store to that object. With AA, however, this is not
      sufficient: non-overlapping stores and loads to the same object all need to be
      tested for dependencies separately, we cannot only test all loads to an object
      against only the last store (see PR18497 for an explicit example).
      
      To mitigate any unwelcome compile-time impact when not using AA, only one store
      is kept in the list per object when not using AA.
      
      This, along with a stack coloring change to come shortly, will provide a test
      case, fix PR18497 (and allow LLVM to compile itself using -enable-aa-sched-mi
      on x86-64).
      
      llvm-svn: 199657
      a228a818
    • Evgeniy Stepanov's avatar
      [msandr] Access app TLS directly in native exec mode. · e98f9099
      Evgeniy Stepanov authored
      In optimized hybrid execution we do not use DynamoRIO private loader, which
      mangles TLS access, so we can access the application's TLS directly.
      
      Patch by Qin Zhao.
      
      llvm-svn: 199655
      e98f9099
    • David Woodhouse's avatar
      [x86] Fix disassembly of MOV16ao16 et al. · caaa2850
      David Woodhouse authored
      The addition of IC_OPSIZE_ADSIZE in r198759 wasn't quite complete. It
      also turns out to have been unnecessary. The disassembler handles the
      AdSize prefix for itself, and doesn't care about the difference between
      (e.g.) MOV8ao8 and MOB8ao8_16 definitions. So just let them coexist and
      don't worry about it.
      
      llvm-svn: 199654
      caaa2850
    • David Woodhouse's avatar
      [x86] Fix 16-bit disassembly of JCXZ/JECXZ · 9c74fdb8
      David Woodhouse authored
      llvm-svn: 199653
      9c74fdb8
    • David Woodhouse's avatar
      [x86] Rename MOVSD/STOSD/LODSD/OUTSD to MOVSL/STOSL/LODSL/OUTSL · 3442f342
      David Woodhouse authored
      The disassembler has a special case for 'L' vs. 'W' in its heuristic for
      checking for 32-bit and 16-bit equivalents. We could expand the heuristic,
      but better just to be consistent in using the 'L' suffix.
      
      llvm-svn: 199652
      3442f342
    • David Woodhouse's avatar
      [x86] Fix disassembly of callw instruction · 70ced3e0
      David Woodhouse authored
      Not quite sure why this was marked isAsmParserOnly, but it means that the
      disassembler can't see it either.
      
      llvm-svn: 199651
      70ced3e0
    • David Woodhouse's avatar
      [x86] Fix 16-bit handling of OpSize bit · 5cf4c675
      David Woodhouse authored
      When disassembling in 16-bit mode the meaning of the OpSize bit is
      inverted. Instructions found in the IC_OPSIZE context will actually
      *not* have the 0x66 prefix, and instructions in the IC context will
      have the 0x66 prefix. Make use of the existing special-case handling
      for the 0x66 prefix being in the wrong place, to cope with this.
      
      llvm-svn: 199650
      5cf4c675
    • David Woodhouse's avatar
      [x86] Infer disassembler mode from SubtargetInfo feature bits · 7dd21824
      David Woodhouse authored
      Aside from cleaning up the code, this also adds support for the -code16
      environment and actually enables the MODE_16BIT mode that was previously
      not accessible.
      
      There is no point adding any testing for 16-bit yet though; basically
      nothing will work because we aren't handling the OpSize prefix correctly
      for 16-bit mode.
      
      llvm-svn: 199649
      7dd21824
    • David Woodhouse's avatar
      [x86] Support i386-*-*-code16 triple for emitting 16-bit code · 71d15eda
      David Woodhouse authored
      llvm-svn: 199648
      71d15eda
    • Chandler Carruth's avatar
      [PM] Wire up the Verifier for the new pass manager and connect it to the · 4d35631a
      Chandler Carruth authored
      various opt verifier commandline options.
      
      Mostly mechanical wiring of the verifier to the new pass manager.
      Exercises one of the more unusual aspects of it -- a pass can be either
      a module or function pass interchangably. If this is ever problematic,
      we can make things more constrained, but for things like the verifier
      where there is an "obvious" applicability at both levels, it seems
      convenient.
      
      This is the next-to-last piece of basic functionality left to make the
      opt commandline driving of the new pass manager minimally functional for
      testing and further development. There is still a lot to be done there
      (notably the factoring into .def files to kill the current boilerplate
      code) but it is relatively uninteresting. The only interesting bit left
      for minimal functionality is supporting the registration of analyses.
      I'm planning on doing that on top of the .def file switch mostly because
      the boilerplate for the analyses would be significantly worse.
      
      llvm-svn: 199646
      4d35631a
    • Kai Nacke's avatar
      ARM: add tlsldo relocation · e51c8138
      Kai Nacke authored
      Add support for the symbol(tlsldo) relocation. This is required in order to 
      solve PR18554.
      
      Reviewed by R. Golin, A. Korobeynikov.
      
      llvm-svn: 199644
      e51c8138
    • Bradley Smith's avatar
      [ARM] Add ACLE enum/wchar size predefines · 0f28f0cf
      Bradley Smith authored
      llvm-svn: 199642
      0f28f0cf
    • NAKAMURA Takumi's avatar
      [CMake] Apply ADDITIONAL_HEADERS introduced in r199639. · bf6d1efb
      NAKAMURA Takumi authored
      llvm-svn: 199640
      bf6d1efb
    • NAKAMURA Takumi's avatar
      [CMake] llvm_process_sources: Introduce a parameter, ADDITIONAL_HEADERS. · 6acf320a
      NAKAMURA Takumi authored
      ADDITIONAL_HEADERS is intended to add header files for IDEs as hint.
      
      For example:
        add_llvm_library(LLVMSupport
          Host.cpp
          ADDITIONAL_HEADERS
            Unix/Host.inc
            Windows/Host.inc
          )
      
      llvm-svn: 199639
      6acf320a
    • Artyom Skrobov's avatar
      [ARM] Do not generate Tag_DIV_use=AllowDIVExt when hardware div is... · 10e76a4e
      Artyom Skrobov authored
      [ARM] Do not generate Tag_DIV_use=AllowDIVExt when hardware div is non-optional: it should have the default value of AllowDIVIfExists
      
      llvm-svn: 199638
      10e76a4e
    • Chandler Carruth's avatar
      Revert my commit in r199620 that added sections about namespaces to the · 36dc5191
      Chandler Carruth authored
      coding standards, and instead fix the existing section.
      
      Thanks to Daniel Jasper for pointing out we already had a section
      devoted to this topic. Instead of adding sections, just hack on this
      section some. Also fix the example in the anonymous namespace section
      below it to agree with the new advice.
      
      As a re-cap, this switches the LLVM preferred style to never indent
      namespaces. Having two approaches just led to endless (and utterly
      pointless) debates about what was "small enough". This wasn't helping
      anyone. The no-indent rule is easy to understand and doesn't really make
      anything harder to read. Moreover, with tools like clang-format it is
      considerably nicer to have simple consistent rules.
      
      llvm-svn: 199637
      36dc5191
    • Chandler Carruth's avatar
      Add the test trees that were supposed to be part of r199632. · 0cfd0e98
      Chandler Carruth authored
      llvm-svn: 199633
      0cfd0e98
    • Chandler Carruth's avatar
      Make the Linux support for finding libc++ somewhat less braindead. · 5a3d8987
      Chandler Carruth authored
      Now instead of just looking in the system root for it, we also look
      relative to the clang binary's directory. This should "just work" in
      almost all cases. I've added test cases accordingly.
      
      This is probably *very* worthwhile to backport to the 3.4 branch so that
      folks can check it out, build it, and use that as their host compiler
      going forward.
      
      llvm-svn: 199632
      5a3d8987
    • Chandler Carruth's avatar
      Revert r199628: "[AArch64 NEON] Fix a bug caused by undef lane when generating VEXT." · f835fc6f
      Chandler Carruth authored
      This test fails the newly added regression tests.
      
      llvm-svn: 199631
      f835fc6f
    • Chandler Carruth's avatar
      Fix a DenseMap iterator invalidation bug causing lots of crashes when · b587ab67
      Chandler Carruth authored
      type units were enabled. The crux of the issue is that the
      addDwarfTypeUnitType routine can end up being indirectly recursive. In
      this case, the reference into the dense map (TU) became invalid by the
      time we popped all the way back and used it to add the DIE type
      signature.
      
      Instead, use early return in the case where we can bypass the recursive
      step and creating a type unit. Then use the pointer to the new type unit
      to set up the DIE type signature in the case where we have to.
      
      I tried really hard to reduce a testcase for this, but it's really
      annoying. You have to get this to be mid-recursion when the densemap
      grows. Even if we got a test case for this today, it'd be very unlikely
      to continue exercising this pattern.
      
      llvm-svn: 199630
      b587ab67
    • Owen Anderson's avatar
      Fix all the remaining lost-fast-math-flags bugs I've been able to find. The... · 1664dc89
      Owen Anderson authored
      Fix all the remaining lost-fast-math-flags bugs I've been able to find.  The most important of these are cases in the generic logic for combining BinaryOperators.
      This logic hadn't been updated to handle FastMathFlags, and it took me a while to detect it because it doesn't show up in a simple search for CreateFAdd.
      
      llvm-svn: 199629
      1664dc89
    • Kevin Qin's avatar
      [AArch64 NEON] Fix a bug caused by undef lane when generating VEXT. · ff42e06e
      Kevin Qin authored
      llvm-svn: 199628
      ff42e06e
    • Alp Toker's avatar
      PR18551: accepts invalid strong enum to bool when operator! is used · c620cab8
      Alp Toker authored
      llvm-svn: 199627
      c620cab8
    • Ted Kremenek's avatar
      Wire up basic parser/sema support for attribute 'returns_nonnull'. · dbf62e3e
      Ted Kremenek authored
      This attribute is supported by GCC.  More generally it should
      probably be a type attribute, but this behavior matches 'nonnull'.
      
      This patch does not include warning logic for checking if a null
      value is returned from a function annotated with this attribute.
      That will come in subsequent patches.
      
      llvm-svn: 199626
      dbf62e3e
    • Ted Kremenek's avatar
      These attributes are no longer "checker-specific." · b5867121
      Ted Kremenek authored
      llvm-svn: 199625
      b5867121
    • Saleem Abdulrasool's avatar
      MC: whitespace · 4cbdbaf7
      Saleem Abdulrasool authored
      Remove hard tabs in favour of spaces.  NFC.
      
      llvm-svn: 199624
      4cbdbaf7
Loading