platform/upstream/Vulkan-Tools.git
7 years agolayers: Fix enum use in GetStateStructPtrFromObject
Chris Forbes [Mon, 24 Apr 2017 18:39:44 +0000 (11:39 -0700)]
layers: Fix enum use in GetStateStructPtrFromObject

Everything around this was updated to use the new enums, but not this
function. Mostly works by accident since many of these coincide.

7 years agolayers: Inline VkCommandBuffer overload of clear_cmd_buf_...
Chris Forbes [Mon, 24 Apr 2017 18:22:45 +0000 (11:22 -0700)]
layers: Inline VkCommandBuffer overload of clear_cmd_buf_...

This was silly. On the very next line, we called GetCBNode again.

7 years agolayers: Drop dead string conversion for command types
Chris Forbes [Mon, 24 Apr 2017 18:18:52 +0000 (11:18 -0700)]
layers: Drop dead string conversion for command types

No callers.

7 years agolayers: Banish 'skip_call' once and forever
Mark Lobodzinski [Mon, 24 Apr 2017 15:11:35 +0000 (09:11 -0600)]
layers: Banish 'skip_call' once and forever

Except for swapchain.cpp, which is undergoing a merge into CV.

Change-Id: I8b18518ef662a9a11a808ef3dce1b8f60d858fb3

7 years agotests: Update database to make validation happy
Jeremy Hayes [Mon, 24 Apr 2017 16:37:44 +0000 (10:37 -0600)]
tests: Update database to make validation happy

Change-Id: I2002d23d09208e4154fe06a864ae9c8d78f0bc49

7 years agolayers: Force all device extensions disabled initially
Chris Forbes [Mon, 24 Apr 2017 16:45:34 +0000 (09:45 -0700)]
layers: Force all device extensions disabled initially

Should really fix device initialization so we don't need to do this
explicitly.

7 years agolayers: Final object-type cleanup and loose ends
Mark Lobodzinski [Mon, 24 Apr 2017 14:58:52 +0000 (08:58 -0600)]
layers: Final object-type cleanup and loose ends

Fixed a few DebugReport object type casts and a couple of missed
spots with internal object type usage.

Change-Id: Iaa8bdcf60d5ec89e1da64227f2b7367ce6c64dc1

7 years agovulkaninfo: Fix various entries in VkPhysicalDeviceFeatures output
Tobias Markus [Sun, 23 Apr 2017 14:18:20 +0000 (16:18 +0200)]
vulkaninfo: Fix various entries in VkPhysicalDeviceFeatures output

The VkPhysicalDeviceFeatures dump missed the multiViewport and
samplerAnisotropy fields. The alphaToOne field was at the wrong position
(compared to the official definition in the Vulkan specification).

The fields {vertex,fragment}StoresAndAtomics as well as
shaderTessellationAndGeometryPointSize had the misleading and incorrect
names {vertex,tessellation,geometry}SideEffects.

7 years agolayers: Change obj type conversion routine name
Mark Lobodzinski [Thu, 13 Apr 2017 20:25:39 +0000 (14:25 -0600)]
layers: Change obj type conversion routine name

Change-Id: I3b4208ca3777ac46b2c5ab2839c268ed4381a2ac

7 years agolayers: Remove unused string helper from CV
Mark Lobodzinski [Thu, 13 Apr 2017 19:36:37 +0000 (13:36 -0600)]
layers: Remove unused string helper from CV

Change-Id: I36daf405a6c8170d7ee61f5a07bdad045f8d6304

7 years agolayers: Switch CV over to layer object types
Mark Lobodzinski [Thu, 13 Apr 2017 17:10:11 +0000 (11:10 -0600)]
layers: Switch CV over to layer object types

Convert internal uses of VkDebugReportObjectTypeEXT for the core-
validation layer to use the internal layer-povided object-type.

Also modified tests for changed error text.

Change-Id: If080f4bf452ead0c6fecc648309bfd95b27fc0ce

7 years agoscripts: Make object string conversion array const
Mark Lobodzinski [Tue, 18 Apr 2017 20:22:10 +0000 (14:22 -0600)]
scripts: Make object string conversion array const

Prevents unused var warnings by changing to be a constant.

Change-Id: Ie8f6cc837dd589074ae2278de34d4bd0a3e66236

7 years agolayers: Use UNKNOWN object type instead zero-cast
Mark Lobodzinski [Thu, 13 Apr 2017 16:06:48 +0000 (10:06 -0600)]
layers: Use UNKNOWN object type instead zero-cast

Change-Id: I36c175e78d7a33667f1485ed0e53f1dadab62a31

7 years agolayers: remove PIPELINE_STATE::vertexAttributeDescriptions
Chris Forbes [Fri, 21 Apr 2017 21:31:05 +0000 (14:31 -0700)]
layers: remove PIPELINE_STATE::vertexAttributeDescriptions

Nobody used this.

7 years agolayers: Simplify ValidateCmd
Chris Forbes [Fri, 21 Apr 2017 20:27:08 +0000 (13:27 -0700)]
layers: Simplify ValidateCmd

