Skip to content

Shader language based off GLSL that allows compiling multiple shaders into modules.

License

Notifications You must be signed in to change notification settings

akb825/ModularShaderLanguage

Repository files navigation

Introduction

ModularShaderLanguage

The Modular Shader Language (MSL) is a pre-compiled shader language with multiple targets. It is effectively a wrapper around GLSL and relies on external tools to handle the main work of the compilation. The primary goals are:

  • Provide an environment more similar to other compiled languages, such as access to a preprocessor and compile-time errors that point to the file.
  • Allow targeting multiple platforms with different capabilities with the same source.
  • Relies on official and external tools as much as possible. This makes the language easier to extend and maintain and allows other third party tools, such as optimizers, to be used.
  • Allows all stages of the pipeline to be specified in the same source. This gives more flexibility in how you organize your source.
  • Allows for render states and sampler states to be declared in the shader. This gives more flexibility in client applications by allowing these to be set in the shader without hard-coding them in the application.
  • Pipeline is linked when compiling the shader modules, allowing for earlier checks and easier loading of shaders in the final application.

Language and compilation overview

See the Language description for a more detailed description.

The core of the language is GLSL 450 for Vulkan with the following changes:

  • Uses a C preprocessor to allow for advanced macros and #includes.
  • Allows tagging of elements to only be included for specific pipeline stages of the shader.
  • Allows the removal of uniform blocks to use the same source on targets that don't support them.
  • Declaration of the full pipeline used with the entry points used at each stage and render states. Multiple pipelines can be declared in the same shader. (e.g. different rendering techniques or passes)
  • Declaration of sampler states.

Not all language features will be available on all targets. The targets will pre-define macros to determine their capabilities, allowing for conditional compiling can be used to switch between implementations when differences arise.

After the initial processing is done on the shader to transform it into standard GLSL, it gets passed into glslang to convert it to SPIR-V. From there, SPIRV-Cross is used to convert from SPIR-V to other targets, including various flavors of GLSL (including ES) and Metal.

After translating the individual entry points to the target language, it may additionally go through an additional tool to process the file. For example, another shader compiler (such as the HLSL or Metal compilers) or an optimizer. (such as GLSL Optimizer)

Multiple shader files may be compiled into a module. Examples for combining modules include:

  • All of the render passes, quality levels, etc. for a single object.
  • Separate modules for each quality level.
  • All of the shaders for a specific library.

Dependencies

The following software is required to build MSL:

  • cmake 3.10 or later
  • boost (required unless only building client library without tests)
  • Python 3 or later (required unless only building client library)
  • glslang (required for compiler, provided as submodule)
  • SPIRV-Cross (required for compiler, provided as submodule)
  • SPIRV-Tools (required for compiler, provided as submodule)
  • FlatBuffers (required if changing the schema)
  • doxygen (optional)
  • gtest (optional)

Note: Boost must be built with C++11 support. For example, when building and installing through the b2 bootstrap command: ./b2 "-std=c++11" -j4 install

Note: When Boost is manually installed, the appropriate variables should be set. In the case of Windows, the Boost_DIR variable should be set. (example: Boost_DIR=C:\local\boost_1_83_0\lib64-msvc-14.1\cmake\Boost-1.83.0) In Windows, the path to the libraries (e.g. C:\local\boost_1_83_0\lib64-msvc-14.1) should be set on PATH to ensure the DLLs can be loaded.

The glslang, SPIRV-Cross, and SPIRV-Tools submodules can be grabbed by running git submodule update --init --recursive.

Additional tools such as Microsoft's HLSL compiler and Apple's Metal compiler will be required when compiling shaders for certain platforms.

Platforms

MSL has been built for and tested on the following platforms:

  • Linux (GCC and LLVM clang)
  • Windows (requires Visual Studio 2017 or later)
  • macOS

C++17 must be supported by the compiler being used.

Building

Building is done with CMake. To build a release build, execute the following commands:

