| OLD | NEW |
| (Empty) |
| 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. | |
| 4 | |
| 5 import("//testing/test.gni") | |
| 6 | |
| 7 # This needs to be a static library rather than a sources set because small | |
| 8 # portions of this are used in some contexts (like chrome_elf), and it | |
| 9 # doesnn't seem to dead-code strip very well. This saves 12K on chrome_elf.dll, | |
| 10 # over a source set, for example. | |
| 11 static_library("sandbox") { | |
| 12 sources = [ | |
| 13 "src/acl.cc", | |
| 14 "src/acl.h", | |
| 15 "src/app_container.cc", | |
| 16 "src/app_container.h", | |
| 17 "src/broker_services.cc", | |
| 18 "src/broker_services.h", | |
| 19 "src/crosscall_client.h", | |
| 20 "src/crosscall_params.h", | |
| 21 "src/crosscall_server.cc", | |
| 22 "src/crosscall_server.h", | |
| 23 "src/eat_resolver.cc", | |
| 24 "src/eat_resolver.h", | |
| 25 "src/filesystem_dispatcher.cc", | |
| 26 "src/filesystem_dispatcher.h", | |
| 27 "src/filesystem_interception.cc", | |
| 28 "src/filesystem_interception.h", | |
| 29 "src/filesystem_policy.cc", | |
| 30 "src/filesystem_policy.h", | |
| 31 "src/handle_closer.cc", | |
| 32 "src/handle_closer.h", | |
| 33 "src/handle_closer_agent.cc", | |
| 34 "src/handle_closer_agent.h", | |
| 35 "src/handle_dispatcher.cc", | |
| 36 "src/handle_dispatcher.h", | |
| 37 "src/handle_interception.cc", | |
| 38 "src/handle_interception.h", | |
| 39 "src/handle_policy.cc", | |
| 40 "src/handle_policy.h", | |
| 41 "src/interception.cc", | |
| 42 "src/interception.h", | |
| 43 "src/interception_agent.cc", | |
| 44 "src/interception_agent.h", | |
| 45 "src/interception_internal.h", | |
| 46 "src/interceptors.h", | |
| 47 "src/internal_types.h", | |
| 48 "src/ipc_tags.h", | |
| 49 "src/job.cc", | |
| 50 "src/job.h", | |
| 51 "src/named_pipe_dispatcher.cc", | |
| 52 "src/named_pipe_dispatcher.h", | |
| 53 "src/named_pipe_interception.cc", | |
| 54 "src/named_pipe_interception.h", | |
| 55 "src/named_pipe_policy.cc", | |
| 56 "src/named_pipe_policy.h", | |
| 57 "src/nt_internals.h", | |
| 58 "src/policy_broker.cc", | |
| 59 "src/policy_broker.h", | |
| 60 "src/policy_engine_opcodes.cc", | |
| 61 "src/policy_engine_opcodes.h", | |
| 62 "src/policy_engine_params.h", | |
| 63 "src/policy_engine_processor.cc", | |
| 64 "src/policy_engine_processor.h", | |
| 65 "src/policy_low_level.cc", | |
| 66 "src/policy_low_level.h", | |
| 67 "src/policy_params.h", | |
| 68 "src/policy_target.cc", | |
| 69 "src/policy_target.h", | |
| 70 "src/process_mitigations.cc", | |
| 71 "src/process_mitigations.h", | |
| 72 "src/process_mitigations_win32k_dispatcher.cc", | |
| 73 "src/process_mitigations_win32k_dispatcher.h", | |
| 74 "src/process_mitigations_win32k_interception.cc", | |
| 75 "src/process_mitigations_win32k_interception.h", | |
| 76 "src/process_mitigations_win32k_policy.cc", | |
| 77 "src/process_mitigations_win32k_policy.h", | |
| 78 "src/process_thread_dispatcher.cc", | |
| 79 "src/process_thread_dispatcher.h", | |
| 80 "src/process_thread_interception.cc", | |
| 81 "src/process_thread_interception.h", | |
| 82 "src/process_thread_policy.cc", | |
| 83 "src/process_thread_policy.h", | |
| 84 "src/registry_dispatcher.cc", | |
| 85 "src/registry_dispatcher.h", | |
| 86 "src/registry_interception.cc", | |
| 87 "src/registry_interception.h", | |
| 88 "src/registry_policy.cc", | |
| 89 "src/registry_policy.h", | |
| 90 "src/resolver.cc", | |
| 91 "src/resolver.h", | |
| 92 "src/restricted_token.cc", | |
| 93 "src/restricted_token.h", | |
| 94 "src/restricted_token_utils.cc", | |
| 95 "src/restricted_token_utils.h", | |
| 96 "src/sandbox.cc", | |
| 97 "src/sandbox.h", | |
| 98 "src/sandbox_factory.h", | |
| 99 "src/sandbox_globals.cc", | |
| 100 "src/sandbox_nt_types.h", | |
| 101 "src/sandbox_nt_util.cc", | |
| 102 "src/sandbox_nt_util.h", | |
| 103 "src/sandbox_policy.h", | |
| 104 "src/sandbox_policy_base.cc", | |
| 105 "src/sandbox_policy_base.h", | |
| 106 "src/sandbox_rand.cc", | |
| 107 "src/sandbox_rand.h", | |
| 108 "src/sandbox_types.h", | |
| 109 "src/sandbox_utils.cc", | |
| 110 "src/sandbox_utils.h", | |
| 111 "src/security_level.h", | |
| 112 "src/service_resolver.cc", | |
| 113 "src/service_resolver.h", | |
| 114 "src/sharedmem_ipc_client.cc", | |
| 115 "src/sharedmem_ipc_client.h", | |
| 116 "src/sharedmem_ipc_server.cc", | |
| 117 "src/sharedmem_ipc_server.h", | |
| 118 "src/sid.cc", | |
| 119 "src/sid.h", | |
| 120 "src/sync_dispatcher.cc", | |
| 121 "src/sync_dispatcher.h", | |
| 122 "src/sync_interception.cc", | |
| 123 "src/sync_interception.h", | |
| 124 "src/sync_policy.cc", | |
| 125 "src/sync_policy.h", | |
| 126 "src/target_interceptions.cc", | |
| 127 "src/target_interceptions.h", | |
| 128 "src/target_process.cc", | |
| 129 "src/target_process.h", | |
| 130 "src/target_services.cc", | |
| 131 "src/target_services.h", | |
| 132 "src/top_level_dispatcher.cc", | |
| 133 "src/top_level_dispatcher.h", | |
| 134 "src/win2k_threadpool.cc", | |
| 135 "src/win2k_threadpool.h", | |
| 136 "src/win_utils.cc", | |
| 137 "src/win_utils.h", | |
| 138 "src/window.cc", | |
| 139 "src/window.h", | |
| 140 ] | |
| 141 | |
| 142 if (current_cpu == "x64") { | |
| 143 sources += [ | |
| 144 "src/interceptors_64.cc", | |
| 145 "src/interceptors_64.h", | |
| 146 "src/resolver_64.cc", | |
| 147 "src/service_resolver_64.cc", | |
| 148 ] | |
| 149 } else if (current_cpu == "x86") { | |
| 150 sources += [ | |
| 151 "src/resolver_32.cc", | |
| 152 "src/service_resolver_32.cc", | |
| 153 "src/sidestep/ia32_modrm_map.cpp", | |
| 154 "src/sidestep/ia32_opcode_map.cpp", | |
| 155 "src/sidestep/mini_disassembler.cpp", | |
| 156 "src/sidestep/mini_disassembler.h", | |
| 157 "src/sidestep/mini_disassembler_types.h", | |
| 158 "src/sidestep/preamble_patcher.h", | |
| 159 "src/sidestep/preamble_patcher_with_stub.cpp", | |
| 160 "src/sidestep_resolver.cc", | |
| 161 "src/sidestep_resolver.h", | |
| 162 ] | |
| 163 } | |
| 164 | |
| 165 configs += [ "//build/config:precompiled_headers" ] | |
| 166 | |
| 167 deps = [ | |
| 168 "//base", | |
| 169 "//base:base_static", | |
| 170 ] | |
| 171 if (current_cpu == "x86") { | |
| 172 deps += [ ":copy_wow_helper" ] | |
| 173 } | |
| 174 } | |
| 175 | |
| 176 if (current_cpu == "x86") { | |
| 177 # Make a target that copies the wow_helper files to the out dir. | |
| 178 # | |
| 179 # TODO(brettw) we can probably just build this now that we have proper | |
| 180 # toolchain support. | |
| 181 copy("copy_wow_helper") { | |
| 182 sources = [ | |
| 183 "wow_helper/wow_helper.exe", | |
| 184 "wow_helper/wow_helper.pdb", | |
| 185 ] | |
| 186 outputs = [ | |
| 187 "$root_out_dir/{{source_file_part}}", | |
| 188 ] | |
| 189 } | |
| 190 } | |
| 191 | |
| 192 test("sbox_integration_tests") { | |
| 193 sources = [ | |
| 194 "src/address_sanitizer_test.cc", | |
| 195 "src/app_container_test.cc", | |
| 196 "src/file_policy_test.cc", | |
| 197 "src/handle_closer_test.cc", | |
| 198 "src/handle_inheritance_test.cc", | |
| 199 "src/handle_policy_test.cc", | |
| 200 "src/integrity_level_test.cc", | |
| 201 "src/ipc_ping_test.cc", | |
| 202 "src/lpc_policy_test.cc", | |
| 203 "src/named_pipe_policy_test.cc", | |
| 204 "src/policy_target_test.cc", | |
| 205 "src/process_mitigations_test.cc", | |
| 206 "src/process_policy_test.cc", | |
| 207 "src/registry_policy_test.cc", | |
| 208 "src/restricted_token_test.cc", | |
| 209 "src/sync_policy_test.cc", | |
| 210 "src/sync_policy_test.h", | |
| 211 "src/unload_dll_test.cc", | |
| 212 "tests/common/controller.cc", | |
| 213 "tests/common/controller.h", | |
| 214 "tests/common/test_utils.cc", | |
| 215 "tests/common/test_utils.h", | |
| 216 "tests/integration_tests/integration_tests.cc", | |
| 217 "tests/integration_tests/integration_tests_test.cc", | |
| 218 ] | |
| 219 | |
| 220 deps = [ | |
| 221 ":sandbox", | |
| 222 "//base/test:test_support", | |
| 223 "//testing/gtest", | |
| 224 ] | |
| 225 } | |
| 226 | |
| 227 test("sbox_validation_tests") { | |
| 228 sources = [ | |
| 229 "tests/common/controller.cc", | |
| 230 "tests/common/controller.h", | |
| 231 "tests/validation_tests/commands.cc", | |
| 232 "tests/validation_tests/commands.h", | |
| 233 "tests/validation_tests/suite.cc", | |
| 234 "tests/validation_tests/unit_tests.cc", | |
| 235 ] | |
| 236 | |
| 237 deps = [ | |
| 238 ":sandbox", | |
| 239 "//base/test:test_support", | |
| 240 "//testing/gtest", | |
| 241 ] | |
| 242 } | |
| 243 | |
| 244 test("sbox_unittests") { | |
| 245 sources = [ | |
| 246 "src/app_container_unittest.cc", | |
| 247 "src/interception_unittest.cc", | |
| 248 "src/ipc_unittest.cc", | |
| 249 "src/job_unittest.cc", | |
| 250 "src/policy_engine_unittest.cc", | |
| 251 "src/policy_low_level_unittest.cc", | |
| 252 "src/policy_opcodes_unittest.cc", | |
| 253 "src/restricted_token_unittest.cc", | |
| 254 "src/sandbox_nt_util_unittest.cc", | |
| 255 "src/service_resolver_unittest.cc", | |
| 256 "src/sid_unittest.cc", | |
| 257 "src/threadpool_unittest.cc", | |
| 258 "src/win_utils_unittest.cc", | |
| 259 "tests/common/test_utils.cc", | |
| 260 "tests/common/test_utils.h", | |
| 261 "tests/unit_tests/unit_tests.cc", | |
| 262 ] | |
| 263 | |
| 264 deps = [ | |
| 265 ":sandbox", | |
| 266 "//base/test:test_support", | |
| 267 "//testing/gtest", | |
| 268 ] | |
| 269 } | |
| 270 | |
| 271 test("sandbox_poc") { | |
| 272 sources = [ | |
| 273 "sandbox_poc/main_ui_window.cc", | |
| 274 "sandbox_poc/main_ui_window.h", | |
| 275 "sandbox_poc/resource.h", | |
| 276 "sandbox_poc/sandbox.cc", | |
| 277 "sandbox_poc/sandbox.h", | |
| 278 "sandbox_poc/sandbox.ico", | |
| 279 "sandbox_poc/sandbox.rc", | |
| 280 ] | |
| 281 | |
| 282 configs -= [ "//build/config/win:console" ] | |
| 283 configs += [ "//build/config/win:windowed" ] | |
| 284 | |
| 285 libs = [ "comctl32.lib" ] | |
| 286 | |
| 287 deps = [ | |
| 288 ":pocdll", | |
| 289 ":sandbox", | |
| 290 ] | |
| 291 } | |
| 292 | |
| 293 shared_library("pocdll") { | |
| 294 sources = [ | |
| 295 "sandbox_poc/pocdll/exports.h", | |
| 296 "sandbox_poc/pocdll/fs.cc", | |
| 297 "sandbox_poc/pocdll/handles.cc", | |
| 298 "sandbox_poc/pocdll/invasive.cc", | |
| 299 "sandbox_poc/pocdll/network.cc", | |
| 300 "sandbox_poc/pocdll/pocdll.cc", | |
| 301 "sandbox_poc/pocdll/processes_and_threads.cc", | |
| 302 "sandbox_poc/pocdll/registry.cc", | |
| 303 "sandbox_poc/pocdll/spyware.cc", | |
| 304 "sandbox_poc/pocdll/utils.h", | |
| 305 ] | |
| 306 | |
| 307 defines = [ "POCDLL_EXPORTS" ] | |
| 308 | |
| 309 deps = [ | |
| 310 "//build/config/sanitizers:deps", | |
| 311 ] | |
| 312 } | |
| OLD | NEW |