Nested !=, == was needlessly weird.

7 years agolayers: Remove GLOBAL_CB_NODE::numCmds
Chris Forbes [Fri, 21 Apr 2017 20:21:58 +0000 (13:21 -0700)]
layers: Remove GLOBAL_CB_NODE::numCmds

Nobody used this.

7 years agolayers: slim down draw counting
Chris Forbes [Fri, 21 Apr 2017 20:15:15 +0000 (13:15 -0700)]
layers: slim down draw counting

We used to care how many draws there were. Now we just care whether
there were /no/ draws (in one place)

7 years agolayers: Fix naming of enable flags for swapchain exts
Chris Forbes [Fri, 21 Apr 2017 20:06:31 +0000 (13:06 -0700)]
layers: Fix naming of enable flags for swapchain exts

Should be consistent with the actual extension names

7 years agolayers: Tidy up tracking of enabled device extensions in CV
Chris Forbes [Fri, 21 Apr 2017 20:01:20 +0000 (13:01 -0700)]
layers: Tidy up tracking of enabled device extensions in CV

- These are all guaranteed initialized.
- Convert code to data.

7 years agoscripts:Updated Validation IDs for spec 1.0.48
Tobin Ehlis [Wed, 19 Apr 2017 23:30:52 +0000 (17:30 -0600)]
scripts:Updated Validation IDs for spec 1.0.48

This was much nicer after that last update. Cmd line was:
python spec.py -update -remap 2937-3217:557-375:669-2819:739-536:
751-2106,4:1263-2956,5:2237-3104:2906-3203:2960-3222

Updated parser to BeautifulSoup so we can now use the HTML spec
directly from online again. You may have to install BeautifulSoup
python module separately to be able to run.

Had to manually import errors 911 and 912 which are only present in
the non-extension spec. This is an issue we're planning to fix when
unique ids are integrated into the spec which may acutally finally
happen within a month.

7 years agodocs: Update Android documentation
Cody Northrop [Mon, 10 Apr 2017 14:00:40 +0000 (08:00 -0600)]
docs: Update Android documentation

7 years agoandroid: Add script that installs APKs
Cody Northrop [Mon, 17 Apr 2017 15:35:43 +0000 (09:35 -0600)]
android: Add script that installs APKs

7 years agoandroid: Add test_APK script for layer validation
Cody Northrop [Tue, 11 Apr 2017 17:05:44 +0000 (11:05 -0600)]
android: Add test_APK script for layer validation

This is a script we've been using internally for a while, no reason
not to make it public.  It installs our layer validation tests, runs
them, and gathers output.  Improvements are welcome!

Usage:

  ./test_APK.sh -s <serial number> -p <plaform name> -f <gtest_filter>

7 years agoandroid: Add build script that includes APK packaging
Cody Northrop [Mon, 27 Mar 2017 19:08:30 +0000 (13:08 -0600)]
android: Add build script that includes APK packaging

7 years agoheader: Update to 1.0.48 Vulkan version
Mark Lobodzinski [Mon, 17 Apr 2017 18:28:27 +0000 (12:28 -0600)]
header: Update to 1.0.48 Vulkan version

- updated include/vulkan/vulkan.h
- updated scripts/vk.xml
- updated layers json files
- updated tests json files
- updated vulkan.hpp

Change-Id: I90407d181ad6a4652e1d1f210ee9b9d21c7857b0

7 years agolayers:Remove old INFO message
Tobin Ehlis [Mon, 17 Apr 2017 17:13:12 +0000 (11:13 -0600)]
layers:Remove old INFO message

INFO message in vkCreateDescriptorPool() is not needed and it was
returning a validation error if the callback returned "true" which is
just wrong. Killing the code altogether.

7 years agolayers: Special-case UO generation of QueuePresentKHR
Chris Forbes [Sun, 16 Apr 2017 01:13:17 +0000 (13:13 +1200)]
layers: Special-case UO generation of QueuePresentKHR

VkPresentInfo::pResults is an /output/ array. The generated code makes a
copy on the way in (pointlessly, but other clients of safe_* might find
this reasonable), but neglects to copy it back on the way out.

Lift the current code generated for QueuePresentKHR back into the
special cases, and add the correct post-call copy.

Fixes #1670.

V3: Just open-code the loop. I don't want to turn off MSVC's fussy mode,
and it's convinced both std::copy and std::copy_n are unsafe with all
raw pointers.

Signed-off-by: Chris Forbes <chrisforbes@google.com>
7 years agolayers:Add image layout validation for descriptors
Tobin Ehlis [Fri, 7 Apr 2017 18:20:30 +0000 (12:20 -0600)]
layers:Add image layout validation for descriptors

This change adds validation to make sure that an image layout at the
time the image is used in a descriptor matches the layout that was
given when the descriptor was updated.

Because image view covers a range of mip levels, loop over each level
and verify layouts one at a time.

