platform/upstream/SPIRV-Tools.git
7 years agoDeadBranchElim: Fix dead block detection to ignore backedges
GregF [Wed, 23 Aug 2017 23:05:38 +0000 (17:05 -0600)]
DeadBranchElim: Fix dead block detection to ignore backedges

- DeadBranchElim: Make sure to mark orphan'd merge blocks and continue
targets as live.
- Add test with loop in dead branch
- Add test that orphan'd merge block is handled.

Fixes https://github.com/KhronosGroup/SPIRV-Tools/issues/776

7 years agoInlineOpaque: Remove from usage until complete Opaque policy is designed.
GregF [Tue, 29 Aug 2017 00:02:14 +0000 (18:02 -0600)]
InlineOpaque: Remove from usage until complete Opaque policy is designed.

7 years agoUpdate changes for fix to issue 782
David Neto [Wed, 30 Aug 2017 03:22:07 +0000 (23:22 -0400)]
Update changes for fix to issue 782

7 years agoInline: Fix remapping of non-label forward references in callee phi
GregF [Wed, 30 Aug 2017 00:35:05 +0000 (18:35 -0600)]
Inline: Fix remapping of non-label forward references in callee phi

7 years agoDisassembler: Print colour codes only when writing to a terminal
David Neto [Mon, 28 Aug 2017 14:30:58 +0000 (10:30 -0400)]
Disassembler: Print colour codes only when writing to a terminal

7 years agoFix encode zero bits on word boundary bug
Andrey Tuganov [Mon, 28 Aug 2017 17:18:45 +0000 (13:18 -0400)]
Fix encode zero bits on word boundary bug

Bit stream writer was manifesting incorrect behaviour when the following
two conditions were met:
- writer was on 64-bit word boundary
- WriteBits was invoked with num_bits=0 (can happen when a Huffman codec has only one
value)

The bug was causing very rare sporadic corruption which was detected by
tests after a random experimental change in MARK-V model.

7 years agoShow result id for CompositeInsert validation failure
David Neto [Thu, 24 Aug 2017 22:11:23 +0000 (18:11 -0400)]
Show result id for CompositeInsert validation failure

7 years agoREADME: Add reference to SPIR-V size reduction white paper
GregF [Thu, 24 Aug 2017 22:36:53 +0000 (16:36 -0600)]
README: Add reference to SPIR-V size reduction white paper

7 years agoWindows: Increase intensity of blue text
David Neto [Thu, 24 Aug 2017 14:34:00 +0000 (10:34 -0400)]
Windows: Increase intensity of blue text

7 years agoFix: background color was erroneously reset on Win32 platform.
Lukas Hermanns [Sun, 20 Aug 2017 12:11:50 +0000 (14:11 +0200)]
Fix: background color was erroneously reset on Win32 platform.

Fix: background color was erroneously reset on Win32 platform.

7 years agoUpdated capabilites for SampleMask
David Neto [Wed, 23 Aug 2017 17:28:48 +0000 (13:28 -0400)]
Updated capabilites for SampleMask

SPIRV-Headers recently fixed the capability dependency
for SampleMask.  It depends on Shader, not SampleRateShading

7 years agoOpt: Create InlineOpaquePass
GregF [Tue, 15 Aug 2017 23:58:28 +0000 (17:58 -0600)]
Opt: Create InlineOpaquePass

Only inline calls to functions with opaque params or return

TODO: Handle parameter type or return type where the opqaue
type is buried within an array.

7 years agoOpt: Have "size" passes process full entry point call tree.
GregF [Thu, 10 Aug 2017 22:42:16 +0000 (16:42 -0600)]
Opt: Have "size" passes process full entry point call tree.

Includes code to deal correctly with OpFunctionParameter. This
is needed by opaque propagation which may not exhaustively inline
entry point functions.

Adds ProcessEntryPointCallTree: a method to do work on the
functions in the entry point call trees in a deterministic order.

7 years agoSupport supplying extra definitions via CMAKE variable
Lei Zhang [Wed, 16 Aug 2017 20:42:50 +0000 (16:42 -0400)]
Support supplying extra definitions via CMAKE variable

7 years agoHuffman codec can serialize to text
Andrey Tuganov [Fri, 11 Aug 2017 20:51:24 +0000 (16:51 -0400)]
Huffman codec can serialize to text

