1 # Copyright (c) 2013 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.
7 '../build/common_untrusted.gypi',
10 # We need to override the variables in untrusted.gypi outside of a
11 # target_condition block because the target_condition block in
12 # untrusted gypi is fully evaluated and interpolated before any of the
13 # target_condition blocks in this file are expanded. This means that any
14 # variables overriden inside a target_condition block in this file will not
15 # affect the values in untrusted.gypi.
19 'nacl_newlib_out_dir': '<(PRODUCT_DIR)/>(nexe_destination_dir)/newlib',
20 'nacl_glibc_out_dir': '<(PRODUCT_DIR)/>(nexe_destination_dir)/glibc',
21 'nacl_pnacl_newlib_out_dir': '<(PRODUCT_DIR)/>(nexe_destination_dir)/pnacl',
22 'nacl_pnacl_newlib_nonsfi_out_dir': '<(PRODUCT_DIR)/>(nexe_destination_dir)/nonsfi',
23 'target_conditions': [
25 # These variables are used for nexe building and for library building.
26 'out_newlib32%': '>(nacl_newlib_out_dir)/>(nexe_target)_newlib_x86_32.nexe',
27 'out_newlib64%': '>(nacl_newlib_out_dir)/>(nexe_target)_newlib_x86_64.nexe',
28 'out_newlib_arm%': '>(nacl_newlib_out_dir)/>(nexe_target)_newlib_arm.nexe',
29 'out_newlib_mips%': '>(nacl_newlib_out_dir)/>(nexe_target)_newlib_mips32.nexe',
30 'nmf_newlib%': '>(nacl_newlib_out_dir)/>(nexe_target).nmf',
31 'out_glibc32%': '>(nacl_glibc_out_dir)/>(nexe_target)_glibc_x86_32.nexe',
32 'out_glibc64%': '>(nacl_glibc_out_dir)/>(nexe_target)_glibc_x86_64.nexe',
33 'out_glibc_arm%': '>(nacl_glibc_out_dir)/>(nexe_target)_glibc_arm.nexe',
34 'nmf_glibc%': '>(nacl_glibc_out_dir)/>(nexe_target).nmf',
35 'out_pnacl_newlib%': '>(nacl_pnacl_newlib_out_dir)/>(nexe_target)_newlib_pnacl.pexe',
36 'nmf_pnacl_newlib%': '>(nacl_pnacl_newlib_out_dir)/>(nexe_target).nmf',
37 'out_pnacl_newlib_x86_32_nonsfi_nexe': '>(nacl_pnacl_newlib_nonsfi_out_dir)/>(nexe_target)_pnacl_newlib_x32_nonsfi.nexe',
38 'out_pnacl_newlib_arm_nonsfi_nexe': '>(nacl_pnacl_newlib_nonsfi_out_dir)/>(nexe_target)_pnacl_newlib_arm_nonsfi.nexe',
39 'nmf_pnacl_newlib_nonsfi%': '>(nacl_pnacl_newlib_nonsfi_out_dir)/>(nexe_target).nmf',
44 '<(DEPTH)/native_client/src/untrusted/nacl/nacl.gyp:nacl_lib',
45 '<(DEPTH)/native_client/src/untrusted/pthread/pthread.gyp:pthread_lib',
46 '<(DEPTH)/ppapi/ppapi_nacl.gyp:ppapi_cpp_lib',
47 '<(DEPTH)/ppapi/native_client/native_client.gyp:ppapi_lib',
49 'target_conditions': [
50 ['test_files!=[] and build_newlib==1', {
53 'destination': '>(nacl_newlib_out_dir)',
60 ['test_files!=[] and "<(target_arch)"!="arm" and "<(target_arch)"!="mipsel" and disable_glibc==0 and build_glibc==1', {
63 'destination': '>(nacl_glibc_out_dir)',
70 # Nonsfi pnacl copy is covered below.
71 ['test_files!=[] and build_pnacl_newlib==1 and disable_pnacl==0', {
74 'destination': '>(nacl_pnacl_newlib_out_dir)',
81 ['test_files!=[] and build_pnacl_newlib==1 and (enable_x86_32_nonsfi==1 or enable_arm_nonsfi==1)', {
84 'destination': '>(nacl_pnacl_newlib_nonsfi_out_dir)',
93 # Patch over the fact that untrusted.gypi doesn't define these in all
110 'create_nmf': '<(DEPTH)/native_client_sdk/src/tools/create_nmf.py',
111 'create_nmf_args_portable%': [],
112 'create_nonsfi_test_nmf': '<(DEPTH)/ppapi/tests/create_nonsfi_test_nmf.py',
114 'target_conditions': [
115 ['generate_nmf==1 and build_newlib==1', {
118 'action_name': 'Generate NEWLIB NMF',
119 'inputs': ['>(create_nmf)'],
120 'outputs': ['>(nmf_newlib)'],
124 '--output=>(nmf_newlib)',
125 '>@(create_nmf_args_portable)',
127 'target_conditions': [
128 ['enable_x86_64==1', {
129 'inputs': ['>(out_newlib64)'],
130 'action': ['>(out_newlib64)'],
132 ['enable_x86_32==1', {
133 'inputs': ['>(out_newlib32)'],
134 'action': ['>(out_newlib32)'],
137 'inputs': ['>(out_newlib_arm)'],
138 'action': ['>(out_newlib_arm)'],
141 'inputs': ['>(out_newlib_mips)'],
142 'action': ['>(out_newlib_mips)'],
148 ['"<(target_arch)"!="arm" and "<(target_arch)"!="mipsel" and generate_nmf==1 and disable_glibc==0 and build_glibc==1', {
150 # NOTE: Use /lib, not /lib64 here; it is a symbolic link which
151 # doesn't work on Windows.
152 'libdir_glibc64': '>(nacl_glibc_tc_root)/x86_64-nacl/lib',
153 'libdir_glibc32': '>(nacl_glibc_tc_root)/x86_64-nacl/lib32',
154 'nacl_objdump': '>(nacl_glibc_tc_root)/bin/x86_64-nacl-objdump',
158 'action_name': 'Generate GLIBC NMF and copy libs',
159 'inputs': ['>(create_nmf)'],
160 # NOTE: There is no explicit dependency for the lib32
161 # and lib64 directories created in the PRODUCT_DIR.
162 # They are created as a side-effect of NMF creation.
163 'outputs': ['>(nmf_glibc)'],
167 '--objdump=>(nacl_objdump)',
168 '--output=>(nmf_glibc)',
169 '--path-prefix=>(nexe_target)_libs',
170 '--stage-dependencies=<(nacl_glibc_out_dir)',
171 '>@(create_nmf_args_portable)',
173 'target_conditions': [
174 ['enable_x86_64==1', {
175 'inputs': ['>(out_glibc64)'],
177 '--library-path=>(libdir_glibc64)',
178 '--library-path=>(tc_lib_dir_glibc64)',
181 ['enable_x86_32==1', {
182 'inputs': ['>(out_glibc32)'],
184 '--library-path=>(libdir_glibc32)',
185 '--library-path=>(tc_lib_dir_glibc32)',
188 # TODO(ncbray) handle arm case. We don't have ARM glibc yet.
193 ['generate_nmf==1 and build_pnacl_newlib==1 and disable_pnacl==0', {
196 'action_name': 'Generate PNACL NEWLIB NMF',
197 # NOTE: create_nmf must be first, it is the script python
199 'inputs': ['>(create_nmf)', '>(out_pnacl_newlib)'],
200 'outputs': ['>(nmf_pnacl_newlib)'],
204 '--output=>(nmf_pnacl_newlib)',
205 '>(out_pnacl_newlib)',
206 '>@(create_nmf_args_portable)',
211 ['generate_nmf==1 and build_pnacl_newlib==1 and disable_pnacl==0 and (enable_x86_32_nonsfi==1 or enable_arm_nonsfi==1)', {
214 'action_name': 'Generate PNACL NEWLIB nonsfi NMF',
215 'inputs': ['>(create_nonsfi_test_nmf)'],
216 'outputs': ['>(nmf_pnacl_newlib_nonsfi)'],
219 '>(create_nonsfi_test_nmf)',
220 '>@(create_nmf_args_portable)',
221 '--output=>(nmf_pnacl_newlib_nonsfi)',
223 'target_conditions': [
224 ['enable_x86_32_nonsfi==1 and "<(target_arch)"=="ia32"', {
225 'inputs': ['>(out_pnacl_newlib_x86_32_nonsfi_nexe)'],
227 '--program=>(out_pnacl_newlib_x86_32_nonsfi_nexe)',
231 ['enable_x86_32_nonsfi==1 and "<(target_arch)"=="x64"', {
232 'inputs': ['>(out_pnacl_newlib_x86_32_nonsfi_nexe)'],
234 '--program=>(out_pnacl_newlib_x86_32_nonsfi_nexe)',
235 # This should be used only for nacl_helper_nonsfi test.
236 # In theory this should be x86-32. However, currently
237 # fallback logic to x86-32-nonsfi is not implemented,
238 # and, moreover, it would break the tests for current
239 # nacl_helper in Non-SFI mode on x64 Chrome.
240 # So, here we introduce the hack to use "x86-64" in order
241 # to take the benefit to run nacl_helper_nonsfi tests on
243 # TODO(hidehiko): Remove this hack.
247 ['enable_arm_nonsfi==1', {
248 'inputs': ['>(out_pnacl_newlib_arm_nonsfi_nexe)'],
250 '--program=>(out_pnacl_newlib_arm_nonsfi_nexe)',