Also Updated a number of validate functions to use cont ptr params for
data that they aren't changing.

7 years agoscripts: Convert ugly case statment to nice array
Mark Lobodzinski [Thu, 13 Apr 2017 14:36:18 +0000 (08:36 -0600)]
scripts: Convert ugly case statment to nice array

Since this was codegen'd, we can just create a static array for the
object type conversion and do away with all of the switch statement
mess.

Change-Id: I5fb20778d64f0675afa9c1563e2d44d22d5b4a02

7 years agolayers: Switch to codegen'd obj_type string helper
Mark Lobodzinski [Tue, 11 Apr 2017 21:43:49 +0000 (15:43 -0600)]
layers: Switch to codegen'd obj_type string helper

Updated LVTs for error string changes as well.

Change-Id: I5e0da92a9859e8ada7374af42a21a3f8f7629fdd

7 years agolayers: Use gen'd object types in object_tracker
Mark Lobodzinski [Tue, 11 Apr 2017 21:37:17 +0000 (15:37 -0600)]
layers: Use gen'd object types in object_tracker

Change-Id: I2166407bffcbf037d9b7898d91c674ed60fc95ba

7 years agoscripts: Add object type string helper func
Mark Lobodzinski [Tue, 11 Apr 2017 21:31:51 +0000 (15:31 -0600)]
scripts: Add object type string helper func

Also fixed a bug with the object type names.

Change-Id: Iea3c89a2e53266704aff0727296cce0e460195ce

7 years agolayers: Remove unnecessary args from OT helper fcns
Mark Lobodzinski [Tue, 11 Apr 2017 19:57:45 +0000 (13:57 -0600)]
layers: Remove unnecessary args from OT helper fcns

Change-Id: I0deb4d43c83cd126d0d4bb4e158907148a6e3753

7 years agolayers: Object tracker variable renaming/clang-format
Mark Lobodzinski [Mon, 3 Apr 2017 17:36:40 +0000 (11:36 -0600)]
layers: Object tracker variable renaming/clang-format

Change-Id: Id39eea99003c58dc183f45d4164c852328bc9826

7 years agolayers: Some object tracker cleanup
Mark Lobodzinski [Mon, 3 Apr 2017 17:34:36 +0000 (11:34 -0600)]
layers: Some object tracker cleanup

Change-Id: I8d4d82d763289df9dd9834236fdb984922304f11

7 years agolayers: Fix parameter validation ext enable struct
Mark Lobodzinski [Wed, 12 Apr 2017 19:57:42 +0000 (13:57 -0600)]
layers: Fix parameter validation ext enable struct

Change-Id: I48c27be03e5ccb4621e7c7fb7b21bb0bf1d8bceb

7 years agolayers: Fix object tracker extension struct
Mark Lobodzinski [Wed, 12 Apr 2017 19:56:58 +0000 (13:56 -0600)]
layers: Fix object tracker extension struct

Change-Id: Iec29cc46df0f12d7e1da4daa18fb02d5023151b5

7 years agolayers: Allow UO to codegen vkAllocateMemory
Mark Lobodzinski [Tue, 11 Apr 2017 15:38:34 +0000 (09:38 -0600)]
layers: Allow UO to codegen vkAllocateMemory

This was a special case, manually written as it contained a pnext
extension chain containing Vulkan handles. Codegen now covers this
case.

Change-Id: I086d4314aeb9968c3f151e4e7134de7846c1c8d0

7 years agoscripts: Add extension unwrapping support routines
Mark Lobodzinski [Fri, 7 Apr 2017 21:31:35 +0000 (15:31 -0600)]
scripts: Add extension unwrapping support routines

Change-Id: I86f30aed8a35d91d4c08585210cc0571a27c7430

7 years agoscripts: Add pNext-chain extension helper function
Mark Lobodzinski [Thu, 6 Apr 2017 16:07:42 +0000 (10:07 -0600)]
scripts: Add pNext-chain extension helper function

Unique-objects layer did not handle extension structs or chains of
extension structs. Automated generation and handling of unwrapped
struct chains.

Change-Id: I8cc813c9bf7290bbcec257245848e54e1ce8a0f7

7 years agovulkaninfo: Add missing case for CPU device
Chris Forbes [Wed, 12 Apr 2017 00:22:51 +0000 (17:22 -0700)]
vulkaninfo: Add missing case for CPU device

Fixes #1664

7 years agoscripts: Defer unique_objects processing
Mark Lobodzinski [Thu, 6 Apr 2017 21:22:07 +0000 (15:22 -0600)]
scripts: Defer unique_objects processing

Codegen created wrap/unwrap code on the fly as commands were processed
by the XML. Deferred codegen until all the data was complete and
collected.

Change-Id: I295ab59ad5dd24a5321e348cb18f96f2d0eed824

7 years agoheader: Update to 1.0.47 Vulkan version
Mark Lobodzinski [Mon, 10 Apr 2017 14:02:29 +0000 (08:02 -0600)]
header: Update to 1.0.47 Vulkan version

