Skip to content
  1. Jan 20, 2014
    • 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
    • Ed Maste's avatar
      Relax alias test for failing command · e108405a
      Ed Maste authored
      The alias test "exprf x 1234" expands to "expr -f x 1234" and is
      expected to fail: it ends up trying to evaluate the invalid expression
      
          void
          $__lldb_expr(void *$__lldb_arg)
          {
              -f x 1234;
          }
      
      On FreeBSD LLDB ends up finding a static function f() in a math library,
      and thus the error produced does not include "use of undeclared
      identifier 'f'".
      
      We will report failure to parse the expression in any case, so require
      only that error message.
      
      llvm-svn: 199623
      e108405a
    • Chandler Carruth's avatar
      [PM] Fix a contradiction in the comments noticed by Anders. · 81fdde5d
      Chandler Carruth authored
      Have I mentioned that functions returning true on error and false on
      success are confusing? They're more confusing when their name is
      "verify". Anyways...
      
      llvm-svn: 199622
      81fdde5d
    • Kevin Qin's avatar
      [AArch64 NEON] Accept both #0.0 and #0 for comparing with floating point zero in asm parser. · ef66ff78
      Kevin Qin authored
      For FCMEQ, FCMGE, FCMGT, FCMLE and FCMLT, floating point zero will be
      printed as #0.0 instead of #0. To support the history codes using #0,
      we consider to let asm parser accept both #0.0 and #0.
      
      llvm-svn: 199621
      ef66ff78
    • Chandler Carruth's avatar
      Add some wording to the coding standards to say how to indent namespaces · 8660df47
      Chandler Carruth authored
      (and to mention namespace ending comments). This is based on a quick
      discussion on the developer mailing list where there was essentially no
      objections to a simple and consistent rule. This should avoid future
      debates about whether or not a namespace is "big enough" to indent. It
      also matches clang-format's current behavior with LLVM source code which
      hasn't really seen any opposition in code reviews that I spot checked.
      
      llvm-svn: 199620
      8660df47
    • Alp Toker's avatar
      MSVC 2013 type trait support · 73287bfe
      Alp Toker authored
      Implement type trait primitives used in the latest edition of the Microsoft
      standard C++ library type_traits header.
      
      With this change we can parse much of the Visual Studio 2013 standard headers,
      particularly anything that includes <type_traits>.
      
      Fully implemented, available in all language modes:
      
       * __is_constructible()
       * __is_nothrow_constructible()
       * __is_nothrow_assignable()
      
      Partially implemented, semantic analysis WIP, available as MS extensions:
      
       * __is_destructible()
       * __is_nothrow_destructible()
      
      llvm-svn: 199619
      73287bfe
    • Alp Toker's avatar
      Fix nothrow trait with multiple default constructors · b4bca414
      Alp Toker authored
      Check all default ctors, not just the first one we see. This brings
      __has_nothrow_constructor() in line with the other unary type traits.
      
      A C++ class can have multiple default constructors but clang was only checking
      the first one written, presumably due to ambiguity in the GNU specification.
      
      MSVC has the same bug, while g++ has the correct implementation which we now
      match.
      
      llvm-svn: 199618
      b4bca414
    • Richard Smith's avatar
      PR18544: don't assert that 'operator new' is not declared inside a namespace; · f600441a
      Richard Smith authored
      such an assert will fail in invalid code that does so!
      
      llvm-svn: 199617
      f600441a
  2. Jan 19, 2014
Loading