OLD | NEW |
1 #ifndef SkColor_opts_neon_DEFINED | 1 #ifndef SkColor_opts_neon_DEFINED |
2 #define SkColor_opts_neon_DEFINED | 2 #define SkColor_opts_neon_DEFINED |
3 | 3 |
4 #include "SkTypes.h" | 4 #include "SkTypes.h" |
5 | 5 |
| 6 #include <arm_neon.h> |
| 7 |
6 #define NEON_A (SK_A32_SHIFT / 8) | 8 #define NEON_A (SK_A32_SHIFT / 8) |
7 #define NEON_R (SK_R32_SHIFT / 8) | 9 #define NEON_R (SK_R32_SHIFT / 8) |
8 #define NEON_G (SK_G32_SHIFT / 8) | 10 #define NEON_G (SK_G32_SHIFT / 8) |
9 #define NEON_B (SK_B32_SHIFT / 8) | 11 #define NEON_B (SK_B32_SHIFT / 8) |
10 | 12 |
| 13 static inline uint16x8_t SkAlpha255To256_neon8(uint8x8_t alpha) { |
| 14 return vaddw_u8(vdupq_n_u16(1), alpha); |
| 15 } |
| 16 |
| 17 static inline uint8x8_t SkAlphaMul_neon8(uint8x8_t color, uint16x8_t scale) { |
| 18 return vshrn_n_u16(vmovl_u8(color) * scale, 8); |
| 19 } |
| 20 |
| 21 static inline uint8x8x4_t SkAlphaMulQ_neon8(uint8x8x4_t color, uint16x8_t scale)
{ |
| 22 uint8x8x4_t ret; |
| 23 |
| 24 ret.val[NEON_A] = SkAlphaMul_neon8(color.val[NEON_A], scale); |
| 25 ret.val[NEON_R] = SkAlphaMul_neon8(color.val[NEON_R], scale); |
| 26 ret.val[NEON_G] = SkAlphaMul_neon8(color.val[NEON_G], scale); |
| 27 ret.val[NEON_B] = SkAlphaMul_neon8(color.val[NEON_B], scale); |
| 28 |
| 29 return ret; |
| 30 } |
| 31 |
11 #endif /* #ifndef SkColor_opts_neon_DEFINED */ | 32 #endif /* #ifndef SkColor_opts_neon_DEFINED */ |
OLD | NEW |