Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(239)

Unified Diff: tests/VkUploadPixelsTests.cpp

Issue 1718693002: Add vulkan files into skia repo. (Closed) Base URL: https://skia.googlesource.com/skia.git@merge
Patch Set: fix path Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « tests/VkClearTests.cpp ('k') | third_party/shaderc/Debug/OGLCompiler.lib » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/VkUploadPixelsTests.cpp
diff --git a/tests/VkUploadPixelsTests.cpp b/tests/VkUploadPixelsTests.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..043ea45a81d07482e5c78bf858fd7356970e92c2
--- /dev/null
+++ b/tests/VkUploadPixelsTests.cpp
@@ -0,0 +1,160 @@
+
+/*
+ * Copyright 2015 Google Inc.
+ *
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+// This is a GPU-backend specific test. It relies on static intializers to work
+
+#include "SkTypes.h"
+
+#if SK_SUPPORT_GPU && SK_ALLOW_STATIC_GLOBAL_INITIALIZERS && defined(SK_VULKAN)
+
+#include "GrContextFactory.h"
+#include "GrTest.h"
+#include "Test.h"
+#include "vk/GrVkGpu.h"
+
+
+void fill_pixel_data(int width, int height, GrColor* data) {
+
+ // build red-green gradient
+ for (int j = 0; j < height; ++j) {
+ for (int i = 0; i < width; ++i) {
+ unsigned int red = (unsigned int)(256.f*(i / (float)width));
+ unsigned int green = (unsigned int)(256.f*(j / (float)height));
+ data[i + j*width] = GrColorPackRGBA(red - (red>>8), green - (green>>8), 0xff, 0xff);
+ }
+ }
+}
+
+bool does_full_buffer_contain_correct_color(GrColor* srcBuffer,
+ GrColor* dstBuffer,
+ GrPixelConfig config,
+ int width,
+ int height) {
+ GrColor* srcPtr = srcBuffer;
+ GrColor* dstPtr = dstBuffer;
+ for (int j = 0; j < height; ++j) {
+ for (int i = 0; i < width; ++i) {
+ if (srcPtr[i] != dstPtr[i]) {
+ return false;
+ }
+ }
+ srcPtr += width;
+ dstPtr += width;
+ }
+ return true;
+}
+
+void basic_texture_test(skiatest::Reporter* reporter, GrContext* context, GrPixelConfig config,
+ bool renderTarget, bool linearTiling) {
+ GrVkGpu* gpu = static_cast<GrVkGpu*>(context->getGpu());
+ gpu->discard(NULL);
+
+ const int kWidth = 16;
+ const int kHeight = 16;
+ SkAutoTMalloc<GrColor> srcBuffer(kWidth*kHeight);
+ SkAutoTMalloc<GrColor> dstBuffer(kWidth*kHeight);
+
+ fill_pixel_data(kWidth, kHeight, srcBuffer.get());
+
+ const GrVkCaps* caps = reinterpret_cast<const GrVkCaps*>(context->caps());
+
+ bool canCreate = true;
+ // the expectation is that the given config is texturable/renderable with optimal tiling
+ // but may not be with linear tiling
+ if (linearTiling) {
+ if (!caps->isConfigTexurableLinearly(config) ||
+ (renderTarget && !caps->isConfigRenderableLinearly(config, false))) {
+ canCreate = false;
+ }
+ }
+
+ GrSurfaceDesc surfDesc;
+ surfDesc.fFlags = renderTarget ? kRenderTarget_GrSurfaceFlag : kNone_GrSurfaceFlags;
+ if (linearTiling) {
+ surfDesc.fFlags |= kZeroCopy_GrSurfaceFlag;
+ }
+ surfDesc.fOrigin = kTopLeft_GrSurfaceOrigin;
+ surfDesc.fWidth = kWidth;
+ surfDesc.fHeight = kHeight;
+ surfDesc.fConfig = config;
+ surfDesc.fSampleCnt = 0;
+ GrTexture* tex0 = gpu->createTexture(surfDesc, false, srcBuffer, 0);
+ if (tex0) {
+ REPORTER_ASSERT(reporter, canCreate);
+ gpu->readPixels(tex0, 0, 0, kWidth, kHeight, config, dstBuffer, 0);
+ REPORTER_ASSERT(reporter, does_full_buffer_contain_correct_color(srcBuffer,
+ dstBuffer,
+ config,
+ kWidth,
+ kHeight));
+
+ tex0->writePixels(2, 10, 10, 2, config, srcBuffer);
+ memset(dstBuffer, 0, kWidth*kHeight*sizeof(GrColor));
+ gpu->readPixels(tex0, 2, 10, 10, 2, config, dstBuffer, 0);
+ REPORTER_ASSERT(reporter, does_full_buffer_contain_correct_color(srcBuffer,
+ dstBuffer,
+ config,
+ 10,
+ 2));
+
+ tex0->unref();
+ } else {
+ REPORTER_ASSERT(reporter, !canCreate);
+ }
+
+ surfDesc.fOrigin = kBottomLeft_GrSurfaceOrigin;
+ GrTexture* tex1 = gpu->createTexture(surfDesc, false, srcBuffer, 0);
+ if (tex1) {
+ REPORTER_ASSERT(reporter, canCreate);
+ gpu->readPixels(tex1, 0, 0, kWidth, kHeight, config, dstBuffer, 0);
+ REPORTER_ASSERT(reporter, does_full_buffer_contain_correct_color(srcBuffer,
+ dstBuffer,
+ config,
+ kWidth,
+ kHeight));
+
+ tex1->writePixels(5, 4, 4, 5, config, srcBuffer);
+ memset(dstBuffer, 0, kWidth*kHeight*sizeof(GrColor));
+ gpu->readPixels(tex1, 5, 4, 4, 5, config, dstBuffer, 0);
+ REPORTER_ASSERT(reporter, does_full_buffer_contain_correct_color(srcBuffer,
+ dstBuffer,
+ config,
+ 4,
+ 5));
+
+ tex1->unref();
+ } else {
+ REPORTER_ASSERT(reporter, !canCreate);
+ }
+}
+
+DEF_GPUTEST(VkUploadPixelsTests, reporter, factory) {
+ GrContextOptions opts;
+ opts.fSuppressPrints = true;
+ GrContextFactory debugFactory(opts);
+ for (int type = 0; type < GrContextFactory::kLastGLContextType; ++type) {
+ if (static_cast<GrContextFactory::GLContextType>(type) !=
+ GrContextFactory::kNative_GLContextType) {
+ continue;
+ }
+ GrContext* context = debugFactory.get(static_cast<GrContextFactory::GLContextType>(type));
+ if (context) {
+ basic_texture_test(reporter, context, kRGBA_8888_GrPixelConfig, false, false);
+ basic_texture_test(reporter, context, kRGBA_8888_GrPixelConfig, true, false);
+ basic_texture_test(reporter, context, kRGBA_8888_GrPixelConfig, false, true);
+ basic_texture_test(reporter, context, kRGBA_8888_GrPixelConfig, true, true);
+ basic_texture_test(reporter, context, kBGRA_8888_GrPixelConfig, false, false);
+ basic_texture_test(reporter, context, kBGRA_8888_GrPixelConfig, true, false);
+ basic_texture_test(reporter, context, kBGRA_8888_GrPixelConfig, false, true);
+ basic_texture_test(reporter, context, kBGRA_8888_GrPixelConfig, true, true);
+ }
+
+ }
+}
+
+#endif
« no previous file with comments | « tests/VkClearTests.cpp ('k') | third_party/shaderc/Debug/OGLCompiler.lib » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698