blob: 5cac6c8fc75b4d667c2486b9c8dd10ffccd8daba [file] [log] [blame]
commit-bot@chromium.orge997c262013-08-28 15:07:58 +00001
rmistry@google.comd6bab022013-12-02 13:50:38 +00002#include "SkColor.h"
3#include "SkColorPriv.h"
commit-bot@chromium.orge997c262013-08-28 15:07:58 +00004#include "SkBlitMask.h"
rmistry@google.comd6bab022013-12-02 13:50:38 +00005#include "SkUtilsArm.h"
6#include "SkBlitMask_opts_arm_neon.h"
commit-bot@chromium.orge997c262013-08-28 15:07:58 +00007
8SkBlitMask::ColorProc SkBlitMask::PlatformColorProcs(SkBitmap::Config dstConfig,
9 SkMask::Format maskFormat,
10 SkColor color) {
rmistry@google.comd6bab022013-12-02 13:50:38 +000011#if SK_ARM_NEON_IS_NONE
12 return NULL;
13#else
commit-bot@chromium.org0e8c8ef2014-02-06 21:27:40 +000014/* ** This has been disabled until we can diagnose and fix the SIGILL generated
15 ** in the NEON code. See http://skbug.com/2067 for details.
rmistry@google.comd6bab022013-12-02 13:50:38 +000016#if SK_ARM_NEON_IS_DYNAMIC
17 if (!sk_cpu_arm_has_neon()) {
18 return NULL;
19 }
20#endif
21 if ((SkBitmap::kARGB_8888_Config == dstConfig) &&
22 (SkMask::kA8_Format == maskFormat)) {
23 return D32_A8_Factory_neon(color);
24 }
commit-bot@chromium.org0e8c8ef2014-02-06 21:27:40 +000025*/
rmistry@google.comd6bab022013-12-02 13:50:38 +000026#endif
27
28 // We don't need to handle the SkMask::kLCD16_Format case as the default
29 // LCD16 will call us through SkBlitMask::PlatformBlitRowProcs16()
30
commit-bot@chromium.orge997c262013-08-28 15:07:58 +000031 return NULL;
32}
33
34SkBlitMask::BlitLCD16RowProc SkBlitMask::PlatformBlitRowProcs16(bool isOpaque) {
rmistry@google.comd6bab022013-12-02 13:50:38 +000035 if (isOpaque) {
36 return SK_ARM_NEON_WRAP(SkBlitLCD16OpaqueRow);
37 } else {
38 return SK_ARM_NEON_WRAP(SkBlitLCD16Row);
39 }
commit-bot@chromium.orge997c262013-08-28 15:07:58 +000040}
41
42SkBlitMask::RowProc SkBlitMask::PlatformRowProcs(SkBitmap::Config dstConfig,
43 SkMask::Format maskFormat,
44 RowFlags flags) {
45 return NULL;
46}