- updated include/vulkan/vulkan.h
- updated scripts/vk.xml
- updated layers json files
- updated tests json files
- updated vulkan.hpp

Change-Id: I0da07ad3d623d0f249593fa2d7d8e336e6ee8ad7

7 years agolayers:Refactor image layout validation
Tobin Ehlis [Fri, 17 Feb 2017 22:17:04 +0000 (15:17 -0700)]
layers:Refactor image layout validation

Streamline some of the image layout validation code. At the time of
CmdBeginRenderPass() remove the layout transition from validation code
and perform the layout transitions all at once.
This allows a bit of transition code to be killed so that the initial
transition code can share TransitionSubpassLayouts() function.

7 years agoloader: Fix loader and layer negotiation
Mark Young [Wed, 29 Mar 2017 19:39:27 +0000 (13:39 -0600)]
loader: Fix loader and layer negotiation

Resolve missing struct sType as well as extern of
vkNegotiateLoaderAndLayerInterface as a C function.  Finally,
bump up the JSON file version so it looks for the negotiate
function.

Change-Id: I7fd4784fce6cbd0c303f7b2bb354542e4b16b1df

7 years agobuild: Add notifications to travis config
Cody Northrop [Thu, 6 Apr 2017 19:18:13 +0000 (13:18 -0600)]
build: Add notifications to travis config

7 years agolayers: Fix GH 1639.
Jeremy Hayes [Tue, 4 Apr 2017 21:05:52 +0000 (15:05 -0600)]
layers: Fix GH 1639.

Check base+count instead of just base. Fix FramebufferCreateErrors test
to use the correct number of mip levels. Also, add a test for count,
fix a few function names, and apply some soothing const cream.

Change-Id: Ib2deb8bc27e76138f83b3dd32529583a30085cda

7 years agobuild: Add object_types codegen steps for Android
Mark Lobodzinski [Wed, 5 Apr 2017 14:18:18 +0000 (08:18 -0600)]
build: Add object_types codegen steps for Android

Change-Id: If54d83c9b5c67ad92f7510718e1194391bf9fff5

7 years agocmake: Add build steps for object types header
Mark Lobodzinski [Tue, 4 Apr 2017 13:38:17 +0000 (07:38 -0600)]
cmake: Add build steps for object types header

Change-Id: I395922f4876d1d3b950a4edd0aac9fc73733b9d5

7 years agoscripts: Add external/internal object type xlation
Mark Lobodzinski [Tue, 4 Apr 2017 18:07:38 +0000 (12:07 -0600)]
scripts: Add external/internal object type xlation

Change-Id: Ib621d93069912bac6bbdc643c02fe6b711803c6f

7 years agoscripts: Add object_type header file gen interface
Mark Lobodzinski [Mon, 3 Apr 2017 22:59:15 +0000 (16:59 -0600)]
scripts: Add object_type header file gen interface

Change-Id: I2e4a9be203f13daccc5674d0b8f66729046af46c

7 years agoscripts: Add object type enum generation to helper
Mark Lobodzinski [Mon, 3 Apr 2017 22:58:04 +0000 (16:58 -0600)]
scripts: Add object type enum generation to helper

Extended the helper_file_generator to produce an object type enum
header file.

Change-Id: I8013091b34028522d8f50ef3941d7021b262613c

7 years agoscripts:Fixup a few val error db mistakes
Tobin Ehlis [Wed, 5 Apr 2017 13:55:29 +0000 (07:55 -0600)]
scripts:Fixup a few val error db mistakes

Correctly mark which checks are implemented so that vkvalidatelayerdoc
documenation validation will pass.

7 years agoscripts:Update unique IDs for spec v1.0.45.1
Tobin Ehlis [Tue, 4 Apr 2017 18:23:48 +0000 (12:23 -0600)]
scripts:Update unique IDs for spec v1.0.45.1

Another massive update. Totally overhauled the mapping algorithm.
The basic outline of the new algorithm is:
-Try to map complete error message to prev ID
-Then try to map error msg w/o link to prev ID
-Finally try to map just core error string (no section) to prev ID
-Else assign it a new unique ID

See code for complete details.

In anticipation of integrated uniqueIDs I took a little liberty with
this update in that I didn't attempt to remap EVERY new ID to previous
IDs. I did many of them and made sure to account for every previous ID
that was implemented.
IDs will all be undergoing a one-time change with their integration
into the spec anyway so there is little harm in letting non-implemented
IDs drift a bit for now and it helps save my sanity.
I did add a validation step to the spec.py script to make sure and flag
any IDs that previously were implemented and suddenly are no longer in
the re-mapped version of IDs.

I manually presevered IDs 911 & 912 which get masked from the extension
spec.
I also had to do some manual updates on an offline spec to keep the
parser from breaking on the non-xhtml compliant spec.

