mirror of
https://github.com/status-im/Vulkan-Docs.git
synced 2025-01-13 07:24:11 +00:00
26f0bdbf1e
* Update release number to 72. Github Issues: * Restructure the repository to put the specification `Makefile` and associated spec source material at the top level, `vk.xml` and associated scripts material in `xml/`, and generated include and source files in `include/vulkan/` and `src/ext_loader/`, respectively (public issue 436). * Add missing bullet point markup to flink:vkCmdCopyImage valid usage statement, so it gets a VUID assigned (public issue 627). * Fix broken links in a couple of extension appendices (public pull request 665). * Add the \<platform> tag to the index in section 4.1 of the registry schema documentation, and add the protect= attribute of \<extension> tags to the comments in `registry.rnc` (public issues 673, 678). * Add missing valid usage statements for sparse image interactions to flink:VkImageCreateInfo (public pull request 675). * Fix improper usage and grammar of "`can: not`" (public pull request 681). * Remove duplicate spec language and NOTE on present layout between the flink:vkAcquireNextImageKHR and flink:vkAcquireNextImage2KHR commands (public pull request 685). * Fix some typos and markup issues (public pull request 689; public issues 642, 667, 687). * Fix typo etext:VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_FENCE_FD_BIT -> ename:VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT in the <<external-semaphore-handle-types-compatibility, External semaphore handle types compatibility>> table (public pull request 691). Internal Issues: * Remove the need for the "`noautovalidity`" attribute on extension structures in `vk.xml`. It is now implied by the "`structextends`" attribute instead (internal issue 942). * Replace uses of "`currently bound`" with "`bound`", since "`currently`" is redundant and distracting, and add a corresponding rule to the style guide (internal issue 993). * Fixed subtle issues with the last updates to flink:vkAcquireNextImageKHR language that had resulted in ambiguities (internal issue 1178). * Make it clear that only one query of a given type is allowed at a time by reordering valid usage statements for flink:vkCmdBeginQuery and flink:vkCmdEndQuery, and removing redundant ones (internal issue 1213). * Swapped OL1 and OL3 in `tessparamUL.svg` to match previous version, and fixed where "`(no edge)`" appears (internal issue 1215). Other Issues: * Fixed a minor problem with the valid usage statement extraction script, and corresponding markup in the spec source. New Extensions: * `VK_AMD_shader_core_properties` * `VK_EXT_descriptor_indexing` * `VK_NV_shader_subgroup_partitioned`
111 lines
3.4 KiB
Makefile
111 lines
3.4 KiB
Makefile
# Copyright (c) 2013-2018 The Khronos Group Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
# If a recipe fails, delete its target file. Without this cleanup, the leftover
|
|
# file from the failed recipe can falsely satisfy dependencies on subsequent
|
|
# runs of `make`.
|
|
.DELETE_ON_ERROR:
|
|
|
|
# Generator scripts and options
|
|
# GENOPTS can be e.g. '-noprotect'
|
|
|
|
PYTHON ?= python3
|
|
PYFILES = genheaders.py reg.py
|
|
GENOPTS =
|
|
|
|
# Generate Vulkan header from XML. Many other files can be generated
|
|
# from vk.xml using the scripts, but they are all generated in ../ as
|
|
# part of the process of building the Specification.
|
|
#
|
|
# Targets:
|
|
#
|
|
# default / install - regenerate headers in ../include/vulkan/.
|
|
# validate - run XML validator on vk.xml against the schema.
|
|
# test - check if vulkan_core.h compiles.
|
|
# clean_dirt - remove intermediate files.
|
|
# clean - remove installed and intermediate files.
|
|
|
|
INCLUDE = ../include
|
|
VULKAN = $(INCLUDE)/vulkan
|
|
SRC = ../src
|
|
|
|
# Vulkan platform-specific headers
|
|
PLATFORM_HEADERS = \
|
|
$(VULKAN)/vulkan_android.h \
|
|
$(VULKAN)/vulkan_ios.h \
|
|
$(VULKAN)/vulkan_macos.h \
|
|
$(VULKAN)/vulkan_mir.h \
|
|
$(VULKAN)/vulkan_vi.h \
|
|
$(VULKAN)/vulkan_wayland.h \
|
|
$(VULKAN)/vulkan_win32.h \
|
|
$(VULKAN)/vulkan_xcb.h \
|
|
$(VULKAN)/vulkan_xlib.h \
|
|
$(VULKAN)/vulkan_xlib_xrandr.h
|
|
HEADERS = $(VULKAN)/vulkan_core.h $(PLATFORM_HEADERS)
|
|
EXTLOADER = $(SRC)/ext_loader
|
|
EXTSRCS = $(EXTLOADER)/vulkan_ext.c
|
|
|
|
default install: $(HEADERS) $(EXTSRCS)
|
|
|
|
################################################
|
|
|
|
# Autogenerate vulkan header from XML API description
|
|
|
|
# Python and XML files on which vulkan_core.h depends
|
|
VKH_DEPENDS = vk.xml genvk.py reg.py generator.py
|
|
|
|
$(HEADERS): $(VKH_DEPENDS)
|
|
$(PYTHON) genvk.py -registry vk.xml -o $(VULKAN) $(notdir $@)
|
|
|
|
platform: $(PLATFORM_HEADERS)
|
|
|
|
# Verify registry XML file against the schema
|
|
validate:
|
|
jing -c registry.rnc vk.xml
|
|
|
|
# Test that vulkan_core.h compiles
|
|
|
|
# Platforms to test
|
|
TESTDEFS = -DVK_USE_PLATFORM_XCB_KHR -DVK_USE_PLATFORM_XLIB_KHR
|
|
|
|
test: $(HEADERS) $(VULKAN)/vulkan.h $(VULKAN)/vk_platform.h
|
|
gcc -Wall -pedantic -std=c99 -c -I$(INCLUDE) test.c
|
|
g++ -Wall -c -std=c++98 -I$(INCLUDE) test.c
|
|
g++ -Wall -c -std=c++11 -I$(INCLUDE) test.c
|
|
gcc $(TESTDEFS) -Wall -pedantic -std=c99 -c -I$(INCLUDE) test.c
|
|
rm test.o
|
|
|
|
################################################
|
|
|
|
# Autogenerate extension loader from XML API description
|
|
# This also generates $(EXTLOADER)/vulkan_ext.h
|
|
|
|
#$(EXTLOADER)/vulkan_ext.c: $(VKH_DEPENDS)
|
|
$(EXTSRCS): $(VKH_DEPENDS)
|
|
$(PYTHON) genvk.py -registry vk.xml -o $(EXTLOADER) vulkan_ext.c
|
|
|
|
################################################
|
|
|
|
# Files to clean up
|
|
PYDIRT = diag.txt dumpReg.txt errwarn.txt *.pyc regdump.txt
|
|
DIRT = $(PYDIRT) ERRS \#*
|
|
|
|
# Clean intermediate files
|
|
clean_dirt:
|
|
-rm -f $(DIRT)
|
|
|
|
# Clean generated targets as well as intermediates.
|
|
clean clobber: clean_dirt
|
|
-rm -f $(HEADERS) $(PLATFORM_HEADERS) $(EXTSRCS)
|