Skip to content
  1. Jul 14, 2015
  2. Jul 13, 2015
    • NAKAMURA Takumi's avatar
      clang/test/Driver/cuda-options.cu REQUIRES clang-driver, at least. · 7227a88f
      NAKAMURA Takumi authored
      llvm-svn: 242067
      7227a88f
    • Artem Belevich's avatar
      Fixed regex to properly match '64' in the test case. · e9a400e0
      Artem Belevich authored
      llvm-svn: 242065
      e9a400e0
    • Artem Belevich's avatar
      [cuda] Driver changes to compile and stitch together host and device-side CUDA code. · cd42e7f7
      Artem Belevich authored
        - Changed driver pipeline to compile host and device side of CUDA
          files and incorporate results of device-side compilation into host
          object file.
      
        - Added a test for cuda pipeline creation in clang driver.
      
        New clang options:
        --cuda-host-only   - Do host-side compilation only.
        --cuda-device-only - Do device-side compilation only.
      
        --cuda-gpu-arch=<ARCH> - specify GPU architecture for device-side
          compilation. E.g. sm_35, sm_30. Default is sm_20. May be used more
          than once in which case one device-compilation will be done per
          unique specified GPU architecture.
      
        Differential Revision: http://reviews.llvm.org/D9509
      
      llvm-svn: 242058
      cd42e7f7
    • Ben Langmuir's avatar
      [Modules] Allow missing header before a missing requirement · 75a7e435
      Ben Langmuir authored
      And make the module unavailable without breaking any parent modules.
      
      If there's a missing requirement after we've already seen a missing
      header, still update the IsMissingRequiement bit correctly.  Also,
      diagnose missing requirements before missing headers, since the
      existence of the header is moot if there are missing requirements.
      
      llvm-svn: 242055
      75a7e435
    • Ulrich Weigand's avatar
      Support alternate attribute spelling __enable_if__ · ef5aa29e
      Ulrich Weigand authored
      Attribute names usually support an alternate spelling that uses double
      underscores before and after the attribute name, like e.g. attribute
      ((__aligned__)) for attribute ((aligned)). This is necessary to allow
      use of attributes in system headers without polluting the name space.
      
      However, for attribute ((enable_if)) that alternate spelling does not
      work correctly. This is because of code in Parser::ParseGNUAttributeArgs
      (ParseDecl.cpp) that specifically checks for the "enable_if" spelling
      without allowing the alternate spelling.
      
      Similar code in ParseDecl.cpp uses the normalizeAttrName helper to allow
      both spellings. This patch adds use of that helper for the "enable_if"
      check as well, which fixes attribute ((__enable_if__)).
      
      Differential Revision: http://reviews.llvm.org/D11142
      
      llvm-svn: 242029
      ef5aa29e
    • Rafael Espindola's avatar
      Set the linkage before setting the visibility. · d6e66945
      Rafael Espindola authored
      Otherwise the visibility setting code would not know that a given
      function was available_externally.
      
      Fixes PR24097.
      
      llvm-svn: 242012
      d6e66945
    • Davide Italiano's avatar
      [Sema] If lvalue to rvalue reference cast is valid don't emit diagnostic. · a2275910
      Davide Italiano authored
      In the test, y1 is not reference compatible to y2 and we currently assume
      the cast is ill-formed so we emit a diagnostic. Instead, in order to honour
      the standard, if y1 it's not reference-compatible to y2 then it can't be
      converted using a static_cast, and a reinterpret_cast should be tried instead.
      Richard Smith provided the correct interpretation of the standard and
      explanation about the subtle difference between "can't be cast" and "the cast
      is ill-formed". The former applies in this case.
      
      PR:		23802
      llvm-svn: 241998
      a2275910
  3. Jul 11, 2015
    • Richard Smith's avatar
      [modules] When checking the include guard for a header, check whether it's · e70dadd6
      Richard Smith authored
      visible in the module we're considering entering. Previously we assumed that if
      we knew the include guard for a modular header, we'd already parsed it, but
      that need not be the case if a header is present in the current module and one
      of its dependencies; the result of getting this wrong was that the current
      module's submodule for the header would end up empty.
      
      llvm-svn: 241953
      e70dadd6
    • Reid Kleckner's avatar
      Disable C++ EH by default for clang-cl and MSVC environments · 0bb1fc41
      Reid Kleckner authored
      We don't need any more bug reports from users telling us that MSVC-style
      C++ exceptions are broken. Developers and adventurous users can still
      test the existing functionality by passing along -fexceptions to either
      clang or clang-cl.
      
      llvm-svn: 241952
      0bb1fc41
  4. Jul 10, 2015
    • Jordan Rose's avatar
      [analyzer] When forced to fake a block type, do it correctly. · 9503501d
      Jordan Rose authored
      BlockDecl has a poor AST representation because it doesn't carry its type
      with it. Instead, the containing BlockExpr has the full type. This almost
      never matters for the analyzer, but if the block decl contains static
      local variables we need to synthesize a region to put them in, and this
      region will necessarily not have the right type.
      
      Even /that/ doesn't matter, unless
      
      (1) the block calls the function or method containing the block, and
      (2) the value of the block expr is used in some interesting way.
      
      In this case, we actually end up needing the type of the block region,
      and it will be set to our synthesized type. It turns out we've been doing
      a terrible job faking that type -- it wasn't a block pointer type at all.
      This commit fixes that to at least guarantee a block pointer type, using
      the signature written by the user if there is one.
      
      This is not really a correct answer because the block region's type will
      /still/ be wrong, but further efforts to make this right in the analyzer
      would probably be silly. We should just change the AST.
      
      rdar://problem/21698099
      
      llvm-svn: 241944
      9503501d
    • David Majnemer's avatar
      [MS ABI] Don't generates code for unreferenced inline definitions of library builtins · c0c42f3d
      David Majnemer authored
      We should only consider declarations which were written, implicit
      declarations shouldn't be considered.
      
      This fixes PR24084.
      
      llvm-svn: 241941
      c0c42f3d
    • Richard Smith's avatar
      [modules] Fix "prefer own module over others" rule when selecting a module for... · 8692a4d1
      Richard Smith authored
      [modules] Fix "prefer own module over others" rule when selecting a module for a header to work in the presence of module hierarchy.
      
      llvm-svn: 241936
      8692a4d1
    • Evgeniy Stepanov's avatar
      Add an experimental flag -fsanitize-memory-use-after-dtor. · 45be9e0d
      Evgeniy Stepanov authored
      This flag will enable detection of use-after-destructor (but before
      memory deallocation) bugs. No actual functionality yet.
      
      https://code.google.com/p/address-sanitizer/issues/detail?id=73
      
      Patch by Naomi Musgrave.
      
      llvm-svn: 241935
      45be9e0d
    • Akira Hatanaka's avatar
      [inlineasm] Attach readonly and readnone to inline-asm instructions. · 10bdb2b1
      Akira Hatanaka authored
      Previously, clang/llvm treated inline-asm instructions conservatively,
      choosing not to eliminate the instructions or hoisting them out of a loop
      even when it was safe to do so. This commit makes changes to attach a
      readonly or readnone attribute to an inline-asm instruction, which enables
      passes such as LICM and EarlyCSE to move or optimize away the instruction.
      
      rdar://problem/11358192
      
      Differential Revision: http://reviews.llvm.org/D10546
      
      llvm-svn: 241930
      10bdb2b1
    • Eric Christopher's avatar
      Refactor PPC ABI handling to accept and silently ignore -mabi=altivec. · 71e5e3de
      Eric Christopher authored
      All of the ABIs we support are altivec style anyhow and so the option
      doesn't make much sense with the modern ABIs. We could make this a more
      noisy ignore, but it would break builds for projects that just pass
      it along by default because of historical reasons.
      
      llvm-svn: 241925
      71e5e3de
    • Ulrich Weigand's avatar
      Respect alignment of nested bitfields · 03ce2a16
      Ulrich Weigand authored
      tools/clang/test/CodeGen/packed-nest-unpacked.c contains this test:
      
      struct XBitfield {
        unsigned b1 : 10;
        unsigned b2 : 12;
        unsigned b3 : 10;
      };
      struct YBitfield {
        char x;
        struct XBitfield y;
      } __attribute((packed));
      struct YBitfield gbitfield;
      
      unsigned test7() {
        // CHECK: @test7
        // CHECK: load i32, i32* getelementptr inbounds (%struct.YBitfield, %struct.YBitfield* @gbitfield, i32 0, i32 1, i32 0), align 4
        return gbitfield.y.b2;
      }
      
      The "align 4" is actually wrong.  Accessing all of "gbitfield.y" as a single
      i32 is of course possible, but that still doesn't make it 4-byte aligned as
      it remains packed at offset 1 in the surrounding gbitfield object.
      
      This alignment was changed by commit r169489, which also introduced changes
      to bitfield access code in CGExpr.cpp.  Code before that change used to take
      into account *both* the alignment of the field to be accessed within the
      current struct, *and* the alignment of that outer struct itself; this logic
      was removed by the above commit.
      
      Neglecting to consider both values can cause incorrect code to be generated
      (I've seen an unaligned access crash on SystemZ due to this bug).
      
      In order to always use the best known alignment value, this patch removes
      the CGBitFieldInfo::StorageAlignment member and replaces it with a
      StorageOffset member specifying the offset from the start of the surrounding
      struct to the bitfield's underlying storage.  This offset can then be combined
      with the best-known alignment for a bitfield access lvalue to determine the
      alignment to use when accessing the bitfield's storage.
      
      Differential Revision: http://reviews.llvm.org/D11034
      
      llvm-svn: 241916
      03ce2a16
    • Nemanja Ivanovic's avatar
      672a1476
    • Nemanja Ivanovic's avatar
      Add missing builtins to altivec.h for ABI compliance (vol. 3) · 26c3534b
      Nemanja Ivanovic authored
      This patch corresponds to review:
      http://reviews.llvm.org/D10972
      
      Fix for the handling of dependent features that are enabled by default
      on some CPU's (such as -mvsx, -mpower8-vector).
      
      Also provides a number of new interfaces or fixes existing ones in
      altivec.h.
      
      Changed signatures to conform to ABI:
      vector short vec_perm(vector signed short, vector signed short, vector unsigned char)
      vector int vec_perm(vector signed int, vector signed int, vector unsigned char)
      vector long long vec_perm(vector signed long long, vector signed long long, vector unsigned char)
      vector signed char vec_sld(vector signed char, vector signed char, const int)
      vector unsigned char vec_sld(vector unsigned char, vector unsigned char, const int)
      vector bool char vec_sld(vector bool char, vector bool char, const int)
      vector unsigned short vec_sld(vector unsigned short, vector unsigned short, const int)
      vector signed short vec_sld(vector signed short, vector signed short, const int)
      vector signed int vec_sld(vector signed int, vector signed int, const int)
      vector unsigned int vec_sld(vector unsigned int, vector unsigned int, const int)
      vector float vec_sld(vector float, vector float, const int)
      vector signed char vec_splat(vector signed char, const int)
      vector unsigned char vec_splat(vector unsigned char, const int)
      vector bool char vec_splat(vector bool char, const int)
      vector signed short vec_splat(vector signed short, const int)
      vector unsigned short vec_splat(vector unsigned short, const int)
      vector bool short vec_splat(vector bool short, const int)
      vector pixel vec_splat(vector pixel, const int)
      vector signed int vec_splat(vector signed int, const int)
      vector unsigned int vec_splat(vector unsigned int, const int)
      vector bool int vec_splat(vector bool int, const int)
      vector float vec_splat(vector float, const int)
      
      Added a VSX path to:
      vector float vec_round(vector float)
      
      Added interfaces:
      vector signed char vec_eqv(vector signed char, vector signed char)
      vector signed char vec_eqv(vector bool char, vector signed char)
      vector signed char vec_eqv(vector signed char, vector bool char)
      vector unsigned char vec_eqv(vector unsigned char, vector unsigned char)
      vector unsigned char vec_eqv(vector bool char, vector unsigned char)
      vector unsigned char vec_eqv(vector unsigned char, vector bool char)
      vector signed short vec_eqv(vector signed short, vector signed short)
      vector signed short vec_eqv(vector bool short, vector signed short)
      vector signed short vec_eqv(vector signed short, vector bool short)
      vector unsigned short vec_eqv(vector unsigned short, vector unsigned short)
      vector unsigned short vec_eqv(vector bool short, vector unsigned short)
      vector unsigned short vec_eqv(vector unsigned short, vector bool short)
      vector signed int vec_eqv(vector signed int, vector signed int)
      vector signed int vec_eqv(vector bool int, vector signed int)
      vector signed int vec_eqv(vector signed int, vector bool int)
      vector unsigned int vec_eqv(vector unsigned int, vector unsigned int)
      vector unsigned int vec_eqv(vector bool int, vector unsigned int)
      vector unsigned int vec_eqv(vector unsigned int, vector bool int)
      vector signed long long vec_eqv(vector signed long long, vector signed long long)
      vector signed long long vec_eqv(vector bool long long, vector signed long long)
      vector signed long long vec_eqv(vector signed long long, vector bool long long)
      vector unsigned long long vec_eqv(vector unsigned long long, vector unsigned long long)
      vector unsigned long long vec_eqv(vector bool long long, vector unsigned long long)
      vector unsigned long long vec_eqv(vector unsigned long long, vector bool long long)
      vector float vec_eqv(vector float, vector float)
      vector float vec_eqv(vector bool int, vector float)
      vector float vec_eqv(vector float, vector bool int)
      vector double vec_eqv(vector double, vector double)
      vector double vec_eqv(vector bool long long, vector double)
      vector double vec_eqv(vector double, vector bool long long)
      vector bool long long vec_perm(vector bool long long, vector bool long long, vector unsigned char)
      vector double vec_round(vector double)
      vector double vec_splat(vector double, const int)
      vector bool long long vec_splat(vector bool long long, const int)
      vector signed long long vec_splat(vector signed long long, const int)
      vector unsigned long long vec_splat(vector unsigned long long,
      vector bool int vec_sld(vector bool int, vector bool int, const int)
      vector bool short vec_sld(vector bool short, vector bool short, const int)
      
      llvm-svn: 241904
      26c3534b
    • NAKAMURA Takumi's avatar
      ddb44b85
    • Benjamin Kramer's avatar
      0429b7ae
    • Benjamin Kramer's avatar
      Reapply test for r241811 with a fix for msvc compat mode. · 3cfdf204
      Benjamin Kramer authored
      Delayed template parsing interferes with code completion, just distable it for
      this test. This reverts r241811.
      
      llvm-svn: 241899
      3cfdf204
    • Ulrich Weigand's avatar
      Respect alignment when loading up a coerced function argument · 6e2cea6f
      Ulrich Weigand authored
      Code in CGCall.cpp that loads up function arguments that need to be
      coerced to a different type may in some cases ignore the fact that
      the source of the argument is not naturally aligned. This may cause
      incorrect code to be generated. In some places in CreateCoercedLoad,
      we already have setAlignment calls to address this, but I ran into one
      where it was missing, causing wrong code generation on SystemZ.
      
      However, in that location, we do not actually know what alignment of
      the source location we can rely on; the callers do not pass anything
      to this routine. This is already an issue in other places in
      CreateCoercedLoad; and the same problem exists for CreateCoercedStore.
      
      To avoid pessimising code, and to fix the FIXMEs already in place,
      this patch also adds an alignment argument to the CreateCoerced*
      routines and uses it instead of forcing an alignment of 1. The
      callers are changed to pass in the best information they have.
      
      This actually requires changes in a number of existing test cases
      since we now get better alignment in many places.
      
      Differential Revision: http://reviews.llvm.org/D11033
      
      llvm-svn: 241898
      6e2cea6f
    • Daniel Jasper's avatar
      Remove test that tests referring to the current working directory. You · 7dc6b500
      Daniel Jasper authored
      cannot assume that the current working directory is writable in all test
      environments. I don't know a better way to write this test of hand, lets
      discuss. Possibly, a better option would be to put these together with
      other test testing the driver directly.
      
      llvm-svn: 241885
      7dc6b500
    • NAKAMURA Takumi's avatar
      Revert test lines added in r241811, "[CodeCompletion] Don't crash on member... · 0de292f5
      NAKAMURA Takumi authored
      Revert test lines added in r241811, "[CodeCompletion] Don't crash on member inits of templated constructors.", for now.
      
      It doesn't pass for targeting MS mode.
      
      llvm-svn: 241882
      0de292f5
    • Reid Kleckner's avatar
      Re-enable 32-bit SEH after the alignment fix · 8819a406
      Reid Kleckner authored
      llvm-svn: 241878
      8819a406
  5. Jul 09, 2015
Loading