- 11 Nov, 2020 6 commits
-
-
Antonio Maiorano authored
Formatted using: find ${DIR} -iname "*.cc" -o -iname "*.h" -o -iname "*.hpp" -o -iname "*.cpp" -o -iname "*.inl" | xargs ${CLANG_FORMAT} -i -style=file Bug: b/144825072 Change-Id: Ie6ebd83f85dc11a044dec4514a1e81edbbd4ed21 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/50169Reviewed-by:Nicolas Capens <nicolascapens@google.com> Tested-by:
Antonio Maiorano <amaiorano@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com>
-
Antonio Maiorano authored
Formatted using: find ${DIR} -iname "*.cc" -o -iname "*.h" -o -iname "*.hpp" -o -iname "*.cpp" -o -iname "*.inl" | xargs ${CLANG_FORMAT} -i -style=file Bug: b/144825072 Change-Id: Icda5e53cbbe0c95a24ca4e16750f2368f7daa0e1 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/50168Reviewed-by:Nicolas Capens <nicolascapens@google.com> Tested-by:
Antonio Maiorano <amaiorano@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com>
-
Nicolas Capens authored
llvm::orc::JITTargetMachineBuilder::detectHost() currently states: // FIXME: getProcessTriple is bogus. It returns the host LLVM was compiled on, // rather than a valid triple for the current process. This change uses LLVM_DEFAULT_TARGET_TRIPLE instead, which we define based on the platform and predefined macros (see llvm-config.h). This doesn't fix any known bugs, but it's good to not leave the triple unknown, to avoid future issues. This change also refactors passing the JITTargetMachineBuilder by rvalue reference and uses some less cryptic variable names. Bug: b/171236524 Change-Id: I7be752be66082654307210817250eb1dd025cb0c Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49851Tested-by:
Nicolas Capens <nicolascapens@google.com> Reviewed-by:
Antonio Maiorano <amaiorano@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com>
-
Sean Risser authored
Since we track the SPV_ENV_... version with VkConfig.hpp, any other directory that includes VkConfig has to have a dependency on SPIR-V Tools. Bug: b/172837769 Change-Id: I7962ee278c3240c9461acaedcd9cbbca0c08c0d6 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/50208Reviewed-by:
Nicolas Capens <nicolascapens@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com> Tested-by:
Sean Risser <srisser@google.com>
-
Jason Macnak authored
... to support a fresh merge into AOSP including https://swiftshader-review.googlesource.com/c/SwiftShader/+/49688 to unblock ANGLE CI. Introduces a libLLVM10_swiftshader_debug to handle linker errors around LLVMJIT_ORCv1.cpp including llvm/Support/Error.h and whether or not LLVM_ENABLE_ABI_BREAKING_CHECKS is defined. Bug: b/147316305 Test: TreeHugger build on aosp/1494218 Change-Id: I513cb76f03f49699e4a0e8b0c7d3e59a2baa3a86 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/50148 Presubmit-Ready: Jason Macnak <natsu@google.com> Reviewed-by:
Nicolas Capens <nicolascapens@google.com> Tested-by:
Jason Macnak <natsu@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com>
-
Antonio Maiorano authored
This ReactorUnitTest fails if the fix made in swiftshader-cl/50008 is reverted. Git hash of fix: 3476ca34 Bug: angleproject:4482 Change-Id: I0d1977923f7d8ea1c02e905b0c0c5273a19864c0 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/50075 Kokoro-Result: kokoro <noreply+kokoro@google.com> Tested-by:
Antonio Maiorano <amaiorano@google.com> Reviewed-by:
Nicolas Capens <nicolascapens@google.com>
-
- 10 Nov, 2020 1 commit
-
-
Sean Risser authored
Multiple places in the codebase use SPV_VERSION_1_1, which makes updating the SPIR-V version a nuissance. Now only VkConfig.hpp tracks that information. Bug: b/172837769 Change-Id: I9ba09b431e48e2205cf0d8b428417b72a3f514cb Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/50128Reviewed-by:
Alexis Hétu <sugoi@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com> Tested-by:
Sean Risser <srisser@google.com>
-
- 06 Nov, 2020 2 commits
-
-
Valerie Hau authored
Add validateBufferSize and getTransportSize Bug: b/131089111 Test: build, boot Change-Id: Ie5ce20010c8a00eebde239d149faa1fb0fc07195 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/50074Tested-by:
Nicolas Capens <nicolascapens@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com> Reviewed-by:
Jason Macnak <natsu@google.com> Reviewed-by:
Nicolas Capens <nicolascapens@google.com>
-
Jaebaek Seo authored
For DebugValue with index parameter, the debugger code does not use the correct member index. It results in "undefined" value even when the shader actually provide the value. Bug: b/148401179 Change-Id: Ic563db74503200c1a6dc71a5e1744b75df63d610 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/50072 Kokoro-Result: kokoro <noreply+kokoro@google.com> Tested-by:
Jaebaek Seo <jaebaek@google.com> Reviewed-by:
Ben Clayton <bclayton@google.com>
-
- 05 Nov, 2020 6 commits
-
-
Sean Risser authored
* changes: Update SPIR-V Tools to a61d07a72 Squashed 'third_party/SPIRV-Tools/' changes from f7da52775..a61d07a72
-
Nicolas Capens authored
Bug: b/123642959 Change-Id: I145adbd76fe04f0bdf9fb7ee4e581aaeaba5fccc Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/50069Tested-by:
Nicolas Capens <nicolascapens@google.com> Reviewed-by:
Alexis Hétu <sugoi@google.com>
-
Antonio Maiorano authored
See the first bug I fixed related to this: 7fefd483. That bug fix ensured that arguments are accessed relative to 'ebp' rather than 'esp' on Windows x86. However, when an arg Variable gets split (see LocalVariableSplitter), the new Variable that's linked to the original arg Variable must also use 'ebp' in the same way. This is now fixed by making sure to set its "isArg" state to match that of the "linked stack root" Variable at the same time as we set its "stackOffset" in the same way. Thus, when stackVarToAsmOperand is called during emitIAS, split Variables are properly addressed using the correct frame pointer. See the detailed design doc: https://docs.google.com/document/d/1IBsWg2V9_arWGYkpuwlKdne4lkA6XwSQ8fp99l8BmnA This fixes the intermittent crash reported here: https://bugs.chromium.org/p/angleproject/issues/detail?id=4482#c15 Bug: angleproject:4482 Change-Id: Ibc089f3a5b9a44f40f130a3db8656011212d2983 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/50008 Kokoro-Result: kokoro <noreply+kokoro@google.com> Tested-by:
Antonio Maiorano <amaiorano@google.com> Reviewed-by:
Nicolas Capens <nicolascapens@google.com>
-
Antonio Maiorano authored
Using std::unordered_set to hold unmaterialized variables meant that when materializeAll was called, the order of variables would differ between runs of the same executable on the same target. Instead, we now use a map of Variable* to a monotonically increasing counter, allowing us to not only guarantee order-consistency across runs, but also means we can submit variables in the order they are declared, which may be preferable by the JIT backend. Note that this also affects LLVM; however, LLVM likely already performs stack variable reordering, so the effects are minimized. Nonetheless, this change likely also fixes determinism when using LLVM. Bug: angleproject:4482 Bug: b/172365901 Change-Id: I5698085ab96663b3c9a2fae4f01b1c1b3aac8b4b Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49949 Presubmit-Ready: Antonio Maiorano <amaiorano@google.com> Tested-by:
Antonio Maiorano <amaiorano@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com> Reviewed-by:
Nicolas Capens <nicolascapens@google.com>
-
Sean Risser authored
Changes: a61d07a72 spirv-val: Fix SPV_KHR_fragment_shading_rate VUID label (#4014) 650acb575 spirv-val: Label Layer and ViewportIndex VUIDs (#4013) 0c036df28 Add dead function elimination to -O (#4015) c2b2b5788 Add DebugValue for invisible store in single_store_elim (#4002) c74d5523b Fix SSA re-writing in the presence of variable pointers. (#4010) 02195a029 spirv-fuzz: Fixes to pass management (#4011) bcf5b211d spirv-fuzz: Add support for reining in rogue fuzzer passes (#3987) 7d250ed51 spirv-fuzz: Fix assertion failure in FuzzerPassAddCompositeExtract (#3995) f9937bcc8 spirv-fuzz: Fix invalid equation facts (#4009) aa6035f1c spirv-fuzz: Fix bugs in TransformationFlattenConditionalBranch (#4006) 5735576f8 spirv-fuzz: Fix bug related to transformation applicability (#3990) Commands: ./third_party/update-spirvtools.sh Bug: b/123642959 Change-Id: I3c4f10f78f63a75dcec8036a6a9488a82aebf84c -
Sean Risser authored
a61d07a72 spirv-val: Fix SPV_KHR_fragment_shading_rate VUID label (#4014) 650acb575 spirv-val: Label Layer and ViewportIndex VUIDs (#4013) 0c036df28 Add dead function elimination to -O (#4015) c2b2b5788 Add DebugValue for invisible store in single_store_elim (#4002) c74d5523b Fix SSA re-writing in the presence of variable pointers. (#4010) 02195a029 spirv-fuzz: Fixes to pass management (#4011) bcf5b211d spirv-fuzz: Add support for reining in rogue fuzzer passes (#3987) 7d250ed51 spirv-fuzz: Fix assertion failure in FuzzerPassAddCompositeExtract (#3995) f9937bcc8 spirv-fuzz: Fix invalid equation facts (#4009) aa6035f1c spirv-fuzz: Fix bugs in TransformationFlattenConditionalBranch (#4006) 5735576f8 spirv-fuzz: Fix bug related to transformation applicability (#3990) git-subtree-dir: third_party/SPIRV-Tools git-subtree-split: a61d07a72763c1eb200de0a2c316703643a0d1d9
-
- 04 Nov, 2020 5 commits
-
-
Nicolas Capens authored
An update to vulkan.hpp made it no longer provide the same default arguments, leading to ambiguous calls. Bug: b/158231104 Change-Id: I0dae25fc6f98b9aca6818edb740dfdfa17b84d52 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49989 Presubmit-Ready: Nicolas Capens <nicolascapens@google.com> Tested-by:
Nicolas Capens <nicolascapens@google.com> Reviewed-by:
Alexis Hétu <sugoi@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com>
-
Nicolas Capens authored
This was tested by using __writeeflags(__readeflags() | 0x40000) to enable alignment checks on x86. Bug: b/169957911 Change-Id: Ie97b2fda281548fac94b13abe93213a9a1495b0c Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/48929Tested-by:
Nicolas Capens <nicolascapens@google.com> Reviewed-by:
Sean Risser <srisser@google.com> Reviewed-by:
Alexis Hétu <sugoi@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com>
-
Nicolas Capens authored
https://llvm.org/docs/LangRef.html#alloca-instruction does not specify the type of the 'NumElements' parameter explicitly, but it is multiplied by sizeof(<type>), which itself is of type size_t and thus 64-bit on a 64-bit platform. This assumption is made by MemorySanitizer when it emits instructions corresponding to this multiplication, which get constant folded and requires both operands to be of the same bit size. Bug: b/155148722 Change-Id: I432e69bfcea4d40ce7b593637fd242bc1a25a714 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49888Tested-by:
Nicolas Capens <nicolascapens@google.com> Reviewed-by:
Antonio Maiorano <amaiorano@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com>
-
Nicolas Capens authored
Runtime symbols referenced by MemorySanitizer instrumentation (e.g. __msan_warning_noreturn) reside in the executable and are exported from it (i.e. __attribute__((visibility("default"))). They can be resolved using dlsym(RTLD_DEFAULT). This works for either an executable or shared library using Reactor. Note that this differs from our regular symbol Resolver approach which lists pairs of symbol names and addresses. There is no public header which declares these MSan symbols, and if we list symbols only available in a newer version of LLVM's compiler-rt, the executable won't link or the shared library won't load. This change has no effect at this point. A later change will enable MemorySanitizer intrumentation for Reactor routines. Bug: b/155148722 Change-Id: I4601e499a2bf7073dbdd68679b74518500ebe217 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49848Reviewed-by:Antonio Maiorano <amaiorano@google.com> Tested-by:
Nicolas Capens <nicolascapens@google.com>
-
Nicolas Capens authored
Most of Chromium uses Subzero as the JIT backend for Reactor, but Fuchsia on ARM64 uses LLVM, which previously broke when switching to ORCv2 due to LLVM_ENABLE_ABI_BREAKING_CHECKS being set inconsistently https://swiftshader-review.googlesource.com/c/SwiftShader/+/49908 Bug: b/171897980 Bug: chromium:1140854 Change-Id: I4ab3422387fa966fb76fb90b27532630de69594a Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49852 Kokoro-Result: kokoro <noreply+kokoro@google.com> Tested-by:
Nicolas Capens <nicolascapens@google.com> Reviewed-by:
Antonio Maiorano <amaiorano@google.com>
-
- 03 Nov, 2020 4 commits
-
-
Nicolas Capens authored
Bug: b/149490161 Change-Id: I15f009d69ddb0725f8171f728195fbf94059c6e7 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49928Tested-by:
Nicolas Capens <nicolascapens@google.com> Reviewed-by:
Antonio Maiorano <amaiorano@google.com>
-
SwiftShader Regression Bot authored
Reactor backend: LLVM Change-Id: I26387d86e55d9f56589298a1f364ff090ab9f49a Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49209Tested-by:
Nicolas Capens <nicolascapens@google.com> Reviewed-by:
Alexis Hétu <sugoi@google.com>
-
Nicolas Capens authored
LLVM_ENABLE_ABI_BREAKING_CHECKS was disabled everywhere except for Fuchsia. It triggered llvm::Error::assertIsChecked() in the new ORCv2 code because we're supposed to check Expected<> didn't return an error by casting it to a bool, which we only do in Debug builds. Since this option costs performance in Release builds and we don't want to abort on errors (especially benign ones), it should only be enable for Debug builds. This is also the default behavior for standalone builds of LLVM: https://llvm.org/docs/ProgrammersManual.html#abi-breaking-checks Bug: b/171236524 Bug: chromium:1140854 Change-Id: If886fe9ef61d0f5392949d34a63ed3d7de7aa916 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49908Reviewed-by:
Antonio Maiorano <amaiorano@google.com> Tested-by:
Nicolas Capens <nicolascapens@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com>
-
Jari Komppa authored
Since there does not seem to be any elegant way of checking whether a class is the first base class in c++ (given that the 2009 c++ proposal n2965 was rejected), this python script does it by scanning all source files for illegal patterns. The python file was implemented in a way to enable easy addition of further checks, should need arise. Bug: b/152253831 Change-Id: I25701a3302579700ccb6222141843d27f38d9069 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49788 Kokoro-Result: kokoro <noreply+kokoro@google.com> Reviewed-by:
Nicolas Capens <nicolascapens@google.com> Tested-by:
Jari Komppa <jari@siru.fi>
-
- 02 Nov, 2020 9 commits
-
-
Nicolas Capens authored
The target triple is used by MemorySanitizer to determine where to map the shadow and origin data, which is OS specific. When not set, the MemorySanitizer::initializeModule() method, which inserts an __msan_init call to the module's constructor list, produces an "unsupported operating system" error. Note that JITs like Reactor have no use for a module constructor list (__msan_init gets called during executable startup), but there is currently no way to skip this initialization. Leaving it unused is fine though. Likewise, setting the target triple has not other known JIT uses at the moment, but it can't hurt. Bug: b/155148722 Change-Id: Ia31d8c71ee495aadd91530a8d1c5fdc93add8e01 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49853 Kokoro-Result: kokoro <noreply+kokoro@google.com> Tested-by:
Nicolas Capens <nicolascapens@google.com> Reviewed-by:
Antonio Maiorano <amaiorano@google.com>
-
Alexis Hétu authored
* changes: Update SPIR-V Tools to f7da52775 Squashed 'third_party/SPIRV-Tools/' changes from 82b378d671..f7da527757
-
Nicolas Capens authored
We were mixing uses of ::llvm:: and llvm:: Since it is a well-known namespace, there's virtually no risk of unintentionally reusing the same name. This follows the recommendation of go/totw/151. Bug: consistency cleanup Change-Id: I914f7a2d7b76f21f1f0758506319f2dd47cc1832 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49828Tested-by:
Nicolas Capens <nicolascapens@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com> Reviewed-by:
Antonio Maiorano <amaiorano@google.com>
-
Nicolas Capens authored
MemorySanitizer doesn't support instrumenting masked_gather and masked_scatter LLVM intrinsics. Its visitIntrinsicInst() method ends up calling handleUnknownIntrinsic(), which silently doesn't handle it and subsequently visitInstruction() checks all operands for poisoned bits. In the case of a scatter, a 0 bit in the mask means the corresponding element doesn't get written, so it doesn't matter if it's uninitialized data. The current implementation leads to false positives. Work around it by emulating gather and scatter as element-wise loads and stores. This can be correctly instrumented by MemorySanitizer. Note this change has no effect currently since we don't support MSan instrumentation for Reactor yet. We just unpoison all stores. Previously we did that in element-wise manner after the intrinsic executes. Now it's done as part of the element stores. Bug: b/155148722 Change-Id: I9058cd926667fb6df5d9626bc87fb2d0a596771b Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49809Tested-by:
Nicolas Capens <nicolascapens@google.com> Reviewed-by:
Antonio Maiorano <amaiorano@google.com>
-
Nicolas Capens authored
A statement like "If(Bool(b)) {}" would lead to interpreting part of its maco expansion "IfElseData ifElse__(Bool(b));" as a function declaration. See https://en.wikipedia.org/wiki/Most_vexing_parse Fix it by using C++11 universal initialization syntax. Bug: b/155148722 Change-Id: I64d0a28f64a4735a61776a44dfb7560d2854cde3 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49808 Kokoro-Result: kokoro <noreply+kokoro@google.com> Reviewed-by:Antonio Maiorano <amaiorano@google.com> Tested-by:
Nicolas Capens <nicolascapens@google.com>
-
Alexis Hetu authored
Changes: f7da527757 Temporarily add EmptyPass to prevent glslang from failing (#4004) Commands: ./third_party/update-spirvtools.sh Bug: b/123642959 Change-Id: If776b87d8c72e12a71e864ecd9a0ce4d61f9ddbc -
Alexis Hetu authored
f7da527757 Temporarily add EmptyPass to prevent glslang from failing (#4004) git-subtree-dir: third_party/SPIRV-Tools git-subtree-split: f7da527757140ae701be58274ce6db2f4234d9ff
-
Antonio Maiorano authored
UBSAN pointed out that memcpy cannot have nullptr dest or source, which I've also fixed; however, this also made me realize a latent bug: the dest and source args needed to be swapped. It seems this bug hasn't bit us yet because the normal use-case is to resize the bitvector, and then call 'set' to set all bits to 0 or 1. In any case, still worth fixing. Bug: b/171581990 Change-Id: Iaaa7e019b53ae661f49c97195f2d144b5715f164 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49528 Presubmit-Ready: Antonio Maiorano <amaiorano@google.com> Reviewed-by:
Nicolas Capens <nicolascapens@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com> Tested-by:
Antonio Maiorano <amaiorano@google.com>
-
Jari Komppa authored
This change adds third_party directory to the ignore list for the pre-submit script. Bug: b/171873846 Change-Id: Ic1a6fee89c76e8ca3526c95e29335eacf2e505f1 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49768 Kokoro-Result: kokoro <noreply+kokoro@google.com> Reviewed-by:
Nicolas Capens <nicolascapens@google.com> Tested-by:
Jari Komppa <jari@siru.fi>
-
- 30 Oct, 2020 6 commits
-
-
Alexis Hétu authored
* changes: Update SPIR-V Tools to 82b378d67 Squashed 'third_party/SPIRV-Tools/' changes from 8a5500656..82b378d67 Update SPIR-V Headers to 7845730ca Squashed 'third_party/SPIRV-Headers/' changes from 979924c8b..7845730ca
-
Jari Komppa authored
This change makes sure the memset template is not used with classes that contain virtual members. Bug: b/152253831 Change-Id: I07d4777f33a9bd55c8f99d8b50a80c13df5d5805 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49648 Kokoro-Result: kokoro <noreply+kokoro@google.com> Reviewed-by:
Nicolas Capens <nicolascapens@google.com> Tested-by:
Jari Komppa <jari@siru.fi>
-
Alexis Hetu authored
Changes: 82b378d67 spirv-opt: Add support to prevent functions from being inlined if they have DontInline flag (#3858) 56d0f5035 Propagate OpLine to all applied instructions in spirv-opt (#3951) 7403dfafd CMake: Add SPIRV_TOOLS_BUILD_STATIC flag (#3910) 25ee27576 Avoid copying a ref in a loop (#4000) 5edb328e8 spirv-val: Allow the ViewportIndex and Layer built-ins on SPIR-V 1.5 (#3986) cbd1fa6c4 Simplify logic to decide whether CCP modified the IR (#3997) df4198e50 Add DebugValue for DebugDecl invisible to value assignment (#3973) 34ae8a475 Fix bounds check instrumentation to handle 16-bit values (#3983) abe2eff36 spirv-fuzz: Add expand vector reduction transformation (#3869) 99ad4f1e2 spirv-fuzz: Don't replace irrelevant indices in OpAccessChain (#3988) 895dafcc1 spirv-fuzz: Add FuzzerPassAddCompositeExtract (#3904) 69f07da41 spirv-fuzz: Fix mismatch with shrinker step limit (#3985) 9223493f4 spirv-fuzz: Fix off-by-one error in replayer (#3982) 4f5423187 spirv-fuzz: Get order right for OpSelect arguments (#3974) 88f7bcb6a spirv-fuzz: Do not add synonym-creating loops in dead blocks (#3975) 64eaa9832 spirv-fuzz: Skip OpTypeSampledImage when propagating up (#3976) 53f2a69c1 spirv-fuzz: Pass OpUndef in function call if needed (#3978) de2c0ba20 spirv-fuzz: Fix off-by-one in TransformationCompositeConstruct (#3979) dc4a18228 spirv-fuzz: Tolerate absent ids in data synonym fact management (#3966) 8496780f5 spirv-fuzz: Fix to id availability (#3971) 3b7aebca4 spirv-fuzz: Fix operand types (#3962) 6fe34cdf1 Update SPIRV-Headers revision in DEPS file (#3961) a8d7062fe spirv-fuzz: Don't flatten conditional if condition is irrelevant (#3944) a3d5378df spirv-fuzz: Do not produce OpPhis of type OpTypeSampledImage (#3964) 7edd0525b spirv-fuzz: Restrict fuzzer pass to reachable blocks (#3970) f03779a1a spirv-fuzz: Handle more types when extending OpPhi instructions (#3969) c794b7046 spirv-fuzz: Skip early terminator wrappers when merging returns (#3968) dc9c6407d spirv-fuzz: Avoid irrelevant constants in synonym-creating loops (#3967) 26954c281 spirv-fuzz: Skip dead blocks in FuzzerPassAddOpPhiSynonyms (#3965) 5600fb85b spirv-fuzz: Avoid the type manager when looking for struct types (#3963) ba15b5886 spirv-fuzz: Fix to TransformationDuplicateRegionWithSelection (#3941) 598435004 spirv-fuzz: Skip OpFunction when replacing irrelevant ids (#3932) 8362eae55 spirv-fuzz: Use component-wise selectors when flattening conditional branches (#3921) ebe0ea09f Add SPV_EXT_shader_image_int64 (#3852) a1d38174b Support SPV_KHR_fragment_shading_rate (#3943) 6fac705e7 spirv-val: Fix validation of OpPhi instructions (#3919) b1350659b spirv-fuzz: Avoid void struct member when outlining functions (#3936) fd0f295da spirv-fuzz: Do not allow Block-decorated structs when adding parameters (#3931) 5d7893b37 spirv-fuzz: Fix to operand id type (#3937) cd1d3b6e0 spirv-fuzz: Handle dead blocks in TransformationEquationInstruction (#3933) 6cdae9da7 spirv-fuzz: Do not allow sampled image load when flattening conditionals (#3930) 7e1825a59 spirv-fuzz: Take care of OpPhi instructions when inlining (#3939) 502e98295 spirv-fuzz: Fix to TransformationInlineFunction (#3913) bf1a11dab spirv-fuzz: Wrap early terminators before merging returns (#3925) fd3948e16 Add DebugValue for function param regardless of scope (#3923) 663d050a9 Temporary fix to make GoogleTest compile. (#3922) dd534e877 spirv-fuzz: Lower probability of adding bit instruction synonyms (#3917) 53aeba10c spirv-fuzz: Fix handling of OpPhi in FlattenConditionalBranch (#3916) 5c64374dd spirv-fuzz: Avoid creating blocks without parents (#3908) 57b3723c5 spirv-fuzz: Do not allow creation of constants of block-decorated structs (#3903) 12ca825a6 spirv-fuzz: Fixes related to irrelevant ids (#3901) 2e6cf706e spirv-fuzz: Fix to transformation that adds a synonym via a loop (#3898) 4b884928d spirv-fuzz: Fix to duplicate region with selection (#3896) c2553a315 spirv-fuzz: Do not expose synonym facts for non-existent ids (#3891) 360228785 spirv-fuzz: Do not add synonyms involving irrelevant ids (#3890) d52f79122 spirv-fuzz: Do not replace irrelevant ids that are not in blocks (#3892) e02265992 spirv-fuzz: Wrap OpKill and similar in function calls (#3884) 11d592422 Update val to handle reversed instruction sections. (#3887) fc8264854 spirv-fuzz: Replace dead-block terminators with OpKill etc. (#3882) 63cc22d64 spirv-fuzz: TransformationPropagateInstructionDown (#3692) 65b2a9e81 spirv-fuzz: Transformation to add wrappers for OpKill and similar (#3881) 624b16cd0 spirv-fuzz: Use overflow ids when duplicating regions (#3878) bd0dd9cef spirv-fuzz: Fix rvalue references (#3883) f15133788 spirv-fuzz: Avoid using block-decorated structs in transformations (#3877) 0e8553072 spirv-fuzz: Use overflow ids when inlining functions (#3880) 67f8e2edd Debug info preservation in convert-local-access-chains pass (#3835) d91afd8de spirv-fuzz: Refactor fact manager tests (#3879) b920b620a spirv-fuzz: Integrate spirv-reduce with shrinker (#3849) 74a711a76 spirv-fuzz: Only recommend passes when a pass had an effect (#3863) fc7860e2d spirv-fuzz: Merge the return instructions in a function (#3838) 57abfd88c Debug info preservation in redundancy-elimination pass (#3839) e24603836 Debug info preservation in if-conversion pass (#3861) 16cc197c8 spirv-fuzz: Refactor conditions in the fact manager (#3867) 615fbe6cb spirv-fuzz: TransformationWrapRegionInSelection (#3674) f2b8a4ee5 spirv-fuzz: Enable some passes with high probability (#3860) 50e04f612 spirv-fuzz: Do not add constants for Block-decorated structs (#3862) 8edd79ddc spirv-fuzz: Fix to FuzzerPassFlattenConditionalBranches (#3865) 719bade4f spirv-fuzz: Fix TransformationRecordSynonymousConstants (#3868) 009facc97 spirv-fuzz: Fix flatten conditional branch transformation (#3859) fcb22ecf0 spirv-fuzz: Report fresh ids in transformations (#3856) c6ca885c0 [spirv-dis] Add some context comments to disassembly. (#3847) 446adb05f Fix use-after-move in val/validate.cpp (#3848) 4b07d50cd spirv-fuzz: Fix bug in TransformationDuplicateRegionWithSelection (#3819) fec56146a spirv-fuzz: Support OpNot bit instruction case (#3841) 9e17b9d07 spirv-fuzz: Return IR and transformation context after replay (#3846) e12087d6c spirv-fuzz: fix test (#3845) 9edeeafdb spirv-fuzz: Use unique_ptr<FactManager> in TransformationContext (#3844) 50dacda55 Start SPIRV-Tools v2020.6 b27e039c6 Finalize SPIRV-Tools v2020.5 a5903a969 Update CHANGES 330c72549 spirv-fuzz: Support dead blocks in TransformationAddSynonym (#3832) 36185f8b0 spirv-fuzz: Move IRContext parameter into constructor (#3837) 0e7fe4d35 Add missing backticks around <result-id> (#3840) d1bb98fd4 Validate SPIRV Version number when parsing binary header (#3834) 67525bded spirv-fuzz: Create synonym of int constant using a loop (#3790) 7cc4b4d2c Fix compiler error on macOS with XCode12 (#3836) 5a5b750aa spirv-fuzz: Handle OpPhis in TransformationInlineFunction (#3833) 0a1fb588c Update CHANGES 125b64241 spirv-fuzz: Refactor fuzzer, replayer and shrinker (#3818) 60ce96e2f spirv-fuzz: Add pass recommendations (#3757) 2945963cc spirv-fuzz: Consider all ids from dead blocks irrelevant (#3795) 50ae4c5f4 Fix header guard macros (#3811) 296e9c7bc spirv-fuzz: Fix TransformationDuplicateRegionWithSelection (#3815) 937a757f0 spirv-val: Add DeviceIndex (#3812) 34ef0c3fd Fix missed modification flagging (#3814) 748edbf8c spirv-fuzz: Use an irrelevant id for the unused components (#3810) 8d49fb2f4 spirv-fuzz: Improvements to random number generation (#3809) 7e28d809c Add buffer oob check to bindless instrumentation (#3800) 8fc504110 spirv-fuzz: Remove CanFindOrCreateZeroConstant (#3807) e8ce4355a spirv-fuzz: Add bit instruction synonym transformation (#3775) e7c84feda spirv-fuzz: Skip unreachable blocks (#3729) f20b523cb Fix build errors (#3804) 3131686d2 spirv-fuzz: Handle invalid ids in fact manager (#3742) 4c239bd81 spirv-fuzz: Support memory instructions MoveInstructionDown (#3700) 1e1c308de spirv-fuzz: Pass submanagers to other submanagers when necessary (#3796) f62357e7b spirv-fuzz: Transformation to flatten conditional branch (#3667) 5df930054 spirv-val: Add BaseInstance, BaseVertex, DrawIndex, and ViewIndex (#3782) 286b3095d Properly mark IR changed if instruction folder creates more than one constant. (#3799) 726af6f78 Add missing file to BUILD.gn (#3798) 244e6c1be spirv-fuzz: Add TransformationDuplicateRegionWithSelection (#3773) 5dcb576b6 spirv-reduce: Support reducing a specific function (#3774) de7d57984 spirv-reduce: Refactoring (#3793) ed9863e46 Favour 'integrity' over 'coherence' as a replacement for 'sanity'. (#3619) 8743d385f spirv-fuzz: Fix header guards in transformations/fuzzer passes (#3784) 2de7d3af0 spirv-fuzz: Add SPIRV_FUZZ_PROTOC_COMMAND (#3789) e589d0d57 Add missing include (#3788) a715b1b40 Improve spirv-fuzz CMake code (#3781) a187dd58a Allow SPV_KHR_8bit_storage extension. (#3780) 1ab52e54a spirv-opt: Add function to compute nesting depth of a block (#3771) fd05605be spirv-fuzz: Transformation to convert OpSelect to conditional branch (#3681) 2c60d16a6 spirv-val: Add Vulkan VUID labels to BuiltIn (#3756) c341f7a6c spirv-fuzz: Add support for BuiltIn decoration (#3736) c278dada9 spirv-fuzz: Fix GetIdEquivalenceClasses (#3767) 788468408 spirv-fuzz: Replace id in OpPhi coming from a dead predecessor (#3744) 3daabd321 spirv-fuzz: Transformation to replace the use of an irrelevant id (#3697) d7f078f27 spirv-fuzz: TransformationMutatePointer (#3737) 43a518601 spirv-fuzz: Compute interprocedural loop nesting depth of blocks (#3753) 8a0ebd40f Correctly replace debug lexical scope of instruction (#3718) f428aa39c spirv-fuzz: Remove opaque pointer design pattern (#3755) 08291a3a9 spirv-fuzz: Create synonym via OpPhi and existing synonyms (#3701) 7e4948b2a Add LoopNestingDepth function to StructuredCFGAnalysis (#3754) 50cf38b8c spirv-fuzz: Do not make synonyms of void result ids (#3747) bceab9fab Do not register DebugFunction for functions optimized away. (#3749) e02f178a7 Handle DebugScope in compact-ids pass (#3724) 9e26ae045 spirv-fuzz: Overflow ids (#3734) 2205254cf Fix DebugNoScope to not output InlinedAt operand. (#3748) 230f363e6 spirv-fuzz: Split the fact manager into multiple files (#3699) 5adc5ae64 spirv-fuzz: Add inline function transformation (#3517) 1341b58a8 spirv-fuzz: Fix MaybeGetZeroConstant (#3740) 12df3cafe Fix SSA-rewrite to remove DebugDeclare for variables without loads (#3719) 3f8501de9 Add undef for inlined void function (#3720) 4dd122392 spirv-fuzz: Add words instead of logical operands (#3728) b79773a35 CCP should mark IR changed if it created new constants. (#3732) a711c594b spirv-fuzz: add FuzzerPassAddCompositeInserts (#3606) 582c276d4 spirv-fuzz: Support pointer types in FuzzerPassAddParameters (#3627) 3434cb0b0 Let ADCE pass check DebugScope (#3703) ee7f0c882 spirv-opt: Implement opt::Function::HasEarlyReturn function (#3711) e28436f2b spirv-fuzz: Check termination instructions when donating modules (#3710) 1023dd7a0 Fix -Wrange-loop-analysis warning (#3712) 82f4bf128 spirv-fuzz: Check header dominance when adding dead block (#3694) b8de4f57e Allow DebugTypeTemplate for Type operand (#3702) c20995ef8 spirv-fuzz: Improve code coverage of tests (#3686) eade36db2 spirv-fuzz: Fuzzer pass to randomly apply loop preheaders (#3668) 72ea7bec4 spirv-fuzz: Support identical predecessors in TransformationPropagateInstructionUp (#3689) b4c4da3e7 Improve non-semantic instruction handling in the optimizer (#3693) 948577c5d Fix the bug (#3680) df859f77d spirv-fuzz: Check integer and float width capabilities (#3670) 2641d3351 spirv-fuzz: consider additional access chain instructions (#3672) 5e5929455 spirv-fuzz: Ignore specialization constants (#3664) 1435e427d Fix the bug (#3683) be099cde1 spirv-fuzz: Fix width in FuzzerPassAddEquationInstructions (#3685) f0ca96d12 Preserve debug info in dead-insert-elim pass (#3652) 0d629b903 Validate more OpenCL.DebugInfo.100 instructions (#3684) 13a65b1ae Only validation locations for appropriate execution models (#3656) fd3cabd8b spirv-fuzz: Fix in operand type assertion (#3666) f50553867 spirv-opt: Add spvOpcodeIsAccessChain (#3682) b7056e7e0 spirv-fuzz: FuzzerPassPropagateInstructionsUp (#3478) 8e1380996 Handle no index access chain in local access chain convert (#3678) bdeeae78a Roll 2 dependencies (#3677) 2990a2192 Avoid using /MP4 for clang on windows. (#3662) 7b2dd11dd spirv-fuzz: TransformationReplaceAddSubMulWithCarryingExtended (#3598) 6d7f34fbf spirv-fuzz: Add TransformationMakeVectorOperationDynamic (#3597) d29eac95a spirv-fuzz: iterate over blocks in replace linear algebra pass (#3654) efc85ff66 spirv-fuzz: make outliner pass use additional transformations (#3604) 5fd92a7e0 OpenCL.DebugInfo.100 DebugTypeArray with variable size (#3549) 3f33a9aa5 spirv-opt: Improve the code of the Instruction class (#3610) 0419751b0 spirv-fuzz: Handle OpPhis in livesafe functions (#3642) a10e76059 spirv-fuzz: Handle OpPhi during constant obfuscation (#3640) 28f32ca53 spirv-fuzz: Fix FuzzerPassCopyObjects (#3638) 8bc27a1cf spirv-fuzz: Remove OpFunctionCall operands in correct order (#3630) d9c73ebd9 spirv-fuzz: Handle capabilities during module donation (#3651) 9f2223602 spirv-fuzz: Refactor boilerplate in TransformationAddParameter (#3625) 92a71657f spirv-fuzz: TransformationMoveInstructionDown (#3477) b78f4b151 Remove DebugDeclare only for target variables in ssa-rewrite (#3511) 91cea06ab Fix typo in ASAN CI build (#3623) 2aaa8653d spirv-fuzz: Transformation to add loop preheader (#3599) 96bcc8274 spirv-fuzz: Pass to replace int operands with ints of opposite signedness (#3612) ebaefda66 Debug info preservation in loop-unroll pass (#3548) 50300450a Validator support for non-semantic clspv reflection (#3618) ab4fe12a4 spirv-fuzz: Fix memory bugs (#3622) c6e6597c4 spirv-fuzz: Implement the OpOuterProduct linear algebra case (#3617) 054f034ea spirv-fuzz: Compute corollary facts from OpBitcast (#3538) a1ea15c90 Update some language usage. (#3611) 863b8e3d3 spirv-fuzz: Relax type constraints in DataSynonym facts (#3602) 7e75fea9e spirv-fuzz: Remove non-deterministic behaviour (#3608) f9b088fe0 Avoid use of 'sanity' and 'sanity check' in the code base (#3585) 150be20d4 spirv-fuzz: Add condition to make functions livesafe (#3587) ce16ccf38 Rolling 4 dependencies (#3601) 1dfc6fc7e spirv-fuzz: Implement the OpTranspose linear algebra case (#3589) b63f0e5ed Fix SyntaxWarning in Python 3.8 (#3388) 6aed7ffbc CMake: Enable building with BUILD_SHARED_LIBS=1 (#3490) 31c821393 Avoid operand type range checks (#3379) 6a3eb679b Preserve debug info in scalar replacement pass (#3461) 2796840d2 Update OpenCL capabilities validation (#3149) b25ee93c2 build(deps): bump lodash from 4.17.15 to 4.17.19 in /tools/sva (#3596) Commands: ./third_party/update-spirvtools.sh Bug: b/123642959 Change-Id: Idde3643775d090b11dcb37ec2b3bd5a93c5e56fc -
Alexis Hetu authored
82b378d67 spirv-opt: Add support to prevent functions from being inlined if they have DontInline flag (#3858) 56d0f5035 Propagate OpLine to all applied instructions in spirv-opt (#3951) 7403dfafd CMake: Add SPIRV_TOOLS_BUILD_STATIC flag (#3910) 25ee27576 Avoid copying a ref in a loop (#4000) 5edb328e8 spirv-val: Allow the ViewportIndex and Layer built-ins on SPIR-V 1.5 (#3986) cbd1fa6c4 Simplify logic to decide whether CCP modified the IR (#3997) df4198e50 Add DebugValue for DebugDecl invisible to value assignment (#3973) 34ae8a475 Fix bounds check instrumentation to handle 16-bit values (#3983) abe2eff36 spirv-fuzz: Add expand vector reduction transformation (#3869) 99ad4f1e2 spirv-fuzz: Don't replace irrelevant indices in OpAccessChain (#3988) 895dafcc1 spirv-fuzz: Add FuzzerPassAddCompositeExtract (#3904) 69f07da41 spirv-fuzz: Fix mismatch with shrinker step limit (#3985) 9223493f4 spirv-fuzz: Fix off-by-one error in replayer (#3982) 4f5423187 spirv-fuzz: Get order right for OpSelect arguments (#3974) 88f7bcb6a spirv-fuzz: Do not add synonym-creating loops in dead blocks (#3975) 64eaa9832 spirv-fuzz: Skip OpTypeSampledImage when propagating up (#3976) 53f2a69c1 spirv-fuzz: Pass OpUndef in function call if needed (#3978) de2c0ba20 spirv-fuzz: Fix off-by-one in TransformationCompositeConstruct (#3979) dc4a18228 spirv-fuzz: Tolerate absent ids in data synonym fact management (#3966) 8496780f5 spirv-fuzz: Fix to id availability (#3971) 3b7aebca4 spirv-fuzz: Fix operand types (#3962) 6fe34cdf1 Update SPIRV-Headers revision in DEPS file (#3961) a8d7062fe spirv-fuzz: Don't flatten conditional if condition is irrelevant (#3944) a3d5378df spirv-fuzz: Do not produce OpPhis of type OpTypeSampledImage (#3964) 7edd0525b spirv-fuzz: Restrict fuzzer pass to reachable blocks (#3970) f03779a1a spirv-fuzz: Handle more types when extending OpPhi instructions (#3969) c794b7046 spirv-fuzz: Skip early terminator wrappers when merging returns (#3968) dc9c6407d spirv-fuzz: Avoid irrelevant constants in synonym-creating loops (#3967) 26954c281 spirv-fuzz: Skip dead blocks in FuzzerPassAddOpPhiSynonyms (#3965) 5600fb85b spirv-fuzz: Avoid the type manager when looking for struct types (#3963) ba15b5886 spirv-fuzz: Fix to TransformationDuplicateRegionWithSelection (#3941) 598435004 spirv-fuzz: Skip OpFunction when replacing irrelevant ids (#3932) 8362eae55 spirv-fuzz: Use component-wise selectors when flattening conditional branches (#3921) ebe0ea09f Add SPV_EXT_shader_image_int64 (#3852) a1d38174b Support SPV_KHR_fragment_shading_rate (#3943) 6fac705e7 spirv-val: Fix validation of OpPhi instructions (#3919) b1350659b spirv-fuzz: Avoid void struct member when outlining functions (#3936) fd0f295da spirv-fuzz: Do not allow Block-decorated structs when adding parameters (#3931) 5d7893b37 spirv-fuzz: Fix to operand id type (#3937) cd1d3b6e0 spirv-fuzz: Handle dead blocks in TransformationEquationInstruction (#3933) 6cdae9da7 spirv-fuzz: Do not allow sampled image load when flattening conditionals (#3930) 7e1825a59 spirv-fuzz: Take care of OpPhi instructions when inlining (#3939) 502e98295 spirv-fuzz: Fix to TransformationInlineFunction (#3913) bf1a11dab spirv-fuzz: Wrap early terminators before merging returns (#3925) fd3948e16 Add DebugValue for function param regardless of scope (#3923) 663d050a9 Temporary fix to make GoogleTest compile. (#3922) dd534e877 spirv-fuzz: Lower probability of adding bit instruction synonyms (#3917) 53aeba10c spirv-fuzz: Fix handling of OpPhi in FlattenConditionalBranch (#3916) 5c64374dd spirv-fuzz: Avoid creating blocks without parents (#3908) 57b3723c5 spirv-fuzz: Do not allow creation of constants of block-decorated structs (#3903) 12ca825a6 spirv-fuzz: Fixes related to irrelevant ids (#3901) 2e6cf706e spirv-fuzz: Fix to transformation that adds a synonym via a loop (#3898) 4b884928d spirv-fuzz: Fix to duplicate region with selection (#3896) c2553a315 spirv-fuzz: Do not expose synonym facts for non-existent ids (#3891) 360228785 spirv-fuzz: Do not add synonyms involving irrelevant ids (#3890) d52f79122 spirv-fuzz: Do not replace irrelevant ids that are not in blocks (#3892) e02265992 spirv-fuzz: Wrap OpKill and similar in function calls (#3884) 11d592422 Update val to handle reversed instruction sections. (#3887) fc8264854 spirv-fuzz: Replace dead-block terminators with OpKill etc. (#3882) 63cc22d64 spirv-fuzz: TransformationPropagateInstructionDown (#3692) 65b2a9e81 spirv-fuzz: Transformation to add wrappers for OpKill and similar (#3881) 624b16cd0 spirv-fuzz: Use overflow ids when duplicating regions (#3878) bd0dd9cef spirv-fuzz: Fix rvalue references (#3883) f15133788 spirv-fuzz: Avoid using block-decorated structs in transformations (#3877) 0e8553072 spirv-fuzz: Use overflow ids when inlining functions (#3880) 67f8e2edd Debug info preservation in convert-local-access-chains pass (#3835) d91afd8de spirv-fuzz: Refactor fact manager tests (#3879) b920b620a spirv-fuzz: Integrate spirv-reduce with shrinker (#3849) 74a711a76 spirv-fuzz: Only recommend passes when a pass had an effect (#3863) fc7860e2d spirv-fuzz: Merge the return instructions in a function (#3838) 57abfd88c Debug info preservation in redundancy-elimination pass (#3839) e24603836 Debug info preservation in if-conversion pass (#3861) 16cc197c8 spirv-fuzz: Refactor conditions in the fact manager (#3867) 615fbe6cb spirv-fuzz: TransformationWrapRegionInSelection (#3674) f2b8a4ee5 spirv-fuzz: Enable some passes with high probability (#3860) 50e04f612 spirv-fuzz: Do not add constants for Block-decorated structs (#3862) 8edd79ddc spirv-fuzz: Fix to FuzzerPassFlattenConditionalBranches (#3865) 719bade4f spirv-fuzz: Fix TransformationRecordSynonymousConstants (#3868) 009facc97 spirv-fuzz: Fix flatten conditional branch transformation (#3859) fcb22ecf0 spirv-fuzz: Report fresh ids in transformations (#3856) c6ca885c0 [spirv-dis] Add some context comments to disassembly. (#3847) 446adb05f Fix use-after-move in val/validate.cpp (#3848) 4b07d50cd spirv-fuzz: Fix bug in TransformationDuplicateRegionWithSelection (#3819) fec56146a spirv-fuzz: Support OpNot bit instruction case (#3841) 9e17b9d07 spirv-fuzz: Return IR and transformation context after replay (#3846) e12087d6c spirv-fuzz: fix test (#3845) 9edeeafdb spirv-fuzz: Use unique_ptr<FactManager> in TransformationContext (#3844) 50dacda55 Start SPIRV-Tools v2020.6 b27e039c6 Finalize SPIRV-Tools v2020.5 a5903a969 Update CHANGES 330c72549 spirv-fuzz: Support dead blocks in TransformationAddSynonym (#3832) 36185f8b0 spirv-fuzz: Move IRContext parameter into constructor (#3837) 0e7fe4d35 Add missing backticks around <result-id> (#3840) d1bb98fd4 Validate SPIRV Version number when parsing binary header (#3834) 67525bded spirv-fuzz: Create synonym of int constant using a loop (#3790) 7cc4b4d2c Fix compiler error on macOS with XCode12 (#3836) 5a5b750aa spirv-fuzz: Handle OpPhis in TransformationInlineFunction (#3833) 0a1fb588c Update CHANGES 125b64241 spirv-fuzz: Refactor fuzzer, replayer and shrinker (#3818) 60ce96e2f spirv-fuzz: Add pass recommendations (#3757) 2945963cc spirv-fuzz: Consider all ids from dead blocks irrelevant (#3795) 50ae4c5f4 Fix header guard macros (#3811) 296e9c7bc spirv-fuzz: Fix TransformationDuplicateRegionWithSelection (#3815) 937a757f0 spirv-val: Add DeviceIndex (#3812) 34ef0c3fd Fix missed modification flagging (#3814) 748edbf8c spirv-fuzz: Use an irrelevant id for the unused components (#3810) 8d49fb2f4 spirv-fuzz: Improvements to random number generation (#3809) 7e28d809c Add buffer oob check to bindless instrumentation (#3800) 8fc504110 spirv-fuzz: Remove CanFindOrCreateZeroConstant (#3807) e8ce4355a spirv-fuzz: Add bit instruction synonym transformation (#3775) e7c84feda spirv-fuzz: Skip unreachable blocks (#3729) f20b523cb Fix build errors (#3804) 3131686d2 spirv-fuzz: Handle invalid ids in fact manager (#3742) 4c239bd81 spirv-fuzz: Support memory instructions MoveInstructionDown (#3700) 1e1c308de spirv-fuzz: Pass submanagers to other submanagers when necessary (#3796) f62357e7b spirv-fuzz: Transformation to flatten conditional branch (#3667) 5df930054 spirv-val: Add BaseInstance, BaseVertex, DrawIndex, and ViewIndex (#3782) 286b3095d Properly mark IR changed if instruction folder creates more than one constant. (#3799) 726af6f78 Add missing file to BUILD.gn (#3798) 244e6c1be spirv-fuzz: Add TransformationDuplicateRegionWithSelection (#3773) 5dcb576b6 spirv-reduce: Support reducing a specific function (#3774) de7d57984 spirv-reduce: Refactoring (#3793) ed9863e46 Favour 'integrity' over 'coherence' as a replacement for 'sanity'. (#3619) 8743d385f spirv-fuzz: Fix header guards in transformations/fuzzer passes (#3784) 2de7d3af0 spirv-fuzz: Add SPIRV_FUZZ_PROTOC_COMMAND (#3789) e589d0d57 Add missing include (#3788) a715b1b40 Improve spirv-fuzz CMake code (#3781) a187dd58a Allow SPV_KHR_8bit_storage extension. (#3780) 1ab52e54a spirv-opt: Add function to compute nesting depth of a block (#3771) fd05605be spirv-fuzz: Transformation to convert OpSelect to conditional branch (#3681) 2c60d16a6 spirv-val: Add Vulkan VUID labels to BuiltIn (#3756) c341f7a6c spirv-fuzz: Add support for BuiltIn decoration (#3736) c278dada9 spirv-fuzz: Fix GetIdEquivalenceClasses (#3767) 788468408 spirv-fuzz: Replace id in OpPhi coming from a dead predecessor (#3744) 3daabd321 spirv-fuzz: Transformation to replace the use of an irrelevant id (#3697) d7f078f27 spirv-fuzz: TransformationMutatePointer (#3737) 43a518601 spirv-fuzz: Compute interprocedural loop nesting depth of blocks (#3753) 8a0ebd40f Correctly replace debug lexical scope of instruction (#3718) f428aa39c spirv-fuzz: Remove opaque pointer design pattern (#3755) 08291a3a9 spirv-fuzz: Create synonym via OpPhi and existing synonyms (#3701) 7e4948b2a Add LoopNestingDepth function to StructuredCFGAnalysis (#3754) 50cf38b8c spirv-fuzz: Do not make synonyms of void result ids (#3747) bceab9fab Do not register DebugFunction for functions optimized away. (#3749) e02f178a7 Handle DebugScope in compact-ids pass (#3724) 9e26ae045 spirv-fuzz: Overflow ids (#3734) 2205254cf Fix DebugNoScope to not output InlinedAt operand. (#3748) 230f363e6 spirv-fuzz: Split the fact manager into multiple files (#3699) 5adc5ae64 spirv-fuzz: Add inline function transformation (#3517) 1341b58a8 spirv-fuzz: Fix MaybeGetZeroConstant (#3740) 12df3cafe Fix SSA-rewrite to remove DebugDeclare for variables without loads (#3719) 3f8501de9 Add undef for inlined void function (#3720) 4dd122392 spirv-fuzz: Add words instead of logical operands (#3728) b79773a35 CCP should mark IR changed if it created new constants. (#3732) a711c594b spirv-fuzz: add FuzzerPassAddCompositeInserts (#3606) 582c276d4 spirv-fuzz: Support pointer types in FuzzerPassAddParameters (#3627) 3434cb0b0 Let ADCE pass check DebugScope (#3703) ee7f0c882 spirv-opt: Implement opt::Function::HasEarlyReturn function (#3711) e28436f2b spirv-fuzz: Check termination instructions when donating modules (#3710) 1023dd7a0 Fix -Wrange-loop-analysis warning (#3712) 82f4bf128 spirv-fuzz: Check header dominance when adding dead block (#3694) b8de4f57e Allow DebugTypeTemplate for Type operand (#3702) c20995ef8 spirv-fuzz: Improve code coverage of tests (#3686) eade36db2 spirv-fuzz: Fuzzer pass to randomly apply loop preheaders (#3668) 72ea7bec4 spirv-fuzz: Support identical predecessors in TransformationPropagateInstructionUp (#3689) b4c4da3e7 Improve non-semantic instruction handling in the optimizer (#3693) 948577c5d Fix the bug (#3680) df859f77d spirv-fuzz: Check integer and float width capabilities (#3670) 2641d3351 spirv-fuzz: consider additional access chain instructions (#3672) 5e5929455 spirv-fuzz: Ignore specialization constants (#3664) 1435e427d Fix the bug (#3683) be099cde1 spirv-fuzz: Fix width in FuzzerPassAddEquationInstructions (#3685) f0ca96d12 Preserve debug info in dead-insert-elim pass (#3652) 0d629b903 Validate more OpenCL.DebugInfo.100 instructions (#3684) 13a65b1ae Only validation locations for appropriate execution models (#3656) fd3cabd8b spirv-fuzz: Fix in operand type assertion (#3666) f50553867 spirv-opt: Add spvOpcodeIsAccessChain (#3682) b7056e7e0 spirv-fuzz: FuzzerPassPropagateInstructionsUp (#3478) 8e1380996 Handle no index access chain in local access chain convert (#3678) bdeeae78a Roll 2 dependencies (#3677) 2990a2192 Avoid using /MP4 for clang on windows. (#3662) 7b2dd11dd spirv-fuzz: TransformationReplaceAddSubMulWithCarryingExtended (#3598) 6d7f34fbf spirv-fuzz: Add TransformationMakeVectorOperationDynamic (#3597) d29eac95a spirv-fuzz: iterate over blocks in replace linear algebra pass (#3654) efc85ff66 spirv-fuzz: make outliner pass use additional transformations (#3604) 5fd92a7e0 OpenCL.DebugInfo.100 DebugTypeArray with variable size (#3549) 3f33a9aa5 spirv-opt: Improve the code of the Instruction class (#3610) 0419751b0 spirv-fuzz: Handle OpPhis in livesafe functions (#3642) a10e76059 spirv-fuzz: Handle OpPhi during constant obfuscation (#3640) 28f32ca53 spirv-fuzz: Fix FuzzerPassCopyObjects (#3638) 8bc27a1cf spirv-fuzz: Remove OpFunctionCall operands in correct order (#3630) d9c73ebd9 spirv-fuzz: Handle capabilities during module donation (#3651) 9f2223602 spirv-fuzz: Refactor boilerplate in TransformationAddParameter (#3625) 92a71657f spirv-fuzz: TransformationMoveInstructionDown (#3477) b78f4b151 Remove DebugDeclare only for target variables in ssa-rewrite (#3511) 91cea06ab Fix typo in ASAN CI build (#3623) 2aaa8653d spirv-fuzz: Transformation to add loop preheader (#3599) 96bcc8274 spirv-fuzz: Pass to replace int operands with ints of opposite signedness (#3612) ebaefda66 Debug info preservation in loop-unroll pass (#3548) 50300450a Validator support for non-semantic clspv reflection (#3618) ab4fe12a4 spirv-fuzz: Fix memory bugs (#3622) c6e6597c4 spirv-fuzz: Implement the OpOuterProduct linear algebra case (#3617) 054f034ea spirv-fuzz: Compute corollary facts from OpBitcast (#3538) a1ea15c90 Update some language usage. (#3611) 863b8e3d3 spirv-fuzz: Relax type constraints in DataSynonym facts (#3602) 7e75fea9e spirv-fuzz: Remove non-deterministic behaviour (#3608) f9b088fe0 Avoid use of 'sanity' and 'sanity check' in the code base (#3585) 150be20d4 spirv-fuzz: Add condition to make functions livesafe (#3587) ce16ccf38 Rolling 4 dependencies (#3601) 1dfc6fc7e spirv-fuzz: Implement the OpTranspose linear algebra case (#3589) b63f0e5ed Fix SyntaxWarning in Python 3.8 (#3388) 6aed7ffbc CMake: Enable building with BUILD_SHARED_LIBS=1 (#3490) 31c821393 Avoid operand type range checks (#3379) 6a3eb679b Preserve debug info in scalar replacement pass (#3461) 2796840d2 Update OpenCL capabilities validation (#3149) b25ee93c2 build(deps): bump lodash from 4.17.15 to 4.17.19 in /tools/sva (#3596) git-subtree-dir: third_party/SPIRV-Tools git-subtree-split: 82b378d671836b51343b010ca9ec32db14485147
-
Alexis Hetu authored
Changes: 7845730ca Bump revision to 4, for SPIR-V 1.5. 05836bdba Add SPV_EXT_shader_image_int64 (#170) be32cb6c8 Added SPV_KHR_fragment_shading_rate (#172) c43a43c7c Register the Xenia emulator as a generator (#171) d4e76fb32 Register the Messiah SPIR-V CodeGen (#169) 060627f0b Register the ANGLE compiler (#168) 03a842f95 Rebuild of latest headers, which slightly moves OpTerminateInvocation 3fdabd0da Reserve SPIR-V token range for upcoming Intel extensions. (#165) 5538bf438 Update BUILD.bazel and BUILD.gn (#166) 96013f32b Publish the headers for the clspv embedded reflection non-semantic extended instruction set (#164) 76afa6397 Update the registry in spir-v.xml to modernize and split out opcodes. (#156) Commands: ./third_party/update-spirvheaders.sh Bug: b/123642959 Change-Id: I68027fa8e2770cac37af6d648fbb655b2112ee88 -
Alexis Hetu authored
7845730ca Bump revision to 4, for SPIR-V 1.5. 05836bdba Add SPV_EXT_shader_image_int64 (#170) be32cb6c8 Added SPV_KHR_fragment_shading_rate (#172) c43a43c7c Register the Xenia emulator as a generator (#171) d4e76fb32 Register the Messiah SPIR-V CodeGen (#169) 060627f0b Register the ANGLE compiler (#168) 03a842f95 Rebuild of latest headers, which slightly moves OpTerminateInvocation 3fdabd0da Reserve SPIR-V token range for upcoming Intel extensions. (#165) 5538bf438 Update BUILD.bazel and BUILD.gn (#166) 96013f32b Publish the headers for the clspv embedded reflection non-semantic extended instruction set (#164) 76afa6397 Update the registry in spir-v.xml to modernize and split out opcodes. (#156) git-subtree-dir: third_party/SPIRV-Headers git-subtree-split: 7845730cab6ebbdeb621e7349b7dc1a59c3377be
-
- 29 Oct, 2020 1 commit
-
-
Nicolas Capens authored
llvm::PointerType::isValidElementType() checks that the pointee type is not void. Use a byte pointer instead. Bug: b/155148722 Change-Id: Ibf2fd23ce0a19a6947a6817f0b73753cfa170832 Reviewed-on: https://swiftshader-review.googlesource.com/c/SwiftShader/+/49568Tested-by:
Nicolas Capens <nicolascapens@google.com> Reviewed-by:
Ben Clayton <bclayton@google.com> Kokoro-Result: kokoro <noreply+kokoro@google.com>
-