mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-05-14 19:31:25 +00:00
This reverts commit 8cc6205bf7cfba2816052a0cc5d81debd8d52028. Reason for revert: Graphite actually reuses the bind groups between draw calls using different pipelines and this change prevents it from happening. Original change's description: > Disable frontend cache when implicit device sync is on. > > Normal behavior of ApiObjectBase's APIRelease() which only locks the > device when last ref dropped is not thread safe if the object is cached > as raw pointers by the device. Example of cached objects: bind group > layout, pipeline, sampler, shader module. > > The following scenario could happen: > - thread A: > - shaderModuleA.APIRealease() > - shaderModuleA.refCount.Decrement() == true (ref count has reached zero) > - going to call shaderModuleA.LockAndDeleteThis(). > - thread B: > - device.CreateShaderModule(). > - lock() > - device.GetOrCreateShaderModule() > - shaderModuleA is in the cache, so return it. > - unlock() > - thread A: > - starting to call shaderModuleA.LockAndDeleteThis() > - lock() > - erase shaderModuleA from the cache. > - delete shaderModuleA. > - unlock() > > This CL disables caching when ImplicitDeviceSynchronization is turned on > until we find a better solution. > > Bug: dawn:1769 > Change-Id: Ideb2a717ece0a40e18bd1c2bef00817262bd25da > Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/127900 > Commit-Queue: Quyen Le <lehoangquyen@chromium.org> > Reviewed-by: Austin Eng <enga@chromium.org> > Kokoro: Kokoro <noreply+kokoro@google.com> TBR=cwallez@chromium.org,enga@chromium.org,noreply+kokoro@google.com,dawn-scoped@luci-project-accounts.iam.gserviceaccount.com,lehoangquyen@chromium.org Change-Id: Ib13bba8005402d06963865fae919388a91e718f0 No-Presubmit: true No-Tree-Checks: true No-Try: true Bug: dawn:1769 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/128440 Reviewed-by: Austin Eng <enga@chromium.org> Kokoro: Kokoro <noreply+kokoro@google.com> Commit-Queue: Quyen Le <lehoangquyen@chromium.org>