ecc555540b
Unblocks angle roller into skia that was triggering an assert in EGLImageTest. In that test, there were two egl contexts created that shared the same egl display. The child context was destroyed first, and ANGLEGLContext's destroyGLContext() implementation always called eglTerminate on the display. According to the egl spec you're not supposed to do anything with the terminated display other than call makeCurrent() to release any active context. In this case, the child context's termination would cause the display to be deferred until the parent context was destroyed. This triggered a bug in ANGLE's D3D backend, leading to the assert. However, with that fixed, we then trigger critical error messages about calling eglDestroySurface, etc. in the parent context's destroyGLContext() function since the display was terminated out from beneath it. This change adds a rudimentary ownership tracking mechanism to the ANGLEGLContext so that when a child context is cleaned up it won't call eglTerminate on its display. This happens to avoid the bug in ANGLE's D3D backend as well as silencing the critical warnings if it were fixed. Bug: skia:12413 Change-Id: I31f64189315a1921adbee204d11138272d4b40af Reviewed-on: https://skia-review.googlesource.com/c/skia/+/446182 Commit-Queue: Robert Phillips <robertphillips@google.com> Auto-Submit: Michael Ludwig <michaelludwig@google.com> Reviewed-by: Robert Phillips <robertphillips@google.com> |
||
---|---|---|
.. | ||
d3d | ||
dawn | ||
gl | ||
mock | ||
mtl | ||
vk | ||
BackendSurfaceFactory.cpp | ||
BackendSurfaceFactory.h | ||
BackendTextureImageFactory.cpp | ||
BackendTextureImageFactory.h | ||
FenceSync.h | ||
FlushFinishTracker.cpp | ||
FlushFinishTracker.h | ||
GpuTimer.h | ||
GrContextFactory.cpp | ||
GrContextFactory.h | ||
GrTest.cpp | ||
ManagedBackendTexture.cpp | ||
ManagedBackendTexture.h | ||
MemoryCache.cpp | ||
MemoryCache.h | ||
ProxyUtils.cpp | ||
ProxyUtils.h | ||
TestContext.cpp | ||
TestContext.h | ||
TestOps.cpp | ||
TestOps.h | ||
YUVUtils.cpp | ||
YUVUtils.h |