Unity loads compiled shaders from your built application in the following way:
This approach ensures that Unity and the graphics driver avoid processing and storing all the shader variants on the GPU before Unity needs them. But there might be a visible stall when the graphics driver creates a GPU-specific shader variant for the first time.
Unity caches each GPU-specific shader variant, to avoid another stall when Unity needs the shader variant again.
Unity removes the shader variant completely from CPU and GPU memory when there are no longer any objects that reference the shader variant.
Unity only loads compiled shaders that are compatible with the platform’s graphics API, hardware and graphics tier.
If Unity can’t find the shader variant it needs because you or Unity stripped the shader variant from your built application, Unity tries to select a similar shader variant. If Unity can’t find a similar shader variant, it uses the magenta error shader.
You can enable strict shader variant matching to stop Unity trying to select a similar shader variant.
If a shader variant contains multiple subshaders, Unity tries to select and use a single subshader that’s compatible with all of the following:
Unity searches for the first compatible subshader among the following elements in the following order:
If Unity can’t find a compatible subshader, it uses the magenta error shader.
You can set which subshaders are compatible with which hardware using ShaderLab tags. See ShaderLab: assigning tags to a SubShader.
To avoid visible stalls at performance-intensive times, Unity can ask the graphics driver to create GPU representations of shader variants before they’re first needed. This is called prewarming.
You can prewarm in the following ways:
You can also add shader variant collections to the Preloaded shaders section of the Graphics Settings window. Unity uses the ShaderVariantCollection.WarmUp
API to load and prewarm the shader variant collections when your built application starts.
If you build for DirectX 12, Metal or Vulkan, the graphics driver can only create an accurate GPU representation of a shader variant if it knows the exact vertex data layout and render state. If a prewarmed GPU representation is inaccurate, Unity might still stall when it needs to create the accurate representation.
To create accurate variants and avoid stalling, you should prewarm by rendering Materials off-screen.
还可以:
Experimental.Rendering.ShaderWarmup
, but only if you can provide the vertex data layout and set the render state accurately.ShaderVariantCollection.Warmup
or Shader.WarmupAllShaders
, which may create inaccurate prewarmed GPU representations because you can’t provide a vertex data layout or render state.In your built application, Unity stores several ‘chunks’ of compressed shader variant data. Each chunk contains multiple shader variants. When Unity loads a scene at runtime, it loads all the scene’s chunks into CPU memory and decompresses them.
To reduce memory usage on platforms that have limited memory, you can limit the size of chunks and how many decompressed chunks Unity keeps in memory.
To do this, in Player settings, select Other Settings > Shader Variant Loading and adjust the following settings:
0
, which means there’s no limit.See PlayerSettings.SetDefaultShaderChunkCount for more information.
You can use Override to override the values for each platform individually. See PlayerSettings.SetShaderChunkCountForPlatform for more information.
You can also use Shader.maximumChunksOverride to override Default chunk count at runtime.
You can use the following profiler markers to see shader loading in the Profiler:
Shader.ParseThreaded
and Shader.ParseMainThread
for Unity loading the shader object from serialized data.Shader.CreateGPUProgram
for Unity creating a GPU-specific version of a shader variant.Did you find this page useful? Please give it a rating:
Thanks for rating this page!
What kind of problem would you like to report?
Thanks for letting us know! This page has been marked for review based on your feedback.
If you have time, you can provide more information to help us fix the problem faster.
Provide more information
You've told us this page needs code samples. If you'd like to help us further, you could provide a code sample, or tell us about what kind of code sample you'd like to see:
You've told us there are code samples on this page which don't work. If you know how to fix it, or have something better we could use instead, please let us know:
You've told us there is information missing from this page. Please tell us more about what's missing:
You've told us there is incorrect information on this page. If you know what we should change to make it correct, please tell us:
You've told us this page has unclear or confusing information. Please tell us more about what you found unclear or confusing, or let us know how we could make it clearer:
You've told us there is a spelling or grammar error on this page. Please tell us what's wrong:
You've told us this page has a problem. Please tell us more about what's wrong:
Thank you for helping to make the Unity documentation better!
Your feedback has been submitted as a ticket for our documentation team to review.
We are not able to reply to every ticket submitted.