robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2016 Google Inc. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license that can be |
| 5 | * found in the LICENSE file. |
| 6 | */ |
| 7 | |
Mike Klein | c0bd9f9 | 2019-04-23 12:05:21 -0500 | [diff] [blame] | 8 | #include "tests/Test.h" |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 9 | |
Mike Klein | c0bd9f9 | 2019-04-23 12:05:21 -0500 | [diff] [blame] | 10 | #include "include/core/SkBitmap.h" |
| 11 | #include "include/core/SkColorFilter.h" |
| 12 | #include "include/core/SkImage.h" |
| 13 | #include "include/core/SkImageFilter.h" |
| 14 | #include "include/core/SkMatrix.h" |
Michael Ludwig | 55edb50 | 2019-08-05 10:41:10 -0400 | [diff] [blame] | 15 | #include "include/effects/SkImageFilters.h" |
Mike Klein | c0bd9f9 | 2019-04-23 12:05:21 -0500 | [diff] [blame] | 16 | #include "src/core/SkImageFilterCache.h" |
| 17 | #include "src/core/SkSpecialImage.h" |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 18 | |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 19 | SK_USE_FLUENT_IMAGE_FILTER_TYPES |
| 20 | |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 21 | static const int kSmallerSize = 10; |
| 22 | static const int kPad = 3; |
| 23 | static const int kFullSize = kSmallerSize + 2 * kPad; |
| 24 | |
| 25 | static SkBitmap create_bm() { |
Robert Phillips | 40b05c3 | 2019-09-20 12:40:55 -0400 | [diff] [blame] | 26 | SkImageInfo ii = SkImageInfo::Make(kFullSize, kFullSize, kRGBA_8888_SkColorType, |
| 27 | kPremul_SkAlphaType); |
| 28 | |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 29 | SkBitmap bm; |
Robert Phillips | 40b05c3 | 2019-09-20 12:40:55 -0400 | [diff] [blame] | 30 | bm.allocPixels(ii); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 31 | bm.eraseColor(SK_ColorTRANSPARENT); |
| 32 | return bm; |
| 33 | } |
| 34 | |
Ben Wagner | da926db | 2018-05-03 14:39:57 -0400 | [diff] [blame] | 35 | static sk_sp<SkImageFilter> make_filter() { |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 36 | sk_sp<SkColorFilter> filter(SkColorFilters::Blend(SK_ColorBLUE, SkBlendMode::kSrcIn)); |
Michael Ludwig | 55edb50 | 2019-08-05 10:41:10 -0400 | [diff] [blame] | 37 | return SkImageFilters::ColorFilter(std::move(filter), nullptr, nullptr); |
Ben Wagner | da926db | 2018-05-03 14:39:57 -0400 | [diff] [blame] | 38 | } |
| 39 | |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 40 | // Ensure the cache can return a cached image |
| 41 | static void test_find_existing(skiatest::Reporter* reporter, |
robertphillips | 37bd7c3 | 2016-03-17 14:31:39 -0700 | [diff] [blame] | 42 | const sk_sp<SkSpecialImage>& image, |
| 43 | const sk_sp<SkSpecialImage>& subset) { |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 44 | static const size_t kCacheSize = 1000000; |
Hal Canary | 342b7ac | 2016-11-04 11:49:42 -0400 | [diff] [blame] | 45 | sk_sp<SkImageFilterCache> cache(SkImageFilterCache::Create(kCacheSize)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 46 | |
| 47 | SkIRect clip = SkIRect::MakeWH(100, 100); |
senorblanco | 900c367 | 2016-04-27 11:31:23 -0700 | [diff] [blame] | 48 | SkImageFilterCacheKey key1(0, SkMatrix::I(), clip, image->uniqueID(), image->subset()); |
| 49 | SkImageFilterCacheKey key2(0, SkMatrix::I(), clip, subset->uniqueID(), subset->subset()); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 50 | |
| 51 | SkIPoint offset = SkIPoint::Make(3, 4); |
Ben Wagner | da926db | 2018-05-03 14:39:57 -0400 | [diff] [blame] | 52 | auto filter = make_filter(); |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 53 | cache->set(key1, filter.get(), skif::FilterResult<For::kOutput>(image, offset)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 54 | |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 55 | skif::FilterResult<For::kOutput> foundImage; |
| 56 | REPORTER_ASSERT(reporter, cache->get(key1, &foundImage)); |
| 57 | REPORTER_ASSERT(reporter, offset == foundImage.origin()); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 58 | |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 59 | REPORTER_ASSERT(reporter, !cache->get(key2, &foundImage)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 60 | } |
| 61 | |
| 62 | // If either id is different or the clip or the matrix are different the |
| 63 | // cached image won't be found. Even if it is caching the same bitmap. |
| 64 | static void test_dont_find_if_diff_key(skiatest::Reporter* reporter, |
robertphillips | 37bd7c3 | 2016-03-17 14:31:39 -0700 | [diff] [blame] | 65 | const sk_sp<SkSpecialImage>& image, |
| 66 | const sk_sp<SkSpecialImage>& subset) { |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 67 | static const size_t kCacheSize = 1000000; |
Hal Canary | 342b7ac | 2016-11-04 11:49:42 -0400 | [diff] [blame] | 68 | sk_sp<SkImageFilterCache> cache(SkImageFilterCache::Create(kCacheSize)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 69 | |
| 70 | SkIRect clip1 = SkIRect::MakeWH(100, 100); |
| 71 | SkIRect clip2 = SkIRect::MakeWH(200, 200); |
senorblanco | 900c367 | 2016-04-27 11:31:23 -0700 | [diff] [blame] | 72 | SkImageFilterCacheKey key0(0, SkMatrix::I(), clip1, image->uniqueID(), image->subset()); |
| 73 | SkImageFilterCacheKey key1(1, SkMatrix::I(), clip1, image->uniqueID(), image->subset()); |
| 74 | SkImageFilterCacheKey key2(0, SkMatrix::MakeTrans(5, 5), clip1, |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 75 | image->uniqueID(), image->subset()); |
senorblanco | 900c367 | 2016-04-27 11:31:23 -0700 | [diff] [blame] | 76 | SkImageFilterCacheKey key3(0, SkMatrix::I(), clip2, image->uniqueID(), image->subset()); |
| 77 | SkImageFilterCacheKey key4(0, SkMatrix::I(), clip1, subset->uniqueID(), subset->subset()); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 78 | |
| 79 | SkIPoint offset = SkIPoint::Make(3, 4); |
Ben Wagner | da926db | 2018-05-03 14:39:57 -0400 | [diff] [blame] | 80 | auto filter = make_filter(); |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 81 | cache->set(key0, filter.get(), skif::FilterResult<For::kOutput>(image, offset)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 82 | |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 83 | skif::FilterResult<For::kOutput> foundImage; |
| 84 | REPORTER_ASSERT(reporter, !cache->get(key1, &foundImage)); |
| 85 | REPORTER_ASSERT(reporter, !cache->get(key2, &foundImage)); |
| 86 | REPORTER_ASSERT(reporter, !cache->get(key3, &foundImage)); |
| 87 | REPORTER_ASSERT(reporter, !cache->get(key4, &foundImage)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 88 | } |
| 89 | |
| 90 | // Test purging when the max cache size is exceeded |
robertphillips | 37bd7c3 | 2016-03-17 14:31:39 -0700 | [diff] [blame] | 91 | static void test_internal_purge(skiatest::Reporter* reporter, const sk_sp<SkSpecialImage>& image) { |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 92 | SkASSERT(image->getSize()); |
mtklein | 03762fe | 2016-02-21 13:36:50 -0800 | [diff] [blame] | 93 | const size_t kCacheSize = image->getSize() + 10; |
Hal Canary | 342b7ac | 2016-11-04 11:49:42 -0400 | [diff] [blame] | 94 | sk_sp<SkImageFilterCache> cache(SkImageFilterCache::Create(kCacheSize)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 95 | |
| 96 | SkIRect clip = SkIRect::MakeWH(100, 100); |
senorblanco | 900c367 | 2016-04-27 11:31:23 -0700 | [diff] [blame] | 97 | SkImageFilterCacheKey key1(0, SkMatrix::I(), clip, image->uniqueID(), image->subset()); |
| 98 | SkImageFilterCacheKey key2(1, SkMatrix::I(), clip, image->uniqueID(), image->subset()); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 99 | |
| 100 | SkIPoint offset = SkIPoint::Make(3, 4); |
Ben Wagner | da926db | 2018-05-03 14:39:57 -0400 | [diff] [blame] | 101 | auto filter1 = make_filter(); |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 102 | cache->set(key1, filter1.get(), skif::FilterResult<For::kOutput>(image, offset)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 103 | |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 104 | skif::FilterResult<For::kOutput> foundImage; |
| 105 | REPORTER_ASSERT(reporter, cache->get(key1, &foundImage)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 106 | |
| 107 | // This should knock the first one out of the cache |
Ben Wagner | da926db | 2018-05-03 14:39:57 -0400 | [diff] [blame] | 108 | auto filter2 = make_filter(); |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 109 | cache->set(key2, filter2.get(), skif::FilterResult<For::kOutput>(image, offset)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 110 | |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 111 | REPORTER_ASSERT(reporter, cache->get(key2, &foundImage)); |
| 112 | REPORTER_ASSERT(reporter, !cache->get(key1, &foundImage)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 113 | } |
| 114 | |
xidachen | 185a379 | 2017-06-29 11:19:42 -0400 | [diff] [blame] | 115 | // Exercise the purgeByKey and purge methods |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 116 | static void test_explicit_purging(skiatest::Reporter* reporter, |
robertphillips | 37bd7c3 | 2016-03-17 14:31:39 -0700 | [diff] [blame] | 117 | const sk_sp<SkSpecialImage>& image, |
| 118 | const sk_sp<SkSpecialImage>& subset) { |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 119 | static const size_t kCacheSize = 1000000; |
Hal Canary | 342b7ac | 2016-11-04 11:49:42 -0400 | [diff] [blame] | 120 | sk_sp<SkImageFilterCache> cache(SkImageFilterCache::Create(kCacheSize)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 121 | |
| 122 | SkIRect clip = SkIRect::MakeWH(100, 100); |
senorblanco | 900c367 | 2016-04-27 11:31:23 -0700 | [diff] [blame] | 123 | SkImageFilterCacheKey key1(0, SkMatrix::I(), clip, image->uniqueID(), image->subset()); |
| 124 | SkImageFilterCacheKey key2(1, SkMatrix::I(), clip, subset->uniqueID(), image->subset()); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 125 | |
| 126 | SkIPoint offset = SkIPoint::Make(3, 4); |
Ben Wagner | da926db | 2018-05-03 14:39:57 -0400 | [diff] [blame] | 127 | auto filter1 = make_filter(); |
| 128 | auto filter2 = make_filter(); |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 129 | cache->set(key1, filter1.get(), skif::FilterResult<For::kOutput>(image, offset)); |
| 130 | cache->set(key2, filter2.get(), skif::FilterResult<For::kOutput>(image, offset)); |
robertphillips | bde57ed | 2016-04-18 14:49:57 -0700 | [diff] [blame] | 131 | SkDEBUGCODE(REPORTER_ASSERT(reporter, 2 == cache->count());) |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 132 | |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 133 | skif::FilterResult<For::kOutput> foundImage; |
| 134 | REPORTER_ASSERT(reporter, cache->get(key1, &foundImage)); |
| 135 | REPORTER_ASSERT(reporter, cache->get(key2, &foundImage)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 136 | |
Ben Wagner | da926db | 2018-05-03 14:39:57 -0400 | [diff] [blame] | 137 | cache->purgeByImageFilter(filter1.get()); |
robertphillips | bde57ed | 2016-04-18 14:49:57 -0700 | [diff] [blame] | 138 | SkDEBUGCODE(REPORTER_ASSERT(reporter, 1 == cache->count());) |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 139 | |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 140 | REPORTER_ASSERT(reporter, !cache->get(key1, &foundImage)); |
| 141 | REPORTER_ASSERT(reporter, cache->get(key2, &foundImage)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 142 | |
| 143 | cache->purge(); |
robertphillips | bde57ed | 2016-04-18 14:49:57 -0700 | [diff] [blame] | 144 | SkDEBUGCODE(REPORTER_ASSERT(reporter, 0 == cache->count());) |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 145 | |
Michael Ludwig | ea07123 | 2019-08-26 10:52:15 -0400 | [diff] [blame] | 146 | REPORTER_ASSERT(reporter, !cache->get(key1, &foundImage)); |
| 147 | REPORTER_ASSERT(reporter, !cache->get(key2, &foundImage)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 148 | } |
| 149 | |
| 150 | DEF_TEST(ImageFilterCache_RasterBacked, reporter) { |
| 151 | SkBitmap srcBM = create_bm(); |
| 152 | |
| 153 | const SkIRect& full = SkIRect::MakeWH(kFullSize, kFullSize); |
| 154 | |
robertphillips | 3e30227 | 2016-04-20 11:48:36 -0700 | [diff] [blame] | 155 | sk_sp<SkSpecialImage> fullImg(SkSpecialImage::MakeFromRaster(full, srcBM)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 156 | |
| 157 | const SkIRect& subset = SkIRect::MakeXYWH(kPad, kPad, kSmallerSize, kSmallerSize); |
| 158 | |
robertphillips | 3e30227 | 2016-04-20 11:48:36 -0700 | [diff] [blame] | 159 | sk_sp<SkSpecialImage> subsetImg(SkSpecialImage::MakeFromRaster(subset, srcBM)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 160 | |
| 161 | test_find_existing(reporter, fullImg, subsetImg); |
| 162 | test_dont_find_if_diff_key(reporter, fullImg, subsetImg); |
| 163 | test_internal_purge(reporter, fullImg); |
| 164 | test_explicit_purging(reporter, fullImg, subsetImg); |
| 165 | } |
| 166 | |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 167 | |
robertphillips | cbc5bcc | 2016-02-19 10:41:12 -0800 | [diff] [blame] | 168 | // Shared test code for both the raster and gpu-backed image cases |
Robert Phillips | 2746765 | 2019-01-10 16:34:22 -0500 | [diff] [blame] | 169 | static void test_image_backed(skiatest::Reporter* reporter, |
| 170 | GrContext* context, |
| 171 | const sk_sp<SkImage>& srcImage) { |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 172 | const SkIRect& full = SkIRect::MakeWH(kFullSize, kFullSize); |
| 173 | |
Robert Phillips | 2746765 | 2019-01-10 16:34:22 -0500 | [diff] [blame] | 174 | sk_sp<SkSpecialImage> fullImg(SkSpecialImage::MakeFromImage(context, full, srcImage)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 175 | |
| 176 | const SkIRect& subset = SkIRect::MakeXYWH(kPad, kPad, kSmallerSize, kSmallerSize); |
| 177 | |
Robert Phillips | 2746765 | 2019-01-10 16:34:22 -0500 | [diff] [blame] | 178 | sk_sp<SkSpecialImage> subsetImg(SkSpecialImage::MakeFromImage(context, subset, srcImage)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 179 | |
| 180 | test_find_existing(reporter, fullImg, subsetImg); |
| 181 | test_dont_find_if_diff_key(reporter, fullImg, subsetImg); |
| 182 | test_internal_purge(reporter, fullImg); |
| 183 | test_explicit_purging(reporter, fullImg, subsetImg); |
| 184 | } |
| 185 | |
robertphillips | cbc5bcc | 2016-02-19 10:41:12 -0800 | [diff] [blame] | 186 | DEF_TEST(ImageFilterCache_ImageBackedRaster, reporter) { |
| 187 | SkBitmap srcBM = create_bm(); |
| 188 | |
reed | 9ce9d67 | 2016-03-17 10:51:11 -0700 | [diff] [blame] | 189 | sk_sp<SkImage> srcImage(SkImage::MakeFromBitmap(srcBM)); |
robertphillips | cbc5bcc | 2016-02-19 10:41:12 -0800 | [diff] [blame] | 190 | |
Robert Phillips | 2746765 | 2019-01-10 16:34:22 -0500 | [diff] [blame] | 191 | test_image_backed(reporter, nullptr, srcImage); |
robertphillips | cbc5bcc | 2016-02-19 10:41:12 -0800 | [diff] [blame] | 192 | } |
| 193 | |
Mike Klein | c0bd9f9 | 2019-04-23 12:05:21 -0500 | [diff] [blame] | 194 | #include "include/gpu/GrContext.h" |
| 195 | #include "include/gpu/GrTexture.h" |
Mike Klein | c0bd9f9 | 2019-04-23 12:05:21 -0500 | [diff] [blame] | 196 | #include "src/gpu/GrContextPriv.h" |
| 197 | #include "src/gpu/GrProxyProvider.h" |
| 198 | #include "src/gpu/GrResourceProvider.h" |
| 199 | #include "src/gpu/GrSurfaceProxyPriv.h" |
Greg Daniel | f91aeb2 | 2019-06-18 09:58:02 -0400 | [diff] [blame] | 200 | #include "src/gpu/GrTextureProxy.h" |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 201 | |
Robert Phillips | 1afd4cd | 2018-01-08 13:40:32 -0500 | [diff] [blame] | 202 | static sk_sp<GrTextureProxy> create_proxy(GrProxyProvider* proxyProvider) { |
Robert Phillips | 2c6d2bf | 2017-02-21 10:19:29 -0500 | [diff] [blame] | 203 | SkBitmap srcBM = create_bm(); |
Brian Osman | 2700abc | 2018-09-12 10:19:41 -0400 | [diff] [blame] | 204 | sk_sp<SkImage> srcImage(SkImage::MakeFromBitmap(srcBM)); |
Brian Salomon | 96b383a | 2019-08-13 16:55:41 -0400 | [diff] [blame] | 205 | return proxyProvider->createTextureProxy(srcImage, 1, SkBudgeted::kYes, SkBackingFit::kExact); |
Robert Phillips | 2c6d2bf | 2017-02-21 10:19:29 -0500 | [diff] [blame] | 206 | } |
| 207 | |
egdaniel | ab527a5 | 2016-06-28 08:07:26 -0700 | [diff] [blame] | 208 | DEF_GPUTEST_FOR_RENDERING_CONTEXTS(ImageFilterCache_ImageBackedGPU, reporter, ctxInfo) { |
Robert Phillips | e78b725 | 2017-04-06 07:59:41 -0400 | [diff] [blame] | 209 | GrContext* context = ctxInfo.grContext(); |
| 210 | |
Robert Phillips | 9da87e0 | 2019-02-04 13:26:26 -0500 | [diff] [blame] | 211 | sk_sp<GrTextureProxy> srcProxy(create_proxy(context->priv().proxyProvider())); |
Robert Phillips | e78b725 | 2017-04-06 07:59:41 -0400 | [diff] [blame] | 212 | if (!srcProxy) { |
| 213 | return; |
| 214 | } |
| 215 | |
Robert Phillips | 9da87e0 | 2019-02-04 13:26:26 -0500 | [diff] [blame] | 216 | if (!srcProxy->instantiate(context->priv().resourceProvider())) { |
robertphillips | cbc5bcc | 2016-02-19 10:41:12 -0800 | [diff] [blame] | 217 | return; |
| 218 | } |
Brian Salomon | fd98c2c | 2018-07-31 17:25:29 -0400 | [diff] [blame] | 219 | GrTexture* tex = srcProxy->peekTexture(); |
robertphillips | cbc5bcc | 2016-02-19 10:41:12 -0800 | [diff] [blame] | 220 | |
Robert Phillips | b67821d | 2017-12-13 15:00:45 -0500 | [diff] [blame] | 221 | GrBackendTexture backendTex = tex->getBackendTexture(); |
| 222 | |
Greg Daniel | 7ef28f3 | 2017-04-20 16:41:55 +0000 | [diff] [blame] | 223 | GrSurfaceOrigin texOrigin = kTopLeft_GrSurfaceOrigin; |
Robert Phillips | e78b725 | 2017-04-06 07:59:41 -0400 | [diff] [blame] | 224 | sk_sp<SkImage> srcImage(SkImage::MakeFromTexture(context, |
Greg Daniel | 7ef28f3 | 2017-04-20 16:41:55 +0000 | [diff] [blame] | 225 | backendTex, |
| 226 | texOrigin, |
Greg Daniel | f5d8758 | 2017-12-18 14:48:15 -0500 | [diff] [blame] | 227 | kRGBA_8888_SkColorType, |
| 228 | kPremul_SkAlphaType, nullptr, |
| 229 | nullptr, nullptr)); |
robertphillips | cbc5bcc | 2016-02-19 10:41:12 -0800 | [diff] [blame] | 230 | if (!srcImage) { |
| 231 | return; |
| 232 | } |
| 233 | |
Robert Phillips | 3390e15 | 2017-01-31 17:53:34 -0500 | [diff] [blame] | 234 | GrSurfaceOrigin readBackOrigin; |
Robert Phillips | c550995 | 2018-04-04 15:54:55 -0400 | [diff] [blame] | 235 | GrBackendTexture readBackBackendTex = srcImage->getBackendTexture(false, &readBackOrigin); |
| 236 | if (!GrBackendTexture::TestingOnly_Equals(readBackBackendTex, backendTex)) { |
| 237 | ERRORF(reporter, "backend mismatch\n"); |
Robert Phillips | 3390e15 | 2017-01-31 17:53:34 -0500 | [diff] [blame] | 238 | } |
Robert Phillips | c550995 | 2018-04-04 15:54:55 -0400 | [diff] [blame] | 239 | REPORTER_ASSERT(reporter, GrBackendTexture::TestingOnly_Equals(readBackBackendTex, backendTex)); |
| 240 | |
Greg Daniel | 7ef28f3 | 2017-04-20 16:41:55 +0000 | [diff] [blame] | 241 | if (readBackOrigin != texOrigin) { |
| 242 | ERRORF(reporter, "origin mismatch %d %d\n", readBackOrigin, texOrigin); |
Robert Phillips | 3390e15 | 2017-01-31 17:53:34 -0500 | [diff] [blame] | 243 | } |
Greg Daniel | 7ef28f3 | 2017-04-20 16:41:55 +0000 | [diff] [blame] | 244 | REPORTER_ASSERT(reporter, readBackOrigin == texOrigin); |
Robert Phillips | 3390e15 | 2017-01-31 17:53:34 -0500 | [diff] [blame] | 245 | |
Robert Phillips | 2746765 | 2019-01-10 16:34:22 -0500 | [diff] [blame] | 246 | test_image_backed(reporter, context, srcImage); |
robertphillips | cbc5bcc | 2016-02-19 10:41:12 -0800 | [diff] [blame] | 247 | } |
| 248 | |
bsalomon | 68d9134 | 2016-04-12 09:59:58 -0700 | [diff] [blame] | 249 | DEF_GPUTEST_FOR_RENDERING_CONTEXTS(ImageFilterCache_GPUBacked, reporter, ctxInfo) { |
Robert Phillips | 2c6d2bf | 2017-02-21 10:19:29 -0500 | [diff] [blame] | 250 | GrContext* context = ctxInfo.grContext(); |
robertphillips | cbc5bcc | 2016-02-19 10:41:12 -0800 | [diff] [blame] | 251 | |
Robert Phillips | 9da87e0 | 2019-02-04 13:26:26 -0500 | [diff] [blame] | 252 | sk_sp<GrTextureProxy> srcProxy(create_proxy(context->priv().proxyProvider())); |
Robert Phillips | 2c6d2bf | 2017-02-21 10:19:29 -0500 | [diff] [blame] | 253 | if (!srcProxy) { |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 254 | return; |
| 255 | } |
| 256 | |
| 257 | const SkIRect& full = SkIRect::MakeWH(kFullSize, kFullSize); |
| 258 | |
Robert Phillips | 2c6d2bf | 2017-02-21 10:19:29 -0500 | [diff] [blame] | 259 | sk_sp<SkSpecialImage> fullImg(SkSpecialImage::MakeDeferredFromGpu( |
| 260 | context, full, |
robertphillips | 37bd7c3 | 2016-03-17 14:31:39 -0700 | [diff] [blame] | 261 | kNeedNewImageUniqueID_SpecialImage, |
Robert Phillips | 40b05c3 | 2019-09-20 12:40:55 -0400 | [diff] [blame] | 262 | srcProxy, |
| 263 | GrColorType::kRGBA_8888, nullptr)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 264 | |
| 265 | const SkIRect& subset = SkIRect::MakeXYWH(kPad, kPad, kSmallerSize, kSmallerSize); |
| 266 | |
Robert Phillips | 2c6d2bf | 2017-02-21 10:19:29 -0500 | [diff] [blame] | 267 | sk_sp<SkSpecialImage> subsetImg(SkSpecialImage::MakeDeferredFromGpu( |
| 268 | context, subset, |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 269 | kNeedNewImageUniqueID_SpecialImage, |
Robert Phillips | 40b05c3 | 2019-09-20 12:40:55 -0400 | [diff] [blame] | 270 | srcProxy, |
| 271 | GrColorType::kRGBA_8888, nullptr)); |
robertphillips | df7bb47 | 2016-02-19 08:19:40 -0800 | [diff] [blame] | 272 | |
| 273 | test_find_existing(reporter, fullImg, subsetImg); |
| 274 | test_dont_find_if_diff_key(reporter, fullImg, subsetImg); |
| 275 | test_internal_purge(reporter, fullImg); |
| 276 | test_explicit_purging(reporter, fullImg, subsetImg); |
| 277 | } |