Refactored the Huffman codec implementation and added ability to
serialize to C++-like text format. This would reduce the time-complexity
if loading hard-coded codecs.

7 years agoOpt: Add opaque tests
GregF [Tue, 15 Aug 2017 21:54:41 +0000 (15:54 -0600)]
Opt: Add opaque tests

7 years agoAdd id descriptor feature to SPIR-V
Andrey Tuganov [Wed, 2 Aug 2017 20:47:25 +0000 (16:47 -0400)]
Add id descriptor feature to SPIR-V

Id descriptors are computed as a recursive hash of all instructions used
to define an id. Descriptors are invarint of actual id values and
the similar code in different files would produce the same descriptors.

Multiple ids can have the same descriptor. For example
%1 = OpConstant %u32 1
%2 = OpConstant %u32 1
would produce two ids with the same descriptor. But
%3 = OpConstant %s32 1
%4 = OpConstant %u32 2
would have descriptors different from %1 and %2.

Descriptors will be used as handles of move-to-front sequences in SPIR-V
compression.

7 years agoADCE: Add support for function calls
GregF [Fri, 4 Aug 2017 21:04:37 +0000 (15:04 -0600)]
ADCE: Add support for function calls

ADCE will now generate correct code in the presence of function calls.
This is needed for opaque type optimization needed by glslang. Currently
all function calls are marked as live. TODO: mark calls live only if they
write a non-local.

7 years agoUpdate CHANGE to list fix for issue 755
David Neto [Thu, 10 Aug 2017 17:13:33 +0000 (13:13 -0400)]
Update CHANGE to list fix for issue 755

7 years agoInliner: callee can have early return that isn't multi-return
David Neto [Wed, 9 Aug 2017 18:59:04 +0000 (14:59 -0400)]
Inliner: callee can have early return that isn't multi-return

Avoid generating an invalid OpLabel.
Create the continue target for the single-trip loop only if
you actually created the header for the single-trip loop.

Fixes https://github.com/KhronosGroup/SPIRV-Tools/issues/755

7 years agoAccessChainConvert: Add HasOnlySupportedRefs()
GregF [Fri, 4 Aug 2017 18:00:30 +0000 (12:00 -0600)]
AccessChainConvert: Add HasOnlySupportedRefs()

This avoids conversion on variables which will not ultimately be optimized.
Also removed an obsolete restriction from FindTargetVars(). Also added
decorates to supported refs (eg. RelaxedPrecision). Also fixed name to
IsNonTypeDecorate().

7 years agoInline: Split out InlineExhaustivePass from InlinePass
GregF [Tue, 1 Aug 2017 23:20:13 +0000 (17:20 -0600)]
Inline: Split out InlineExhaustivePass from InlinePass

7 years agoMem2Reg: Allow Image and Sampler types as base target types.
GregF [Thu, 3 Aug 2017 23:27:02 +0000 (17:27 -0600)]
Mem2Reg: Allow Image and Sampler types as base target types.

7 years agoUpdate CHANGES with common uniform loads pass
David Neto [Fri, 4 Aug 2017 21:48:22 +0000 (17:48 -0400)]
Update CHANGES with common uniform loads pass

7 years agoUpdate README.md with new code-reduction passes
GregF [Thu, 3 Aug 2017 16:37:26 +0000 (10:37 -0600)]
Update README.md with new code-reduction passes

7 years agoAdd CommonUniformElim pass
GregF [Mon, 3 Jul 2017 23:23:04 +0000 (17:23 -0600)]
Add CommonUniformElim pass

- UniformElim: Only process reachable blocks

- UniformElim: Don't reuse loads of samplers and images across blocks.
  Added a second phase which only reuses loads within a block for samplers
  and images.

- UniformElim: Upgrade CopyObject skipping in GetPtr

- UniformElim: Add extensions whitelist
  Currently disallowing SPV_KHR_variable_pointers because it doesn't
  handle extended pointer forms.

- UniformElim: Do not process shaders with GroupDecorate

- UniformElim: Bail on shaders with non-32-bit ints.

- UniformElim: Document support for only single index and add TODO.

7 years agoAdd MemPass, move all shared functions to it.
GregF [Thu, 27 Jul 2017 19:30:12 +0000 (13:30 -0600)]
Add MemPass, move all shared functions to it.

7 years agoAdd multi-sequence move-to-front implementation
Andrey Tuganov [Mon, 24 Jul 2017 18:29:35 +0000 (14:29 -0400)]
Add multi-sequence move-to-front implementation

