Fix Windows build, add Sandbox implementation.

[email protected]

Review URL: https://codereview.chromium.org/301193005

git-svn-id: svn://svn.chromium.org/chrome/trunk/src@274160 0039d316-1c4b-4281-b951-d872f2087c98
diff --git a/BUILD.gn b/BUILD.gn
index 6b7394d9..507d536 100644
--- a/BUILD.gn
+++ b/BUILD.gn
@@ -46,7 +46,7 @@
     "//mojo",
     "//net",
     "//ppapi:ppapi_c",
-    "//sandbox",
+    #"//sandbox",
     #"//sdch",
     "//skia",
     "//sql",
diff --git a/sandbox/BUILD.gn b/sandbox/BUILD.gn
index ffe22a4..71de29f 100644
--- a/sandbox/BUILD.gn
+++ b/sandbox/BUILD.gn
@@ -9,7 +9,7 @@
   # TODO(GYP)
   #} else if (is_mac) {
   #  deps = [ "//sandbox/mac:sandbox" ]
-  #} else if (is_linux || is_android) {
-  #  deps = [ "//sandbox/linux:sandbox" ]
+  } else if (is_linux || is_android) {
+    deps = [ "//sandbox/linux:sandbox" ]
   }
 }
diff --git a/sandbox/win/BUILD.gn b/sandbox/win/BUILD.gn
new file mode 100644
index 0000000..3c5bca6
--- /dev/null
+++ b/sandbox/win/BUILD.gn
@@ -0,0 +1,285 @@
+# Copyright 2014 The Chromium Authors. All rights reserved.

+# Use of this source code is governed by a BSD-style license that can be

+# found in the LICENSE file.

+

