| OLD | NEW | 
|---|
| 1 /* | 1 /* | 
| 2  * Copyright 2009 The Android Open Source Project | 2  * Copyright 2009 The Android Open Source Project | 
| 3  * | 3  * | 
| 4  * Use of this source code is governed by a BSD-style license that can be | 4  * Use of this source code is governed by a BSD-style license that can be | 
| 5  * found in the LICENSE file. | 5  * found in the LICENSE file. | 
| 6  */ | 6  */ | 
| 7 | 7 | 
| 8 | 8 | 
| 9 #include "SkBitmapScaler.h" | 9 #include "SkBitmapScaler.h" | 
| 10 #include "SkBitmapProcState.h" | 10 #include "SkBitmapProcState.h" | 
| (...skipping 12 matching lines...) Expand all  Loading... | 
| 23     int count, | 23     int count, | 
| 24     uint16_t* SK_RESTRICT colors) SK_ATTRIBUTE_OPTIMIZE_O1; | 24     uint16_t* SK_RESTRICT colors) SK_ATTRIBUTE_OPTIMIZE_O1; | 
| 25 | 25 | 
| 26 void SI8_D16_nofilter_DX_arm(const SkBitmapProcState& s, | 26 void SI8_D16_nofilter_DX_arm(const SkBitmapProcState& s, | 
| 27                              const uint32_t* SK_RESTRICT xy, | 27                              const uint32_t* SK_RESTRICT xy, | 
| 28                              int count, uint16_t* SK_RESTRICT colors) { | 28                              int count, uint16_t* SK_RESTRICT colors) { | 
| 29     SkASSERT(count > 0 && colors != NULL); | 29     SkASSERT(count > 0 && colors != NULL); | 
| 30     SkASSERT(s.fInvType <= (SkMatrix::kTranslate_Mask | SkMatrix::kScale_Mask)); | 30     SkASSERT(s.fInvType <= (SkMatrix::kTranslate_Mask | SkMatrix::kScale_Mask)); | 
| 31     SkASSERT(kNone_SkFilterQuality == s.fFilterLevel); | 31     SkASSERT(kNone_SkFilterQuality == s.fFilterLevel); | 
| 32 | 32 | 
| 33     const uint16_t* SK_RESTRICT table = s.fBitmap->getColorTable()->read16BitCac
     he(); | 33     const uint16_t* SK_RESTRICT table = s.fPixmap.ctable()->read16BitCache(); | 
| 34     const uint8_t* SK_RESTRICT srcAddr = (const uint8_t*)s.fBitmap->getPixels(); | 34     const uint8_t* SK_RESTRICT srcAddr = (const uint8_t*)s.fPixmap.addr(); | 
| 35 | 35 | 
| 36     // buffer is y32, x16, x16, x16, x16, x16 | 36     // buffer is y32, x16, x16, x16, x16, x16 | 
| 37     // bump srcAddr to the proper row, since we're told Y never changes | 37     // bump srcAddr to the proper row, since we're told Y never changes | 
| 38     SkASSERT((unsigned)xy[0] < (unsigned)s.fBitmap->height()); | 38     SkASSERT((unsigned)xy[0] < (unsigned)s.fPixmap.height()); | 
| 39     srcAddr = (const uint8_t*)((const char*)srcAddr + | 39     srcAddr = (const uint8_t*)((const char*)srcAddr + xy[0] * s.fPixmap.rowBytes
     ()); | 
| 40                                xy[0] * s.fBitmap->rowBytes()); |  | 
| 41 | 40 | 
| 42     uint8_t src; | 41     uint8_t src; | 
| 43 | 42 | 
| 44     if (1 == s.fBitmap->width()) { | 43     if (1 == s.fPixmap.width()) { | 
| 45         src = srcAddr[0]; | 44         src = srcAddr[0]; | 
| 46         uint16_t dstValue = table[src]; | 45         uint16_t dstValue = table[src]; | 
| 47         sk_memset16(colors, dstValue, count); | 46         sk_memset16(colors, dstValue, count); | 
| 48     } else { | 47     } else { | 
| 49         int i; | 48         int i; | 
| 50         int count8 = count >> 3; | 49         int count8 = count >> 3; | 
| 51         const uint16_t* SK_RESTRICT xx = (const uint16_t*)(xy + 1); | 50         const uint16_t* SK_RESTRICT xx = (const uint16_t*)(xy + 1); | 
| 52 | 51 | 
| 53         asm volatile ( | 52         asm volatile ( | 
| 54             "cmp        %[count8], #0                  \n\t"  // compare loop co
     unter with 0 | 53             "cmp        %[count8], #0                  \n\t"  // compare loop co
     unter with 0 | 
| (...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 112     int count, | 111     int count, | 
| 113     SkPMColor* SK_RESTRICT colors) SK_ATTRIBUTE_OPTIMIZE_O1; | 112     SkPMColor* SK_RESTRICT colors) SK_ATTRIBUTE_OPTIMIZE_O1; | 
| 114 | 113 | 
| 115 void SI8_opaque_D32_nofilter_DX_arm(const SkBitmapProcState& s, | 114 void SI8_opaque_D32_nofilter_DX_arm(const SkBitmapProcState& s, | 
| 116                                     const uint32_t* SK_RESTRICT xy, | 115                                     const uint32_t* SK_RESTRICT xy, | 
| 117                                     int count, SkPMColor* SK_RESTRICT colors) { | 116                                     int count, SkPMColor* SK_RESTRICT colors) { | 
| 118     SkASSERT(count > 0 && colors != NULL); | 117     SkASSERT(count > 0 && colors != NULL); | 
| 119     SkASSERT(s.fInvType <= (SkMatrix::kTranslate_Mask | SkMatrix::kScale_Mask)); | 118     SkASSERT(s.fInvType <= (SkMatrix::kTranslate_Mask | SkMatrix::kScale_Mask)); | 
| 120     SkASSERT(kNone_SkFilterQuality == s.fFilterLevel); | 119     SkASSERT(kNone_SkFilterQuality == s.fFilterLevel); | 
| 121 | 120 | 
| 122     const SkPMColor* SK_RESTRICT table = s.fBitmap->getColorTable()->readColors(
     ); | 121     const SkPMColor* SK_RESTRICT table = s.fPixmap.ctable()->readColors(); | 
| 123     const uint8_t* SK_RESTRICT srcAddr = (const uint8_t*)s.fBitmap->getPixels(); | 122     const uint8_t* SK_RESTRICT srcAddr = (const uint8_t*)s.fPixmap.addr(); | 
| 124 | 123 | 
| 125     // buffer is y32, x16, x16, x16, x16, x16 | 124     // buffer is y32, x16, x16, x16, x16, x16 | 
| 126     // bump srcAddr to the proper row, since we're told Y never changes | 125     // bump srcAddr to the proper row, since we're told Y never changes | 
| 127     SkASSERT((unsigned)xy[0] < (unsigned)s.fBitmap->height()); | 126     SkASSERT((unsigned)xy[0] < (unsigned)s.fPixmap.height()); | 
| 128     srcAddr = (const uint8_t*)((const char*)srcAddr + xy[0] * s.fBitmap->rowByte
     s()); | 127     srcAddr = (const uint8_t*)((const char*)srcAddr + xy[0] * s.fPixmap.rowBytes
     ()); | 
| 129 | 128 | 
| 130     if (1 == s.fBitmap->width()) { | 129     if (1 == s.fPixmap.width()) { | 
| 131         uint8_t src = srcAddr[0]; | 130         uint8_t src = srcAddr[0]; | 
| 132         SkPMColor dstValue = table[src]; | 131         SkPMColor dstValue = table[src]; | 
| 133         sk_memset32(colors, dstValue, count); | 132         sk_memset32(colors, dstValue, count); | 
| 134     } else { | 133     } else { | 
| 135         const uint16_t* xx = (const uint16_t*)(xy + 1); | 134         const uint16_t* xx = (const uint16_t*)(xy + 1); | 
| 136 | 135 | 
| 137         asm volatile ( | 136         asm volatile ( | 
| 138             "subs       %[count], %[count], #8        \n\t"   // decrement count
      by 8, set flags | 137             "subs       %[count], %[count], #8        \n\t"   // decrement count
      by 8, set flags | 
| 139             "blt        2f                            \n\t"   // if count < 0, b
     ranch to singles | 138             "blt        2f                            \n\t"   // if count < 0, b
     ranch to singles | 
| 140             "1:                                       \n\t"   // eights loop | 139             "1:                                       \n\t"   // eights loop | 
| (...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 192  */ | 191  */ | 
| 193 void SkBitmapProcState::platformProcs() { | 192 void SkBitmapProcState::platformProcs() { | 
| 194 #if !defined(SK_CPU_ARM64) && SK_ARM_ARCH >= 6 && !defined(SK_CPU_BENDIAN) | 193 #if !defined(SK_CPU_ARM64) && SK_ARM_ARCH >= 6 && !defined(SK_CPU_BENDIAN) | 
| 195     bool isOpaque = 256 == fAlphaScale; | 194     bool isOpaque = 256 == fAlphaScale; | 
| 196     bool justDx = false; | 195     bool justDx = false; | 
| 197 | 196 | 
| 198     if (fInvType <= (SkMatrix::kTranslate_Mask | SkMatrix::kScale_Mask)) { | 197     if (fInvType <= (SkMatrix::kTranslate_Mask | SkMatrix::kScale_Mask)) { | 
| 199         justDx = true; | 198         justDx = true; | 
| 200     } | 199     } | 
| 201 | 200 | 
| 202     switch (fBitmap->colorType()) { | 201     switch (fPixmap.colorType()) { | 
| 203         case kIndex_8_SkColorType: | 202         case kIndex_8_SkColorType: | 
| 204             if (justDx && kNone_SkFilterQuality == fFilterLevel) { | 203             if (justDx && kNone_SkFilterQuality == fFilterLevel) { | 
| 205 #if 0   /* crashing on android device */ | 204 #if 0   /* crashing on android device */ | 
| 206                 fSampleProc16 = SI8_D16_nofilter_DX_arm; | 205                 fSampleProc16 = SI8_D16_nofilter_DX_arm; | 
| 207                 fShaderProc16 = NULL; | 206                 fShaderProc16 = NULL; | 
| 208 #endif | 207 #endif | 
| 209                 if (isOpaque) { | 208                 if (isOpaque) { | 
| 210                     // this one is only very slighty faster than the C version | 209                     // this one is only very slighty faster than the C version | 
| 211                     fSampleProc32 = SI8_opaque_D32_nofilter_DX_arm; | 210                     fSampleProc32 = SI8_opaque_D32_nofilter_DX_arm; | 
| 212                     fShaderProc32 = NULL; | 211                     fShaderProc32 = NULL; | 
| 213                 } | 212                 } | 
| 214             } | 213             } | 
| 215             break; | 214             break; | 
| 216         default: | 215         default: | 
| 217             break; | 216             break; | 
| 218     } | 217     } | 
| 219 #endif | 218 #endif | 
| 220 } | 219 } | 
| 221 | 220 | 
| 222 /////////////////////////////////////////////////////////////////////////////// | 221 /////////////////////////////////////////////////////////////////////////////// | 
| 223 | 222 | 
| 224 extern void platformConvolutionProcs_arm_neon(SkConvolutionProcs* procs); | 223 extern void platformConvolutionProcs_arm_neon(SkConvolutionProcs* procs); | 
| 225 | 224 | 
| 226 void platformConvolutionProcs_arm(SkConvolutionProcs* procs) { | 225 void platformConvolutionProcs_arm(SkConvolutionProcs* procs) { | 
| 227 } | 226 } | 
| 228 | 227 | 
| 229 void SkBitmapScaler::PlatformConvolutionProcs(SkConvolutionProcs* procs) { | 228 void SkBitmapScaler::PlatformConvolutionProcs(SkConvolutionProcs* procs) { | 
| 230     SK_ARM_NEON_WRAP(platformConvolutionProcs_arm)(procs); | 229     SK_ARM_NEON_WRAP(platformConvolutionProcs_arm)(procs); | 
| 231 } | 230 } | 
| OLD | NEW | 
|---|