xref: /OK3568_Linux_fs/yocto/meta-openembedded/meta-oe/recipes-graphics/vk-gl-cts/khronos-cts.inc (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1LICENSE = "Apache-2.0"
2LIC_FILES_CHKSUM = "file://LICENSE;md5=3b83ef96387f14655fc854ddc3c6bd57"
3
4SRC_URI = "\
5	git://github.com/KhronosGroup/VK-GL-CTS.git;protocol=https;name=vk-gl-cts;nobranch=1 \
6	git://github.com/google/amber;protocol=https;destsuffix=git/external/amber/src;name=amber;branch=main \
7	git://github.com/KhronosGroup/glslang.git;protocol=https;destsuffix=git/external/glslang/src;name=glslang;branch=master \
8	git://github.com/KhronosGroup/SPIRV-Headers.git;protocol=https;destsuffix=git/external/spirv-headers/src;name=spirv-headers;branch=master \
9	git://github.com/KhronosGroup/SPIRV-Tools.git;protocol=https;destsuffix=git/external/spirv-tools/src;name=spirv-tools;branch=master \
10	https://raw.githubusercontent.com/baldurk/renderdoc/v1.1/renderdoc/api/app/renderdoc_app.h;subdir=git/external/renderdoc/src;name=renderdoc \
11"
12
13S = "${WORKDIR}/git"
14
15SRCREV_FORMAT = "vk-gl-cts_amber_glslang_spirv-headers_spirv-tools"
16
17S = "${WORKDIR}/git"
18
19inherit pkgconfig cmake features_check
20
21ANY_OF_DISTRO_FEATURES += "opengl wayland"
22
23DEPENDS += "libpng zlib virtual/libgles2"
24
25SRC_URI += "file://0001-Workaround-for-GCC-11-uninit-variable-warnings-946.patch;patchdir=external/amber/src \
26            file://0001-Include-limits-header-for-numeric_limits.patch;patchdir=external/vulkancts \
27            file://0001-vulkancts.patch \
28            file://0001-use-library-sonames-for-linking.patch \
29"
30
31SRC_URI:append:libc-musl = "\
32	file://fix-musl.patch \
33"
34DEPENDS:append:libc-musl = " libexecinfo"
35
36SRC_URI:append:toolchain-clang = "\
37	file://fix-clang-private-operator.patch \
38"
39
40# The best thing for the user to do is to not specify any of the following
41# PACKAGECONFIGs (i.e. leave it blank) which tells the project to do its own
42# probing and build what it thinks is appropriate.
43# However, if you want, you can specify one of the following PACKAGECONFIGs
44# to override this behaviour.
45PACKAGECONFIG ??= ""
46PACKAGECONFIG[surfaceless] = "-DDEQP_TARGET=surfaceless,,,,,wayland x11_egl x11_glx x11_egl_glx"
47PACKAGECONFIG[wayland] = "-DDEQP_TARGET=wayland,,wayland,,,surfaceless x11_egl x11_glx x11_egl_glx"
48PACKAGECONFIG[x11_egl] = "-DDEQP_TARGET=x11_egl,,virtual/libx11 virtual/egl,,,surfaceless wayland x11_glx x11_egl_glx"
49PACKAGECONFIG[x11_glx] = "-DDEQP_TARGET=x11_glx,,virtual/libx11,,,surfaceless wayland x11_egl x11_egl_glx"
50PACKAGECONFIG[x11_egl_glx] = "-DDEQP_TARGET=x11_glx,,virtual/libx11 virtual/egl,,,surfaceless wayland x11_egl x11_glx"
51
52python __anonymous() {
53    # if the user doesn't specify any PACKAGECONFIG then the cts build system
54    # is going to probe the sysroot to try to figure out what to build
55    # in this case we try to guess whether the user is building for wayland
56    # or x11 and add the required dependencies automatically
57    distrofeatures = (d.getVar("DISTRO_FEATURES") or "")
58    if not bb.utils.contains_any("PACKAGECONFIG", ["surfaceless", "wayland", "x11_egl", "x11_glx", "x11_egl_glx"], True, False, d):
59        if "wayland" in distrofeatures:
60            d.appendVar("DEPENDS", " wayland ")
61        if "x11" in distrofeatures:
62            d.appendVar("DEPENDS", " virtual/libx11 virtual/egl ")
63}
64
65CTSDIR = "/usr/lib/${BPN}"
66
67FILES:${PN} += "${CTSDIR}"
68