Add MultiMoveToFront class which supports multiple move-to-front
sequences and allows to promote value in all sequences at once.

Added caching for last accessed sequence handle and last accessed value
in each sequence.

7 years agoUpdate CHANGES with recently added optimizations
David Neto [Tue, 1 Aug 2017 19:33:15 +0000 (15:33 -0400)]
Update CHANGES with recently added optimizations

7 years agoOpt: Add new size-reduction passes to usage message.
GregF [Tue, 1 Aug 2017 18:55:29 +0000 (12:55 -0600)]
Opt: Add new size-reduction passes to usage message.

7 years agoAdded C++ code generation to spirv-stats
Andrey Tuganov [Mon, 31 Jul 2017 17:08:38 +0000 (13:08 -0400)]
Added C++ code generation to spirv-stats

The tool can now generate C++ code returning some of the historgrams and
Huffman codecs generated from those historgrams.

7 years agoAdd Appveyor config that uses VS 2017
David Neto [Tue, 1 Aug 2017 15:42:28 +0000 (11:42 -0400)]
Add Appveyor config that uses VS 2017

7 years agoOpt: Delete names and decorations of dead instructions
GregF [Wed, 26 Jul 2017 22:34:41 +0000 (18:34 -0400)]
Opt: Delete names and decorations of dead instructions

7 years agoOpt: HasOnlySupportedRefs should consider OpCopyObject
Lei Zhang [Mon, 24 Jul 2017 15:43:47 +0000 (11:43 -0400)]
Opt: HasOnlySupportedRefs should consider OpCopyObject

This fixes test failure after merging the previous pull request.

7 years agoRevert "Revert "Opt: LocalBlockElim: Add HasOnlySupportedRefs""
Lei Zhang [Mon, 24 Jul 2017 14:37:38 +0000 (10:37 -0400)]
Revert "Revert "Opt: LocalBlockElim: Add HasOnlySupportedRefs""

This reverts commit df96e243c633b939690a42d89904e04f50126e86.

7 years agoAdd extension whitelists to size-reduction passes.
GregF [Wed, 19 Jul 2017 00:57:26 +0000 (18:57 -0600)]
Add extension whitelists to size-reduction passes.

Currently only SPV_KHR_variable_pointers is disallowed in passes which
do pointer analysis. Positive and negative tests of the general extensions
mechanism were added to aggressive_dce but cover all passes.

7 years agoRevert "Opt: LocalBlockElim: Add HasOnlySupportedRefs"
Lei Zhang [Sat, 22 Jul 2017 14:48:28 +0000 (10:48 -0400)]
Revert "Opt: LocalBlockElim: Add HasOnlySupportedRefs"

This reverts commit 2d0f7fbc1151004c4cf111b947f1070a03dfe092.

7 years agoOpt: LocalBlockElim: Add HasOnlySupportedRefs
greg-lunarg [Sat, 22 Jul 2017 14:32:19 +0000 (08:32 -0600)]
Opt: LocalBlockElim: Add HasOnlySupportedRefs

Verifies that targeted variables have only access chain and direct
loads and stores as references.

7 years agoFix handling of CopyObject in GetPtr and its call sites
GregF [Tue, 18 Jul 2017 20:42:51 +0000 (14:42 -0600)]
Fix handling of CopyObject in GetPtr and its call sites

7 years agoFix Visual Studio size_t cast compiler warning
Lenny Komow [Thu, 13 Jul 2017 17:13:14 +0000 (11:13 -0600)]
Fix Visual Studio size_t cast compiler warning

Visual Studio was complaining about possible loss of data on 64-bit
builds, due to an implicit cast from size_t to int. This changes the
data to use an int with no cast.

7 years agoLocalMultiStore: Always put varId for backedge on loop phi function.
Greg Fischer [Tue, 11 Jul 2017 22:52:19 +0000 (16:52 -0600)]
LocalMultiStore: Always put varId for backedge on loop phi function.

And always patch the backedge operand when patching phi functions. This
approach is more correct and cleaner. The previous code was generating
incorrect phis when the backedge block had no predecessors.

7 years agoDeadBranchElim: Improve algorithm to only remove blocks with no predecessors
GregF [Mon, 10 Jul 2017 23:20:35 +0000 (17:20 -0600)]
DeadBranchElim: Improve algorithm to only remove blocks with no predecessors

