mtklein | d2ffd36 | 2015-05-12 06:11:21 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2015 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 "SkUtils.h" |
| 9 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 10 | namespace { // See Sk4px.h |
| 11 | |
mtklein | d2ffd36 | 2015-05-12 06:11:21 -0700 | [diff] [blame] | 12 | static_assert(sizeof(Sk4px) == 16, "This file uses memcpy / sk_memset32, so exact size matters."); |
| 13 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 14 | inline Sk4px Sk4px::DupPMColor(SkPMColor px) { |
mtklein | 059ac00 | 2015-06-22 10:39:38 -0700 | [diff] [blame] | 15 | Sk4px px4 = Sk16b(); |
| 16 | sk_memset32((uint32_t*)&px4, px, 4); |
| 17 | return px4; |
mtklein | d2ffd36 | 2015-05-12 06:11:21 -0700 | [diff] [blame] | 18 | } |
| 19 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 20 | inline Sk4px Sk4px::Load4(const SkPMColor px[4]) { |
mtklein | d2ffd36 | 2015-05-12 06:11:21 -0700 | [diff] [blame] | 21 | Sk4px px4 = Sk16b(); |
| 22 | memcpy(&px4, px, 16); |
| 23 | return px4; |
| 24 | } |
| 25 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 26 | inline Sk4px Sk4px::Load2(const SkPMColor px[2]) { |
mtklein | d2ffd36 | 2015-05-12 06:11:21 -0700 | [diff] [blame] | 27 | Sk4px px2 = Sk16b(); |
| 28 | memcpy(&px2, px, 8); |
| 29 | return px2; |
| 30 | } |
| 31 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 32 | inline Sk4px Sk4px::Load1(const SkPMColor px[1]) { |
mtklein | d2ffd36 | 2015-05-12 06:11:21 -0700 | [diff] [blame] | 33 | Sk4px px1 = Sk16b(); |
| 34 | memcpy(&px1, px, 4); |
| 35 | return px1; |
| 36 | } |
| 37 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 38 | inline void Sk4px::store4(SkPMColor px[4]) const { memcpy(px, this, 16); } |
| 39 | inline void Sk4px::store2(SkPMColor px[2]) const { memcpy(px, this, 8); } |
| 40 | inline void Sk4px::store1(SkPMColor px[1]) const { memcpy(px, this, 4); } |
mtklein | d2ffd36 | 2015-05-12 06:11:21 -0700 | [diff] [blame] | 41 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 42 | inline Sk4px::Wide Sk4px::widenLo() const { |
mtklein | d2ffd36 | 2015-05-12 06:11:21 -0700 | [diff] [blame] | 43 | return Sk16h(this->kth< 0>(), this->kth< 1>(), this->kth< 2>(), this->kth< 3>(), |
| 44 | this->kth< 4>(), this->kth< 5>(), this->kth< 6>(), this->kth< 7>(), |
| 45 | this->kth< 8>(), this->kth< 9>(), this->kth<10>(), this->kth<11>(), |
| 46 | this->kth<12>(), this->kth<13>(), this->kth<14>(), this->kth<15>()); |
| 47 | } |
| 48 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 49 | inline Sk4px::Wide Sk4px::widenHi() const { return this->widenLo() << 8; } |
mtklein | d2ffd36 | 2015-05-12 06:11:21 -0700 | [diff] [blame] | 50 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 51 | inline Sk4px::Wide Sk4px::widenLoHi() const { return this->widenLo() + this->widenHi(); } |
mtklein | 4be181e | 2015-07-14 10:54:19 -0700 | [diff] [blame] | 52 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 53 | inline Sk4px::Wide Sk4px::mulWiden(const Sk16b& other) const { |
mtklein | d2ffd36 | 2015-05-12 06:11:21 -0700 | [diff] [blame] | 54 | return this->widenLo() * Sk4px(other).widenLo(); |
| 55 | } |
| 56 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 57 | inline Sk4px Sk4px::Wide::addNarrowHi(const Sk16h& other) const { |
mtklein | d2ffd36 | 2015-05-12 06:11:21 -0700 | [diff] [blame] | 58 | Sk4px::Wide r = (*this + other) >> 8; |
| 59 | return Sk16b(r.kth< 0>(), r.kth< 1>(), r.kth< 2>(), r.kth< 3>(), |
| 60 | r.kth< 4>(), r.kth< 5>(), r.kth< 6>(), r.kth< 7>(), |
| 61 | r.kth< 8>(), r.kth< 9>(), r.kth<10>(), r.kth<11>(), |
| 62 | r.kth<12>(), r.kth<13>(), r.kth<14>(), r.kth<15>()); |
| 63 | } |
mtklein | 8a90edc | 2015-05-13 12:19:42 -0700 | [diff] [blame] | 64 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 65 | inline Sk4px Sk4px::alphas() const { |
mtklein | 8a90edc | 2015-05-13 12:19:42 -0700 | [diff] [blame] | 66 | static_assert(SK_A32_SHIFT == 24, "This method assumes little-endian."); |
| 67 | return Sk16b(this->kth< 3>(), this->kth< 3>(), this->kth< 3>(), this->kth< 3>(), |
| 68 | this->kth< 7>(), this->kth< 7>(), this->kth< 7>(), this->kth< 7>(), |
| 69 | this->kth<11>(), this->kth<11>(), this->kth<11>(), this->kth<11>(), |
| 70 | this->kth<15>(), this->kth<15>(), this->kth<15>(), this->kth<15>()); |
| 71 | } |
| 72 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 73 | inline Sk4px Sk4px::Load4Alphas(const SkAlpha a[4]) { |
mtklein | 8a90edc | 2015-05-13 12:19:42 -0700 | [diff] [blame] | 74 | return Sk16b(a[0], a[0], a[0], a[0], |
| 75 | a[1], a[1], a[1], a[1], |
| 76 | a[2], a[2], a[2], a[2], |
| 77 | a[3], a[3], a[3], a[3]); |
| 78 | } |
| 79 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 80 | inline Sk4px Sk4px::Load2Alphas(const SkAlpha a[2]) { |
mtklein | 8a90edc | 2015-05-13 12:19:42 -0700 | [diff] [blame] | 81 | return Sk16b(a[0], a[0], a[0], a[0], |
| 82 | a[1], a[1], a[1], a[1], |
| 83 | 0,0,0,0, |
| 84 | 0,0,0,0); |
| 85 | } |
mtklein | 0135a41 | 2015-05-15 10:36:21 -0700 | [diff] [blame] | 86 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 87 | inline Sk4px Sk4px::zeroAlphas() const { |
mtklein | 0135a41 | 2015-05-15 10:36:21 -0700 | [diff] [blame] | 88 | static_assert(SK_A32_SHIFT == 24, "This method assumes little-endian."); |
| 89 | return Sk16b(this->kth< 0>(), this->kth< 1>(), this->kth< 2>(), 0, |
| 90 | this->kth< 4>(), this->kth< 5>(), this->kth< 6>(), 0, |
| 91 | this->kth< 8>(), this->kth< 9>(), this->kth<10>(), 0, |
| 92 | this->kth<12>(), this->kth<13>(), this->kth<14>(), 0); |
| 93 | } |
| 94 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 95 | inline Sk4px Sk4px::zeroColors() const { |
mtklein | 0135a41 | 2015-05-15 10:36:21 -0700 | [diff] [blame] | 96 | static_assert(SK_A32_SHIFT == 24, "This method assumes little-endian."); |
| 97 | return Sk16b(0,0,0, this->kth< 3>(), |
| 98 | 0,0,0, this->kth< 7>(), |
| 99 | 0,0,0, this->kth<11>(), |
| 100 | 0,0,0, this->kth<15>()); |
| 101 | } |
| 102 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 103 | inline Sk4px Sk4px::Load4(const SkPMColor16 src[4]) { |
mtklein | ced1585 | 2015-07-22 10:52:53 -0700 | [diff] [blame] | 104 | SkPMColor src32[4]; |
| 105 | for (int i = 0; i < 4; i++) { src32[i] = SkPixel16ToPixel32(src[i]); } |
| 106 | return Load4(src32); |
| 107 | } |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 108 | inline Sk4px Sk4px::Load2(const SkPMColor16 src[2]) { |
mtklein | ced1585 | 2015-07-22 10:52:53 -0700 | [diff] [blame] | 109 | SkPMColor src32[2]; |
| 110 | for (int i = 0; i < 2; i++) { src32[i] = SkPixel16ToPixel32(src[i]); } |
| 111 | return Load2(src32); |
| 112 | } |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 113 | inline Sk4px Sk4px::Load1(const SkPMColor16 src[1]) { |
mtklein | ced1585 | 2015-07-22 10:52:53 -0700 | [diff] [blame] | 114 | SkPMColor src32 = SkPixel16ToPixel32(src[0]); |
| 115 | return Load1(&src32); |
| 116 | } |
| 117 | |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 118 | inline void Sk4px::store4(SkPMColor16 dst[4]) const { |
mtklein | ced1585 | 2015-07-22 10:52:53 -0700 | [diff] [blame] | 119 | SkPMColor dst32[4]; |
| 120 | this->store4(dst32); |
| 121 | for (int i = 0; i < 4; i++) { dst[i] = SkPixel32ToPixel16(dst32[i]); } |
| 122 | } |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 123 | inline void Sk4px::store2(SkPMColor16 dst[2]) const { |
mtklein | ced1585 | 2015-07-22 10:52:53 -0700 | [diff] [blame] | 124 | SkPMColor dst32[2]; |
| 125 | this->store2(dst32); |
| 126 | for (int i = 0; i < 2; i++) { dst[i] = SkPixel32ToPixel16(dst32[i]); } |
| 127 | } |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 128 | inline void Sk4px::store1(SkPMColor16 dst[1]) const { |
mtklein | ced1585 | 2015-07-22 10:52:53 -0700 | [diff] [blame] | 129 | SkPMColor dst32; |
| 130 | this->store1(&dst32); |
| 131 | dst[0] = SkPixel32ToPixel16(dst32); |
| 132 | } |
mtklein | 082e329 | 2015-08-12 11:56:43 -0700 | [diff] [blame^] | 133 | |
| 134 | } // namespace |