Command line was:
python spec.py -update -remap 92-72:97-77:112-92:116-96:123-103:124-105:
133-114:148-2349:154-133,2:156-135:157-139:204-156:205-155:206-154:
417-269:1189-769:1417-938:1446-965:1448-967:1449-968:1487-974:
2193-1430,5:683-496:684-494:728-529:729-527:1628-1086:1731-1180:
1736-1183:1796-1234:1815-1251

7 years agowinsdk: Fix missing vulkaninfo file extension
Lenny Komow [Tue, 4 Apr 2017 21:35:28 +0000 (15:35 -0600)]
winsdk: Fix missing vulkaninfo file extension

Change-Id: I9cef2172ed568372bca512d597099c37e4f0766e

7 years agolayers: Fix incorrect feature protect for KHX ext
Mark Lobodzinski [Mon, 3 Apr 2017 16:39:08 +0000 (10:39 -0600)]
layers: Fix incorrect feature protect for KHX ext

Change-Id: I503c2984163455fd5fd91df6fa70da1dc88fc684

7 years agodemos: Remove DbgMsgs from incremental_present ext
Ian Elliott [Tue, 28 Mar 2017 17:10:18 +0000 (11:10 -0600)]
demos: Remove DbgMsgs from incremental_present ext

The only DbgMsg messages left tell the user, if they use
"--incremental_present", whether the functionality is actually being
used, or if the VK_KHR_incremental_present extension isn't available.

NOTE: When somebody wants to see all of the DbgMsg messages, they should
use "git revert" with this commit.

Change-Id: Ic4189cbec2a64c50135b16c331c808fbbce975dc

7 years agodemos: Use VK_KHR_incremental_present extension
Ian Elliott [Tue, 28 Mar 2017 17:06:33 +0000 (11:06 -0600)]
demos: Use VK_KHR_incremental_present extension

Show how to use the VK_KHR_incremental_present extension.  Other notes:

- There are a few diagnostic DbgMsg()'s, which can help show the usage.
- Added a "--incremental_present" command-line option to turn on use of
  VK_KHR_incremental_present
- Should compile and run on Windows, Linux, and Android, but the feature will
  only really be used on systems that support the extension.

Change-Id: I8a79d806cab7d35197c94dd85358a62b6b7469be

7 years agolayers: incremental_present parameter validation
Tobin Ehlis [Fri, 13 Jan 2017 19:13:57 +0000 (12:13 -0700)]
layers: incremental_present parameter validation

Add parameter validation for VK_KHR_incremental_present extension.
If the VkPresentRegionsKHR is included down the struct chain for
QueuePresentKHR() validate its parameters.

Change-Id: I97abe552411f229eecbbf7df7d565f7953cdd1b7

7 years agolayers: incremental_present rectangle validation
Tobin Ehlis [Fri, 13 Jan 2017 19:21:07 +0000 (12:21 -0700)]
layers: incremental_present rectangle validation

In core_validation verify the offset, extent & layer values for each
VkRectLayerKHR struct passed into vkQueuePresentKHR() for the
VK_KHR_incremental_present extension.

Change-Id: I4aa7cbac61afa6f4c9e733bb51cd486aadab5cec

7 years agoheader: Update to 1.0.46 Vulkan version
Mark Lobodzinski [Mon, 3 Apr 2017 14:22:04 +0000 (08:22 -0600)]
header: Update to 1.0.46 Vulkan version

- updated include/vulkan/vulkan.h
- updated scripts/vk.xml
- updated layers json files
- updated tests json files
- fixed include/vulkan/vulkan.hpp -- see Note

Note: The Vulkan.hpp generator asserted when processing the 1.0.46 header
files. Added a temporary workaround for this issue, but it may affect
use of the vulkan.hpp header file.

Change-Id: Iab296bf2004fbf6099baaab148994b15b0392381

7 years agoscripts: Add ceiling function to vk_struct_size_helper
mizhen [Fri, 31 Mar 2017 15:08:16 +0000 (09:08 -0600)]
scripts: Add ceiling function to vk_struct_size_helper

Change-Id: Ia377c52e43442fec17b823c888df6685eff0aca5

7 years agoloader: Fix loader crash with multiple instances
Lenny Komow [Fri, 31 Mar 2017 19:43:35 +0000 (13:43 -0600)]
loader: Fix loader crash with multiple instances

Change-Id: Ia72feb84bcc8bfa479694e901beb4fa685fdfdf3

7 years agolayers: Fix WriteDescriptorSet::dstSet validation
Dustin Graves [Thu, 30 Mar 2017 21:42:16 +0000 (15:42 -0600)]
layers: Fix WriteDescriptorSet::dstSet validation

VkWriteDescriptorSet::dstSet is ignored by vkCmdPushDescriptorSetsKHR,
so the 'must not be a null handle' validation for dstSet has been moved
from the code validating the VkWriteDescriptor struct members to the
code validating the vkUpdateDescriptorSets function parameters.

Change-Id: Ia6f11d33e4d57d4c848aab72cfd91da5d5a15a30

7 years agoandroid: Update to matching desktop glslang version
Cody Northrop [Wed, 29 Mar 2017 23:14:35 +0000 (17:14 -0600)]
android: Update to matching desktop glslang version

