mesa/.gitlab-ci/windows
Yonggang Luo 5109790cf9 ci/msvc: Install both msvc2019 and msvc2022
Currently only msvc2019 are used

This is did intentionally, so we have a history script install msvc2019 only within vs2022

Signed-off-by: Yonggang Luo <luoyonggang@gmail.com>
Reviewed-by: Jesse Natalie <jenatali@microsoft.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/26736>
2023-12-24 11:46:43 +00:00
..
deqp_runner_run.ps1 ci: deduplicate constructing the ARTIFACTS_BASE_URL 2023-12-13 21:12:22 +00:00
Dockerfile_build ci/msvc: Improve msvc init 2023-12-24 11:46:43 +00:00
Dockerfile_msvc ci/msvc: Improve msvc init 2023-12-24 11:46:43 +00:00
Dockerfile_test ci/msvc: Improve msvc init 2023-12-24 11:46:43 +00:00
mesa_build.ps1 ci/msvc: Rename vs to msvc for consistence 2023-12-24 11:46:43 +00:00
mesa_container.ps1 ci/windows: Use 2 container stages 2022-01-21 22:38:16 +00:00
mesa_deps_build.ps1 ci/msvc: Rename vs to msvc for consistence 2023-12-24 11:46:43 +00:00
mesa_deps_choco.ps1 ci/msvc: Split install vulkan sdk out of choco 2023-12-24 11:46:43 +00:00
mesa_deps_msvc.ps1 ci/msvc: Install both msvc2019 and msvc2022 2023-12-24 11:46:43 +00:00
mesa_deps_test.ps1 ci/msvc: Rename vs to msvc for consistence 2023-12-24 11:46:43 +00:00
mesa_deps_vulkan_sdk.ps1 ci/msvc: Split install vulkan sdk out of choco 2023-12-24 11:46:43 +00:00
mesa_init_msvc.ps1 ci/msvc: Install both msvc2019 and msvc2022 2023-12-24 11:46:43 +00:00
piglit_run.ps1 CI/windows: Apply CI_FDO_CONCURRENT to piglit too 2023-01-27 01:49:19 +00:00
README.md ci/vs2019: switch to powershell 7 2022-06-14 21:14:33 +00:00
spirv2dxil_check.ps1 ci/windows: Get DXIL.dll (and DXCompiler.dll) from GitHub and put it in System32 2022-11-03 23:54:45 +00:00
spirv2dxil_run.ps1 ci/windows: normalize line endings 2022-01-19 15:17:17 +00:00

Native Windows GitLab CI builds

Unlike Linux, Windows cannot reuse the freedesktop ci-templates as they exist as we do not have Podman, Skopeo, or even Docker-in-Docker builds available under Windows.

We still reuse the same model: build a base container with the core operating system and infrequently-changed build dependencies, then execute Mesa builds only inside that base container. This is open-coded in PowerShell scripts.

Base container build

The base container build job executes the mesa_container.ps1 script which reproduces the ci-templates behaviour. It looks for the registry image in the user's namespace, and exits if found. If not found, it tries to copy the same image tag from the upstream Mesa repository. If that is not found, the image is rebuilt inside the user's namespace.

The rebuild executes docker build which calls mesa_deps.ps1 inside the container to fetch and install all build dependencies. This includes Visual Studio Community Edition (downloaded from Microsoft, under the license which allows use by open-source projects), other build tools from Chocolatey, and finally Meson and Python dependencies from PyPI.

This job is executed inside a Windows shell environment directly inside the host, without Docker.

Mesa build

The Mesa build runs inside the base container, executing mesa_build.ps1. This simply compiles Mesa using Meson and Ninja, executing the build and unit tests. Currently, no build artifacts are captured.

Using build scripts locally

*.ps1 scripts for building dockers are using PowerShell 7 to run