| OLD | NEW |
| (Empty) |
| 1 // Copyright (c) 2010 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 #ifndef SANDBOX_SRC_PROCESS_THREAD_DISPATCHER_H_ | |
| 6 #define SANDBOX_SRC_PROCESS_THREAD_DISPATCHER_H_ | |
| 7 | |
| 8 #include <stdint.h> | |
| 9 | |
| 10 #include "base/macros.h" | |
| 11 #include "base/strings/string16.h" | |
| 12 #include "sandbox/win/src/crosscall_server.h" | |
| 13 #include "sandbox/win/src/sandbox_policy_base.h" | |
| 14 | |
| 15 namespace sandbox { | |
| 16 | |
| 17 // This class handles process and thread-related IPC calls. | |
| 18 class ThreadProcessDispatcher : public Dispatcher { | |
| 19 public: | |
| 20 explicit ThreadProcessDispatcher(PolicyBase* policy_base); | |
| 21 ~ThreadProcessDispatcher() override {} | |
| 22 | |
| 23 // Dispatcher interface. | |
| 24 bool SetupService(InterceptionManager* manager, int service) override; | |
| 25 | |
| 26 private: | |
| 27 // Processes IPC requests coming from calls to NtOpenThread() in the target. | |
| 28 bool NtOpenThread(IPCInfo* ipc, uint32_t desired_access, uint32_t thread_id); | |
| 29 | |
| 30 // Processes IPC requests coming from calls to NtOpenProcess() in the target. | |
| 31 bool NtOpenProcess(IPCInfo* ipc, | |
| 32 uint32_t desired_access, | |
| 33 uint32_t process_id); | |
| 34 | |
| 35 // Processes IPC requests from calls to NtOpenProcessToken() in the target. | |
| 36 bool NtOpenProcessToken(IPCInfo* ipc, | |
| 37 HANDLE process, | |
| 38 uint32_t desired_access); | |
| 39 | |
| 40 // Processes IPC requests from calls to NtOpenProcessTokenEx() in the target. | |
| 41 bool NtOpenProcessTokenEx(IPCInfo* ipc, | |
| 42 HANDLE process, | |
| 43 uint32_t desired_access, | |
| 44 uint32_t attributes); | |
| 45 | |
| 46 // Processes IPC requests coming from calls to CreateProcessW() in the target. | |
| 47 bool CreateProcessW(IPCInfo* ipc, | |
| 48 base::string16* name, | |
| 49 base::string16* cmd_line, | |
| 50 base::string16* cur_dir, | |
| 51 CountedBuffer* info); | |
| 52 | |
| 53 // Processes IPC requests coming from calls to CreateThread() in the target. | |
| 54 bool CreateThread(IPCInfo* ipc, | |
| 55 SIZE_T stack_size, | |
| 56 LPTHREAD_START_ROUTINE start_address, | |
| 57 LPVOID parameter, | |
| 58 DWORD creation_flags); | |
| 59 | |
| 60 PolicyBase* policy_base_; | |
| 61 DISALLOW_COPY_AND_ASSIGN(ThreadProcessDispatcher); | |
| 62 }; | |
| 63 | |
| 64 } // namespace sandbox | |
| 65 | |
| 66 #endif // SANDBOX_SRC_PROCESS_THREAD_DISPATCHER_H_ | |
| OLD | NEW |