diff options
author | Allan Sandfeld Jensen <allan.jensen@qt.io> | 2020-10-12 14:27:29 +0200 |
---|---|---|
committer | Allan Sandfeld Jensen <allan.jensen@qt.io> | 2020-10-13 09:35:20 +0000 |
commit | c30a6232df03e1efbd9f3b226777b07e087a1122 (patch) | |
tree | e992f45784689f373bcc38d1b79a239ebe17ee23 /chromium/third_party/skia/gm/asyncrescaleandread.cpp | |
parent | 7b5b123ac58f58ffde0f4f6e488bcd09aa4decd3 (diff) | |
download | qtwebengine-chromium-85-based.tar.gz |
BASELINE: Update Chromium to 85.0.4183.14085-based
Change-Id: Iaa42f4680837c57725b1344f108c0196741f6057
Reviewed-by: Allan Sandfeld Jensen <allan.jensen@qt.io>
Diffstat (limited to 'chromium/third_party/skia/gm/asyncrescaleandread.cpp')
-rw-r--r-- | chromium/third_party/skia/gm/asyncrescaleandread.cpp | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/chromium/third_party/skia/gm/asyncrescaleandread.cpp b/chromium/third_party/skia/gm/asyncrescaleandread.cpp index 0e808140192..f119144b192 100644 --- a/chromium/third_party/skia/gm/asyncrescaleandread.cpp +++ b/chromium/third_party/skia/gm/asyncrescaleandread.cpp @@ -43,6 +43,9 @@ static sk_sp<SkImage> do_read_and_scale(SkSurface* surface, const SkIRect& srcRe SkFilterQuality quality) { auto* context = new AsyncContext(); surface->asyncRescaleAndReadPixels(ii, srcRect, rescaleGamma, quality, async_callback, context); + if (auto ctx = surface->getContext()) { + ctx->submit(); + } while (!context->fCalled) { // Only GPU should actually be asynchronous. SkASSERT(surface->getCanvas()->getGrContext()); @@ -69,6 +72,9 @@ static sk_sp<SkImage> do_read_and_scale_yuv(SkSurface* surface, SkYUVColorSpace AsyncContext context; surface->asyncRescaleAndReadPixelsYUV420(yuvCS, SkColorSpace::MakeSRGB(), srcRect, size, rescaleGamma, quality, async_callback, &context); + if (auto ctx = surface->getContext()) { + ctx->submit(); + } while (!context.fCalled) { // Only GPU should actually be asynchronous. SkASSERT(surface->getCanvas()->getGrContext()); @@ -99,6 +105,7 @@ static sk_sp<SkImage> do_read_and_scale_yuv(SkSurface* surface, SkYUVColorSpace GrFlushInfo flushInfo; flushInfo.fFlags = kSyncCpu_GrFlushFlag; gr->flush(flushInfo); + gr->submit(true); gr->deleteBackendTexture(backendTextures[0]); gr->deleteBackendTexture(backendTextures[1]); gr->deleteBackendTexture(backendTextures[2]); |