aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core
diff options
context:
space:
mode:
authorGravatar Mike Klein <mtklein@chromium.org>2017-05-23 12:20:38 -0400
committerGravatar Skia Commit-Bot <skia-commit-bot@chromium.org>2017-05-23 17:02:53 +0000
commit87db00111596d432908882a13982adde79793a7c (patch)
treef1eddaef5810ed9b6d72629508c6868fc6493c99 /src/core
parent5373609d90d8f84b75718b15f3522f9d2f4226cb (diff)
move sk_memset?? to SkOpts
This lets the compiler generate AVX versions with wider writes. Change-Id: Ia63825e70c72bdb4d14bef97d8b4ea4be54c9d84 Reviewed-on: https://skia-review.googlesource.com/17715 Reviewed-by: Florin Malita <fmalita@chromium.org> Commit-Queue: Mike Klein <mtklein@chromium.org>
Diffstat (limited to 'src/core')
-rw-r--r--src/core/SkOpts.cpp5
-rw-r--r--src/core/SkOpts.h4
-rw-r--r--src/core/SkUtils.cpp16
-rw-r--r--src/core/SkUtils.h13
4 files changed, 19 insertions, 19 deletions
diff --git a/src/core/SkOpts.cpp b/src/core/SkOpts.cpp
index 4666e73ce3..33c3690f4e 100644
--- a/src/core/SkOpts.cpp
+++ b/src/core/SkOpts.cpp
@@ -44,6 +44,7 @@
#include "SkChecksum_opts.h"
#include "SkMorphologyImageFilter_opts.h"
#include "SkSwizzler_opts.h"
+#include "SkUtils_opts.h"
#include "SkXfermode_opts.h"
namespace SkOpts {
@@ -81,6 +82,10 @@ namespace SkOpts {
DEFINE_DEFAULT(srcover_srgb_srgb);
+ DEFINE_DEFAULT(memset16);
+ DEFINE_DEFAULT(memset32);
+ DEFINE_DEFAULT(memset64);
+
DEFINE_DEFAULT(hash_fn);
DEFINE_DEFAULT(convolve_vertically);
diff --git a/src/core/SkOpts.h b/src/core/SkOpts.h
index bf9a96382f..31153f929a 100644
--- a/src/core/SkOpts.h
+++ b/src/core/SkOpts.h
@@ -53,6 +53,10 @@ namespace SkOpts {
// If nsrc < ndst, we loop over src to create a pattern.
extern void (*srcover_srgb_srgb)(uint32_t* dst, const uint32_t* src, int ndst, int nsrc);
+ extern void (*memset16)(uint16_t[], uint16_t, int);
+ extern void (*memset32)(uint32_t[], uint32_t, int);
+ extern void (*memset64)(uint64_t[], uint64_t, int);
+
// The fastest high quality 32-bit hash we can provide on this platform.
extern uint32_t (*hash_fn)(const void*, size_t, uint32_t seed);
static inline uint32_t hash(const void* data, size_t bytes, uint32_t seed=0) {
diff --git a/src/core/SkUtils.cpp b/src/core/SkUtils.cpp
index 311394d70c..85ebb3e29c 100644
--- a/src/core/SkUtils.cpp
+++ b/src/core/SkUtils.cpp
@@ -8,22 +8,6 @@
#include "SkUtils.h"
-void sk_memset16(uint16_t buffer[], uint16_t value, int count) {
- for (int i = 0; i < count; i++) {
- buffer[i] = value;
- }
-}
-void sk_memset32(uint32_t buffer[], uint32_t value, int count) {
- for (int i = 0; i < count; i++) {
- buffer[i] = value;
- }
-}
-void sk_memset64(uint64_t buffer[], uint64_t value, int count) {
- for (int i = 0; i < count; i++) {
- buffer[i] = value;
- }
-}
-
/* 0xxxxxxx 1 total
10xxxxxx // never a leading byte
110xxxxx 2 total
diff --git a/src/core/SkUtils.h b/src/core/SkUtils.h
index 241a61ad2f..2ae6f87eea 100644
--- a/src/core/SkUtils.h
+++ b/src/core/SkUtils.h
@@ -10,15 +10,22 @@
#include "SkTypes.h"
#include "SkMath.h"
+#include "SkOpts.h"
/** Similar to memset(), but it assigns a 16, 32, or 64-bit value into the buffer.
@param buffer The memory to have value copied into it
@param value The value to be copied into buffer
@param count The number of times value should be copied into the buffer.
*/
-void sk_memset16(uint16_t buffer[], uint16_t value, int count);
-void sk_memset32(uint32_t buffer[], uint32_t value, int count);
-void sk_memset64(uint64_t buffer[], uint64_t value, int count);
+static inline void sk_memset16(uint16_t buffer[], uint16_t value, int count) {
+ SkOpts::memset16(buffer, value, count);
+}
+static inline void sk_memset32(uint32_t buffer[], uint32_t value, int count) {
+ SkOpts::memset32(buffer, value, count);
+}
+static inline void sk_memset64(uint64_t buffer[], uint64_t value, int count) {
+ SkOpts::memset64(buffer, value, count);
+}
///////////////////////////////////////////////////////////////////////////////
#define kMaxBytesInUTF8Sequence 4