7 years agoexternal: Update external reference commit ID
Mike Weiblen [Wed, 29 Mar 2017 21:41:20 +0000 (15:41 -0600)]
external: Update external reference commit ID

Update glslang to latest.

Change-Id: I2d235b4282a61764949105b1b76ff9d1cddc204a

7 years agolayers: Rename format utils, strip Vk
Dave Houlton [Wed, 29 Mar 2017 17:43:58 +0000 (11:43 -0600)]
layers: Rename format utils, strip Vk

Change-Id: I4d192db22c51d2e9224b74487bfd5d6a58405028

7 years agolayers: refactor layer utils
Dave Houlton [Mon, 27 Mar 2017 23:25:54 +0000 (17:25 -0600)]
layers: refactor layer utils

Split format-related helper fxns out of vk_layer_utils.cpp into a new
file vk_format_utils.cpp.  Remove the duplicated fxns in the render
framework and share the new format utils across both projects.
Rename the util fxns into CamelCase per coding std.

Change-Id: I0f9a34bc5931dfca085dfdc8d4800664aec526cf

7 years agolayers: Add ios, mac and nintendo surface tracking
Mark Lobodzinski [Wed, 29 Mar 2017 16:51:30 +0000 (10:51 -0600)]
layers: Add ios, mac and nintendo surface tracking

Three extensions have been added that get VkSurface objects for
various operating environments. Added functions to object_tracker
to catch the creation of these Vulkan objects to prevent spurious
validation errors. Extensions are VK_NN_vi_surface, VK_MVK_ios_surface
and VK_MVK_macos_surface.

Change-Id: I0357a3a012c5020a5ab44877fd9fef627e769121

7 years agolayers: Remove unneccessary line in unique_objects
Mark Lobodzinski [Wed, 29 Mar 2017 17:55:44 +0000 (11:55 -0600)]
layers: Remove unneccessary line in unique_objects

Change-Id: If658b4196e895a1229495c6acb40fb50feadd02c

7 years agolayers: Fix push_desc_with_template in unique_objs
Mark Lobodzinski [Tue, 28 Mar 2017 22:22:56 +0000 (16:22 -0600)]
layers: Fix push_desc_with_template in unique_objs

Added unwrapping of vulkan objects embedded in this APIs data buffer.

Change-Id: Ibbee614148d10efe9a954cd793f0e92881300c71

7 years agolayers: Fix extension func/core struct codegen
Dustin Graves [Tue, 28 Mar 2017 20:18:54 +0000 (14:18 -0600)]
layers: Fix extension func/core struct codegen

Fix code generation for extension functions receiving struct parameter
types defined by core Vulkan.  Extensions are processed as separate
features by the code generator, and the type info required for structure
generation was not being shared across features.  The code generator has
been modified to share type info across features so that the validation
code generated for extension functions includes validation for core
structures:
 - Prevent unique objects and parameter validation code generators from
   clearing struct type info data structures at the start of feature
   processing.
 - Remove unused data structures from unique objects code generator.
 - Adds handle unwrapping and parameter validation for elements in the
   vkCmdPushDescriptorSetKHR pDescriptorWrites parameter.
 - Adds handle unwrapping and parameter validation for elements in the
   vkCreateSharedSwapCHainsKHR pCreateInfos parameter.
 - Adds VkAllocationCallback parameter validation to the WSI and
   descriptor update template extensions functions.

Change-Id: I016aa6550681dbf7d6bda834272374ce63ed1940

7 years agolayers: Add shader_subgroup_vote ext shader caps
Mark Lobodzinski [Tue, 28 Mar 2017 20:09:16 +0000 (14:09 -0600)]
layers: Add shader_subgroup_vote ext shader caps

Recognize and validate shader capabilities added in the new
VK_KHR_shader_subgroup_vote extension.

Change-Id: Ifbbcb1aa3b056707750c53d9a18965bfcae9028f

7 years agolayers: Add shader_subgroup_ballot ext shader caps
Mark Lobodzinski [Tue, 28 Mar 2017 19:34:55 +0000 (13:34 -0600)]
layers: Add shader_subgroup_ballot ext shader caps

Recognize and validate shader capabilities added in the new
VK_KHR_shader_subgroup_ballot extension.

Change-Id: I79f02f50600dcbd85f7b91aeefe56bb426f53b6b

7 years agolayers: Support viewport_array2 ext shader caps
Mark Lobodzinski [Thu, 23 Mar 2017 20:47:03 +0000 (14:47 -0600)]
layers: Support viewport_array2 ext shader caps

Recognize and validate shader capabilities added in the new
VK_NV_viewport_array2 extension.

Change-Id: Ifeb21d9230ca071a56246acc928add0a572b55f9

7 years agolayers: Support CapabilitySampleMaskOverrideCoverage
Mark Lobodzinski [Thu, 23 Mar 2017 20:30:25 +0000 (14:30 -0600)]
layers: Support CapabilitySampleMaskOverrideCoverage

