blob: 2fd0e95809e5bb07dc3467ecce203fe66e657d63 [file] [log] [blame]
scroggo@google.comd4adfa32014-02-05 16:35:12 +00001# Gyp file for opts projects
epoger@google.comae85aea2011-05-31 13:50:51 +00002{
epoger@google.comae85aea2011-05-31 13:50:51 +00003 'targets': [
4 # Due to an unfortunate intersection of lameness between gcc and gyp,
5 # we have to build the *_SSE2.cpp files in a separate target. The
6 # gcc lameness is that, in order to compile SSE2 intrinsics code, it
7 # must be passed the -msse2 flag. However, with this flag, it may
8 # emit SSE2 instructions even for scalar code, such as the CPUID
9 # test used to test for the presence of SSE2. So that, and all other
10 # code must be compiled *without* -msse2. The gyp lameness is that it
11 # does not allow file-specific CFLAGS, so we must create this extra
12 # target for those files to be compiled with -msse2.
13 #
14 # This is actually only a problem on 32-bit Linux (all Intel Macs have
15 # SSE2, Linux x86_64 has SSE2 by definition, and MSC will happily emit
16 # SSE2 from instrinsics, while generating plain ol' 386 for everything
17 # else). However, to keep the .gyp file simple and avoid platform-specific
18 # build breakage, we do this on all platforms.
19
20 # For about the same reason, we need to compile the ARM opts files
21 # separately as well.
22 {
23 'target_name': 'opts',
borenet@google.comefb1d772012-10-10 19:45:51 +000024 'product_name': 'skia_opts',
epoger@google.comae85aea2011-05-31 13:50:51 +000025 'type': 'static_library',
borenet@google.comefb1d772012-10-10 19:45:51 +000026 'standalone_static_library': 1,
bungeman@google.comb8f36552013-07-22 14:39:45 +000027 'dependencies': [
28 'core.gyp:*',
senorblanco@chromium.org0ded88d2014-01-24 15:43:50 +000029 'effects.gyp:*'
bungeman@google.comb8f36552013-07-22 14:39:45 +000030 ],
epoger@google.comae85aea2011-05-31 13:50:51 +000031 'include_dirs': [
epoger@google.comae85aea2011-05-31 13:50:51 +000032 '../src/core',
djsollen@google.coma44e6c62012-01-09 14:38:25 +000033 '../src/opts',
epoger@google.comae85aea2011-05-31 13:50:51 +000034 ],
35 'conditions': [
caryclark@google.com867cbd82012-09-20 15:45:41 +000036 [ 'skia_arch_type == "x86" and skia_os != "ios"', {
tomhudson@google.com95ad1552012-02-14 18:28:54 +000037 'conditions': [
mtklein@google.comd9d5c052013-07-31 20:09:25 +000038 [ 'skia_os in ["linux", "freebsd", "openbsd", "solaris", "nacl", "chromeos", "android"]', {
tomhudson@google.com95ad1552012-02-14 18:28:54 +000039 'cflags': [
40 '-msse2',
41 ],
42 }],
43 ],
humper@google.comb0889472013-07-09 21:37:14 +000044 'include_dirs': [
45 '../include/utils',
46 ],
mtklein@google.comd9d5c052013-07-31 20:09:25 +000047 'dependencies': [
48 'opts_ssse3',
49 ],
djsollen@google.com58629292011-11-03 13:08:29 +000050 'sources': [
djsollen@google.coma44e6c62012-01-09 14:38:25 +000051 '../src/opts/opts_check_SSE2.cpp',
djsollen@google.com58629292011-11-03 13:08:29 +000052 '../src/opts/SkBitmapProcState_opts_SSE2.cpp',
humper@google.comb0889472013-07-09 21:37:14 +000053 '../src/opts/SkBitmapFilter_opts_SSE2.cpp',
djsollen@google.com58629292011-11-03 13:08:29 +000054 '../src/opts/SkBlitRow_opts_SSE2.cpp',
tomhudson@google.com8dd90a92012-03-19 13:49:50 +000055 '../src/opts/SkBlitRect_opts_SSE2.cpp',
senorblanco@chromium.org27eec462013-11-08 20:49:04 +000056 '../src/opts/SkBlurImage_opts_SSE2.cpp',
senorblanco@chromium.org7a47ad32013-10-30 21:57:04 +000057 '../src/opts/SkMorphology_opts_SSE2.cpp',
djsollen@google.com58629292011-11-03 13:08:29 +000058 '../src/opts/SkUtils_opts_SSE2.cpp',
commit-bot@chromium.orgdf187c72013-10-09 14:39:46 +000059 '../src/opts/SkXfermode_opts_none.cpp',
djsollen@google.com58629292011-11-03 13:08:29 +000060 ],
61 }],
djsollen@google.comf7542ba2013-07-31 12:57:27 +000062 [ 'skia_arch_type == "arm" and arm_version >= 7', {
djsollen@google.com58629292011-11-03 13:08:29 +000063 # The assembly uses the frame pointer register (r7 in Thumb/r11 in
64 # ARM), the compiler doesn't like that.
65 'cflags!': [
66 '-fno-omit-frame-pointer',
djsollen@google.com5afbbc42012-11-29 15:09:58 +000067 '-mapcs-frame',
68 '-mapcs',
djsollen@google.com58629292011-11-03 13:08:29 +000069 ],
70 'cflags': [
71 '-fomit-frame-pointer',
djsollen@google.com5afbbc42012-11-29 15:09:58 +000072 '-mno-apcs-frame',
djsollen@google.com58629292011-11-03 13:08:29 +000073 ],
digit@google.comeec9dbc2012-05-30 13:54:41 +000074 'variables': {
75 'arm_neon_optional%': '<(arm_neon_optional>',
76 },
djsollen@google.com58629292011-11-03 13:08:29 +000077 'sources': [
djsollen@google.coma44e6c62012-01-09 14:38:25 +000078 '../src/opts/memset.arm.S',
djsollen@google.com58629292011-11-03 13:08:29 +000079 '../src/opts/SkBitmapProcState_opts_arm.cpp',
commit-bot@chromium.orge997c262013-08-28 15:07:58 +000080 '../src/opts/SkBlitMask_opts_arm.cpp',
djsollen@google.com58629292011-11-03 13:08:29 +000081 '../src/opts/SkBlitRow_opts_arm.cpp',
digit@google.coma8dd1ce2012-08-08 22:06:29 +000082 '../src/opts/SkBlitRow_opts_arm.h',
commit-bot@chromium.org57641652014-02-10 15:01:05 +000083 '../src/opts/SkBlurImage_opts_arm.cpp',
84 '../src/opts/SkMorphology_opts_arm.cpp',
85 '../src/opts/SkUtils_opts_arm.cpp',
commit-bot@chromium.orgdf187c72013-10-09 14:39:46 +000086 '../src/opts/SkXfermode_opts_arm.cpp',
djsollen@google.com58629292011-11-03 13:08:29 +000087 ],
digit@google.comeec9dbc2012-05-30 13:54:41 +000088 'conditions': [
89 [ 'arm_neon == 1 or arm_neon_optional == 1', {
90 'dependencies': [
91 'opts_neon',
92 ]
caryclark@google.com867cbd82012-09-20 15:45:41 +000093 }],
94 [ 'skia_os == "ios"', {
95 'sources!': [
caryclark@google.com594dd3c2012-09-24 19:33:57 +000096 # these fail to compile under xcode for ios
caryclark@google.com867cbd82012-09-20 15:45:41 +000097 '../src/opts/memset.arm.S',
caryclark@google.com594dd3c2012-09-24 19:33:57 +000098 '../src/opts/SkBitmapProcState_opts_arm.cpp',
99 '../src/opts/SkBlitRow_opts_arm.cpp',
caryclark@google.com867cbd82012-09-20 15:45:41 +0000100 ],
101 }],
digit@google.comeec9dbc2012-05-30 13:54:41 +0000102 ],
djsollen@google.com58629292011-11-03 13:08:29 +0000103 }],
scroggo@google.comd4adfa32014-02-05 16:35:12 +0000104 [ '(skia_arch_type == "mips") or (skia_arch_type == "arm" and arm_version < 7) \
105 or (skia_os == "ios") \
106 or (skia_os == "android" and skia_arch_type not in ["x86", "arm", "mips"])', {
djsollen@google.com58629292011-11-03 13:08:29 +0000107 'sources': [
108 '../src/opts/SkBitmapProcState_opts_none.cpp',
commit-bot@chromium.orge997c262013-08-28 15:07:58 +0000109 '../src/opts/SkBlitMask_opts_none.cpp',
djsollen@google.com58629292011-11-03 13:08:29 +0000110 '../src/opts/SkBlitRow_opts_none.cpp',
senorblanco@chromium.org27eec462013-11-08 20:49:04 +0000111 '../src/opts/SkBlurImage_opts_none.cpp',
senorblanco@chromium.org7a47ad32013-10-30 21:57:04 +0000112 '../src/opts/SkMorphology_opts_none.cpp',
djsollen@google.com58629292011-11-03 13:08:29 +0000113 '../src/opts/SkUtils_opts_none.cpp',
commit-bot@chromium.orgdf187c72013-10-09 14:39:46 +0000114 '../src/opts/SkXfermode_opts_none.cpp',
djsollen@google.com58629292011-11-03 13:08:29 +0000115 ],
116 }],
commit-bot@chromium.orge72a4082014-02-28 16:07:39 +0000117 [ 'skia_android_framework', {
118 'cflags!': [
119 '-msse2',
120 '-mfpu=neon',
121 '-fomit-frame-pointer',
122 '-mno-apcs-frame',
123 ]
124 }],
epoger@google.comae85aea2011-05-31 13:50:51 +0000125 ],
126 },
tomhudson@google.com95ad1552012-02-14 18:28:54 +0000127 # For the same lame reasons as what is done for skia_opts, we have to
128 # create another target specifically for SSSE3 code as we would not want
129 # to compile the SSE2 code with -mssse3 which would potentially allow
130 # gcc to generate SSSE3 code.
131 {
132 'target_name': 'opts_ssse3',
borenet@google.comefb1d772012-10-10 19:45:51 +0000133 'product_name': 'skia_opts_ssse3',
tomhudson@google.com95ad1552012-02-14 18:28:54 +0000134 'type': 'static_library',
borenet@google.comefb1d772012-10-10 19:45:51 +0000135 'standalone_static_library': 1,
bungeman@google.comb8f36552013-07-22 14:39:45 +0000136 'dependencies': [
137 'core.gyp:*',
senorblanco@chromium.org0ded88d2014-01-24 15:43:50 +0000138 'effects.gyp:*'
bungeman@google.comb8f36552013-07-22 14:39:45 +0000139 ],
tomhudson@google.com95ad1552012-02-14 18:28:54 +0000140 'include_dirs': [
tomhudson@google.com95ad1552012-02-14 18:28:54 +0000141 '../src/core',
142 ],
143 'conditions': [
commit-bot@chromium.orge72a4082014-02-28 16:07:39 +0000144 [ 'skia_os in ["linux", "freebsd", "openbsd", "solaris", "nacl", "chromeos", "android"] \
145 and not skia_android_framework', {
tomhudson@google.com95ad1552012-02-14 18:28:54 +0000146 'cflags': [
147 '-mssse3',
148 ],
149 }],
commit-bot@chromium.org4460de42013-08-06 18:13:01 +0000150 # (Mac has -mssse3 globally.)
djsollen@google.come341cb32012-06-28 16:08:05 +0000151 [ 'skia_arch_type == "x86"', {
tomhudson@google.com95ad1552012-02-14 18:28:54 +0000152 'sources': [
153 '../src/opts/SkBitmapProcState_opts_SSSE3.cpp',
154 ],
155 }],
156 ],
157 },
digit@google.comeec9dbc2012-05-30 13:54:41 +0000158 # NEON code must be compiled with -mfpu=neon which also affects scalar
159 # code. To support dynamic NEON code paths, we need to build all
160 # NEON-specific sources in a separate static library. The situation
161 # is very similar to the SSSE3 one.
162 {
163 'target_name': 'opts_neon',
borenet@google.comefb1d772012-10-10 19:45:51 +0000164 'product_name': 'skia_opts_neon',
digit@google.comeec9dbc2012-05-30 13:54:41 +0000165 'type': 'static_library',
borenet@google.comefb1d772012-10-10 19:45:51 +0000166 'standalone_static_library': 1,
bungeman@google.comb8f36552013-07-22 14:39:45 +0000167 'dependencies': [
168 'core.gyp:*',
senorblanco@chromium.org0ded88d2014-01-24 15:43:50 +0000169 'effects.gyp:*'
bungeman@google.comb8f36552013-07-22 14:39:45 +0000170 ],
digit@google.comeec9dbc2012-05-30 13:54:41 +0000171 'include_dirs': [
digit@google.comeec9dbc2012-05-30 13:54:41 +0000172 '../src/core',
digit@google.comfce02ac2012-08-01 14:25:07 +0000173 '../src/opts',
digit@google.comeec9dbc2012-05-30 13:54:41 +0000174 ],
175 'cflags!': [
176 '-fno-omit-frame-pointer',
177 '-mfpu=vfp', # remove them all, just in case.
178 '-mfpu=vfpv3',
179 '-mfpu=vfpv3-d16',
180 ],
commit-bot@chromium.orge72a4082014-02-28 16:07:39 +0000181 'conditions': [
182 [ 'not skia_android_framework', {
183 'cflags': [
184 '-mfpu=neon',
185 '-fomit-frame-pointer',
186 ],
187 }],
digit@google.comeec9dbc2012-05-30 13:54:41 +0000188 ],
djsollen@google.com4dcc6242013-01-23 18:56:38 +0000189 'ldflags': [
190 '-march=armv7-a',
191 '-Wl,--fix-cortex-a8',
192 ],
digit@google.comeec9dbc2012-05-30 13:54:41 +0000193 'sources': [
194 '../src/opts/memset16_neon.S',
195 '../src/opts/memset32_neon.S',
digit@google.com3ada0ef2012-08-13 14:06:34 +0000196 '../src/opts/SkBitmapProcState_arm_neon.cpp',
digit@google.comfce02ac2012-08-01 14:25:07 +0000197 '../src/opts/SkBitmapProcState_matrixProcs_neon.cpp',
commit-bot@chromium.orga96176d2014-01-28 15:18:54 +0000198 '../src/opts/SkBitmapProcState_matrix_neon.h',
rmistry@google.comd6bab022013-12-02 13:50:38 +0000199 '../src/opts/SkBlitMask_opts_arm_neon.cpp',
digit@google.coma8dd1ce2012-08-08 22:06:29 +0000200 '../src/opts/SkBlitRow_opts_arm_neon.cpp',
senorblanco@chromium.org1d62f422013-12-04 18:19:45 +0000201 '../src/opts/SkBlurImage_opts_neon.cpp',
senorblanco@chromium.orgf376f5d2013-11-11 16:48:51 +0000202 '../src/opts/SkMorphology_opts_neon.cpp',
commit-bot@chromium.orgcd7992b2013-10-17 16:29:34 +0000203 '../src/opts/SkXfermode_opts_arm_neon.cpp',
digit@google.comeec9dbc2012-05-30 13:54:41 +0000204 ],
205 },
epoger@google.comae85aea2011-05-31 13:50:51 +0000206 ],
207}