Must be careful not to remove blocks pointed at by unreachable blocks

7 years agoMinor code review feedback on AggressiveDCE
David Neto [Mon, 10 Jul 2017 15:45:59 +0000 (11:45 -0400)]
Minor code review feedback on AggressiveDCE

7 years agoAdd AggressiveDCEPass
GregF [Thu, 8 Jun 2017 16:37:21 +0000 (10:37 -0600)]
Add AggressiveDCEPass

Create aggressive dead code elimination pass
This pass eliminates unused code from functions. In addition,
it detects and eliminates code which may have spurious uses but which do
not contribute to the output of the function. The most common cause of
such code sequences is summations in loops whose result is no longer used
due to dead code elimination. This optimization has additional compile
time cost over standard dead code elimination.

This pass only processes entry point functions. It also only processes
shaders with logical addressing. It currently will not process functions
with function calls. It currently only supports the GLSL.std.450 extended
instruction set. It currently does not support any extensions.

This pass will be made more effective by first running passes that remove
dead control flow and inlines function calls.

This pass can be especially useful after running Local Access Chain
Conversion, which tends to cause cycles of dead code to be left after
Store/Load elimination passes are completed. These cycles cannot be
eliminated with standard dead code elimination.

Additionally: This transform uses a whitelist of instructions that it
knows do have side effects, (a.k.a. combinators).  It assumes other
instructions have side effects: it will not remove them, and assumes
they have side effects via their ID operands.

7 years agoAdd LocalMultiStoreElim pass
GregF [Fri, 16 Jun 2017 21:37:31 +0000 (15:37 -0600)]
Add LocalMultiStoreElim pass

A SSA local variable load/store elimination pass.
For every entry point function, eliminate all loads and stores of function
scope variables only referenced with non-access-chain loads and stores.
Eliminate the variables as well.

The presence of access chain references and function calls can inhibit
the above optimization.

Only shader modules with logical addressing are currently processed.
Currently modules with any extensions enabled are not processed. This
is left for future work.

This pass is most effective if preceeded by Inlining and
LocalAccessChainConvert. LocalSingleStoreElim and LocalSingleBlockElim
will reduce the work that this pass has to do.

7 years agoDeadBranchElim: Add DeadBranchElimPass
GregF [Fri, 2 Jun 2017 19:23:20 +0000 (13:23 -0600)]
DeadBranchElim: Add DeadBranchElimPass

7 years agoInclude memory and semantics IDs when iterating over inbound IDs
David Neto [Tue, 4 Jul 2017 20:24:46 +0000 (16:24 -0400)]
Include memory and semantics IDs when iterating over inbound IDs

Fixes Instruction::ForEachInId so it covers
SPV_OPERAND_TYPE_MEMORY_SEMANTICS_ID and SPV_OPERAND_TYPE_SCOPE_ID.
Future proof a bit by using the common spvIsIdType routine.

Fixes https://github.com/KhronosGroup/SPIRV-Tools/issues/697

7 years agoMARK-V decoder supports extended instructions
Andrey Tuganov [Fri, 30 Jun 2017 18:59:24 +0000 (14:59 -0400)]
MARK-V decoder supports extended instructions

7 years agoUpdate CHANGES to say we use GNUIntallDirs
David Neto [Tue, 4 Jul 2017 16:27:31 +0000 (12:27 -0400)]
Update CHANGES to say we use GNUIntallDirs

7 years agoDefine variable to skip installation
d3x0r [Tue, 4 Jul 2017 13:11:40 +0000 (06:11 -0700)]
Define variable to skip installation

If this is used as a static library in another project, this does not
need to be installed, and otherwise will just clutter the application's install.
To use, define SKIP_SPIRV_TOOLS_INSTALL which internally defines
ENABLE_SPIRV_TOOLS_INSTALL to control installation.

Also include GNUInstallDirs to get standard output 'lib' directory which is sometimes 'lib64' and not 'lib'

7 years agoConvert pattern stack from deque to vector, and share it
Chris Forbes [Tue, 27 Jun 2017 23:28:22 +0000 (16:28 -0700)]
Convert pattern stack from deque to vector, and share it

Also move various vector::reserve calls to State ctor
Negligible perf benefit, but more tidy.

7 years agoAdded fixed width encoding to bit_stream
Andrey Tuganov [Thu, 29 Jun 2017 19:05:34 +0000 (15:05 -0400)]
Added fixed width encoding to bit_stream

