| OLD | NEW | 
|---|
|  | (Empty) | 
| 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 |  | 
| 8 #include <initializer_list> |  | 
| 9 #include "Test.h" |  | 
| 10 |  | 
| 11 #if SK_SUPPORT_GPU |  | 
| 12 #include "GrContext.h" |  | 
| 13 #include "GrTexture.h" |  | 
| 14 #include "GrTextureProvider.h" |  | 
| 15 |  | 
| 16 #include "SkUtils.h" |  | 
| 17 |  | 
| 18 DEF_GPUTEST_FOR_RENDERING_CONTEXTS(CopySurface, reporter, context) { |  | 
| 19     static const int kW = 10; |  | 
| 20     static const int kH = 10; |  | 
| 21     static const size_t kRowBytes = sizeof(uint32_t) * kW; |  | 
| 22 |  | 
| 23     GrSurfaceDesc baseDesc; |  | 
| 24     baseDesc.fConfig = kRGBA_8888_GrPixelConfig; |  | 
| 25     baseDesc.fWidth = kW; |  | 
| 26     baseDesc.fHeight = kH; |  | 
| 27 |  | 
| 28     SkAutoTMalloc<uint32_t> srcPixels(kW * kH); |  | 
| 29     for (int i = 0; i < kW * kH; ++i) { |  | 
| 30         srcPixels.get()[i] = i; |  | 
| 31     } |  | 
| 32 |  | 
| 33     SkAutoTMalloc<uint32_t> dstPixels(kW * kH); |  | 
| 34     for (int i = 0; i < kW * kH; ++i) { |  | 
| 35         dstPixels.get()[i] = ~i; |  | 
| 36     } |  | 
| 37 |  | 
| 38     static const SkIRect kSrcRects[] { |  | 
| 39         { 0,  0, kW  , kH  }, |  | 
| 40         {-1, -1, kW+1, kH+1}, |  | 
| 41         { 1,  1, kW-1, kH-1}, |  | 
| 42         { 5,  5, 6   , 6   }, |  | 
| 43     }; |  | 
| 44 |  | 
| 45     static const SkIPoint kDstPoints[] { |  | 
| 46         { 0   ,  0   }, |  | 
| 47         { 1   ,  1   }, |  | 
| 48         { kW/2,  kH/4}, |  | 
| 49         { kW-1,  kH-1}, |  | 
| 50         { kW  ,  kH  }, |  | 
| 51         { kW+1,  kH+2}, |  | 
| 52         {-1   , -1   }, |  | 
| 53     }; |  | 
| 54 |  | 
| 55     SkAutoTMalloc<uint32_t> read(kW * kH); |  | 
| 56 |  | 
| 57     for (auto sOrigin : {kBottomLeft_GrSurfaceOrigin, kTopLeft_GrSurfaceOrigin})
      { |  | 
| 58         for (auto dOrigin : {kBottomLeft_GrSurfaceOrigin, kTopLeft_GrSurfaceOrig
     in}) { |  | 
| 59             for (auto sFlags: {kRenderTarget_GrSurfaceFlag, kNone_GrSurfaceFlags
     }) { |  | 
| 60                 for (auto dFlags: {kRenderTarget_GrSurfaceFlag, kNone_GrSurfaceF
     lags}) { |  | 
| 61                     for (auto srcRect : kSrcRects) { |  | 
| 62                         for (auto dstPoint : kDstPoints) { |  | 
| 63                             GrSurfaceDesc srcDesc = baseDesc; |  | 
| 64                             srcDesc.fOrigin = sOrigin; |  | 
| 65                             srcDesc.fFlags = sFlags; |  | 
| 66                             GrSurfaceDesc dstDesc = baseDesc; |  | 
| 67                             dstDesc.fOrigin = dOrigin; |  | 
| 68                             dstDesc.fFlags = dFlags; |  | 
| 69 |  | 
| 70                             SkAutoTUnref<GrTexture> src( |  | 
| 71                                 context->textureProvider()->createTexture(srcDes
     c, false, |  | 
| 72                                                                           srcPix
     els.get(), |  | 
| 73                                                                           kRowBy
     tes)); |  | 
| 74                             SkAutoTUnref<GrTexture> dst( |  | 
| 75                                 context->textureProvider()->createTexture(dstDes
     c, false, |  | 
| 76                                                                           dstPix
     els.get(), |  | 
| 77                                                                           kRowBy
     tes)); |  | 
| 78                             if (!src || !dst) { |  | 
| 79                                 ERRORF(reporter, |  | 
| 80                                        "Could not create surfaces for copy surfa
     ce test."); |  | 
| 81                                 continue; |  | 
| 82                             } |  | 
| 83 |  | 
| 84                             bool result = context->copySurface(dst, src, srcRect
     , dstPoint); |  | 
| 85 |  | 
| 86                             bool expectedResult = true; |  | 
| 87                             SkIPoint dstOffset = { dstPoint.fX - srcRect.fLeft, |  | 
| 88                                                    dstPoint.fY - srcRect.fTop }; |  | 
| 89                             SkIRect copiedDstRect = SkIRect::MakeXYWH(dstPoint.f
     X, |  | 
| 90                                                                       dstPoint.f
     Y, |  | 
| 91                                                                       srcRect.wi
     dth(), |  | 
| 92                                                                       srcRect.he
     ight()); |  | 
| 93 |  | 
| 94                             SkIRect copiedSrcRect; |  | 
| 95                             if (!copiedSrcRect.intersect(srcRect, SkIRect::MakeW
     H(kW, kH))) { |  | 
| 96                                 expectedResult = false; |  | 
| 97                             } else { |  | 
| 98                                 // If the src rect was clipped, apply same clipp
     ing to each side of |  | 
| 99                                 // copied dst rect. |  | 
| 100                                 copiedDstRect.fLeft += copiedSrcRect.fLeft - src
     Rect.fLeft; |  | 
| 101                                 copiedDstRect.fTop += copiedSrcRect.fTop - srcRe
     ct.fTop; |  | 
| 102                                 copiedDstRect.fRight -= copiedSrcRect.fRight - s
     rcRect.fRight; |  | 
| 103                                 copiedDstRect.fBottom -= copiedSrcRect.fBottom -
      srcRect.fBottom; |  | 
| 104                             } |  | 
| 105                             if (copiedDstRect.isEmpty() || |  | 
| 106                                 !copiedDstRect.intersect(SkIRect::MakeWH(kW, kH)
     )) { |  | 
| 107                                 expectedResult = false; |  | 
| 108                             } |  | 
| 109                             // To make the copied src rect correct we would appl
     y any dst clipping |  | 
| 110                             // back to the src rect, but we don't use it again s
     o don't bother. |  | 
| 111                             if (expectedResult != result) { |  | 
| 112                                 ERRORF(reporter, "Expected return value %d from 
     copySurface, got " |  | 
| 113                                        "%d.", expectedResult, result); |  | 
| 114                                 continue; |  | 
| 115                             } |  | 
| 116 |  | 
| 117                             if (!expectedResult || !result) { |  | 
| 118                                 continue; |  | 
| 119                             } |  | 
| 120 |  | 
| 121                             sk_memset32(read.get(), 0, kW * kH); |  | 
| 122                             if (!dst->readPixels(0, 0, kW, kH, baseDesc.fConfig,
      read.get(), |  | 
| 123                                                  kRowBytes)) { |  | 
| 124                                 ERRORF(reporter, "Error calling readPixels"); |  | 
| 125                                 continue; |  | 
| 126                             } |  | 
| 127 |  | 
| 128                             bool abort = false; |  | 
| 129                             // Validate that pixels inside copiedDstRect receive
     d the correct value |  | 
| 130                             // from src and that those outside were not modified
     . |  | 
| 131                             for (int y = 0; y < kH && !abort; ++y) { |  | 
| 132                                 for (int x = 0; x < kW; ++x) { |  | 
| 133                                     uint32_t r = read.get()[y * kW + x]; |  | 
| 134                                     if (copiedDstRect.contains(x, y)) { |  | 
| 135                                         int sx = x - dstOffset.fX; |  | 
| 136                                         int sy = y - dstOffset.fY; |  | 
| 137                                         uint32_t s = srcPixels.get()[sy * kW + s
     x]; |  | 
| 138                                         if (s != r) { |  | 
| 139                                             ERRORF(reporter, "Expected dst %d,%d
      to contain " |  | 
| 140                                                    "0x%08x copied from src locat
     ion %d,%d. Got " |  | 
| 141                                                    "0x%08x", x, y, s, sx, sy, r)
     ; |  | 
| 142                                             abort = true; |  | 
| 143                                             break; |  | 
| 144                                         } |  | 
| 145                                     } else { |  | 
| 146                                         uint32_t d = dstPixels.get()[y * kW + x]
     ; |  | 
| 147                                         if (d != r) { |  | 
| 148                                             ERRORF(reporter, "Expected dst %d,%d
      to be unmodified (" |  | 
| 149                                                    "0x%08x). Got 0x%08x", x, y, 
     d, r); |  | 
| 150                                             abort = true; |  | 
| 151                                             break; |  | 
| 152                                         } |  | 
| 153                                     } |  | 
| 154                                 } |  | 
| 155                             } |  | 
| 156                         } |  | 
| 157                     } |  | 
| 158                 } |  | 
| 159             } |  | 
| 160         } |  | 
| 161     } |  | 
| 162 } |  | 
| 163 #endif |  | 
| OLD | NEW | 
|---|