• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Copyright (c) 2012 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.
4
5{
6  'variables': {
7    'conditions': [
8      ['OS=="linux"', {
9        'compile_suid_client': 1,
10        'compile_credentials': 1,
11        'use_base_test_suite': 1,
12      }, {
13        'compile_suid_client': 0,
14        'compile_credentials': 0,
15        'use_base_test_suite': 0,
16      }],
17      ['OS=="linux" and (target_arch=="ia32" or target_arch=="x64" or '
18         'target_arch=="mipsel")', {
19        'compile_seccomp_bpf_demo': 1,
20      }, {
21        'compile_seccomp_bpf_demo': 0,
22      }],
23    ],
24  },
25  'target_defaults': {
26    'target_conditions': [
27      # All linux/ files will automatically be excluded on Android
28      # so make sure we re-include them explicitly.
29      ['OS == "android"', {
30        'sources/': [
31          ['include', '^linux/'],
32        ],
33      }],
34    ],
35  },
36  'targets': [
37    # We have two principal targets: sandbox and sandbox_linux_unittests
38    # All other targets are listed as dependencies.
39    # There is one notable exception: for historical reasons, chrome_sandbox is
40    # the setuid sandbox and is its own target.
41    {
42      'target_name': 'sandbox',
43      'type': 'none',
44      'dependencies': [
45        'sandbox_services',
46      ],
47      'conditions': [
48        [ 'compile_suid_client==1', {
49          'dependencies': [
50            'suid_sandbox_client',
51          ],
52        }],
53        # Compile seccomp BPF when we support it.
54        [ 'use_seccomp_bpf==1', {
55          'dependencies': [
56            'seccomp_bpf',
57            'seccomp_bpf_helpers',
58          ],
59        }],
60      ],
61    },
62    {
63      'target_name': 'sandbox_linux_test_utils',
64      'type': 'static_library',
65      'dependencies': [
66        '../testing/gtest.gyp:gtest',
67      ],
68      'include_dirs': [
69        '../..',
70      ],
71      'sources': [
72        'tests/sandbox_test_runner.cc',
73        'tests/sandbox_test_runner.h',
74        'tests/sandbox_test_runner_function_pointer.cc',
75        'tests/sandbox_test_runner_function_pointer.h',
76        'tests/test_utils.cc',
77        'tests/test_utils.h',
78        'tests/unit_tests.cc',
79        'tests/unit_tests.h',
80      ],
81      'conditions': [
82        [ 'use_seccomp_bpf==1', {
83          'sources': [
84            'seccomp-bpf/bpf_tester_compatibility_delegate.h',
85            'seccomp-bpf/bpf_tests.h',
86            'seccomp-bpf/sandbox_bpf_test_runner.cc',
87            'seccomp-bpf/sandbox_bpf_test_runner.h',
88          ],
89          'dependencies': [
90            'seccomp_bpf',
91          ]
92        }],
93        [ 'use_base_test_suite==1', {
94          'dependencies': [
95            '../base/base.gyp:test_support_base',
96          ],
97          'defines': [
98            'SANDBOX_USES_BASE_TEST_SUITE',
99          ],
100        }],
101      ],
102    },
103    {
104      # The main sandboxing test target.
105      'target_name': 'sandbox_linux_unittests',
106      'includes': [
107        'sandbox_linux_test_sources.gypi',
108      ],
109      'type': 'executable',
110      'conditions': [
111        [ 'OS == "android"', {
112          'variables': {
113            'test_type': 'gtest',
114            'test_suite_name': '<(_target_name)',
115          },
116          'includes': [
117            '../../build/android/test_runner.gypi',
118          ],
119        }]
120      ]
121    },
122    {
123      'target_name': 'seccomp_bpf',
124      'type': '<(component)',
125      'sources': [
126        'bpf_dsl/bpf_dsl.cc',
127        'bpf_dsl/bpf_dsl.h',
128        'bpf_dsl/bpf_dsl_forward.h',
129        'bpf_dsl/bpf_dsl_impl.h',
130        'bpf_dsl/codegen.cc',
131        'bpf_dsl/codegen.h',
132        'bpf_dsl/cons.h',
133        'bpf_dsl/errorcode.h',
134        'bpf_dsl/linux_syscall_ranges.h',
135        'bpf_dsl/policy.cc',
136        'bpf_dsl/policy.h',
137        'bpf_dsl/policy_compiler.cc',
138        'bpf_dsl/policy_compiler.h',
139        'bpf_dsl/seccomp_macros.h',
140        'bpf_dsl/seccomp_macros.h',
141        'bpf_dsl/syscall_set.cc',
142        'bpf_dsl/syscall_set.h',
143        'bpf_dsl/trap_registry.h',
144        'seccomp-bpf/die.cc',
145        'seccomp-bpf/die.h',
146        'seccomp-bpf/sandbox_bpf.cc',
147        'seccomp-bpf/sandbox_bpf.h',
148        'seccomp-bpf/syscall.cc',
149        'seccomp-bpf/syscall.h',
150        'seccomp-bpf/trap.cc',
151        'seccomp-bpf/trap.h',
152      ],
153      'dependencies': [
154        '../base/base.gyp:base',
155        'sandbox_services',
156        'sandbox_services_headers',
157      ],
158      'defines': [
159        'SANDBOX_IMPLEMENTATION',
160      ],
161      'includes': [
162        # Disable LTO due to compiler bug
163        # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=57703
164        '../../build/android/disable_gcc_lto.gypi',
165      ],
166      'include_dirs': [
167        '../..',
168      ],
169    },
170    {
171      'target_name': 'seccomp_bpf_helpers',
172      'type': '<(component)',
173      'sources': [
174        'seccomp-bpf-helpers/baseline_policy.cc',
175        'seccomp-bpf-helpers/baseline_policy.h',
176        'seccomp-bpf-helpers/sigsys_handlers.cc',
177        'seccomp-bpf-helpers/sigsys_handlers.h',
178        'seccomp-bpf-helpers/syscall_parameters_restrictions.cc',
179        'seccomp-bpf-helpers/syscall_parameters_restrictions.h',
180        'seccomp-bpf-helpers/syscall_sets.cc',
181        'seccomp-bpf-helpers/syscall_sets.h',
182      ],
183      'dependencies': [
184        '../base/base.gyp:base',
185        'sandbox_services',
186        'seccomp_bpf',
187      ],
188      'defines': [
189        'SANDBOX_IMPLEMENTATION',
190      ],
191      'include_dirs': [
192        '../..',
193      ],
194    },
195    {
196      # The setuid sandbox, for Linux
197      'target_name': 'chrome_sandbox',
198      'type': 'executable',
199      'sources': [
200        'suid/common/sandbox.h',
201        'suid/common/suid_unsafe_environment_variables.h',
202        'suid/process_util.h',
203        'suid/process_util_linux.c',
204        'suid/sandbox.c',
205      ],
206      'cflags': [
207        # For ULLONG_MAX
208        '-std=gnu99',
209      ],
210      'include_dirs': [
211        '../..',
212      ],
213      # Do not use any sanitizer tools with this binary. http://crbug.com/382766
214      'cflags/': [
215        ['exclude', '-fsanitize'],
216      ],
217      'ldflags/': [
218        ['exclude', '-fsanitize'],
219      ],
220    },
221    { 'target_name': 'sandbox_services',
222      'type': '<(component)',
223      'sources': [
224        'services/init_process_reaper.cc',
225        'services/init_process_reaper.h',
226        'services/proc_util.cc',
227        'services/proc_util.h',
228        'services/resource_limits.cc',
229        'services/resource_limits.h',
230        'services/scoped_process.cc',
231        'services/scoped_process.h',
232        'services/syscall_wrappers.cc',
233        'services/syscall_wrappers.h',
234        'services/thread_helpers.cc',
235        'services/thread_helpers.h',
236        'services/yama.cc',
237        'services/yama.h',
238        'syscall_broker/broker_channel.cc',
239        'syscall_broker/broker_channel.h',
240        'syscall_broker/broker_client.cc',
241        'syscall_broker/broker_client.h',
242        'syscall_broker/broker_common.h',
243        'syscall_broker/broker_file_permission.cc',
244        'syscall_broker/broker_file_permission.h',
245        'syscall_broker/broker_host.cc',
246        'syscall_broker/broker_host.h',
247        'syscall_broker/broker_policy.cc',
248        'syscall_broker/broker_policy.h',
249        'syscall_broker/broker_process.cc',
250        'syscall_broker/broker_process.h',
251      ],
252      'dependencies': [
253        '../base/base.gyp:base',
254      ],
255      'defines': [
256        'SANDBOX_IMPLEMENTATION',
257      ],
258      'conditions': [
259        ['compile_credentials==1', {
260          'sources': [
261            'services/credentials.cc',
262            'services/credentials.h',
263            'services/namespace_sandbox.cc',
264            'services/namespace_sandbox.h',
265            'services/namespace_utils.cc',
266            'services/namespace_utils.h',
267          ],
268          'dependencies': [
269            # for capability.h.
270            'sandbox_services_headers',
271          ],
272        }],
273      ],
274      'include_dirs': [
275        '..',
276      ],
277    },
278    { 'target_name': 'sandbox_services_headers',
279      'type': 'none',
280      'sources': [
281        'system_headers/arm64_linux_syscalls.h',
282        'system_headers/arm64_linux_ucontext.h',
283        'system_headers/arm_linux_syscalls.h',
284        'system_headers/arm_linux_ucontext.h',
285        'system_headers/capability.h',
286        'system_headers/i386_linux_ucontext.h',
287        'system_headers/linux_futex.h',
288        'system_headers/linux_seccomp.h',
289        'system_headers/linux_syscalls.h',
290        'system_headers/linux_time.h',
291        'system_headers/linux_ucontext.h',
292        'system_headers/mips_linux_syscalls.h',
293        'system_headers/mips_linux_ucontext.h',
294        'system_headers/x86_32_linux_syscalls.h',
295        'system_headers/x86_64_linux_syscalls.h',
296      ],
297      'include_dirs': [
298        '..',
299      ],
300    },
301    {
302      'target_name': 'suid_sandbox_client',
303      'type': '<(component)',
304      'sources': [
305        'suid/common/sandbox.h',
306        'suid/common/suid_unsafe_environment_variables.h',
307        'suid/client/setuid_sandbox_client.cc',
308        'suid/client/setuid_sandbox_client.h',
309        'suid/client/setuid_sandbox_host.cc',
310        'suid/client/setuid_sandbox_host.h',
311      ],
312      'defines': [
313        'SANDBOX_IMPLEMENTATION',
314      ],
315      'dependencies': [
316        '../base/base.gyp:base',
317        'sandbox_services',
318      ],
319      'include_dirs': [
320        '..',
321      ],
322    },
323    {
324      'target_name': 'bpf_dsl_golden',
325      'type': 'none',
326      'actions': [
327        {
328          'action_name': 'generate',
329          'inputs': [
330            'bpf_dsl/golden/generate.py',
331            'bpf_dsl/golden/i386/ArgSizePolicy.txt',
332            'bpf_dsl/golden/i386/BasicPolicy.txt',
333            'bpf_dsl/golden/i386/ElseIfPolicy.txt',
334            'bpf_dsl/golden/i386/MaskingPolicy.txt',
335            'bpf_dsl/golden/i386/MoreBooleanLogicPolicy.txt',
336            'bpf_dsl/golden/i386/NegativeConstantsPolicy.txt',
337            'bpf_dsl/golden/i386/SwitchPolicy.txt',
338            'bpf_dsl/golden/x86-64/ArgSizePolicy.txt',
339            'bpf_dsl/golden/x86-64/BasicPolicy.txt',
340            'bpf_dsl/golden/x86-64/BooleanLogicPolicy.txt',
341            'bpf_dsl/golden/x86-64/ElseIfPolicy.txt',
342            'bpf_dsl/golden/x86-64/MaskingPolicy.txt',
343            'bpf_dsl/golden/x86-64/MoreBooleanLogicPolicy.txt',
344            'bpf_dsl/golden/x86-64/NegativeConstantsPolicy.txt',
345            'bpf_dsl/golden/x86-64/SwitchPolicy.txt',
346          ],
347          'outputs': [
348            '<(SHARED_INTERMEDIATE_DIR)/sandbox/linux/bpf_dsl/golden/golden_files.h',
349          ],
350          'action': [
351            'python',
352            'linux/bpf_dsl/golden/generate.py',
353            '<(SHARED_INTERMEDIATE_DIR)/sandbox/linux/bpf_dsl/golden/golden_files.h',
354            'linux/bpf_dsl/golden/i386/ArgSizePolicy.txt',
355            'linux/bpf_dsl/golden/i386/BasicPolicy.txt',
356            'linux/bpf_dsl/golden/i386/ElseIfPolicy.txt',
357            'linux/bpf_dsl/golden/i386/MaskingPolicy.txt',
358            'linux/bpf_dsl/golden/i386/MoreBooleanLogicPolicy.txt',
359            'linux/bpf_dsl/golden/i386/NegativeConstantsPolicy.txt',
360            'linux/bpf_dsl/golden/i386/SwitchPolicy.txt',
361            'linux/bpf_dsl/golden/x86-64/ArgSizePolicy.txt',
362            'linux/bpf_dsl/golden/x86-64/BasicPolicy.txt',
363            'linux/bpf_dsl/golden/x86-64/BooleanLogicPolicy.txt',
364            'linux/bpf_dsl/golden/x86-64/ElseIfPolicy.txt',
365            'linux/bpf_dsl/golden/x86-64/MaskingPolicy.txt',
366            'linux/bpf_dsl/golden/x86-64/MoreBooleanLogicPolicy.txt',
367            'linux/bpf_dsl/golden/x86-64/NegativeConstantsPolicy.txt',
368            'linux/bpf_dsl/golden/x86-64/SwitchPolicy.txt',
369          ],
370          'message': 'Generating header from golden files ...',
371        },
372      ],
373    },
374  ],
375  'conditions': [
376    [ 'OS=="android"', {
377      'targets': [
378      {
379        'target_name': 'sandbox_linux_unittests_stripped',
380        'type': 'none',
381        'dependencies': [ 'sandbox_linux_unittests' ],
382        'actions': [{
383          'action_name': 'strip sandbox_linux_unittests',
384          'inputs': [ '<(PRODUCT_DIR)/sandbox_linux_unittests' ],
385          'outputs': [ '<(PRODUCT_DIR)/sandbox_linux_unittests_stripped' ],
386          'action': [ '<(android_strip)', '<@(_inputs)', '-o', '<@(_outputs)' ],
387        }],
388      },
389      {
390        'target_name': 'sandbox_linux_unittests_deps',
391        'type': 'none',
392        'dependencies': [
393          'sandbox_linux_unittests_stripped',
394        ],
395        # For the component build, ensure dependent shared libraries are
396        # stripped and put alongside sandbox_linux_unittests to simplify pushing
397        # to the device.
398        'variables': {
399           'output_dir': '<(PRODUCT_DIR)/sandbox_linux_unittests_deps/',
400           'native_binary': '<(PRODUCT_DIR)/sandbox_linux_unittests_stripped',
401           'include_main_binary': 0,
402        },
403        'includes': [
404          '../../build/android/native_app_dependencies.gypi'
405        ],
406      }],
407    }],
408    [ 'OS=="android"', {
409      'conditions': [
410        ['test_isolation_mode != "noop"', {
411          'targets': [
412            {
413              'target_name': 'sandbox_linux_unittests_android_run',
414              'type': 'none',
415              'dependencies': [
416                'sandbox_linux_unittests',
417              ],
418              'includes': [
419                '../../build/isolate.gypi',
420              ],
421              'sources': [
422                '../sandbox_linux_unittests_android.isolate',
423              ],
424            },
425          ],
426        },
427      ],
428    ],
429    }],
430    ['test_isolation_mode != "noop"', {
431      'targets': [
432        {
433          'target_name': 'sandbox_linux_unittests_run',
434          'type': 'none',
435          'dependencies': [
436            'sandbox_linux_unittests',
437          ],
438          'includes': [
439            '../../build/isolate.gypi',
440          ],
441          'sources': [
442            '../sandbox_linux_unittests.isolate',
443          ],
444        },
445      ],
446    }],
447  ],
448}
449