+source_set("sandbox") {

+  sources = [

+    "src/acl.cc",

+    "src/acl.h",

+    "src/app_container.cc",

+    "src/app_container.h",

+    "src/broker_services.cc",

+    "src/broker_services.h",

+    "src/crosscall_client.h",

+    "src/crosscall_params.h",

+    "src/crosscall_server.cc",

+    "src/crosscall_server.h",

+    "src/eat_resolver.cc",

+    "src/eat_resolver.h",

+    "src/filesystem_dispatcher.cc",

+    "src/filesystem_dispatcher.h",

+    "src/filesystem_interception.cc",

+    "src/filesystem_interception.h",

+    "src/filesystem_policy.cc",

+    "src/filesystem_policy.h",

+    "src/handle_closer.cc",

+    "src/handle_closer.h",

+    "src/handle_closer_agent.cc",

+    "src/handle_closer_agent.h",

+    "src/handle_dispatcher.cc",

+    "src/handle_dispatcher.h",

+    "src/handle_interception.cc",

+    "src/handle_interception.h",

+    "src/handle_policy.cc",

+    "src/handle_policy.h",

+    "src/handle_table.cc",

+    "src/handle_table.h",

+    "src/interception.cc",

+    "src/interception.h",

+    "src/interception_agent.cc",

+    "src/interception_agent.h",

+    "src/interception_internal.h",

+    "src/interceptors.h",

+    "src/internal_types.h",

+    "src/ipc_tags.h",

+    "src/job.cc",

+    "src/job.h",

+    "src/named_pipe_dispatcher.cc",

+    "src/named_pipe_dispatcher.h",

+    "src/named_pipe_interception.cc",

+    "src/named_pipe_interception.h",

+    "src/named_pipe_policy.cc",

+    "src/named_pipe_policy.h",

+    "src/nt_internals.h",

+    "src/policy_broker.cc",

+    "src/policy_broker.h",

+    "src/policy_engine_opcodes.cc",

+    "src/policy_engine_opcodes.h",

+    "src/policy_engine_params.h",

+    "src/policy_engine_processor.cc",

+    "src/policy_engine_processor.h",

+    "src/policy_low_level.cc",

+    "src/policy_low_level.h",

+    "src/policy_params.h",

+    "src/policy_target.cc",

+    "src/policy_target.h",

+    "src/process_mitigations.cc",

+    "src/process_mitigations.h",

+    "src/process_thread_dispatcher.cc",

+    "src/process_thread_dispatcher.h",

+    "src/process_thread_interception.cc",

+    "src/process_thread_interception.h",

+    "src/process_thread_policy.cc",

+    "src/process_thread_policy.h",

+    "src/registry_dispatcher.cc",

+    "src/registry_dispatcher.h",

+    "src/registry_interception.cc",

+    "src/registry_interception.h",

+    "src/registry_policy.cc",

+    "src/registry_policy.h",

+    "src/resolver.cc",

+    "src/resolver.h",

+    "src/restricted_token_utils.cc",

+    "src/restricted_token_utils.h",

+    "src/restricted_token.cc",

+    "src/restricted_token.h",

+    "src/sandbox_factory.h",

+    "src/sandbox_globals.cc",

+    "src/sandbox_nt_types.h",

+    "src/sandbox_nt_util.cc",

+    "src/sandbox_nt_util.h",

+    "src/sandbox_policy_base.cc",

+    "src/sandbox_policy_base.h",

+    "src/sandbox_policy.h",

+    "src/sandbox_types.h",

+    "src/sandbox_utils.cc",

+    "src/sandbox_utils.h",

+    "src/sandbox.cc",

+    "src/sandbox.h",

+    "src/security_level.h",

+    "src/service_resolver.cc",

+    "src/service_resolver.h",

+    "src/shared_handles.cc",

+    "src/shared_handles.h",

+    "src/sharedmem_ipc_client.cc",

+    "src/sharedmem_ipc_client.h",

+    "src/sharedmem_ipc_server.cc",

+    "src/sharedmem_ipc_server.h",

+    "src/sid.cc",

+    "src/sid.h",

+    "src/sync_dispatcher.cc",

+    "src/sync_dispatcher.h",

+    "src/sync_interception.cc",

+    "src/sync_interception.h",

+    "src/sync_policy.cc",

+    "src/sync_policy.h",

+    "src/target_interceptions.cc",

+    "src/target_interceptions.h",

+    "src/target_process.cc",

+    "src/target_process.h",

+    "src/target_services.cc",

+    "src/target_services.h",

+    "src/win_utils.cc",

+    "src/win_utils.h",

+    "src/win2k_threadpool.cc",

+    "src/win2k_threadpool.h",

+    "src/window.cc",

+    "src/window.h",

+  ]

+

+  if (cpu_arch == "x64" ){

+    sources += [

+      "src/interceptors_64.cc",

+      "src/interceptors_64.h",

+      "src/resolver_64.cc",

+      "src/service_resolver_64.cc",

+      "src/Wow64_64.cc",

+    ]

+  } else if (cpu_arch == "x86") {

+    sources += [

+      "src/resolver_32.cc",

+      "src/service_resolver_32.cc",

+      "src/sidestep_resolver.cc",

+      "src/sidestep_resolver.h",

+      "src/sidestep/ia32_modrm_map.cpp",

+      "src/sidestep/ia32_opcode_map.cpp",

+      "src/sidestep/mini_disassembler_types.h",

+      "src/sidestep/mini_disassembler.cpp",

+      "src/sidestep/mini_disassembler.h",

+      "src/sidestep/preamble_patcher_with_stub.cpp",

+      "src/sidestep/preamble_patcher.h",

+      "src/Wow64.cc",

+      "src/Wow64.h",

+    ]

+  }

+

+  deps = [

+    ":copy_wow_helper",

+    "//base",

+  ]

+}

+

+if (cpu_arch == "x86") {

+  # Make a target that copies the wow_helper files to the out dir.

+  #

+  # TODO(brettw) we can probably just build this now that we have proper

+  # toolchain support.

+  copy("copy_wow_helper") {

+    sources = [

+      "wow_helper/wow_helper.exe",

+      "wow_helper/wow_helper.pdb",

+    ]

+    outputs = [ "$root_out_dir/{{source_file_part}}" ]

+  }

+}

+

+test("sbox_integration_tests") {

+  sources = [

+    "src/app_container_test.cc",

+    "src/file_policy_test.cc",

+    "src/handle_inheritance_test.cc",

+    "src/handle_policy_test.cc",

+    "tests/integration_tests/integration_tests_test.cc",

+    "src/handle_closer_test.cc",

+    "src/integrity_level_test.cc",

+    "src/ipc_ping_test.cc",

+    "src/named_pipe_policy_test.cc",

+    "src/policy_target_test.cc",

+    "src/process_mitigations_test.cc",

+    "src/process_policy_test.cc",

+    "src/registry_policy_test.cc",

+    "src/sync_policy_test.cc",

+    "src/sync_policy_test.h",

+    "src/unload_dll_test.cc",

+    "tests/common/controller.cc",

+    "tests/common/controller.h",

+    "tests/common/test_utils.cc",

+    "tests/common/test_utils.h",

+    "tests/integration_tests/integration_tests.cc",

+  ]

+

+  deps = [

+    ":sandbox",

+    "//testing/gtest",

+  ]

+}

