| Commit message (Collapse) | Author | Age | Files | Lines |
| ... | |
| |
|
|
|
|
|
|
|
|
| |
This exception format is not specific to Windows x64. A similar approach is
taken on nearly all architectures. Generalise the name to reflect reality.
This will eventually be used for Windows on ARM data emission as well.
Switch the enum and namespace into an enum class.
llvm-svn: 212000
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Rename the routines to reflect the reality that they are more related to call
frame information than to Win64 EH. Although EH is implemented in an intertwined
manner by augmenting with an exception handler and an associated parameter, the
majority of these routines emit information required to unwind the frames. This
also helps identify that these routines are generic for most windows platforms
(they apply equally to nearly all architectures except x86) although the
encoding of the information is architecture dependent.
Unwinding data is emitted via EmitWinCFI* and exception handling information via
EmitWinEH*.
llvm-svn: 211994
|
| |
|
|
|
|
| |
simplify some code.
llvm-svn: 211993
|
| |
|
|
| |
llvm-svn: 211986
|
| |
|
|
| |
llvm-svn: 211985
|
| |
|
|
|
|
|
| |
RuntimeDyld now uses MCInst::dump_pretty() which introduces a dependency on
'MC'.
llvm-svn: 211978
|
| |
|
|
|
|
| |
No functionality change, just correcting the assertion message.
llvm-svn: 211977
|
| |
|
|
|
|
|
|
|
|
|
| |
lowering for v16i8.
ASan and some bots caught this bug with existing test cases. Fixing it
even fixed a miscompile with one of the test cases. I'm still a bit
suspicious of this test case as I've not taken a proper amount of time
to think about it, but the fix here is strict goodness.
llvm-svn: 211976
|
| |
|
|
|
|
|
| |
a temporary file. This fixes the test in cases where the source tree is
mounted read-only.
llvm-svn: 211975
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
These show up really frequently, not the least with actual splats. =] We
lowered these quite badly before. The new code path tries to widen i8
shuffles to i16 shuffles in a splat-like way. There are still some
inefficiencies in our i16 splat logic though, so we aren't really done
here.
Also, for certain patterns (bit of a gather-and-splat) we still
generate pretty silly code, and I've left a fixme for addressing it.
However, I'm not actually worried about this code pattern as much. The
old shuffle lowering generates a 29 instruction monstrosity for it that
should execute much more slowly.
llvm-svn: 211974
|
| |
|
|
|
|
|
|
|
| |
This was generated while trying to debug a test, it shouldn't have been
checked in.
Thanks to Alexander Kornienko for spotting this.
llvm-svn: 211973
|
| |
|
|
|
|
|
|
|
| |
that have been enabled.
Without this, testers will fail when llvm-rtdyld is invoked with triples for
unsupported targets.
llvm-svn: 211969
|
| |
|
|
| |
llvm-svn: 211967
|
| |
|
|
| |
llvm-svn: 211963
|
| |
|
|
|
|
| |
Some users' C++11 standard libraries don't support std::to_string yet.
llvm-svn: 211961
|
| |
|
|
| |
llvm-svn: 211960
|
| |
|
|
|
|
|
|
|
| |
Make llvm-cov compatible with gcov for cases where multiple files are
specified on the command line. That is, loop over each one and report
coverage, and report errors on stderr only rather than via return
code.
llvm-svn: 211959
|
| |
|
|
|
|
| |
Hopefully this will unbreak the windows bots.
llvm-svn: 211958
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
This patch adds a "-verify" mode to the llvm-rtdyld utility. In verify mode,
llvm-rtdyld will test supplied expressions against the linked program images
that it creates in memory. This scheme can be used to verify the correctness
of the relocation logic applied by RuntimeDyld.
The expressions to test will be read out of files passed via the -check option
(there may be more than one of these). Expressions to check are extracted from
lines of the form:
# rtdyld-check: <expression>
This system is designed to fit the llvm-lit regression test workflow. It is
format and target agnostic, and supports verification of images linked for
remote targets. The expression language is defined in
llvm/include/llvm/RuntimeDyldChecker.h . Examples can be found in
test/ExecutionEngine/RuntimeDyld.
llvm-svn: 211956
|
| |
|
|
|
|
|
|
|
|
|
|
|
| |
lowering.
For maximum irony, I had already discovered this bug, diagnosed it, and
left FIXMEs about it in the test cases. =[ I just failed to go back over
those until after i had reduced a bootstrap miscompile down to a single
TU, stared at the assembly for an hour, and figured out the bug. Again.
Oh well.
llvm-svn: 211955
|
| |
|
|
|
|
| |
triggered in GCC.
llvm-svn: 211953
|
| |
|
|
|
|
| |
own. Thanks Hal!
llvm-svn: 211952
|
| |
|
|
|
|
| |
ensure that it isn't lexed as a multiline comment. This silences some -Wcomment warnings.
llvm-svn: 211950
|
| |
|
|
| |
llvm-svn: 211949
|
| |
|
|
|
|
| |
Also clean up some of the logic in NVVMReflect.cpp while we're messing around in there.
llvm-svn: 211948
|
| |
|
|
|
|
| |
ones representable as MVTs
llvm-svn: 211947
|
| |
|
|
| |
llvm-svn: 211946
|
| |
|
|
| |
llvm-svn: 211945
|
| |
|
|
| |
llvm-svn: 211944
|
| |
|
|
|
|
| |
that does not support initialization
llvm-svn: 211943
|
| |
|
|
| |
llvm-svn: 211942
|
| |
|
|
|
|
| |
common linkage
llvm-svn: 211941
|
| |
|
|
|
|
| |
be emitted
llvm-svn: 211940
|
| |
|
|
|
|
|
|
|
|
| |
The address space of the pointer must be global (1) for these intrinsics. There must also be alignment metadata attached to the intrinsic calls, e.g.
%val = tail call i32 @llvm.nvvm.ldu.i.global.i32.p1i32(i32 addrspace(1)* %ptr), !align !0
!0 = metadata !{i32 4}
llvm-svn: 211939
|
| |
|
|
|
|
| |
structs and vectors
llvm-svn: 211938
|
| |
|
|
| |
llvm-svn: 211937
|
| |
|
|
| |
llvm-svn: 211936
|
| |
|
|
|
|
| |
This also introduces DAGCombiner patterns for mul.wide to multiply two smaller integers and produce a larger integer
llvm-svn: 211935
|
| |
|
|
| |
llvm-svn: 211934
|
| |
|
|
| |
llvm-svn: 211933
|
| |
|
|
| |
llvm-svn: 211932
|
| |
|
|
| |
llvm-svn: 211931
|
| |
|
|
| |
llvm-svn: 211930
|
| |
|
|
|
|
| |
Default PTX version is set to PTX 3.2
llvm-svn: 211929
|
| |
|
|
| |
llvm-svn: 211928
|
| |
|
|
|
|
|
| |
NVPTX is a bit special in the optimizations it requires, so this gives
us better control over the backend optimization pipeline.
llvm-svn: 211927
|
| |
|
|
| |
llvm-svn: 211926
|
| |
|
|
|
|
| |
structures and vectors
llvm-svn: 211925
|
| |
|
|
| |
llvm-svn: 211924
|
| |
|
|
| |
llvm-svn: 211923
|