Fixed width encoding is intended to be used for small unsigned integers
when the upper bound is known both to the encoder and the decoder
(for example move-to-front rank).

7 years agoAdded compression tool tools/spirv-markv. Work in progress.
Andrey Tuganov [Wed, 31 May 2017 17:07:51 +0000 (13:07 -0400)]
Added compression tool tools/spirv-markv. Work in progress.

Command line application is located at tools/spirv-markv
API at include/spirv-tools/markv.h

At the moment only very basic compression is implemented, mostly varint.
Scope of supported SPIR-V opcodes is also limited.

Using a simple move-to-front implementation instead of encoding mapped
ids.

Work in progress:
- Does not cover all of SPIR-V
- Does not promise compatibility of compression/decompression across
  different versions of the code.

7 years agoAdded log(n) move-to-front implementation
Andrey Tuganov [Mon, 12 Jun 2017 16:01:39 +0000 (12:01 -0400)]
Added log(n) move-to-front implementation

The implementation is based on AVL and order statistic tree.

It accepts all kinds of values and the implementation
doesn't expect the behaviour to be consistent with id coding.

Intended by SPIR-V compression algorithms.

7 years agoAdded Huffman codec to utils
Andrey Tuganov [Thu, 25 May 2017 15:21:12 +0000 (11:21 -0400)]
Added Huffman codec to utils

Attached ids to Huffman nodes for deterministic internal node
comparison.

7 years agoTravis CI: stop requiring sudo and use make instead of ninja
Lei Zhang [Tue, 27 Jun 2017 15:20:34 +0000 (11:20 -0400)]
Travis CI: stop requiring sudo and use make instead of ninja

This gives us shorter testing time since we can use the container
based testing environment, which starts faster. Also using make
means we don't need to install ninja separately.

7 years agoDon't do hash lookup twice in FindDef
Chris Forbes [Tue, 27 Jun 2017 21:21:33 +0000 (14:21 -0700)]
Don't do hash lookup twice in FindDef

7 years agoMove spv_instruction_t's into vector
Chris Forbes [Tue, 27 Jun 2017 21:21:00 +0000 (14:21 -0700)]
Move spv_instruction_t's into vector

No need to incur another copy here. These guys have embedded vectors
we'd rather not copy.

7 years agoReserve expected length of instructions vector
Chris Forbes [Tue, 27 Jun 2017 18:55:14 +0000 (11:55 -0700)]
Reserve expected length of instructions vector

7 years agoMove some temp vectors into parser state
Chris Forbes [Tue, 27 Jun 2017 18:00:06 +0000 (11:00 -0700)]
Move some temp vectors into parser state

We don't need to churn the allocations for these every instruction.

7 years agoBlockMerge: Add BlockMergePass
GregF [Wed, 7 Jun 2017 21:28:53 +0000 (15:28 -0600)]
BlockMerge: Add BlockMergePass

Also, add BasicBlock::tail()

7 years agoUpdate CHANGES
David Neto [Thu, 22 Jun 2017 14:22:55 +0000 (10:22 -0400)]
Update CHANGES

- Describe support for AMD extensions
- Describe recently added optimizer passes

7 years agoAdd support for SPV AMD extensions
Rex Xu [Wed, 21 Jun 2017 07:58:00 +0000 (15:58 +0800)]
Add support for SPV AMD extensions

7 years agomem2reg: Add InsertExtractElimPass
GregF [Fri, 26 May 2017 16:33:11 +0000 (10:33 -0600)]
mem2reg: Add InsertExtractElimPass

7 years agoTransform multiple entry points
David Neto [Tue, 20 Jun 2017 19:57:47 +0000 (15:57 -0400)]
Transform multiple entry points

Don't stop just after one because of short-circuiting logical-or.

7 years agomem2reg: Add LocalSingleStoreElimPass
GregF [Fri, 19 May 2017 23:31:28 +0000 (17:31 -0600)]
mem2reg: Add LocalSingleStoreElimPass

Eliminate function scope variables with one store, if possible.

7 years agomem2reg: Add pass to eliminate local loads and stores in single block.
GregF [Thu, 18 May 2017 20:51:55 +0000 (14:51 -0600)]
mem2reg: Add pass to eliminate local loads and stores in single block.

