Clone of chromium aad1ce808763f59c7a3753e08f1500a104ecc6fd refs/remotes/origin/HEAD
diff --git a/skia/BUILD.gn b/skia/BUILD.gn
new file mode 100644
index 0000000..042d03d
--- /dev/null
+++ b/skia/BUILD.gn
@@ -0,0 +1,712 @@
+# Copyright (c) 2013 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+import("//build/config/features.gni")
+import("//build/config/ui.gni")
+if (cpu_arch == "arm") {
+ import("//build/config/arm.gni")
+}
+
+skia_support_gpu = !is_ios
+skia_support_pdf = !is_ios && printing_mode != 0
+
+# The list of Skia defines that are to be set for chromium.
+gypi_skia_defines = exec_script(
+ "//build/gypi_to_gn.py",
+ [ rebase_path("//third_party/skia/gyp/skia_for_chromium_defines.gypi"),
+ "--replace=<(skia_include_path)=//third_party/skia/include",
+ "--replace=<(skia_src_path)=//third_party/skia/src" ],
+ "scope",
+ [ "//third_party/skia/gyp/skia_for_chromium_defines.gypi" ])
+
+# The list of Skia core sources that are to be set for chromium.
+gypi_skia_core = exec_script(
+ "//build/gypi_to_gn.py",
+ [ rebase_path("//third_party/skia/gyp/core.gypi"),
+ "--replace=<(skia_include_path)=//third_party/skia/include",
+ "--replace=<(skia_src_path)=//third_party/skia/src" ],
+ "scope",
+ [ "//third_party/skia/gyp/core.gypi" ])
+
+# The list of Skia gpu sources that are to be set for chromium.
+gypi_skia_gpu = exec_script(
+ "//build/gypi_to_gn.py",
+ [ rebase_path("//third_party/skia/gyp/gpu.gypi"),
+ "--replace=<(skia_include_path)=//third_party/skia/include",
+ "--replace=<(skia_src_path)=//third_party/skia/src" ],
+ "scope",
+ [ "//third_party/skia/gyp/gpu.gypi" ])
+
+# The list of Skia pdf sources that are to be set for chromium.
+gypi_skia_pdf = exec_script(
+ "//build/gypi_to_gn.py",
+ [ rebase_path("//third_party/skia/gyp/pdf.gypi"),
+ "--replace=<(skia_include_path)=//third_party/skia/include",
+ "--replace=<(skia_src_path)=//third_party/skia/src" ],
+ "scope",
+ [ "//third_party/skia/gyp/pdf.gypi" ])
+
+# The list of Skia effects that are to be set for chromium.
+gypi_skia_effects = exec_script(
+ "//build/gypi_to_gn.py",
+ [ rebase_path("//third_party/skia/gyp/effects.gypi"),
+ "--replace=<(skia_include_path)=//third_party/skia/include",
+ "--replace=<(skia_src_path)=//third_party/skia/src" ],
+ "scope",
+ [ "//third_party/skia/gyp/effects.gypi" ])
+
+# The list of Skia utilss that are to be set for chromium.
+gypi_skia_utils = exec_script(
+ "//build/gypi_to_gn.py",
+ [ rebase_path("//third_party/skia/gyp/utils.gypi"),
+ "--replace=<(skia_include_path)=//third_party/skia/include",
+ "--replace=<(skia_src_path)=//third_party/skia/src" ],
+ "scope",
+ [ "//third_party/skia/gyp/utils.gypi" ])
+
+# The list of Skia files is kept in skia_gn_files.gypi. Read it.
+gypi_values = exec_script(
+ "//build/gypi_to_gn.py",
+ [ rebase_path("skia_gn_files.gypi"),
+ "--replace=<(skia_include_path)=//third_party/skia/include",
+ "--replace=<(skia_src_path)=//third_party/skia/src" ],
+ "scope",
+ [ "skia_gn_files.gypi" ])
+
+# External-facing config for dependent code.
+config("skia_config") {
+ include_dirs = [
+ "config",
+ "ext",
+ "//third_party/skia/include/config",
+ "//third_party/skia/include/core",
+ "//third_party/skia/include/effects",
+ "//third_party/skia/include/images",
+ "//third_party/skia/include/lazy",
+ "//third_party/skia/include/pathops",
+ "//third_party/skia/include/pdf",
+ "//third_party/skia/include/pipe",
+ "//third_party/skia/include/ports",
+ "//third_party/skia/include/utils",
+ "//third_party/skia/src/core",
+ "//third_party/skia/src/image",
+ "//third_party/skia/src/opts",
+ "//third_party/skia/src/ports",
+ "//third_party/skia/src/sfnt",
+ "//third_party/skia/src/utils",
+ "//third_party/skia/src/lazy",
+ ]
+
+ defines = gypi_skia_defines.skia_for_chromium_defines
+
+ defines += [
+ "SK_ENABLE_INST_COUNT=0",
+ "GR_GL_CUSTOM_SETUP_HEADER=\"GrGLConfig_chrome.h\"",
+ "SK_ENABLE_LEGACY_API_ALIASING=1",
+ "SK_ATTR_DEPRECATED=SK_NOTHING_ARG1",
+ "GR_GL_IGNORE_ES3_MSAA=0",
+ "SK_WILL_NEVER_DRAW_PERSPECTIVE_TEXT",
+ "SK_SUPPORT_LEGACY_GETTOTALCLIP",
+ ]
+
+ if (component_mode == "shared_library") {
+ defines += [ "SKIA_DLL" ]
+ }
+
+ if (skia_support_gpu) {
+ include_dirs += [
+ "//third_party/skia/include/gpu",
+ "//third_party/skia/src/gpu",
+ ]
+ defines += [ "SK_SUPPORT_GPU=1" ]
+ } else {
+ defines += [ "SK_SUPPORT_GPU=0" ]
+ }
+
+ # For POSIX platforms, prefer the Mutex implementation provided by Skia
+ # since it does not generate static initializers.
+ if (is_posix) {
+ defines += [ "SK_USE_POSIX_THREADS" ]
+ }
+
+ if (is_android) {
+ defines += [
+ "SK_BUILD_FOR_ANDROID",
+ "USE_CHROMIUM_SKIA",
+ ]
+ }
+
+ if (is_mac) {
+ defines += [ "SK_BUILD_FOR_MAC" ]
+ }
+}
+
+# Internal-facing config for Skia library code.
+config("skia_library_config") {
+ # These include directories are only included for Skia code and are not
+ # exported to dependents. It's not clear if this is on purpose, but this
+ # matches the GYP build.
+ include_dirs = []
+ if (is_mac || is_ios) {
+ include_dirs += [ "//third_party/skia/include/utils/mac" ]
+ }
+ if (is_mac) {
+ include_dirs += [ "//third_party/skia/include/utils/ios" ]
+ }
+
+ defines = [
+ #skia_export_defines ???) TODO
+
+ # skia uses static initializers to initialize the serialization logic
+ # of its "pictures" library. This is currently not used in chrome; if
+ # it ever gets used the processes that use it need to call
+ # SkGraphics::Init().
+ "SK_ALLOW_STATIC_GLOBAL_INITIALIZERS=0",
+
+ # Forcing the unoptimized path for the offset image filter in skia until
+ # all filters used in Blink support the optimized path properly
+ "SK_DISABLE_OFFSETIMAGEFILTER_OPTIMIZATION",
+
+ "IGNORE_ROT_AA_RECT_OPT",
+
+ "SK_IGNORE_BLURRED_RRECT_OPT",
+
+ # this flag forces Skia not to use typographic metrics with GDI.
+ "SK_GDI_ALWAYS_USE_TEXTMETRICS_FOR_FONT_METRICS",
+
+ "SK_USE_DISCARDABLE_SCALEDIMAGECACHE",
+ ]
+
+ if (component_mode == "shared_library") {
+ defines += [ "SKIA_IMPLEMENTATION=1" ]
+ }
+
+ if (cpu_arch == "arm") {
+ if (arm_use_neon) {
+ defines += [ "SK_ARM_HAS_NEON" ]
+ }
+ if (arm_optionally_use_neon) {
+ defines += [ "SK_ARM_HAS_OPTIONAL_NEON" ]
+ }
+ }
+
+ # Settings for text blitting, chosen to approximate the system browser.
+ if (is_linux) {
+ defines += [
+ "SK_GAMMA_EXPONENT=1.2",
+ "SK_GAMMA_CONTRAST=0.2",
+ "SK_HIGH_QUALITY_IS_LANCZOS",
+ ]
+ } else if (is_android) {
+ defines += [
+ "SK_GAMMA_APPLY_TO_A8",
+ "SK_GAMMA_EXPONENT=1.4",
+ "SK_GAMMA_CONTRAST=0.0",
+ ]
+ } else if (is_win) {
+ defines += [
+ "SK_GAMMA_SRGB",
+ "SK_GAMMA_CONTRAST=0.5",
+ "SK_HIGH_QUALITY_IS_LANCZOS",
+ ]
+ } else if (is_mac) {
+ defines += [
+ "SK_GAMMA_SRGB",
+ "SK_GAMMA_CONTRAST=0.0",
+ "SK_HIGH_QUALITY_IS_LANCZOS",
+ ]
+ }
+
+ if (is_android) {
+ defines += [
+ # Android devices are typically more memory constrained, so default to a
+ # smaller glyph cache (it may be overriden at runtime when the renderer
+ # starts up, depending on the actual device memory).
+ "SK_DEFAULT_FONT_CACHE_LIMIT=1048576" # 1024 * 1024
+ ]
+ } else {
+ defines += [ "SK_DEFAULT_FONT_CACHE_LIMIT=20971520" ] # 20 * 1024 * 1024
+ }
+
+ if (is_win) {
+ include_dirs = [
+ "//third_party/skia/include/utils/win",
+ "//third_party/skia/src/utils/win",
+ ]
+
+ defines += [ "SK_FONTHOST_USES_FONTMGR" ]
+
+ cflags = [
+ "/wd4244", # conversion from 'type1( __int64)' to 'type2 (unsigned int)'
+ "/wd4267", # conversion from 'size_t' (64 bit) to 'type'(32 bit).
+ "/wd4341", # signed value is out of range for enum constant.
+ "/wd4345", # Object is default-initialized if initialization is omitted.
+ "/wd4390", # ';'empty statement found in looping;is it what was intended?
+ "/wd4554", # 'operator' : check operator precedence for possible error
+ "/wd4748", # compiler will disable optimizations if a function has inline
+ # assembly code contains flow control(jmp or jcc) statements.
+ "/wd4800", # forcing value to bool 'true/false'(assigning int to bool).
+ ]
+ }
+}
+
+component("skia") {
+ sources = [
+ # Chrome sources.
+ "config/SkUserConfig.h",
+ "ext/analysis_canvas.cc",
+ "ext/analysis_canvas.h",
+ "ext/benchmarking_canvas.cc",
+ "ext/benchmarking_canvas.h",
+ "ext/bitmap_platform_device.h",
+ "ext/convolver.cc",
+ "ext/convolver.h",
+ "ext/event_tracer_impl.cc",
+ "ext/event_tracer_impl.h",
+ "ext/fontmgr_default_win.cc",
+ "ext/fontmgr_default_win.h",
+ "ext/google_logging.cc",
+ "ext/image_operations.cc",
+ "ext/image_operations.h",
+ "ext/lazy_pixel_ref.cc",
+ "ext/lazy_pixel_ref.h",
+ "ext/SkThread_chrome.cc",
+ "ext/opacity_draw_filter.cc",
+ "ext/opacity_draw_filter.h",
+ "ext/pixel_ref_utils.cc",
+ "ext/pixel_ref_utils.h",
+ "ext/platform_canvas.cc",
+ "ext/platform_canvas.h",
+ "ext/platform_device.cc",
+ "ext/platform_device.h",
+ "ext/platform_device_linux.cc",
+ "ext/platform_device_mac.cc",
+ "ext/platform_device_win.cc",
+ "ext/recursive_gaussian_convolution.cc",
+ "ext/recursive_gaussian_convolution.h",
+ "ext/refptr.h",
+ "ext/SkDiscardableMemory_chrome.h",
+ "ext/SkDiscardableMemory_chrome.cc",
+ "ext/SkMemory_new_handler.cpp",
+ "ext/skia_trace_shim.h",
+ "ext/skia_utils_base.cc",
+ "ext/skia_utils_base.h",
+ "ext/skia_utils_ios.mm",
+ "ext/skia_utils_ios.h",
+ "ext/skia_utils_mac.mm",
+ "ext/skia_utils_mac.h",
+ "ext/skia_utils_win.cc",
+ "ext/skia_utils_win.h",
+ "ext/vector_canvas.h",
+ "ext/vector_platform_device_emf_win.cc",
+ "ext/vector_platform_device_emf_win.h",
+ "ext/vector_platform_device_skia.cc",
+ "ext/vector_platform_device_skia.h",
+ ]
+
+ # The skia gypi values are relative to the skia_dir, so we need to rebase.
+ sources += gypi_skia_core.sources
+ sources += gypi_skia_effects.sources
+ sources += gypi_skia_utils.sources
+ sources += gypi_skia_pdf.sources
+ sources += gypi_values.skia_library_sources
+
+ if (cpu_arch == "arm") {
+ sources += [
+ "//third_party/skia/src/core/SkUtilsArm.cpp",
+ "//third_party/skia/src/core/SkUtilsArm.h",
+ ]
+ }
+
+ # GPU
+ if (skia_support_gpu) {
+ sources += gypi_skia_gpu.skgpu_sources
+ sources += gypi_skia_gpu.skgpu_null_gl_sources
+ }
+
+ # Remove unused util files include in utils.gypi
+ sources -= [
+ "//third_party/skia/src/utils/SkCondVar.cpp",
+ "//third_party/skia/src/utils/SkCondVar.h",
+ "//third_party/skia/src/utils/SkRunnable.h",
+
+ "//third_party/skia/include/utils/SkBoundaryPatch.h",
+ "//third_party/skia/include/utils/SkFrontBufferedStream.h",
+ "//third_party/skia/include/utils/SkCamera.h",
+ "//third_party/skia/include/utils/SkCanvasStateUtils.h",
+ "//third_party/skia/include/utils/SkCubicInterval.h",
+ "//third_party/skia/include/utils/SkCullPoints.h",
+ "//third_party/skia/include/utils/SkDebugUtils.h",
+ "//third_party/skia/include/utils/SkDumpCanvas.h",
+ "//third_party/skia/include/utils/SkEventTracer.h",
+ "//third_party/skia/include/utils/SkInterpolator.h",
+ "//third_party/skia/include/utils/SkLayer.h",
+ "//third_party/skia/include/utils/SkMeshUtils.h",
+ "//third_party/skia/include/utils/SkNinePatch.h",
+ "//third_party/skia/include/utils/SkParse.h",
+ "//third_party/skia/include/utils/SkParsePaint.h",
+ "//third_party/skia/include/utils/SkParsePath.h",
+ "//third_party/skia/include/utils/SkRandom.h",
+ "//third_party/skia/include/utils/SkWGL.h",
+
+ "//third_party/skia/src/utils/SkBitmapHasher.cpp",
+ "//third_party/skia/src/utils/SkBitmapHasher.h",
+ "//third_party/skia/src/utils/SkBoundaryPatch.cpp",
+ "//third_party/skia/src/utils/SkFrontBufferedStream.cpp",
+ "//third_party/skia/src/utils/SkCamera.cpp",
+ "//third_party/skia/src/utils/SkCanvasStack.h",
+ "//third_party/skia/src/utils/SkCubicInterval.cpp",
+ "//third_party/skia/src/utils/SkCullPoints.cpp",
+ "//third_party/skia/src/utils/SkDumpCanvas.cpp",
+ "//third_party/skia/src/utils/SkFloatUtils.h",
+ "//third_party/skia/src/utils/SkGatherPixelRefsAndRects.cpp",
+ "//third_party/skia/src/utils/SkGatherPixelRefsAndRects.h",
+ "//third_party/skia/src/utils/SkInterpolator.cpp",
+ "//third_party/skia/src/utils/SkLayer.cpp",
+ "//third_party/skia/src/utils/SkMD5.cpp",
+ "//third_party/skia/src/utils/SkMD5.h",
+ "//third_party/skia/src/utils/SkMeshUtils.cpp",
+ "//third_party/skia/src/utils/SkNinePatch.cpp",
+ "//third_party/skia/src/utils/SkOSFile.cpp",
+ "//third_party/skia/src/utils/SkParse.cpp",
+ "//third_party/skia/src/utils/SkParseColor.cpp",
+ "//third_party/skia/src/utils/SkParsePath.cpp",
+ "//third_party/skia/src/utils/SkPathUtils.cpp",
+ "//third_party/skia/src/utils/SkSHA1.cpp",
+ "//third_party/skia/src/utils/SkSHA1.h",
+ "//third_party/skia/src/utils/SkThreadUtils.h",
+ "//third_party/skia/src/utils/SkThreadUtils_pthread.cpp",
+ "//third_party/skia/src/utils/SkThreadUtils_pthread.h",
+ "//third_party/skia/src/utils/SkThreadUtils_pthread_linux.cpp",
+ "//third_party/skia/src/utils/SkThreadUtils_pthread_mach.cpp",
+ "//third_party/skia/src/utils/SkThreadUtils_pthread_other.cpp",
+ "//third_party/skia/src/utils/SkThreadUtils_win.cpp",
+ "//third_party/skia/src/utils/SkTFitsIn.h",
+ "//third_party/skia/src/utils/SkTLogic.h",
+
+ #testing
+ "//third_party/skia/src/fonts/SkGScalerContext.cpp",
+ "//third_party/skia/src/fonts/SkGScalerContext.h",
+ ]
+
+ # need separate win section to handle chromes auto gn filter
+ # (build/config/BUILDCONFIG.gn)
+ if (is_win) {
+ sources -= [
+ "//third_party/skia/src/utils/SkThreadUtils_win.h",
+
+ #windows
+ "//third_party/skia/include/utils/win/SkAutoCoInitialize.h",
+ "//third_party/skia/include/utils/win/SkHRESULT.h",
+ "//third_party/skia/include/utils/win/SkIStream.h",
+ "//third_party/skia/include/utils/win/SkTScopedComPtr.h",
+ "//third_party/skia/src/utils/win/SkAutoCoInitialize.cpp",
+ "//third_party/skia/src/utils/win/SkIStream.cpp",
+ "//third_party/skia/src/utils/win/SkWGL_win.cpp",
+ ]
+ }
+
+ # Fixup Chrome sources.
+ if (is_posix) {
+ sources -= [ "ext/SkThread_chrome.cc" ]
+ }
+ if (is_ios) {
+ sources -= [ "ext/vector_platform_device_skia.cc" ]
+ }
+ if (is_win) {
+ sources -= [ "ext/SkThread_chrome.cc" ]
+ }
+ if (is_android && printing_mode == 0) {
+ sources -= [
+ "ext/skia_utils_base.cc",
+ "ext/vector_platform_device_skia.cc"
+ ]
+ }
+
+ # Fixup skia library sources.
+ if (is_win) {
+ sources -= [
+ "//third_party/skia/src/ports/SkOSFile_posix.cpp",
+ "//third_party/skia/src/ports/SkTime_Unix.cpp",
+ "//third_party/skia/src/ports/SkTLS_pthread.cpp",
+ ]
+ } else {
+ sources -= [
+ "//third_party/skia/src/ports/SkFontHost_win.cpp",
+ "//third_party/skia/src/ports/SkFontMgr_win_dw.cpp",
+ "//third_party/skia/src/ports/SkOSFile_win.cpp",
+ "//third_party/skia/src/ports/SkRemotableFontMgr_win_dw.cpp",
+ "//third_party/skia/src/ports/SkScalerContext_win_dw.cpp",
+ "//third_party/skia/src/ports/SkScalerContext_win_dw.h",
+ "//third_party/skia/src/ports/SkTLS_win.cpp",
+ "//third_party/skia/src/ports/SkTypeface_win_dw.cpp",
+ "//third_party/skia/src/ports/SkTypeface_win_dw.h",
+ ]
+ }
+ if (!is_android) {
+ sources -= [
+ "//third_party/skia/src/ports/SkFontConfigParser_android.cpp",
+ "//third_party/skia/src/ports/SkFontMgr_android.cpp",
+ ]
+ }
+ if (!is_mac) {
+ sources -= [
+ "//third_party/skia/src/ports/SkFontHost_mac.cpp",
+ ]
+ }
+
+ if (!is_linux) {
+ sources -= [
+ "//third_party/skia/src/ports/SkFontHost_fontconfig.cpp",
+ "//third_party/skia/src/fonts/SkFontMgr_fontconfig.cpp",
+ "//third_party/skia/src/ports/SkFontConfigInterface_direct.cpp",
+ ]
+ }
+
+ if (!is_linux && !is_android) {
+ sources -= [
+ "//third_party/skia/src/ports/SkFontHost_FreeType_common.cpp",
+ "//third_party/skia/src/ports/SkFontHost_FreeType.cpp",
+ ]
+ }
+
+ # Select the right BitmapPlatformDevice.
+ if (is_win) {
+ sources += [
+ "ext/bitmap_platform_device_win.cc",
+ "ext/bitmap_platform_device_win.h",
+ ]
+ } else if (is_mac) {
+ sources += [
+ "ext/bitmap_platform_device_mac.cc",
+ "ext/bitmap_platform_device_mac.h",
+ ]
+ } else if (use_cairo) {
+ sources += [
+ "ext/bitmap_platform_device_cairo.cc",
+ "ext/bitmap_platform_device_cairo.h",
+ ]
+ } else {
+ sources += [
+ "ext/bitmap_platform_device_skia.cc",
+ "ext/bitmap_platform_device_skia.h",
+ ]
+ }
+
+ if (is_clang) {
+ # Skia won't compile with some of the more strict clang warnings.
+ # e.g. it does:
+ # SkASSERT(!"sk_out_of_memory");
+ configs -= [ "//build/config/clang:extra_warnings" ]
+ }
+
+ configs -= [ "//build/config/compiler:chromium_code" ]
+ configs += [
+ ":skia_library_config",
+ "//build/config/compiler:no_chromium_code"
+ ]
+ public_configs = [ ":skia_config" ]
+
+ deps = [
+ ":skia_opts",
+ "//base",
+ "//base/third_party/dynamic_annotations",
+ "//third_party/zlib",
+ ]
+
+ if (is_win) {
+ configs -= [
+ # Some files define WIN32_LEAN_AND_MEAN and we want to avoid a duplicate
+ # definition warning.
+ "//build/config/win:lean_and_mean",
+ ]
+ }
+
+ if (is_linux) {
+ configs += [
+ "//build/config/linux:fontconfig",
+ "//build/config/linux:freetype2",
+ "//build/config/linux:pangocairo",
+ ]
+ deps += [
+ "//third_party/icu:icuuc",
+ ]
+ }
+
+ if (is_android) {
+ set_sources_assignment_filter([])
+ sources += [
+ "ext/platform_device_linux.cc",
+ ]
+ set_sources_assignment_filter(sources_assignment_filter)
+ deps += [
+ "//third_party/expat",
+ "//third_party/freetype",
+ "//third_party/android_tools:cpu_features",
+ ]
+ }
+
+ if (skia_support_pdf) {
+ deps += [ "//third_party/sfntly" ]
+ }
+
+ if (is_android && !is_debug) {
+ configs -= [ "//build/config/compiler:optimize" ]
+ configs += [ "//build/config/compiler:optimize_max" ]
+ }
+}
+
+# Separated out so it can be compiled with different flags for SSE.
+source_set("skia_opts") {
+ cflags = []
+ defines = []
+
+ if (cpu_arch == "x86" || cpu_arch == "x64") {
+ sources = [
+ "//third_party/skia/src/opts/SkTextureCompression_opts_none.cpp",
+
+ # SSE 2
+ "//third_party/skia/src/opts/opts_check_x86.cpp",
+ "//third_party/skia/src/opts/SkBitmapFilter_opts_SSE2.cpp",
+ "//third_party/skia/src/opts/SkBitmapProcState_opts_SSE2.cpp",
+ "//third_party/skia/src/opts/SkBlitRect_opts_SSE2.cpp",
+ "//third_party/skia/src/opts/SkBlitRow_opts_SSE2.cpp",
+ "//third_party/skia/src/opts/SkBlurImage_opts_SSE2.cpp",
+ "//third_party/skia/src/opts/SkMorphology_opts_SSE2.cpp",
+ "//third_party/skia/src/opts/SkUtils_opts_SSE2.cpp",
+ "//third_party/skia/src/opts/SkXfermode_opts_SSE2.cpp",
+
+ # SSSE 3
+ "//third_party/skia/src/opts/SkBitmapProcState_opts_SSSE3.cpp",
+
+ # SSE 4
+ "//third_party/skia/src/opts/SkBlurImage_opts_SSE4.cpp",
+
+ # Chrome-specific.
+ "ext/convolver_SSE2.cc",
+
+ # These are header files used by this target from the skia one above.
+ "ext/convolver.h",
+ "//third_party/skia/include/core/SkTypes.h",
+ ]
+
+ if (!is_win) {
+ # SSE 4
+ if (cpu_arch == "x86") {
+ sources += [ "//third_party/skia/src/opts/SkBlitRow_opts_SSE4_asm.S" ]
+ } else { # x64
+ sources += [
+ "//third_party/skia/src/opts/SkBlitRow_opts_SSE4_x64_asm.S"
+ ]
+ }
+ }
+
+ if (is_linux || is_mac) {
+ cflags += [ "-msse4.1" ]
+ }
+ } else if (cpu_arch == "arm") {
+ sources = [
+ "//third_party/skia/src/opts/SkBitmapProcState_opts_arm.cpp",
+ ]
+
+ # The assembly uses the frame pointer register (r7 in Thumb/r11 in
+ # ARM), the compiler doesn't like that.
+ cflags += [ "-fomit-frame-pointer" ]
+
+ if (arm_version >= 7) {
+ if (arm_use_neon || arm_optionally_use_neon) {
+ sources += [
+ "//third_party/skia/src/opts/SkBitmapProcState_arm_neon.cpp",
+ "//third_party/skia/src/opts/SkBitmapProcState_matrixProcs_neon.cpp",
+ "//third_party/skia/src/opts/SkBitmapProcState_matrix_clamp_neon.h",
+ "//third_party/skia/src/opts/SkBitmapProcState_matrix_repeat_neon.h",
+ "//third_party/skia/src/opts/SkBlitMask_opts_arm_neon.cpp",
+ "//third_party/skia/src/opts/SkBlitRow_opts_arm_neon.cpp",
+ "//third_party/skia/src/opts/SkBlurImage_opts_neon.cpp",
+ "//third_party/skia/src/opts/SkMorphology_opts_neon.cpp",
+ "//third_party/skia/src/opts/SkTextureCompression_opts_neon.cpp",
+ "//third_party/skia/src/opts/SkXfermode_opts_arm_neon.cpp",
+ "//third_party/skia/src/opts/memset16_neon.S",
+ "//third_party/skia/src/opts/memset32_neon.S",
+ ]
+
+ # Root build config sets -mfpu=$arm_fpu, which we expect to be neon
+ # when running this.
+ if (!arm_use_neon) {
+ configs -= [ "//build/config/compiler:compiler_arm_fpu" ]
+ cflags += [
+ "-mfpu=neon"
+ ]
+ }
+
+ #ldflags = [
+ # "-march=armv7-a",
+ # "-Wl,--fix-cortex-a8",
+ #]
+ }
+ }
+
+ # Non-Neon ARM code.
+ if (arm_version < 7 || !arm_use_neon) {
+ sources += [ "//third_party/skia/src/opts/memset.arm.S" ]
+ }
+
+ if (arm_version < 6) {
+ sources += [
+ "//third_party/skia/src/opts/SkBlitMask_opts_none.cpp",
+ "//third_party/skia/src/opts/SkBlitRow_opts_none.cpp",
+ "//third_party/skia/src/opts/SkBlurImage_opts_none.cpp",
+ "//third_party/skia/src/opts/SkMorphology_opts_none.cpp",
+ "//third_party/skia/src/opts/SkTextureCompression_opts_none.cpp",
+ "//third_party/skia/src/opts/SkUtils_opts_none.cpp",
+ "//third_party/skia/src/opts/SkXfermode_opts_none.cpp",
+ ]
+ } else {
+ # arm version >= 6.
+ sources += [
+ "//third_party/skia/src/opts/SkBlitMask_opts_arm.cpp",
+ "//third_party/skia/src/opts/SkBlitRow_opts_arm.cpp",
+ "//third_party/skia/src/opts/SkBlitRow_opts_arm.h",
+ "//third_party/skia/src/opts/SkBlurImage_opts_arm.cpp",
+ "//third_party/skia/src/opts/SkMorphology_opts_arm.cpp",
+ "//third_party/skia/src/opts/SkTextureCompression_opts_arm.cpp",
+ "//third_party/skia/src/opts/SkUtils_opts_arm.cpp",
+ "//third_party/skia/src/opts/SkXfermode_opts_none.cpp",
+ ]
+ }
+
+ } else if (cpu_arch == "mipsel") {
+ cflags += [ "-fomit-frame-pointer" ]
+ sources = [
+ "//third_party/skia/src/opts/SkBitmapProcState_opts_none.cpp",
+ "//third_party/skia/src/opts/SkBlitMask_opts_none.cpp",
+ "//third_party/skia/src/opts/SkBlitRow_opts_none.cpp",
+ "//third_party/skia/src/opts/SkBlurImage_opts_none.cpp",
+ "//third_party/skia/src/opts/SkMorphology_opts_none.cpp",
+ "//third_party/skia/src/opts/SkTextureCompression_opts_none.cpp",
+ "//third_party/skia/src/opts/SkUtils_opts_none.cpp",
+ "//third_party/skia/src/opts/SkXfermode_opts_none.cpp",
+ ]
+ } else {
+ assert(false, "Need to port cpu specific stuff from skia_library_opts.gyp")
+ }
+
+ if (is_android && !is_debug) {
+ configs -= [ "//build/config/compiler:optimize" ]
+ configs += [ "//build/config/compiler:optimize_max" ]
+ }
+
+ configs -= [ "//build/config/compiler:chromium_code" ]
+ configs += [
+ ":skia_config",
+ ":skia_library_config",
+ "//build/config/compiler:no_chromium_code"
+ ]
+
+ deps = [
+ "//base",
+ ]
+
+ visibility = [ ":skia" ]
+}