1 # Copyright 2014 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
5 # This GYP file defines untrusted (NaCl) targets. All targets in this
6 # file should be conditionally depended upon via 'disable_nacl!=1' to avoid
7 # requiring NaCl sources for building.
11 '../build/common_untrusted.gypi',
16 'target_name': 'ppapi_cpp_lib',
19 'nlib_target': 'libppapi_cpp.a',
20 'nso_target': 'libppapi_cpp.so',
23 'build_pnacl_newlib': 1,
25 '<@(cpp_source_files)',
26 'cpp/module_embedder.h',
27 'cpp/ppp_entrypoints.cc',
31 '<(DEPTH)/native_client/tools.gyp:prep_toolchain',
35 'target_name': 'ppapi_gles2_lib',
38 'nlib_target': 'libppapi_gles2.a',
39 'nso_target': 'libppapi_gles2.so',
42 'build_pnacl_newlib': 1,
47 'lib/gl/gles2/gl2ext_ppapi.c',
48 'lib/gl/gles2/gl2ext_ppapi.h',
49 'lib/gl/gles2/gles2.c',
53 '<(DEPTH)/native_client/tools.gyp:prep_toolchain',
57 'target_name': 'ppapi_nacl_tests',
60 '<(DEPTH)/native_client/tools.gyp:prep_toolchain',
61 '<(DEPTH)/native_client/src/untrusted/nacl/nacl.gyp:nacl_lib',
62 '<(DEPTH)/native_client/src/untrusted/pthread/pthread.gyp:pthread_lib',
64 'native_client/native_client.gyp:ppapi_lib',
67 # This is user code (vs IRT code), so tls accesses do not
68 # need to be indirect through a function call.
69 'newlib_tls_flags=': [],
70 # TODO(bradnelson): Remove this compile flag once new nacl_rev is
73 '-DGL_GLEXT_PROTOTYPES',
75 # Speed up pnacl linking by not generating debug info for tests.
76 # We compile with --strip-all under extra_args so debug info is
77 # discarded anyway. Remove this and the --strip-all flag if
78 # debug info is really needed.
83 'GL_GLEXT_PROTOTYPES',
85 'nexe_target': 'ppapi_nacl_tests',
103 ['target_arch=="ia32"', {
104 'extra_deps_newlib32': [
105 '>(tc_lib_dir_newlib32)/libppapi_cpp.a',
106 '>(tc_lib_dir_newlib32)/libppapi.a',
108 'extra_deps_glibc32': [
109 '>(tc_lib_dir_glibc32)/libppapi_cpp.so',
110 '>(tc_lib_dir_glibc32)/libppapi.so',
113 ['target_arch=="x64" or (target_arch=="ia32" and OS=="win")', {
114 'extra_deps_newlib64': [
115 '>(tc_lib_dir_newlib64)/libppapi_cpp.a',
116 '>(tc_lib_dir_newlib64)/libppapi.a',
118 'extra_deps_glibc64': [
119 '>(tc_lib_dir_glibc64)/libppapi_cpp.so',
120 '>(tc_lib_dir_glibc64)/libppapi.so',
123 ['target_arch=="arm"', {
125 '>(tc_lib_dir_newlib_arm)/libppapi_cpp.a',
126 '>(tc_lib_dir_newlib_arm)/libppapi.a',
130 'extra_deps_pnacl_newlib': [
131 '>(tc_lib_dir_pnacl_newlib)/libppapi_cpp.a',
132 '>(tc_lib_dir_pnacl_newlib)/libppapi.a',
135 '<@(test_common_source_files)',
136 '<@(test_nacl_source_files)',
141 'create_nmf': '<(DEPTH)/native_client_sdk/src/tools/create_nmf.py',
142 'create_nonsfi_test_nmf': 'tests/create_nonsfi_test_nmf.py',
145 ['(target_arch=="ia32" or target_arch=="x64") and disable_glibc==0', {
148 # NOTE: Use /lib, not /lib64 here; it is a symbolic link which
149 # doesn't work on Windows.
150 'libdir_glibc64': '>(nacl_glibc_tc_root)/x86_64-nacl/lib',
151 'libdir_glibc32': '>(nacl_glibc_tc_root)/x86_64-nacl/lib32',
152 'nacl_objdump': '>(nacl_glibc_tc_root)/bin/x86_64-nacl-objdump',
153 'nmf_glibc%': '<(PRODUCT_DIR)/>(nexe_target)_glibc.nmf',
157 'action_name': 'Generate GLIBC NMF and copy libs',
158 # NOTE: create_nmf must be first, it is the script python executes
160 'inputs': ['>(create_nmf)'],
161 # NOTE: There is no explicit dependency for the lib32
162 # and lib64 directories created in the PRODUCT_DIR.
163 # They are created as a side-effect of NMF creation.
164 'outputs': ['>(nmf_glibc)'],
168 '--objdump=>(nacl_objdump)',
169 '--output=>(nmf_glibc)',
170 '--stage-dependencies=<(PRODUCT_DIR)',
173 ['target_arch=="ia32"', {
175 '--library-path=>(libdir_glibc32)',
176 '--library-path=>(tc_lib_dir_glibc32)',
178 'inputs': ['>(out_glibc32)'],
180 ['target_arch=="x64" or (target_arch=="ia32" and OS=="win")', {
182 '--library-path=>(libdir_glibc64)',
183 '--library-path=>(tc_lib_dir_glibc64)',
185 'inputs': ['>(out_glibc64)'],
191 # Test PNaCl pre-translated code (pre-translated to save bot time).
192 # We only care about testing that code generation is correct,
193 # and in-browser translation is tested elsewhere.
194 # NOTE: native_client/build/untrusted.gypi dictates that
195 # PNaCl only generate x86-32 and x86-64 on x86 platforms,
196 # ARM on ARM platforms, or MIPS on MIPS platforms, not all
198 # The same goes for the PNaCl shims. So, we have two variations here.
199 ['disable_pnacl==0 and (target_arch=="ia32" or target_arch=="x64")', {
201 'build_pnacl_newlib': 1,
202 'translate_pexe_with_build': 1,
203 'nmf_pnacl%': '<(PRODUCT_DIR)/>(nexe_target)_pnacl.nmf',
205 # Shim is a dependency for the nexe because we pre-translate.
207 '<(DEPTH)/ppapi/native_client/src/untrusted/pnacl_irt_shim/pnacl_irt_shim.gyp:aot',
211 'action_name': 'Generate PNACL NEWLIB NMF',
212 # NOTE: create_nmf must be first, it is the script python executes
217 'outputs': ['>(nmf_pnacl)'],
221 '--output=>(nmf_pnacl)',
224 ['target_arch=="ia32"', {
226 '>(out_pnacl_newlib_x86_32_nexe)',
229 ['target_arch=="x64" or (target_arch=="ia32" and OS=="win")', {
231 '>(out_pnacl_newlib_x86_64_nexe)',
238 ['disable_pnacl==0 and (target_arch=="ia32" or target_arch=="x64" or target_arch=="arm") and OS=="linux"', {
239 # In addition to above configuration, build x86-32 and arm nonsfi
240 # .nexe files by translating from .pexe binary, for non-SFI mode PPAPI
243 'translate_pexe_with_build': 1,
244 'nmf_nonsfi%': '<(PRODUCT_DIR)/>(nexe_target)_pnacl_nonsfi.nmf',
247 ['target_arch=="ia32" or target_arch=="x64"', {
249 'enable_x86_32_nonsfi': 1,
252 ['target_arch=="arm"', {
254 'enable_arm_nonsfi': 1,
258 # Shim is a dependency for the nexe because we pre-translate.
260 '<(DEPTH)/ppapi/native_client/src/untrusted/pnacl_irt_shim/pnacl_irt_shim.gyp:aot',
264 'action_name': 'Generate PNACL NEWLIB NONSFI NMF',
265 'inputs': ['>(create_nonsfi_test_nmf)'],
266 'outputs': ['>(nmf_nonsfi)'],
269 '>(create_nonsfi_test_nmf)',
270 '--output=>(nmf_nonsfi)',
272 'target_conditions': [
273 ['enable_x86_32_nonsfi==1 and "<(target_arch)"=="ia32"', {
274 'inputs': ['>(out_pnacl_newlib_x86_32_nonsfi_nexe)'],
276 '--program=>(out_pnacl_newlib_x86_32_nonsfi_nexe)',
280 ['enable_x86_32_nonsfi==1 and "<(target_arch)"=="x64"', {
281 'inputs': ['>(out_pnacl_newlib_x86_32_nonsfi_nexe)'],
283 '--program=>(out_pnacl_newlib_x86_32_nonsfi_nexe)',
284 # This should be used only for nacl_helper_nonsfi test.
285 # In theory this should be x86-32. However, currently
286 # fallback logic to x86-32-nonsfi is not implemented,
287 # and, moreover, it would break the tests for current
288 # nacl_helper in Non-SFI mode on x64 Chrome.
289 # So, here we introduce the hack to use "x86-64" in order
290 # to take the benefit to run nacl_helper_nonsfi tests on
292 # TODO(hidehiko): Remove this hack.
296 ['enable_arm_nonsfi==1', {
297 'inputs': ['>(out_pnacl_newlib_arm_nonsfi_nexe)'],
299 '--program=>(out_pnacl_newlib_arm_nonsfi_nexe)',
307 ['disable_pnacl==0 and target_arch=="arm"', {
309 'build_pnacl_newlib': 1,
310 'translate_pexe_with_build': 1,
311 'nmf_pnacl%': '<(PRODUCT_DIR)/>(nexe_target)_pnacl.nmf',
313 # Shim is a dependency for the nexe because we pre-translate.
315 '<(DEPTH)/ppapi/native_client/src/untrusted/pnacl_irt_shim/pnacl_irt_shim.gyp:aot',
319 'action_name': 'Generate PNACL NEWLIB NMF',
320 # NOTE: create_nmf must be first, it is the script python executes
322 'inputs': ['>(create_nmf)', '>(out_pnacl_newlib_arm_nexe)'],
323 'outputs': ['>(nmf_pnacl)'],
327 '--output=>(nmf_pnacl)',
332 ['disable_pnacl==0 and target_arch=="mipsel"', {
334 'build_pnacl_newlib': 1,
335 'translate_pexe_with_build': 1,
336 'nmf_pnacl%': '<(PRODUCT_DIR)/>(nexe_target)_pnacl.nmf',
338 # Shim is a dependency for the nexe because we pre-translate.
340 '<(DEPTH)/ppapi/native_client/src/untrusted/pnacl_irt_shim/pnacl_irt_shim.gyp:aot',
344 'action_name': 'Generate PNACL NEWLIB NMF',
345 'inputs': ['>(create_nmf)', '>(out_pnacl_newlib_mips_nexe)'],
346 'outputs': ['>(nmf_pnacl)'],
350 '--output=>(nmf_pnacl)',