7 years agoDon't install googletest and googlemock
rdb [Wed, 7 Jun 2017 10:14:31 +0000 (12:14 +0200)]
Don't install googletest and googlemock

7 years agoMem2Reg: Add Local Access Chain Convert pass
GregF [Fri, 12 May 2017 23:27:21 +0000 (17:27 -0600)]
Mem2Reg: Add Local Access Chain Convert pass

- Supports OpAccessChain and OpInBoundsAccessChain
- Does not process modules with non-32-bit integer types.

7 years agoFix memory leak in ValidateBinaryUsingContextAndValidationState
Gabríel Arthúr Pétursson [Sat, 3 Jun 2017 23:08:22 +0000 (23:08 +0000)]
Fix memory leak in ValidateBinaryUsingContextAndValidationState

7 years agoBots print output from timed out tests
Andrey Tuganov [Tue, 30 May 2017 17:29:13 +0000 (13:29 -0400)]
Bots print output from timed out tests

Timeout set to 300 seconds. If no timeout, then ctest itself will be
timed out and terminated leaving no output.

7 years agoFixed misspelled ctest flag --output_on_failure
Andrey Tuganov [Mon, 29 May 2017 17:26:46 +0000 (13:26 -0400)]
Fixed misspelled ctest flag --output_on_failure

7 years agoSupport building on FreeBSD
rdb [Sun, 28 May 2017 21:19:58 +0000 (23:19 +0200)]
Support building on FreeBSD

7 years agoCFA: Move TraversalRoots and ComputeAugmentedCFG into CFA
Greg Fischer [Tue, 23 May 2017 17:31:56 +0000 (11:31 -0600)]
CFA: Move TraversalRoots and ComputeAugmentedCFG into CFA

7 years agoCFA: Pull in CalculateDominators
Greg Fischer [Tue, 9 May 2017 00:32:12 +0000 (18:32 -0600)]
CFA: Pull in CalculateDominators

7 years agoDefUseManager: Fix ReplaceAllUsesWith() to update inst_to_used_ids_
GregF [Wed, 17 May 2017 19:33:47 +0000 (13:33 -0600)]
DefUseManager: Fix ReplaceAllUsesWith() to update inst_to_used_ids_

7 years agoAdded extension SPV_VALIDATOR_ignore_type_decl_unique
Andrey Tuganov [Thu, 11 May 2017 19:32:29 +0000 (15:32 -0400)]
Added extension SPV_VALIDATOR_ignore_type_decl_unique

If extension is present in the module, validator will ignore the "type
declaration must be unique" rule.

7 years agoRemove unused this in lambda capture
Lei Zhang [Wed, 17 May 2017 18:12:25 +0000 (14:12 -0400)]
Remove unused this in lambda capture

7 years agoAdd SPIR-V 1.2 support, for OpenCL 2.2
David Neto [Tue, 14 Mar 2017 16:43:41 +0000 (12:43 -0400)]
Add SPIR-V 1.2 support, for OpenCL 2.2

7 years agoFix size_t conversion error on MinGW
David Neto [Mon, 15 May 2017 15:55:22 +0000 (11:55 -0400)]
Fix size_t conversion error on MinGW

7 years agoUpdate CHANGES: note fix of issue 629
David Neto [Fri, 12 May 2017 21:35:18 +0000 (17:35 -0400)]
Update CHANGES: note fix of issue 629

7 years agoInline: Inline early return function if no returns in loop.
Greg Fischer [Fri, 5 May 2017 02:55:53 +0000 (20:55 -0600)]
Inline: Inline early return function if no returns in loop.

7 years agoAdded bit stream utils
Andrey Tuganov [Mon, 24 Apr 2017 19:17:33 +0000 (15:17 -0400)]
Added bit stream utils

Also added generalized zigzag coding.
- Due to signed integers being mostly non-negative, improved zigzag coding
  to favor positive values.

7 years agoStats analyzer aggregates OpConstant usage
Andrey Tuganov [Thu, 4 May 2017 17:35:52 +0000 (13:35 -0400)]
Stats analyzer aggregates OpConstant usage

7 years agoStats analyzer uses validator
Andrey Tuganov [Wed, 3 May 2017 19:26:39 +0000 (15:26 -0400)]
Stats analyzer uses validator

Stats analyzer calls validator to check the instruction and update
validator state.

Fixed unit tests (validator was failing).

