42f710f3fa
This is a reland of commit ae5e846047
Original change's description:
> [graphite] Move Graphite into Skia base directories.
>
> Change-Id: Ie0fb74f3766a8b33387c145bd1151344c25808cb
> Reviewed-on: https://skia-review.googlesource.com/c/skia/+/528708
> Reviewed-by: Kevin Lubick <kjlubick@google.com>
> Reviewed-by: Greg Daniel <egdaniel@google.com>
> Commit-Queue: Jim Van Verth <jvanverth@google.com>
Change-Id: Ia575fd49206ad0b665a6a9153317e738bb321446
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/529059
Reviewed-by: Kevin Lubick <kjlubick@google.com>
Reviewed-by: Greg Daniel <egdaniel@google.com>
Commit-Queue: Jim Van Verth <jvanverth@google.com>
58 lines
2.1 KiB
Plaintext
58 lines
2.1 KiB
Plaintext
/*
|
|
* Copyright 2021 Google LLC
|
|
*
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
#include "tests/Test.h"
|
|
|
|
#include "include/gpu/graphite/BackendTexture.h"
|
|
#include "include/gpu/graphite/Context.h"
|
|
#include "include/gpu/graphite/mtl/MtlTypes.h"
|
|
|
|
#import <Metal/Metal.h>
|
|
|
|
using namespace skgpu::graphite;
|
|
|
|
namespace {
|
|
const SkISize kSize = {16, 16};
|
|
}
|
|
|
|
DEF_GRAPHITE_TEST_FOR_CONTEXTS(MtlBackendTextureTest, reporter, context) {
|
|
MtlTextureInfo textureInfo;
|
|
textureInfo.fSampleCount = 1;
|
|
textureInfo.fLevelCount = 1;
|
|
textureInfo.fFormat = MTLPixelFormatRGBA8Unorm;
|
|
textureInfo.fStorageMode = MTLStorageModePrivate;
|
|
textureInfo.fUsage = MTLTextureUsageShaderRead;
|
|
|
|
// TODO: For now we are just testing the basic case of RGBA single sample because that is what
|
|
// we've added to the backend. However, once we expand the backend support to handle all the
|
|
// formats this test should iterate over a large set of combinations. See the Ganesh
|
|
// MtlBackendAllocationTest for example of doing this.
|
|
|
|
auto beTexture = context->createBackendTexture(kSize, textureInfo);
|
|
REPORTER_ASSERT(reporter, beTexture.isValid());
|
|
context->deleteBackendTexture(beTexture);
|
|
|
|
// It should also pass if we set the usage to be a render target
|
|
textureInfo.fUsage |= MTLTextureUsageRenderTarget;
|
|
beTexture = context->createBackendTexture(kSize, textureInfo);
|
|
REPORTER_ASSERT(reporter, beTexture.isValid());
|
|
context->deleteBackendTexture(beTexture);
|
|
|
|
// It should fail with a format that isn't one of our supported formats
|
|
textureInfo.fFormat = MTLPixelFormatRGB9E5Float;
|
|
beTexture = context->createBackendTexture(kSize, textureInfo);
|
|
REPORTER_ASSERT(reporter, !beTexture.isValid());
|
|
context->deleteBackendTexture(beTexture);
|
|
|
|
// It should fail with a sample count greater than 1
|
|
textureInfo.fFormat = MTLPixelFormatRGBA8Unorm;
|
|
textureInfo.fSampleCount = 4;
|
|
beTexture = context->createBackendTexture(kSize, textureInfo);
|
|
REPORTER_ASSERT(reporter, !beTexture.isValid());
|
|
context->deleteBackendTexture(beTexture);
|
|
}
|