Reland "Go back to cleaning up MIP levels on texture export rather than assuming dirty on texture import."
This is a reland of 01d6fc9d84
Chrome layout tests have been suppressed so this shouldn't block a Skia roll.
Original change's description:
> Go back to cleaning up MIP levels on texture export rather than assuming dirty
> on texture import.
>
> Bug: skia:8155
> Change-Id: I23399f442d52c73906829132f798eda260b6d4ae
> Reviewed-on: https://skia-review.googlesource.com/143291
> Auto-Submit: Brian Salomon <bsalomon@google.com>
> Commit-Queue: Brian Osman <brianosman@google.com>
> Reviewed-by: Brian Osman <brianosman@google.com>
Bug: skia:8155
Change-Id: Ia3843b66c2453daf15e566b7ecf890c2ff4aed22
Reviewed-on: https://skia-review.googlesource.com/143960
Reviewed-by: Brian Salomon <bsalomon@google.com>
Commit-Queue: Brian Salomon <bsalomon@google.com>
This commit is contained in:
parent
da1be46e24
commit
504dd052b9
@ -380,16 +380,12 @@ GrSemaphoresSubmitted GrDrawingManager::prepareSurfaceForExternalIO(
|
|||||||
if (auto* rt = surface->asRenderTarget()) {
|
if (auto* rt = surface->asRenderTarget()) {
|
||||||
gpu->resolveRenderTarget(rt);
|
gpu->resolveRenderTarget(rt);
|
||||||
}
|
}
|
||||||
#if 0
|
|
||||||
// This is temporarily is disabled. See comment in SkImage_Gpu.cpp,
|
|
||||||
// new_wrapped_texture_common().
|
|
||||||
if (auto* tex = surface->asTexture()) {
|
if (auto* tex = surface->asTexture()) {
|
||||||
if (tex->texturePriv().mipMapped() == GrMipMapped::kYes &&
|
if (tex->texturePriv().mipMapped() == GrMipMapped::kYes &&
|
||||||
tex->texturePriv().mipMapsAreDirty()) {
|
tex->texturePriv().mipMapsAreDirty()) {
|
||||||
gpu->regenerateMipMapLevels(tex);
|
gpu->regenerateMipMapLevels(tex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -290,17 +290,6 @@ static sk_sp<SkImage> new_wrapped_texture_common(GrContext* ctx,
|
|||||||
if (!proxy) {
|
if (!proxy) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
#if 1
|
|
||||||
// Temporary fix for crbug.com/850617 that can be cleanly merged back to older branches. Assume
|
|
||||||
// any MIP levels on the incoming texture are dirty. The proper fix is to make them clean on
|
|
||||||
// export. See #if 0'ed out code in GrDrawingManager::prepareSurfaceForExternalIO().
|
|
||||||
SkASSERT(proxy->priv().isInstantiated());
|
|
||||||
if (auto* tex = proxy->priv().peekTexture()) {
|
|
||||||
if (tex->texturePriv().mipMapped() == GrMipMapped::kYes) {
|
|
||||||
proxy->priv().peekTexture()->texturePriv().markMipMapsDirty();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
return sk_make_sp<SkImage_Gpu>(sk_ref_sp(ctx), kNeedNewImageUniqueID, at, std::move(proxy),
|
return sk_make_sp<SkImage_Gpu>(sk_ref_sp(ctx), kNeedNewImageUniqueID, at, std::move(proxy),
|
||||||
std::move(colorSpace), SkBudgeted::kNo);
|
std::move(colorSpace), SkBudgeted::kNo);
|
||||||
}
|
}
|
||||||
|
@ -87,13 +87,7 @@ DEF_GPUTEST_FOR_RENDERING_CONTEXTS(GrWrappedMipMappedTest, reporter, ctxInfo) {
|
|||||||
if (isRT) {
|
if (isRT) {
|
||||||
REPORTER_ASSERT(reporter, texture->texturePriv().mipMapsAreDirty());
|
REPORTER_ASSERT(reporter, texture->texturePriv().mipMapsAreDirty());
|
||||||
} else {
|
} else {
|
||||||
#if 1
|
|
||||||
// This is temporarily checks that the new image DOES have dirty MIP levels. See
|
|
||||||
// comment in SkImage_Gpu.cpp, new_wrapped_texture_common().
|
|
||||||
REPORTER_ASSERT(reporter, texture->texturePriv().mipMapsAreDirty());
|
|
||||||
#else
|
|
||||||
REPORTER_ASSERT(reporter, !texture->texturePriv().mipMapsAreDirty());
|
REPORTER_ASSERT(reporter, !texture->texturePriv().mipMapsAreDirty());
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
REPORTER_ASSERT(reporter, GrMipMapped::kNo == texture->texturePriv().mipMapped());
|
REPORTER_ASSERT(reporter, GrMipMapped::kNo == texture->texturePriv().mipMapped());
|
||||||
|
Loading…
Reference in New Issue
Block a user