bd500f09ce
Reason for revert: Need workaround for chrome to build Original issue's description: > Move Budgeted enum out of SkSurface, use in GrTextureProvider > > BUG=skia: > GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1728093005 > DOCS_PREVIEW= https://skia.org/?cl=1728093005 > > Committed: https://skia.googlesource.com/skia/+/57599fe6c0336feaeeeb9b1996e77b70219b483c TBR=reed@google.com # Skipping CQ checks because original CL landed less than 1 days ago. NOPRESUBMIT=true NOTREECHECKS=true NOTRY=true BUG=skia: Review URL: https://codereview.chromium.org/1734043002
110 lines
4.7 KiB
C++
110 lines
4.7 KiB
C++
/*
|
|
* Copyright 2016 Google Inc.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
#include "Test.h"
|
|
#if SK_SUPPORT_GPU
|
|
#include "gl/GrGLGpu.h"
|
|
#include "GrContext.h"
|
|
#include "SkSurface_Gpu.h"
|
|
#include "../include/gpu/gl/SkGLContext.h"
|
|
#include "../include/gpu/GrTypes.h"
|
|
#include "../include/private/SkTemplates.h"
|
|
|
|
class TestStorageAllocator {
|
|
public:
|
|
static GrTextureStorageAllocator::Result allocateTextureStorage(void* ctx,
|
|
GrBackendObject texture, unsigned width, unsigned height, GrPixelConfig config,
|
|
const void* srcData, GrSurfaceOrigin) {
|
|
TestStorageAllocator* allocator = static_cast<TestStorageAllocator*>(ctx);
|
|
if (!allocator->m_allowAllocation)
|
|
return GrTextureStorageAllocator::Result::kFailed;
|
|
SkAutoTMalloc<uint8_t> pixels(width * height * 4);
|
|
memset(pixels.get(), 0, width * height * 4);
|
|
|
|
GrGLuint id;
|
|
GrGLenum target = GR_GL_TEXTURE_2D;
|
|
GR_GL_CALL(allocator->m_gl, GenTextures(1, &id));
|
|
GR_GL_CALL(allocator->m_gl, BindTexture(target, id));
|
|
GR_GL_CALL(allocator->m_gl, TexParameteri(target, GR_GL_TEXTURE_MAG_FILTER, GR_GL_NEAREST));
|
|
GR_GL_CALL(allocator->m_gl, TexParameteri(target, GR_GL_TEXTURE_MIN_FILTER, GR_GL_NEAREST));
|
|
GR_GL_CALL(allocator->m_gl, TexParameteri(target, GR_GL_TEXTURE_WRAP_S, GR_GL_CLAMP_TO_EDGE));
|
|
GR_GL_CALL(allocator->m_gl, TexParameteri(target, GR_GL_TEXTURE_WRAP_T, GR_GL_CLAMP_TO_EDGE));
|
|
GR_GL_CALL(allocator->m_gl, TexImage2D(target, 0, GR_GL_RGBA, width, height, 0, GR_GL_RGBA,
|
|
GR_GL_UNSIGNED_BYTE, pixels.get()));
|
|
|
|
GrGLTextureInfo* info = reinterpret_cast<GrGLTextureInfo*>(texture);
|
|
info->fID = id;
|
|
info->fTarget = target;
|
|
allocator->m_mostRecentlyAllocatedStorage = id;
|
|
return GrTextureStorageAllocator::Result::kSucceededWithoutUpload;
|
|
}
|
|
static void deallocateTextureStorage(void* ctx, GrBackendObject texture) {
|
|
TestStorageAllocator* allocator = static_cast<TestStorageAllocator*>(ctx);
|
|
GrGLTextureInfo* info = reinterpret_cast<GrGLTextureInfo*>(texture);
|
|
GR_GL_CALL(allocator->m_gl, DeleteTextures(1, &(info->fID)));
|
|
}
|
|
|
|
GrGLuint m_mostRecentlyAllocatedStorage;
|
|
const GrGLInterface* m_gl;
|
|
bool m_allowAllocation;
|
|
};
|
|
|
|
DEF_GPUTEST_FOR_RENDERING_CONTEXTS(CustomTexture, reporter, context, glContext) {
|
|
static const int kWidth = 13;
|
|
static const int kHeight = 13;
|
|
|
|
const GrGLInterface* gl = glContext->gl();
|
|
TestStorageAllocator allocator;
|
|
allocator.m_allowAllocation = true;
|
|
allocator.m_gl = gl;
|
|
GrTextureStorageAllocator grAllocator;
|
|
grAllocator.fAllocateTextureStorage = &TestStorageAllocator::allocateTextureStorage;
|
|
grAllocator.fDeallocateTextureStorage= &TestStorageAllocator::deallocateTextureStorage;
|
|
grAllocator.fCtx = &allocator;
|
|
|
|
SkAutoTUnref<SkSurface> surface(SkSurface_Gpu::NewRenderTarget(
|
|
context, SkSurface_Gpu::kNo_Budgeted, SkImageInfo::MakeN32Premul(kWidth, kHeight), 0,
|
|
NULL, grAllocator));
|
|
REPORTER_ASSERT(reporter, surface);
|
|
GrGLuint id = allocator.m_mostRecentlyAllocatedStorage;
|
|
|
|
SkAutoTUnref<SkImage> image(surface->newImageSnapshot());
|
|
REPORTER_ASSERT(reporter, image->isTextureBacked());
|
|
SkImageInfo imageInfo = SkImageInfo::MakeN32Premul(1,1);
|
|
GrColor dest = 0x11223344;
|
|
REPORTER_ASSERT(reporter, image->readPixels(imageInfo, &dest, 4 * kWidth, 0, 0));
|
|
REPORTER_ASSERT(reporter, GrColorUnpackG(dest) == 0);
|
|
|
|
surface->getCanvas()->clear(SK_ColorGREEN);
|
|
SkAutoTUnref<SkImage> image2(surface->newImageSnapshot());
|
|
REPORTER_ASSERT(reporter, image2->isTextureBacked());
|
|
REPORTER_ASSERT(reporter, allocator.m_mostRecentlyAllocatedStorage != id);
|
|
|
|
REPORTER_ASSERT(reporter, image2->readPixels(imageInfo, &dest, 4 * kWidth, 0, 0));
|
|
REPORTER_ASSERT(reporter, GrColorUnpackG(dest) == 255);
|
|
}
|
|
|
|
DEF_GPUTEST_FOR_RENDERING_CONTEXTS(CustomTextureFailure, reporter, context, glContext) {
|
|
static const int kWidth = 13;
|
|
static const int kHeight = 13;
|
|
|
|
const GrGLInterface* gl = glContext->gl();
|
|
TestStorageAllocator allocator;
|
|
allocator.m_allowAllocation = false;
|
|
allocator.m_gl = gl;
|
|
GrTextureStorageAllocator grAllocator;
|
|
grAllocator.fAllocateTextureStorage = &TestStorageAllocator::allocateTextureStorage;
|
|
grAllocator.fDeallocateTextureStorage= &TestStorageAllocator::deallocateTextureStorage;
|
|
grAllocator.fCtx = &allocator;
|
|
SkAutoTUnref<SkSurface> surface(SkSurface_Gpu::NewRenderTarget(
|
|
context, SkSurface_Gpu::kNo_Budgeted, SkImageInfo::MakeN32Premul(kWidth, kHeight), 0,
|
|
NULL, grAllocator));
|
|
REPORTER_ASSERT(reporter, !surface);
|
|
}
|
|
|
|
#endif
|