Skip to content
  1. Sep 14, 2018
  2. Sep 13, 2018
    • Jim Ingham's avatar
      svn add the new files... · e19adf54
      Jim Ingham authored
      I started from a clean slate to do the checkin, but forgot to svn add the new files.
      Do that now.
      
      Also add the one new source file to CMakeLists.txt
      
      llvm-svn: 342190
      e19adf54
    • Tim Renouf's avatar
      [AMDGPU] Removed unused method · c8af6a46
      Tim Renouf authored
      Summary:
      I accidentally left this behind in D50306, and it causes a build warning
      when I build with gcc7.
      
      Subscribers: arsenm, kzhuravl, jvesely, wdng, nhaehnle, yaxunl, dstuttard, t-tye, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D52022
      
      Change-Id: I30f7a47047e9d9d841f652da66d2fea19e74842c
      llvm-svn: 342189
      c8af6a46
    • Jim Ingham's avatar
      Remember to sort the Xcode project file. NFC. · 2e947040
      Jim Ingham authored
      llvm-svn: 342188
      2e947040
    • Matt Morehouse's avatar
      [SanitizerCoverage] Create comdat for global arrays. · 3bea25e5
      Matt Morehouse authored
      Summary:
      Place global arrays in comdat sections with their associated functions.
      This makes sure they are stripped along with the functions they
      reference, even on the BFD linker.
      
      Reviewers: eugenis
      
      Reviewed By: eugenis
      
      Subscribers: eraman, hiraditya, llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D51902
      
      llvm-svn: 342186
      3bea25e5
    • Jim Ingham's avatar
      Add a "scripted" breakpoint type to lldb. · 3815e702
      Jim Ingham authored
      This change allows you to write a new breakpoint type where the
      logic for setting breakpoints is determined by a Python callback
      written using the SB API's.
      
      Differential Revision: https://reviews.llvm.org/D51830
      
      llvm-svn: 342185
      3815e702
    • Roman Lebedev's avatar
      [NFC][InstCombine] PR38708 - inefficient pattern for high-bits checking 3. · d2316d75
      Roman Lebedev authored
      The last, non-canonical variant:
      https://godbolt.org/z/aCMsPk
      https://rise4fun.com/Alive/I6f
      
      It can only happen due to the extra use on the inner shift.
      But here it is ok.
      
      https://bugs.llvm.org/show_bug.cgi?id=38708
      
      llvm-svn: 342184
      d2316d75
    • Amara Emerson's avatar
    • Roman Lebedev's avatar
      LLVMExegesisX86Tests: link to LLVMCore, too. · b6d188da
      Roman Lebedev authored
      Fixes build for me.
      Refs. D52054
      
      [215/217] Linking CXX executable unittests/tools/llvm-exegesis/X86/LLVMExegesisX86Tests
      FAILED: unittests/tools/llvm-exegesis/X86/LLVMExegesisX86Tests
      : && /usr/bin/g++  -pipe -O2 -g0 -UNDEBUG -fPIC -fvisibility-inlines-hidden -Werror=date-time -std=c++11 -Wall -Wextra -Wno-unused-parameter -Wwrite-strings -Wcast-qual -Wno-missing-field-initializers -pedantic -Wno-long-long -Wno-maybe-uninitialized -Wno-class-memaccess -Wno-noexcept-type -Wdelete-non-virtual-dtor -Wno-comment -fdiagnostics-color -ffunction-sections -fdata-sections -pipe -O2 -g0 -UNDEBUG  -fuse-ld=lld -Wl,--color-diagnostics -Wl,-allow-shlib-undefined     -Wl,-O3 -Wl,--gc-sections unittests/tools/llvm-exegesis/X86/CMakeFiles/LLVMExegesisX86Tests.dir/AssemblerTest.cpp.o unittests/tools/llvm-exegesis/X86/CMakeFiles/LLVMExegesisX86Tests.dir/AnalysisTest.cpp.o unittests/tools/llvm-exegesis/X86/CMakeFiles/LLVMExegesisX86Tests.dir/SnippetGeneratorTest.cpp.o unittests/tools/llvm-exegesis/X86/CMakeFiles/LLVMExegesisX86Tests.dir/RegisterAliasingTest.cpp.o unittests/tools/llvm-exegesis/X86/CMakeFiles/LLVMExegesisX86Tests.dir/TargetTest.cpp.o  -o unittests/tools/llvm-exegesis/X86/LLVMExegesisX86Tests  -Wl,-rpath,/build/llvm-build-GCC-release/lib lib/libLLVMMC.so.8svn lib/libLLVMMCParser.so.8svn lib/libLLVMObject.so.8svn lib/libLLVMSymbolize.so.8svn lib/libLLVMX86CodeGen.so.8svn lib/libLLVMX86AsmParser.so.8svn lib/libLLVMX86AsmPrinter.so.8svn lib/libLLVMX86Desc.so.8svn lib/libLLVMX86Disassembler.so.8svn lib/libLLVMX86Info.so.8svn lib/libLLVMX86Utils.so.8svn lib/libLLVMSupport.so.8svn -lpthread lib/libgtest_main.so.8svn lib/libgtest.so.8svn -lpthread lib/libLLVMExegesis.so.8svn lib/libLLVMExegesisX86.so.8svn && :
      ld.lld: error: undefined symbol: llvm::LLVMContext::~LLVMContext()
      >>> referenced by AssemblerTest.cpp
      >>>               unittests/tools/llvm-exegesis/X86/CMakeFiles/LLVMExegesisX86Tests.dir/AssemblerTest.cpp.o:(exegesis::(anonymous namespace)::X86MachineFunctionGeneratorTest_DISABLED_JitFunction_Test::TestBody())
      
      ld.lld: error: undefined symbol: llvm::LLVMContext::~LLVMContext()
      >>> referenced by AssemblerTest.cpp
      >>>               unittests/tools/llvm-exegesis/X86/CMakeFiles/LLVMExegesisX86Tests.dir/AssemblerTest.cpp.o:(exegesis::(anonymous namespace)::X86MachineFunctionGeneratorTest_DISABLED_JitFunctionXOR32rr_Default_Test::TestBody())
      
      ld.lld: error: undefined symbol: llvm::LLVMContext::~LLVMContext()
      >>> referenced by AssemblerTest.cpp
      >>>               unittests/tools/llvm-exegesis/X86/CMakeFiles/LLVMExegesisX86Tests.dir/AssemblerTest.cpp.o:(void exegesis::MachineFunctionGeneratorBaseTest::Check<int, int, int, int, int, int, int, int>(exegesis::ExegesisTarget const&, llvm::ArrayRef<unsigned int>, llvm::MCInst, int, int, int, int, int, int, int, int))
      
      ld.lld: error: undefined symbol: llvm::LLVMContext::~LLVMContext()
      >>> referenced by AssemblerTest.cpp
      >>>               unittests/tools/llvm-exegesis/X86/CMakeFiles/LLVMExegesisX86Tests.dir/AssemblerTest.cpp.o:(exegesis::(anonymous namespace)::X86MachineFunctionGeneratorTest_DISABLED_JitFunctionMOV32ri_Test::TestBody())
      collect2: error: ld returned 1 exit status
      ninja: build stopped: subcommand failed.
      
      llvm-svn: 342182
      b6d188da
    • Raphael Isemann's avatar
      Add support for descriptions with command completions. · 7f88829c
      Raphael Isemann authored
      Summary:
      This patch adds a framework for adding descriptions to the command completions we provide.
      It also adds descriptions for completed top-level commands so that we can test this code.
      
      Completions are in general supposed to be displayed alongside the completion itself. The descriptions
      can be used to provide additional information about the completion to the user. Examples for descriptions
      are function signatures when completing function calls in the expression command or the binary name
      when providing completion for a symbol.
      
      There is still some boilerplate code from the old completion API left in LLDB (mostly because the respective
      APIs are reused for non-completion related purposes, so the CompletionRequest doesn't make sense to be
      used), so that's why I still had to change some function signatures. Also, as the old API only passes around a
      list of matches, and the descriptions are for these functions just another list, I had to add some code that
      essentially just ensures that both lists are always the same side (e.g. all the manual calls to
      `descriptions->AddString(X)` below a `matches->AddString(Y)` call).
      
      The initial command descriptions that come with this patch are just reusing the existing
      short help that is already added in LLDB.
      
      An example completion with descriptions looks like this:
      ```
      (lldb) pl
      Available completions:
              platform -- Commands to manage and create platforms.
              plugin   -- Commands for managing LLDB plugins.
      ```
      
      Reviewers: #lldb, jingham
      
      Reviewed By: #lldb, jingham
      
      Subscribers: jingham, JDevlieghere, lldb-commits
      
      Differential Revision: https://reviews.llvm.org/D51175
      
      llvm-svn: 342181
      7f88829c
    • Sam Clegg's avatar
      [llvm-exegesis] Add missing MC dependency to CMakeLists.txt · 9b3e7c36
      Sam Clegg authored
      See rL342148
      
      This probably only shows up in BUILD_SHARED_LIBS=ON builds
      which might explain how it crept in.
      
      Differential Revision: https://reviews.llvm.org/D52054
      
      llvm-svn: 342180
      9b3e7c36
    • Peter Collingbourne's avatar
      [bindings/go] Add DebugLoc parameter to InsertXXXAtEnd() · 33d37b2e
      Peter Collingbourne authored
      These functions previously passed nil for the location, which always resulted in a crash.
      
      This is a signature breaking change, but I cannot see how they could have been used before.
      
      Patch by Ben Clayton!
      
      Differential Revision: https://reviews.llvm.org/D51970
      
      llvm-svn: 342179
      33d37b2e
    • Richard Smith's avatar
      Add dependency on new llvm-cxxmap tool to check-llvm. · 3e32c815
      Richard Smith authored
      llvm-svn: 342178
      3e32c815
    • Richard Smith's avatar
      Diagnose likely typos in #include directives. · 2ce63b42
      Richard Smith authored
      Summary:
      When someone writes
      
        #include "<some_file>"
      
      or
      
        #include " some_file "
      
      the compiler returns "file not fuond..." with fonts and quotes that may
      make it hard to see there are excess quotes or surprising bytes in the
      filename.  Assuming that files are usually logically named and start and
      end with an alphanumeric character, we can check for the file's
      existence by stripping the non-alphanumeric leading or trailing
      characters.  If the file is found, emit a non-fatal error with a
      FixItHint.
      
      Patch by Christy Lee!
      
      Reviewers: aaron.ballman, erikjv, rsmith
      
      Reviewed By: rsmith
      
      Subscribers: lebedev.ri, xbolva00, sammccall, modocache, erikjv, aaron.ballman, cfe-commits
      
      Differential Revision: https://reviews.llvm.org/D51333
      
      llvm-svn: 342177
      2ce63b42
    • Craig Topper's avatar
      [MachineInstr] In addRegisterKilled and addRegisterDead, don't remove operands... · 2f88006c
      Craig Topper authored
      [MachineInstr] In addRegisterKilled and addRegisterDead, don't remove operands from inline assembly instructions if they have an associated flag operand.
      
      INLINEASM instructions use extra operands to carry flags. If a register operand is removed without removing the flag operand, then the flags will no longer make sense.
      
      This patch fixes this by preventing the removal when a flag operand is present.
      
      The included test case was generated by MS inline assembly. Longer term maybe we should fix the inline assembly parsing to not generate redundant operands.
      
      Differential Revision: https://reviews.llvm.org/D51829
      
      llvm-svn: 342176
      2f88006c
    • Nirav Dave's avatar
      [X86] Fix register resizings for inline assembly register operands. · 59ad1c84
      Nirav Dave authored
      When replacing a named register input to the appropriately sized
      sub/super-register. In the case of a 64-bit value being assigned to a
      register in 32-bit mode, match GCC's assignment.
      
      Reviewers: eli.friedman, craig.topper
      
      Subscribers: nickdesaulniers, llvm-commits, hiraditya
      
      Differential Revision: https://reviews.llvm.org/D51502
      
      llvm-svn: 342175
      59ad1c84
    • Nirav Dave's avatar
      [X86] Cleanup pair returns. NFCI. · 2060a16d
      Nirav Dave authored
      llvm-svn: 342174
      2060a16d
    • Roman Lebedev's avatar
      [InstCombine] Inefficient pattern for high-bits checking 2 (PR38708) · 6dc87004
      Roman Lebedev authored
      Summary:
      It is sometimes important to check that some newly-computed value
      is non-negative and only n bits wide (where n is a variable.)
      There are many ways to check that:
      https://godbolt.org/z/o4RB8D
      The last variant seems best?
      (I'm sure there are some other variations i haven't thought of..)
      
      More complicated, canonical pattern:
      https://rise4fun.com/Alive/uhA
      
      We do need to have two `switch()`'es like this,
      to not mismatch the swappable predicates.
      
      https://bugs.llvm.org/show_bug.cgi?id=38708
      
      Reviewers: spatel, craig.topper, RKSimon
      
      Reviewed By: spatel
      
      Subscribers: llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D52001
      
      llvm-svn: 342173
      6dc87004
    • George Burgess IV's avatar
      [PartiallyInlineLibCalls] Add DebugCounter support · d565b0f0
      George Burgess IV authored
      This adds DebugCounter support to the PartiallyInlineLibCalls pass,
      which should make debugging/automated bisection easier in the future.
      
      Patch by Zhizhou Yang!
      
      Differential Revision: https://reviews.llvm.org/D50093
      
      llvm-svn: 342172
      d565b0f0
    • Roman Lebedev's avatar
      [NFC][InstCombine] Test what happens if 'unefficient high bit check' pattern is on both sides. · 08374485
      Roman Lebedev authored
      Came up in https://reviews.llvm.org/D52001#1233827
      While we don't do a good job here, we at least want to make
      sure that we don't have any inf-loops.
      
      llvm-svn: 342171
      08374485
    • George Burgess IV's avatar
      [DCE] Add DebugCounter support · 7a8dc3da
      George Burgess IV authored
      Patch by Zhizhou Yang!
      
      Differential Revision: https://reviews.llvm.org/D50092
      
      llvm-svn: 342170
      7a8dc3da
Loading