Recognize and validate shader capability added in the new
VK_NV_sample_mask_override_coverage extension.

Change-Id: I30131189beee8cb5f087846eff3a5f7571d0d309

7 years agolayers: Support CapabilityGeometryShaderPassThroughNV
Mark Lobodzinski [Thu, 23 Mar 2017 20:04:56 +0000 (14:04 -0600)]
layers: Support CapabilityGeometryShaderPassThroughNV

Recognize and validate shader capability added in the new
VK_NV_geometry_shader_passthrough extension.

Change-Id: Iea46b9a8d0c77b695507ac5f1c8f8852f528c210

7 years agoandroid: Update toolchain revisions and locations
Cody Northrop [Mon, 27 Mar 2017 22:30:14 +0000 (16:30 -0600)]
android: Update toolchain revisions and locations

Start pulling from github again for more recent bits.

This includes changes to easily allow changing the repo url.

7 years agoheader: Update to 1.0.45 Vulkan version
Mark Lobodzinski [Mon, 27 Mar 2017 20:40:17 +0000 (14:40 -0600)]
header: Update to 1.0.45 Vulkan version

- updated include/vulkan/vulkan.h
- updated scripts/vk.xml
- updated layers json files
- updated tests json files
- updated include/vulkan/vulkan.hpp
- FIXED scripts/vk.xml (see note)

NOTE:
This commit also includes an unofficial change to vk.xml.  The 1.0.45
header update broke the structure definition for device_features2. The
mangled line has been replaced in this update.

Change-Id: If646355a5b211ca90484d449a1c55412decc3de6

7 years agoloader: Fix loader_extensions codegen for name defs
Mark Lobodzinski [Mon, 27 Mar 2017 21:47:01 +0000 (15:47 -0600)]
loader: Fix loader_extensions codegen for name defs

Codegen attempted to infer name definitions instead of pulling from
the source XML, causing errors in new header updates.

Change-Id: I04e03b45dacf7c943b91e47f6ecffc82354c6f1b

7 years agolayers: Add pNext cycle/redundancy checks to PV
Mark Lobodzinski [Mon, 27 Mar 2017 17:52:02 +0000 (11:52 -0600)]
layers: Add pNext cycle/redundancy checks to PV

Change-Id: I06d311821ef0c10683ad8bdaf076231143cde22f

7 years agoexternals: Update GitHub master commit refs
Mike Weiblen [Mon, 27 Mar 2017 20:54:27 +0000 (14:54 -0600)]
externals: Update GitHub master commit refs

Update commit IDs pointing to external repos:
- glslang_revision
- spirv-tools_revision

Change-Id: I369caf0943c360234854d5ba25e42776417b0e6a

7 years agocube: Remove most DbgMsg usage the VK_GOOGLE_display_timing extension
Ian Elliott [Mon, 27 Mar 2017 20:38:52 +0000 (14:38 -0600)]
cube: Remove most DbgMsg usage the VK_GOOGLE_display_timing extension

The only DbgMsg messages left tell the user, if they use
"--display_timing", whether the functionality is actually being used, or
if the VK_GOOGLE_display_timing extension isn't available.

NOTE: When somebody wants to see all of the DbgMsg messages, they should
use "git revert" with this commit.

7 years agocube: GH1609: Use VK_GOOGLE_display_timing extension
Ian Elliott [Wed, 22 Mar 2017 14:31:27 +0000 (08:31 -0600)]
cube: GH1609: Use VK_GOOGLE_display_timing extension

Show how to use the VK_GOOGLE_display_timing extension (currently, only
available on the Android O release).  Other notes:

- There are many diagnostic DbgMsg()'s, which can help show the usage.
- This includes a port of the Vulkan CTS (dEQP) time code for use in
  cube.
- Added a "--display_timing" command-line option to turn on use of
  VK_GOOGLE_display_timing
- Compiles and runs on Windows, Linux, and Android, but the feature will
  only really be used on systems that support the extension.

7 years agolayers: VK_KHR_maintenance1 false positives
Mike Schuchardt [Tue, 21 Mar 2017 22:33:26 +0000 (16:33 -0600)]
layers: VK_KHR_maintenance1 false positives

Skip checks that no longer apply when VK_KHR_maintenance1 is enabled.

Change-Id: I84d0fe889d0e567045aeb7fa7463dd2ec0d56789

7 years agolayers: Expose core validation extension info
Mike Schuchardt [Tue, 21 Mar 2017 22:30:37 +0000 (16:30 -0600)]
layers: Expose core validation extension info

Change-Id: I94d854ad59d42ea4a0de0b76c7fb3829baf52abb

7 years agolayers: Remove obsolete error check from CV
Mark Lobodzinski [Fri, 24 Mar 2017 21:09:23 +0000 (15:09 -0600)]
layers: Remove obsolete error check from CV

Bad shader capability check is now in the spirv validator.

Change-Id: I3d96f935d0adb7081d6693cfc004ba215391054e