+

+test("sbox_validation_tests") {

+  sources = [

+    "tests/common/controller.cc",

+    "tests/common/controller.h",

+    "tests/validation_tests/unit_tests.cc",

+    "tests/validation_tests/commands.cc",

+    "tests/validation_tests/commands.h",

+    "tests/validation_tests/suite.cc",

+  ]

+

+  deps = [

+    ":sandbox",

+    "//testing/gtest",

+  ]

+}

+

+test("sbox_unittests") {

+  sources = [

+    "src/app_container_unittest.cc",

+    "src/interception_unittest.cc",

+    "src/service_resolver_unittest.cc",

+    "src/restricted_token_unittest.cc",

+    "src/job_unittest.cc",

+    "src/sid_unittest.cc",

+    "src/policy_engine_unittest.cc",

+    "src/policy_low_level_unittest.cc",

+    "src/policy_opcodes_unittest.cc",

+    "src/ipc_unittest.cc",

+    "src/threadpool_unittest.cc",

+    "src/win_utils_unittest.cc",

+    "tests/common/test_utils.cc",

+    "tests/common/test_utils.h",

+    "tests/unit_tests/unit_tests.cc",

+  ]

+

+  deps = [

+    ":sandbox",

+    "//testing/gtest",

+  ]

+}

+

+test("sandbox_poc") {

+  sources = [

+    "sandbox_poc/main_ui_window.cc",

+    "sandbox_poc/main_ui_window.h",

+    "sandbox_poc/resource.h",

+    "sandbox_poc/sandbox.cc",

+    "sandbox_poc/sandbox.h",

+    "sandbox_poc/sandbox.ico",

+    "sandbox_poc/sandbox.rc",

+  ]

+

+  configs -= [ "//build/config/win:console" ]

+  configs += [ "//build/config/win:windowed" ]

+

+  libs = [ "comctl32.lib" ]

+

+  deps = [

+    ":sandbox",

+    ":pocdll",

+  ]

+}

+

+shared_library("pocdll") {

+  sources = [

+    "sandbox_poc/pocdll/exports.h",

+    "sandbox_poc/pocdll/fs.cc",

+    "sandbox_poc/pocdll/handles.cc",

+    "sandbox_poc/pocdll/invasive.cc",

+    "sandbox_poc/pocdll/network.cc",

+    "sandbox_poc/pocdll/pocdll.cc",

+    "sandbox_poc/pocdll/processes_and_threads.cc",

+    "sandbox_poc/pocdll/registry.cc",

+    "sandbox_poc/pocdll/spyware.cc",

+    "sandbox_poc/pocdll/utils.h",

+  ]

+

+  defines = [ "POCDLL_EXPORTS" ]

+}

diff --git a/sql/BUILD.gn b/sql/BUILD.gn
index 2b50eac..d672841 100644
--- a/sql/BUILD.gn
+++ b/sql/BUILD.gn
@@ -22,7 +22,7 @@
   defines = [ "SQL_IMPLEMENTATION" ]
 
   if (is_win) {
-    cflags += [ "/wd4267" ]  # size_t to int.
+    cflags = [ "/wd4267" ]  # size_t to int.
   }
 
   deps = [
diff --git a/tools/gn/secondary/third_party/angle/BUILD.gn b/tools/gn/secondary/third_party/angle/BUILD.gn
index ec3fd6b2..651d42f 100644
--- a/tools/gn/secondary/third_party/angle/BUILD.gn
+++ b/tools/gn/secondary/third_party/angle/BUILD.gn
@@ -568,7 +568,7 @@
     ]
 
     if (is_debug) {
-      defines += [ "ANGLE_ENABLE_PERF" ]
+      defines = [ "ANGLE_ENABLE_PERF" ]
     }
 
     include_dirs = [ "src/libGLESv2" ]
diff --git a/webkit/child/BUILD.gn b/webkit/child/BUILD.gn
index def4037..04611e48 100644
--- a/webkit/child/BUILD.gn
+++ b/webkit/child/BUILD.gn
@@ -23,7 +23,7 @@
   configs += [ "//build/config/compiler:wexit_time_destructors" ]
   if (is_win) {
     # TODO(jschuh): crbug.com/167187 fix size_t to int truncations.
-    cflags += [ "/wd4267" ]
+    cflags = [ "/wd4267" ]
   }
 
   if (is_mac) {