7 years agoAvoid snprintf warning in GCC 7.1
David Neto [Mon, 8 May 2017 19:39:30 +0000 (15:39 -0400)]
Avoid snprintf warning in GCC 7.1

Tries to fix https://github.com/KhronosGroup/SPIRV-Tools/issues/642
See also https://gcc.gnu.org/bugzilla/show_bug.cgi?id=80655

7 years agoInline: Create CFA class
Greg Fischer [Fri, 28 Apr 2017 19:38:10 +0000 (13:38 -0600)]
Inline: Create CFA class

Create class to encapsulate control flow analysis and share across
validator and optimizer. A WIP. Start with DepthFirstTraversal. Next
pull in CalculateDominators.

7 years agoUpdate set_spec_const_default_value_test.cpp
Mike Lothain [Mon, 8 May 2017 12:56:45 +0000 (13:56 +0100)]
Update set_spec_const_default_value_test.cpp

Work around warning of dangling else

7 years agoAdded Markov chain analysis to stats
Andrey Tuganov [Thu, 20 Apr 2017 19:32:38 +0000 (15:32 -0400)]
Added Markov chain analysis to stats

Added data structure to SpirvStats which is used to collect statistics
on opcodes following other opcodes.

Added a simple analysis print-out to spirv-stats.

7 years agoInline: Change "--inline-entry-points-all" to "-exhaustive"
Greg Fischer [Wed, 26 Apr 2017 00:07:35 +0000 (18:07 -0600)]
Inline: Change "--inline-entry-points-all" to "-exhaustive"

7 years agoInline: Fix inliner description in usage message to reflect exceptions.
Greg Fischer [Tue, 25 Apr 2017 23:47:18 +0000 (17:47 -0600)]
Inline: Fix inliner description in usage message to reflect exceptions.

7 years agoInline: Do not inline functions with multiple returns (for now)
GregF [Tue, 25 Apr 2017 19:57:20 +0000 (13:57 -0600)]
Inline: Do not inline functions with multiple returns (for now)

7 years agoAdd bit pattern interface for setting default value for spec constants
qining [Wed, 19 Apr 2017 22:10:59 +0000 (18:10 -0400)]
Add bit pattern interface for setting default value for spec constants

7 years agoUpdate CHANGES with recent news
David Neto [Thu, 20 Apr 2017 19:54:10 +0000 (15:54 -0400)]
Update CHANGES with recent news

7 years agoAdded --compact-ids to /tools/opt
Andrey Tuganov [Tue, 11 Apr 2017 19:11:04 +0000 (15:11 -0400)]
Added --compact-ids to /tools/opt

The pass remaps ids to a compact set which starts with %1 and
has no gaps.

7 years agoAdded option --preserve-numeric-ids to tools/spirv-as
Andrey Tuganov [Tue, 11 Apr 2017 23:46:15 +0000 (19:46 -0400)]
Added option --preserve-numeric-ids to tools/spirv-as

Added options to tools::Assemble

7 years agoAdded statistical analysis tool (tool/stats)
Andrey Tuganov [Thu, 6 Apr 2017 20:55:26 +0000 (16:55 -0400)]
Added statistical analysis tool (tool/stats)

Currently analyzes percentages of the following:
- version (how many 1.0 or 1.1)
- generator
- extension
- capability
- opcode prevalence

7 years agoTest source language HLSL
David Neto [Thu, 6 Apr 2017 15:04:09 +0000 (11:04 -0400)]
Test source language HLSL

7 years agoSupport SPV_KHR_storage_buffer_storage_class
David Neto [Sun, 26 Mar 2017 01:12:22 +0000 (21:12 -0400)]
Support SPV_KHR_storage_buffer_storage_class

Includes interaction with SPV_KHR_variable_pointers

TODO: Update capabilitly dependency tests for new capabilities.

7 years agoValidator support for Variable Pointer extension.
Ehsan Nasiri [Wed, 1 Feb 2017 20:37:39 +0000 (15:37 -0500)]
Validator support for Variable Pointer extension.

If the variable_pointer extension is used:

* OpLoad's pointer argument may be the result of any of the following:
 * OpSelect
 * OpPhi
 * OpFunctionCall
 * OpPtrAccessChain
 * OpCopyObject
 * OpLoad
 * OpConstantNull

* Return value of a function may be a pointer.

* It is valid to use a pointer as the return value of a function.

* OpStore should allow a variable pointer argument.