ModularShaderLanguage$ mkdir build
ModularShaderLanguage$ cd build
ModularShaderLanguage/build$ cmake .. -DCMAKE_BUILD_TYPE=Release
ModularShaderLanguage/build$ make

The tests can be run by running the command:

ModularShaderLanguage/build$ ctest

The following options may be used when running cmake:

Compile Options:

  • -DCMAKE_BUILD_TYPE=Debug|Release: Building in Debug or Release. This should always be specified.
  • -DCMAKE_INSTALL_PREFIX=path: Sets the path to install to when running make install.
  • -DMSL_SHARED=ON|OFF: Set to ON to build with shared libraries, OFF to build with static libraries. Default is OFF.
  • -DMSL_STATIC_RUNTIME=ON|OFF: Set to ON to use the static runtime library on Windows. When OFF, it will respect the existing value of CMAKE_MSVC_RUNTIME_LIBRARY, or use dynamic runtime if otherwise unset. It is not recommended to set this to ON when MSL_SHARED is also ON. Default is OFF.

Enabled Builds

  • -DMSL_BUILD_TESTS=ON|OFF: Set to ON to build the unit tests. gtest must also be found in order to build the unit tests. Defaults to ON.
  • -DMSL_BUILD_DOCS=ON|OFF: Set to ON to build the documentation. doxygen must also be found in order to build the documentation. Defaults to ON.
  • -DMSL_BUILD_COMPILE=ON|OFF: Set to ON to build the compile library. Defaults to ON.
  • -DMSL_BUILD_CLIENT=ON|OFF: Set to ON to build the client library. Defaults to ON.
  • -DMSL_BUILD_TOOLS=ON|OFF: Set to ON to build the tools. Defaults to ON.

Miscellaneous Options:

  • -DMSL_OUTPUT_DIR=directory: The folder to place the output files. This may be explicitly left empty in order to output to the defaults used by cmake, but this may prevent tests and executables from running properly when MSL_SHARED is set to ON. Defaults to ${CMAKE_BINARY_DIR}/output.
  • -DMSL_EXPORTS_DIR=directory: The folder to place the cmake exports when building. This directory can be added to the module path when embedding in other projects to be able to use the library_find() cmake function. Defaults to ${CMAKE_BINARY_DIR}/cmake.
  • -DMSL_ROOT_FOLDER=folder: The root folder for the projects in IDEs that support them. (e.g. Visual Studio or XCode) This is useful if embedding MSL in another project. Defaults to MSL.
  • -DMSL_INSTALL=ON|OFF: Allow installation for MSL components. This can be useful when embedding in other projects to prevent installations from including MSL. For example, when statically linking into a shared library. Default is ON.
  • -DMSL_INSTALL_SET_RPATH=ON|OFF: Set rpath during install for the library and tool on installation. Set to OFF if including in another project that wants to control the rpath. Default is ON.
  • -DCMAKE_OSX_DEPLOYMENT_TARGET=version: Minimum version of macOS to target when building for Mac. Defaults to 10.15.

Once you have built and installed MSL, you can find the various modules with the find_package() CMake function. For example:

find_package(MSL COMPONENTS Compile Client)

In this example both the Compile and Client modules are found, but you can choose only one if you don't require both.

You can either link to the MSL::Module target or use the MSLModule_LIBRARIES and MSLModule_INCLUDE_DIRS CMake variables, replacing Module with the module name. For example: MSLCompile_LIBRARIES and MSLCompile_INCLUDE_DIRS. The MSL::mslc and MSL::mslb-extract targets may also be used for the corresponding tool executables.

Note: In order for find_package() to succeed, you will need to add the base installation path to CMAKE_PREFIX_PATH.

Modules

MSL contains the following modules:

  • Compile: (Optional) The library for processing shader files and compiling them into modules.
  • Client: (Optional) A library for reading in shader modules for C and C++ applications.
  • tools: (Optional) The mslc tool for compiling shader files and mslb-extract tool for extracting info from compiled shaders.

The directory structure of the include files is:

MSL/[Module]/Header.h

For example:

#include <MSL/Compile/Target.h>