7 years agoexternals: Update GitHub master commit refs
Mike Weiblen [Thu, 23 Mar 2017 20:12:18 +0000 (14:12 -0600)]
externals: Update GitHub master commit refs

Update commit IDs to external repos:
- glslang_revision
- spirv-headers_revision
- spirv-tools_revision

Change-Id: I79aa68a65d7440e4223b38401eef9bbb8d5a959f

7 years agolayers: Consider depth+stencil formats to be both float and uint
Chris Forbes [Fri, 10 Mar 2017 02:01:52 +0000 (15:01 +1300)]
layers: Consider depth+stencil formats to be both float and uint

Depending on which aspect we will consume, these can be either type.

Signed-off-by: Chris Forbes <chrisforbes@google.com>
7 years agolayers: Convert fundamental type enum to bit field
Chris Forbes [Fri, 10 Mar 2017 01:58:08 +0000 (14:58 +1300)]
layers: Convert fundamental type enum to bit field

Some VkFormats can be consumed as multiple types -- specifically,
depth/stencil is either float or uint, depending on which aspect we
consume.

Convert to bitfield, and require intersection rather than equality.
While we're at it, drop out some weird special-casing for unknown
component types-- this is left over from when shader validation was much
less complete.

Signed-off-by: Chris Forbes <chrisforbes@google.com>
7 years agolayers: Removing redundant if in unique_objects
Arda Coskunses [Fri, 24 Mar 2017 17:00:52 +0000 (11:00 -0600)]
layers: Removing redundant if in unique_objects

Exact same if check performed multiple times.
Removing redundant one

Change-Id: Iff32a724e58a06b4a967ba2632e60cc5b4050238

7 years agolayers: Refactor ResolveRemainingLevelsLayers
Mark Lobodzinski [Thu, 23 Mar 2017 15:43:35 +0000 (09:43 -0600)]
layers: Refactor ResolveRemainingLevelsLayers

Simplified source and consolidated usage.

Change-Id: I662a94381f3b6119978a53308dc616e942259941

7 years agodemos: Wait for fences before destroying swapchain
Tony Barbour [Thu, 23 Mar 2017 19:25:36 +0000 (13:25 -0600)]
demos: Wait for fences before destroying swapchain

Addresses  GH #1048

Change-Id: Ie94796bcd13dc506e1b97c483763df9023567ac6

7 years agotests: Add test case for VkQueueFlags checks
Mike Schuchardt [Tue, 7 Mar 2017 21:40:28 +0000 (14:40 -0700)]
tests: Add test case for VkQueueFlags checks

Change-Id: I5917fb3fe0360e51cf88196bf5f7d0fe118940b9

7 years agolayers: Add VU enums to VkQueueFlag checks
Mike Schuchardt [Thu, 23 Feb 2017 22:57:37 +0000 (15:57 -0700)]
layers: Add VU enums to VkQueueFlag checks

Split validation of command pool queue flag checks into a dedicated
function and add valid usage error enums.

Change-Id: I4fc4e71d96b818c281ad310dd0d15bca508efb94

7 years agolayers: GH1592, Fix unique_objects DebugMarker Ext
Mark Lobodzinski [Thu, 16 Mar 2017 17:54:35 +0000 (11:54 -0600)]
layers: GH1592, Fix unique_objects DebugMarker Ext

CodeGen ignored these APIs as they contain handles which are embedded
in a structure and aliased. Added manual coverage.

Change-Id: I81cf1945981a8e0b69966a9d0e190e49ff728ea8

7 years agolayers: Add image handles to layout error output
Mark Lobodzinski [Wed, 22 Mar 2017 19:06:12 +0000 (13:06 -0600)]
layers: Add image handles to layout error output

Also fixed up validation tests to handle message formatting changes.

Change-Id: I8671ae531d473bebdc034c33edcd9617ab96b836

7 years agolayers: Fill in core_validation log_msg handles
Mark Lobodzinski [Wed, 22 Mar 2017 13:37:04 +0000 (07:37 -0600)]
layers: Fill in core_validation log_msg handles

Also changed all object handle zero casts to use TYPE_UNKNOWN.

Change-Id: I212fd9dd50a25dec98d1fbf46caa73401450c89f

7 years agolayers: Fill in buffer_validation log_msg handles
Mark Lobodzinski [Tue, 21 Mar 2017 22:41:45 +0000 (16:41 -0600)]
layers: Fill in buffer_validation log_msg handles

Also updated some C-style casts and added TYPE_UNKNOWN where
appropriate.

Change-Id: Ia9c1d013dd73c4f6785df6151ee71715e310187b

7 years agoloader: Add guard around cmake header include.
Jamie Madill [Tue, 21 Mar 2017 17:48:13 +0000 (13:48 -0400)]
loader: Add guard around cmake header include.

This allows non-cmake platforms to compile the loader. Use a define
named VULKAN_NON_CMAKE_BUILD to disable CMAKE-specific features.

Change-Id: I6f6d8731fe1be60fd138e9fe1006c913fb029b47