2008-12-17 15:59:43 +00:00
|
|
|
/*
|
2011-07-28 14:26:00 +00:00
|
|
|
* Copyright 2006 The Android Open Source Project
|
2008-12-17 15:59:43 +00:00
|
|
|
*
|
2011-07-28 14:26:00 +00:00
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
2008-12-17 15:59:43 +00:00
|
|
|
*/
|
|
|
|
|
2015-08-05 20:57:49 +00:00
|
|
|
// IWYU pragma: private, include "SkTypes.h"
|
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
#ifndef SkPostConfig_DEFINED
|
|
|
|
#define SkPostConfig_DEFINED
|
|
|
|
|
2016-08-05 20:04:41 +00:00
|
|
|
#if !defined(SK_DEBUG) && !defined(SK_RELEASE)
|
|
|
|
#ifdef NDEBUG
|
|
|
|
#define SK_RELEASE
|
|
|
|
#else
|
|
|
|
#define SK_DEBUG
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
#if defined(SK_DEBUG) && defined(SK_RELEASE)
|
2013-12-04 16:40:42 +00:00
|
|
|
# error "cannot define both SK_DEBUG and SK_RELEASE"
|
2008-12-17 15:59:43 +00:00
|
|
|
#elif !defined(SK_DEBUG) && !defined(SK_RELEASE)
|
2013-12-04 16:40:42 +00:00
|
|
|
# error "must define either SK_DEBUG or SK_RELEASE"
|
2008-12-17 15:59:43 +00:00
|
|
|
#endif
|
|
|
|
|
2013-12-04 16:40:42 +00:00
|
|
|
/**
|
|
|
|
* Matrix calculations may be float or double.
|
2015-06-09 22:06:22 +00:00
|
|
|
* The default is float, as that's what Chromium's using.
|
2013-12-04 16:40:42 +00:00
|
|
|
*/
|
2012-11-13 20:12:00 +00:00
|
|
|
#if defined(SK_MSCALAR_IS_DOUBLE) && defined(SK_MSCALAR_IS_FLOAT)
|
2013-12-04 16:40:42 +00:00
|
|
|
# error "cannot define both SK_MSCALAR_IS_DOUBLE and SK_MSCALAR_IS_FLOAT"
|
2012-11-13 20:12:00 +00:00
|
|
|
#elif !defined(SK_MSCALAR_IS_DOUBLE) && !defined(SK_MSCALAR_IS_FLOAT)
|
2015-06-09 22:06:22 +00:00
|
|
|
# define SK_MSCALAR_IS_FLOAT
|
2012-11-13 20:12:00 +00:00
|
|
|
#endif
|
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
#if defined(SK_CPU_LENDIAN) && defined(SK_CPU_BENDIAN)
|
2013-12-04 16:40:42 +00:00
|
|
|
# error "cannot define both SK_CPU_LENDIAN and SK_CPU_BENDIAN"
|
2008-12-17 15:59:43 +00:00
|
|
|
#elif !defined(SK_CPU_LENDIAN) && !defined(SK_CPU_BENDIAN)
|
2013-12-04 16:40:42 +00:00
|
|
|
# error "must define either SK_CPU_LENDIAN or SK_CPU_BENDIAN"
|
2008-12-17 15:59:43 +00:00
|
|
|
#endif
|
|
|
|
|
2013-12-04 16:40:42 +00:00
|
|
|
/**
|
|
|
|
* Ensure the port has defined all of SK_X32_SHIFT, or none of them.
|
|
|
|
*/
|
2008-12-17 15:59:43 +00:00
|
|
|
#ifdef SK_A32_SHIFT
|
2013-12-04 16:40:42 +00:00
|
|
|
# if !defined(SK_R32_SHIFT) || !defined(SK_G32_SHIFT) || !defined(SK_B32_SHIFT)
|
|
|
|
# error "all or none of the 32bit SHIFT amounts must be defined"
|
|
|
|
# endif
|
2008-12-17 15:59:43 +00:00
|
|
|
#else
|
2013-12-04 16:40:42 +00:00
|
|
|
# if defined(SK_R32_SHIFT) || defined(SK_G32_SHIFT) || defined(SK_B32_SHIFT)
|
|
|
|
# error "all or none of the 32bit SHIFT amounts must be defined"
|
|
|
|
# endif
|
2008-12-17 15:59:43 +00:00
|
|
|
#endif
|
|
|
|
|
2011-11-23 21:25:35 +00:00
|
|
|
#if !defined(SK_HAS_COMPILER_FEATURE)
|
2013-12-04 16:40:42 +00:00
|
|
|
# if defined(__has_feature)
|
|
|
|
# define SK_HAS_COMPILER_FEATURE(x) __has_feature(x)
|
|
|
|
# else
|
|
|
|
# define SK_HAS_COMPILER_FEATURE(x) 0
|
|
|
|
# endif
|
2011-11-23 21:25:35 +00:00
|
|
|
#endif
|
|
|
|
|
2013-08-06 18:32:29 +00:00
|
|
|
#if !defined(SK_ATTRIBUTE)
|
2013-12-04 16:40:42 +00:00
|
|
|
# if defined(__clang__) || defined(__GNUC__)
|
|
|
|
# define SK_ATTRIBUTE(attr) __attribute__((attr))
|
|
|
|
# else
|
|
|
|
# define SK_ATTRIBUTE(attr)
|
|
|
|
# endif
|
2013-08-06 18:32:29 +00:00
|
|
|
#endif
|
|
|
|
|
2012-08-02 14:03:32 +00:00
|
|
|
#if !defined(SK_SUPPORT_GPU)
|
2013-12-04 16:40:42 +00:00
|
|
|
# define SK_SUPPORT_GPU 1
|
2012-08-02 14:03:32 +00:00
|
|
|
#endif
|
|
|
|
|
2017-11-19 18:20:13 +00:00
|
|
|
#if !defined(SK_SUPPORT_ATLAS_TEXT)
|
|
|
|
# define SK_SUPPORT_ATLAS_TEXT 0
|
|
|
|
#elif SK_SUPPORT_ATLAS_TEXT && !SK_SUPPORT_GPU
|
|
|
|
# error "SK_SUPPORT_ATLAS_TEXT requires SK_SUPPORT_GPU"
|
|
|
|
#endif
|
|
|
|
|
2011-11-23 21:25:35 +00:00
|
|
|
/**
|
|
|
|
* The clang static analyzer likes to know that when the program is not
|
|
|
|
* expected to continue (crash, assertion failure, etc). It will notice that
|
|
|
|
* some combination of parameters lead to a function call that does not return.
|
|
|
|
* It can then make appropriate assumptions about the parameters in code
|
|
|
|
* executed only if the non-returning function was *not* called.
|
|
|
|
*/
|
|
|
|
#if !defined(SkNO_RETURN_HINT)
|
2013-12-04 16:40:42 +00:00
|
|
|
# if SK_HAS_COMPILER_FEATURE(attribute_analyzer_noreturn)
|
|
|
|
static inline void SkNO_RETURN_HINT() __attribute__((analyzer_noreturn));
|
|
|
|
static inline void SkNO_RETURN_HINT() {}
|
|
|
|
# else
|
|
|
|
# define SkNO_RETURN_HINT() do {} while (false)
|
|
|
|
# endif
|
2011-11-23 21:25:35 +00:00
|
|
|
#endif
|
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifdef SK_BUILD_FOR_WIN
|
2013-12-04 16:40:42 +00:00
|
|
|
# ifndef SK_A32_SHIFT
|
|
|
|
# define SK_A32_SHIFT 24
|
|
|
|
# define SK_R32_SHIFT 16
|
|
|
|
# define SK_G32_SHIFT 8
|
|
|
|
# define SK_B32_SHIFT 0
|
|
|
|
# endif
|
|
|
|
#
|
2014-06-19 14:41:58 +00:00
|
|
|
#endif
|
|
|
|
|
2017-12-19 14:09:33 +00:00
|
|
|
#if defined(SK_BUILD_FOR_GOOGLE3)
|
2015-11-18 21:14:14 +00:00
|
|
|
void SkDebugfForDumpStackTrace(const char* data, void* unused);
|
2016-01-29 16:51:04 +00:00
|
|
|
void DumpStackTrace(int skip_count, void w(const char*, void*), void* arg);
|
|
|
|
# define SK_DUMP_GOOGLE3_STACK() DumpStackTrace(0, SkDebugfForDumpStackTrace, nullptr)
|
|
|
|
#else
|
|
|
|
# define SK_DUMP_GOOGLE3_STACK()
|
2015-11-18 21:14:14 +00:00
|
|
|
#endif
|
|
|
|
|
2017-05-11 13:12:57 +00:00
|
|
|
#ifdef SK_BUILD_FOR_WIN
|
|
|
|
// permits visual studio to follow error back to source
|
|
|
|
#define SK_DUMP_LINE_FORMAT(message) \
|
|
|
|
SkDebugf("%s(%d): fatal error: \"%s\"\n", __FILE__, __LINE__, message)
|
|
|
|
#else
|
|
|
|
#define SK_DUMP_LINE_FORMAT(message) \
|
|
|
|
SkDebugf("%s:%d: fatal error: \"%s\"\n", __FILE__, __LINE__, message)
|
|
|
|
#endif
|
|
|
|
|
2016-01-29 16:51:04 +00:00
|
|
|
#ifndef SK_ABORT
|
2016-07-20 16:49:10 +00:00
|
|
|
# define SK_ABORT(message) \
|
2016-01-29 16:51:04 +00:00
|
|
|
do { \
|
|
|
|
SkNO_RETURN_HINT(); \
|
2017-05-11 13:12:57 +00:00
|
|
|
SK_DUMP_LINE_FORMAT(message); \
|
2016-01-29 16:51:04 +00:00
|
|
|
SK_DUMP_GOOGLE3_STACK(); \
|
|
|
|
sk_abort_no_print(); \
|
|
|
|
} while (false)
|
2008-12-17 15:59:43 +00:00
|
|
|
#endif
|
|
|
|
|
2013-12-04 16:40:42 +00:00
|
|
|
/**
|
2011-05-19 15:57:44 +00:00
|
|
|
* We check to see if the SHIFT value has already been defined.
|
|
|
|
* if not, we define it ourself to some default values. We default to OpenGL
|
|
|
|
* order (in memory: r,g,b,a)
|
|
|
|
*/
|
|
|
|
#ifndef SK_A32_SHIFT
|
2013-12-04 16:40:42 +00:00
|
|
|
# ifdef SK_CPU_BENDIAN
|
|
|
|
# define SK_R32_SHIFT 24
|
|
|
|
# define SK_G32_SHIFT 16
|
|
|
|
# define SK_B32_SHIFT 8
|
|
|
|
# define SK_A32_SHIFT 0
|
|
|
|
# else
|
|
|
|
# define SK_R32_SHIFT 0
|
|
|
|
# define SK_G32_SHIFT 8
|
|
|
|
# define SK_B32_SHIFT 16
|
|
|
|
# define SK_A32_SHIFT 24
|
|
|
|
# endif
|
2011-05-19 15:57:44 +00:00
|
|
|
#endif
|
|
|
|
|
2013-08-20 20:28:03 +00:00
|
|
|
/**
|
|
|
|
* SkColor has well defined shift values, but SkPMColor is configurable. This
|
|
|
|
* macro is a convenience that returns true if the shift values are equal while
|
|
|
|
* ignoring the machine's endianness.
|
|
|
|
*/
|
|
|
|
#define SK_COLOR_MATCHES_PMCOLOR_BYTE_ORDER \
|
|
|
|
(SK_A32_SHIFT == 24 && SK_R32_SHIFT == 16 && SK_G32_SHIFT == 8 && SK_B32_SHIFT == 0)
|
|
|
|
|
2013-03-19 14:16:31 +00:00
|
|
|
/**
|
|
|
|
* SK_PMCOLOR_BYTE_ORDER can be used to query the byte order of SkPMColor at compile time. The
|
|
|
|
* relationship between the byte order and shift values depends on machine endianness. If the shift
|
|
|
|
* order is R=0, G=8, B=16, A=24 then ((char*)&pmcolor)[0] will produce the R channel on a little
|
|
|
|
* endian machine and the A channel on a big endian machine. Thus, given those shifts values,
|
|
|
|
* SK_PMCOLOR_BYTE_ORDER(R,G,B,A) will be true on a little endian machine and
|
|
|
|
* SK_PMCOLOR_BYTE_ORDER(A,B,G,R) will be true on a big endian machine.
|
|
|
|
*/
|
|
|
|
#ifdef SK_CPU_BENDIAN
|
2013-12-04 16:40:42 +00:00
|
|
|
# define SK_PMCOLOR_BYTE_ORDER(C0, C1, C2, C3) \
|
2013-03-19 14:16:31 +00:00
|
|
|
(SK_ ## C3 ## 32_SHIFT == 0 && \
|
|
|
|
SK_ ## C2 ## 32_SHIFT == 8 && \
|
|
|
|
SK_ ## C1 ## 32_SHIFT == 16 && \
|
|
|
|
SK_ ## C0 ## 32_SHIFT == 24)
|
|
|
|
#else
|
2013-12-04 16:40:42 +00:00
|
|
|
# define SK_PMCOLOR_BYTE_ORDER(C0, C1, C2, C3) \
|
2013-03-19 14:16:31 +00:00
|
|
|
(SK_ ## C0 ## 32_SHIFT == 0 && \
|
|
|
|
SK_ ## C1 ## 32_SHIFT == 8 && \
|
|
|
|
SK_ ## C2 ## 32_SHIFT == 16 && \
|
|
|
|
SK_ ## C3 ## 32_SHIFT == 24)
|
|
|
|
#endif
|
|
|
|
|
2013-08-15 13:43:23 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////////
|
2008-12-17 15:59:43 +00:00
|
|
|
|
2018-01-24 17:42:55 +00:00
|
|
|
#if defined SK_DEBUG && defined SK_BUILD_FOR_WIN
|
2018-06-08 21:16:26 +00:00
|
|
|
#ifdef free
|
|
|
|
#undef free
|
|
|
|
#endif
|
|
|
|
#include <crtdbg.h>
|
|
|
|
#undef free
|
2008-12-17 15:59:43 +00:00
|
|
|
#endif
|
|
|
|
|
2011-10-03 16:01:10 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
2013-08-06 18:32:29 +00:00
|
|
|
#if !defined(SK_UNUSED)
|
2017-07-31 15:57:21 +00:00
|
|
|
# if !defined(__clang__) && defined(_MSC_VER)
|
2016-08-26 20:17:44 +00:00
|
|
|
# define SK_UNUSED __pragma(warning(suppress:4189))
|
|
|
|
# else
|
|
|
|
# define SK_UNUSED SK_ATTRIBUTE(unused)
|
|
|
|
# endif
|
2013-08-06 18:32:29 +00:00
|
|
|
#endif
|
|
|
|
|
2013-10-31 17:28:30 +00:00
|
|
|
#if !defined(SK_ATTR_DEPRECATED)
|
2013-12-04 16:40:42 +00:00
|
|
|
// FIXME: we ignore msg for now...
|
|
|
|
# define SK_ATTR_DEPRECATED(msg) SK_ATTRIBUTE(deprecated)
|
2013-10-31 17:28:30 +00:00
|
|
|
#endif
|
|
|
|
|
2013-12-04 16:40:42 +00:00
|
|
|
/**
|
|
|
|
* If your judgment is better than the compiler's (i.e. you've profiled it),
|
|
|
|
* you can use SK_ALWAYS_INLINE to force inlining. E.g.
|
|
|
|
* inline void someMethod() { ... } // may not be inlined
|
|
|
|
* SK_ALWAYS_INLINE void someMethod() { ... } // should always be inlined
|
|
|
|
*/
|
2013-11-22 16:56:22 +00:00
|
|
|
#if !defined(SK_ALWAYS_INLINE)
|
|
|
|
# if defined(SK_BUILD_FOR_WIN)
|
|
|
|
# define SK_ALWAYS_INLINE __forceinline
|
|
|
|
# else
|
|
|
|
# define SK_ALWAYS_INLINE SK_ATTRIBUTE(always_inline) inline
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
2016-08-12 15:29:08 +00:00
|
|
|
/**
|
|
|
|
* If your judgment is better than the compiler's (i.e. you've profiled it),
|
|
|
|
* you can use SK_NEVER_INLINE to prevent inlining.
|
|
|
|
*/
|
|
|
|
#if !defined(SK_NEVER_INLINE)
|
|
|
|
# if defined(SK_BUILD_FOR_WIN)
|
|
|
|
# define SK_NEVER_INLINE __declspec(noinline)
|
|
|
|
# else
|
|
|
|
# define SK_NEVER_INLINE SK_ATTRIBUTE(noinline)
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
2013-08-06 18:32:29 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
2015-10-27 20:06:47 +00:00
|
|
|
#if SK_CPU_SSE_LEVEL >= SK_CPU_SSE_LEVEL_SSE1
|
2015-10-28 16:52:20 +00:00
|
|
|
#define SK_PREFETCH(ptr) _mm_prefetch(reinterpret_cast<const char*>(ptr), _MM_HINT_T0)
|
|
|
|
#define SK_WRITE_PREFETCH(ptr) _mm_prefetch(reinterpret_cast<const char*>(ptr), _MM_HINT_T0)
|
2015-10-27 20:06:47 +00:00
|
|
|
#elif defined(__GNUC__)
|
|
|
|
#define SK_PREFETCH(ptr) __builtin_prefetch(ptr)
|
|
|
|
#define SK_WRITE_PREFETCH(ptr) __builtin_prefetch(ptr, 1)
|
2013-11-05 15:03:26 +00:00
|
|
|
#else
|
2015-10-27 20:06:47 +00:00
|
|
|
#define SK_PREFETCH(ptr)
|
|
|
|
#define SK_WRITE_PREFETCH(ptr)
|
2013-11-05 15:03:26 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
2013-12-04 16:40:42 +00:00
|
|
|
|
2012-07-09 18:22:08 +00:00
|
|
|
#ifndef SK_PRINTF_LIKE
|
2013-12-04 16:40:42 +00:00
|
|
|
# if defined(__clang__) || defined(__GNUC__)
|
|
|
|
# define SK_PRINTF_LIKE(A, B) __attribute__((format(printf, (A), (B))))
|
|
|
|
# else
|
|
|
|
# define SK_PRINTF_LIKE(A, B)
|
|
|
|
# endif
|
2012-07-09 18:22:08 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef SK_SIZE_T_SPECIFIER
|
2017-12-04 19:01:30 +00:00
|
|
|
# if defined(_MSC_VER) && !defined(__clang__)
|
2013-12-04 16:40:42 +00:00
|
|
|
# define SK_SIZE_T_SPECIFIER "%Iu"
|
|
|
|
# else
|
|
|
|
# define SK_SIZE_T_SPECIFIER "%zu"
|
|
|
|
# endif
|
2012-07-09 18:22:08 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
2011-12-15 14:16:43 +00:00
|
|
|
#ifndef SK_ALLOW_STATIC_GLOBAL_INITIALIZERS
|
2013-12-04 16:40:42 +00:00
|
|
|
# define SK_ALLOW_STATIC_GLOBAL_INITIALIZERS 1
|
2011-12-15 14:16:43 +00:00
|
|
|
#endif
|
2013-12-04 16:40:42 +00:00
|
|
|
|
2013-12-18 15:27:39 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
2016-08-01 16:22:12 +00:00
|
|
|
#if !defined(SK_GAMMA_EXPONENT)
|
|
|
|
#define SK_GAMMA_EXPONENT (0.0f) // SRGB
|
2014-04-10 22:26:29 +00:00
|
|
|
#endif
|
|
|
|
|
2015-04-29 17:01:22 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef GR_TEST_UTILS
|
2017-07-06 14:09:38 +00:00
|
|
|
# define GR_TEST_UTILS 0
|
2015-04-29 17:01:22 +00:00
|
|
|
#endif
|
|
|
|
|
2016-02-05 23:32:36 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
|
2016-04-18 16:14:00 +00:00
|
|
|
#if defined(SK_HISTOGRAM_ENUMERATION) && defined(SK_HISTOGRAM_BOOLEAN)
|
|
|
|
# define SK_HISTOGRAMS_ENABLED 1
|
|
|
|
#else
|
|
|
|
# define SK_HISTOGRAMS_ENABLED 0
|
|
|
|
#endif
|
|
|
|
|
2016-02-05 23:32:36 +00:00
|
|
|
#ifndef SK_HISTOGRAM_BOOLEAN
|
|
|
|
# define SK_HISTOGRAM_BOOLEAN(name, value)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef SK_HISTOGRAM_ENUMERATION
|
|
|
|
# define SK_HISTOGRAM_ENUMERATION(name, value, boundary_value)
|
|
|
|
#endif
|
|
|
|
|
2013-12-04 16:40:42 +00:00
|
|
|
#endif // SkPostConfig_DEFINED
|