Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(203)

Side by Side Diff: src/opts/SkNx_neon.h

Issue 2144573004: SkRasterPipeline preliminaries (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: MSVC x86 vetoed lambdas. :( Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/core/SkRasterPipeline.cpp ('k') | src/opts/SkNx_sse.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2015 Google Inc. 2 * Copyright 2015 Google Inc.
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 #ifndef SkNx_neon_DEFINED 8 #ifndef SkNx_neon_DEFINED
9 #define SkNx_neon_DEFINED 9 #define SkNx_neon_DEFINED
10 10
(...skipping 368 matching lines...) Expand 10 before | Expand all | Expand 10 after
379 int operator[](int k) const { 379 int operator[](int k) const {
380 SkASSERT(0 <= k && k < 4); 380 SkASSERT(0 <= k && k < 4);
381 union { int32x4_t v; int is[4]; } pun = {fVec}; 381 union { int32x4_t v; int is[4]; } pun = {fVec};
382 return pun.is[k&3]; 382 return pun.is[k&3];
383 } 383 }
384 384
385 SkNx operator + (const SkNx& o) const { return vaddq_s32(fVec, o.fVec); } 385 SkNx operator + (const SkNx& o) const { return vaddq_s32(fVec, o.fVec); }
386 SkNx operator - (const SkNx& o) const { return vsubq_s32(fVec, o.fVec); } 386 SkNx operator - (const SkNx& o) const { return vsubq_s32(fVec, o.fVec); }
387 SkNx operator * (const SkNx& o) const { return vmulq_s32(fVec, o.fVec); } 387 SkNx operator * (const SkNx& o) const { return vmulq_s32(fVec, o.fVec); }
388 388
389 SkNx operator & (const SkNx& o) const { return vandq_s32(fVec, o.fVec); }
389 SkNx operator | (const SkNx& o) const { return vorrq_s32(fVec, o.fVec); } 390 SkNx operator | (const SkNx& o) const { return vorrq_s32(fVec, o.fVec); }
390 391
391 SkNx operator << (int bits) const { SHIFT32(vshlq_n_s32, fVec, bits); } 392 SkNx operator << (int bits) const { SHIFT32(vshlq_n_s32, fVec, bits); }
392 SkNx operator >> (int bits) const { SHIFT32(vshrq_n_s32, fVec, bits); } 393 SkNx operator >> (int bits) const { SHIFT32(vshrq_n_s32, fVec, bits); }
393 394
394 static SkNx Min(const SkNx& a, const SkNx& b) { return vminq_s32(a.fVec, b.f Vec); } 395 static SkNx Min(const SkNx& a, const SkNx& b) { return vminq_s32(a.fVec, b.f Vec); }
395 // TODO as needed 396 // TODO as needed
396 397
397 int32x4_t fVec; 398 int32x4_t fVec;
398 }; 399 };
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
444 445
445 template<> inline Sk4h SkNx_cast<uint16_t, uint8_t>(const Sk4b& src) { 446 template<> inline Sk4h SkNx_cast<uint16_t, uint8_t>(const Sk4b& src) {
446 return vget_low_u16(vmovl_u8(src.fVec)); 447 return vget_low_u16(vmovl_u8(src.fVec));
447 } 448 }
448 449
449 template<> inline Sk4b SkNx_cast<uint8_t, uint16_t>(const Sk4h& src) { 450 template<> inline Sk4b SkNx_cast<uint8_t, uint16_t>(const Sk4h& src) {
450 return vmovn_u16(vcombine_u16(src.fVec, src.fVec)); 451 return vmovn_u16(vcombine_u16(src.fVec, src.fVec));
451 } 452 }
452 453
453 #endif//SkNx_neon_DEFINED 454 #endif//SkNx_neon_DEFINED
OLDNEW
« no previous file with comments | « src/core/SkRasterPipeline.cpp ('k') | src/opts/SkNx_sse.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698