diff options
author | Jeroen Bakker <jbakker> | 2020-07-17 14:47:10 +0300 |
---|---|---|
committer | Jeroen Bakker <jeroen@blender.org> | 2020-07-17 14:47:53 +0300 |
commit | 9582797d4b50a18040e96ae07aa8c7643cbcc25a (patch) | |
tree | d7dc8cf7bd4b6e82cdd059699d86057d7101b330 /source/blender/blenkernel/intern | |
parent | bf2bb6db26113d4c097d3f9201d40d295da223f5 (diff) |
Fix T77867: Link Duplicate Object crashes during batch creation
When using link duplicated objects it could happen that one object is
calculating the GPUBuffers and the second object is marking these
buffers invalid. This introduces threading issues.
This patch fixes this by combining the surface and surface per material
batches. Most likely the surface per material batches are used and when
requested you will most likely need the surface batch for the depth
tests and overlays.
During tests it slightly improves performance as batches aren't thrown
away without using it.
After this patch we can add a quick path for meshes with one material
and two materials.
Alternative approaches that have been checked:
- sync extraction per object: reduced performance to much (-15%)
({D8292})
- post checks: reduced the threading issues, but didn't solve it.
- separating preparation and execution of the extraction ({D8312})
Reviewed By: Clément Foucault
Differential Revision: https://developer.blender.org/D8329
Diffstat (limited to 'source/blender/blenkernel/intern')
0 files changed, 0 insertions, 0 deletions