OLD | NEW |
---|---|
(Empty) | |
1 // Copyright (c) 2011 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 #include "content/browser/handle_enumerator_win.h" | |
6 | |
7 #include <windows.h> | |
8 | |
9 #include "base/logging.h" | |
10 #include "base/process.h" | |
11 #include "base/process_util.h" | |
12 #include "base/win/windows_version.h" | |
13 #include "content/browser/browser_child_process_host.h" | |
14 #include "content/browser/browser_thread.h" | |
15 #include "content/common/result_codes.h" | |
16 | |
17 void HandleEnumerator::EnumerateHandles() { | |
18 ULONG pid = 0; | |
19 pid = ::GetProcessId(handle_); | |
20 if (!pid) | |
21 return; | |
22 ULONG handle_info_size = 0x10000; | |
23 HMODULE ntdll = ::GetModuleHandle(kNtdllDllName); | |
24 if (!ntdll) | |
25 return; | |
26 | |
27 NTQUERYSYSTEMINFORMATION NtQuerySystemInformation = | |
28 reinterpret_cast<NTQUERYSYSTEMINFORMATION>( | |
29 GetProcAddress(ntdll, "NtQuerySystemInformation")); | |
30 NTQUERYOBJECT NtQueryObject = | |
31 reinterpret_cast<NTQUERYOBJECT>(GetProcAddress(ntdll, "NtQueryObject")); | |
32 | |
33 if (!NtQuerySystemInformation || !NtQueryObject) | |
34 return; | |
35 | |
36 SYSTEM_HANDLE_INFORMATION_EX* handle_info = | |
37 reinterpret_cast<SYSTEM_HANDLE_INFORMATION_EX*>( | |
38 new BYTE[handle_info_size]); | |
39 while (NtQuerySystemInformation(SystemHandleInformation, | |
40 handle_info, | |
41 handle_info_size, | |
42 &handle_info_size) | |
43 == STATUS_INFO_LENGTH_MISMATCH) { | |
44 delete handle_info; | |
45 handle_info = reinterpret_cast<SYSTEM_HANDLE_INFORMATION_EX*> | |
46 (new BYTE[handle_info_size]); | |
47 } | |
48 | |
cpu_(ooo_6.6-7.5)
2011/06/08 02:23:28
leaking handle_info ?
Cris Neckar
2011/06/08 18:39:21
Done.
| |
49 string16 output = ProcessTypeString(type_); | |
50 output.append(ASCIIToUTF16(" Process - Handles at shutdown:\n")); | |
51 for (UINT i = 0; i < handle_info->NumberOfHandles; i++) { | |
52 SYSTEM_HANDLE_INFORMATION sys_handle = handle_info->Information[i]; | |
53 HANDLE handle = reinterpret_cast<HANDLE>(sys_handle.Handle); | |
54 if (sys_handle.ProcessId != pid) | |
55 continue; | |
56 | |
57 OBJECT_TYPE_INFORMATION* type_info = | |
58 reinterpret_cast<OBJECT_TYPE_INFORMATION*>( | |
59 new BYTE[sizeof(OBJECT_TYPE_INFORMATION) + kMaxHandleNameLength]); | |
60 if (NtQueryObject(handle_, ObjectTypeInformation, type_info, | |
61 sizeof(OBJECT_TYPE_INFORMATION) + kMaxHandleNameLength, NULL) < 0) | |
62 return; | |
63 | |
64 UNICODE_STRING* name = reinterpret_cast<UNICODE_STRING*>( | |
65 new BYTE[kMaxHandleNameLength]); | |
66 if (NtQueryObject(handle_, ObjectNameInformation, name, | |
67 kMaxHandleNameLength, NULL) < 0) | |
68 return; | |
69 | |
70 string16 handle_type; | |
71 string16 handle_name; | |
72 WideToUTF16(type_info->Name.Buffer, | |
73 type_info->Name.Length/2, &handle_type); | |
74 WideToUTF16(name->Buffer, name->Length/2, &handle_name); | |
75 | |
76 output += ASCIIToUTF16("["); | |
77 output += handle_type; | |
78 output += ASCIIToUTF16("] ("); | |
79 output += handle_name; | |
80 output += ASCIIToUTF16(")\n"); | |
81 output += GetAccessString(StringToHandleType(handle_type), | |
82 sys_handle.GrantedAccess); | |
83 } | |
84 LOG(INFO) << output; | |
85 } | |
86 | |
87 void HandleEnumerator::RunHandleEnumeration() { | |
88 DCHECK(status_ == Starting); | |
89 if (BrowserThread::CurrentlyOn(BrowserThread::IO)) | |
90 FindProcessOnIOThread(); | |
91 else if (BrowserThread::CurrentlyOn(BrowserThread::UI)) | |
92 FindProcessOnUIThread(); | |
93 else | |
94 BrowserThread::PostTask( | |
95 BrowserThread::IO, FROM_HERE, | |
96 NewRunnableMethod(this, | |
97 &HandleEnumerator::FindProcessOnIOThread)); | |
98 } | |
99 | |
100 void HandleEnumerator::FindProcessOnIOThread() { | |
101 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | |
102 | |
103 for (BrowserChildProcessHost::Iterator iter; !iter.Done(); ++iter) { | |
104 if (iter->handle() == handle_) { | |
105 type_ = iter->type(); | |
106 status_ = Finished; | |
107 break; | |
108 } | |
109 } | |
110 | |
111 if (status_ == Starting) { | |
112 status_ = InProgress; | |
113 BrowserThread::PostTask( | |
114 BrowserThread::UI, FROM_HERE, | |
115 NewRunnableMethod(this, | |
116 &HandleEnumerator::FindProcessOnUIThread)); | |
117 } else { | |
118 status_ = Finished; | |
119 BrowserThread::PostTask( | |
120 BrowserThread::PROCESS_LAUNCHER, FROM_HERE, | |
121 NewRunnableMethod(this, | |
122 &HandleEnumerator::EnumerateHandlesAndTerminateProcess)); | |
123 } | |
124 } | |
125 | |
126 void HandleEnumerator::FindProcessOnUIThread() { | |
127 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
128 | |
129 for (RenderProcessHost::iterator renderer_iter( | |
130 RenderProcessHost::AllHostsIterator()); !renderer_iter.IsAtEnd(); | |
131 renderer_iter.Advance()) { | |
132 RenderProcessHost* render_process_host = renderer_iter.GetCurrentValue(); | |
133 if (render_process_host->GetHandle() == handle_) { | |
134 type_ = ChildProcessInfo::RENDER_PROCESS; | |
135 status_ = Finished; | |
136 break; | |
137 } | |
138 } | |
139 | |
140 if (status_ == Starting) { | |
141 status_ = InProgress; | |
142 BrowserThread::PostTask( | |
143 BrowserThread::IO, FROM_HERE, | |
144 NewRunnableMethod(this, | |
145 &HandleEnumerator::FindProcessOnIOThread)); | |
146 } else { | |
147 status_ = Finished; | |
148 BrowserThread::PostTask( | |
149 BrowserThread::PROCESS_LAUNCHER, FROM_HERE, | |
150 NewRunnableMethod(this, | |
151 &HandleEnumerator::EnumerateHandlesAndTerminateProcess)); | |
152 } | |
153 } | |
154 | |
155 void HandleEnumerator::EnumerateHandlesAndTerminateProcess() { | |
156 HandleEnumerator::EnumerateHandles(); | |
157 base::Process process(handle_); | |
158 process.Terminate(ResultCodes::NORMAL_EXIT); | |
159 process.Close(); | |
160 } | |
161 | |
162 string16 HandleEnumerator::ProcessTypeString( | |
cpu_(ooo_6.6-7.5)
2011/06/08 02:23:28
it seems this not need to be a member function of
Cris Neckar
2011/06/08 18:39:21
Done.
| |
163 ChildProcessInfo::ProcessType process_type) { | |
164 switch (process_type) { | |
165 case ChildProcessInfo::UNKNOWN_PROCESS: | |
166 return ASCIIToUTF16("Unknown"); | |
167 case ChildProcessInfo::BROWSER_PROCESS: | |
168 return ASCIIToUTF16("Browser"); | |
169 case ChildProcessInfo::RENDER_PROCESS: | |
170 return ASCIIToUTF16("Renderer"); | |
171 case ChildProcessInfo::PLUGIN_PROCESS: | |
172 return ASCIIToUTF16("Plugin"); | |
173 case ChildProcessInfo::WORKER_PROCESS: | |
174 return ASCIIToUTF16("Worker"); | |
175 case ChildProcessInfo::NACL_LOADER_PROCESS: | |
176 return ASCIIToUTF16("NaCL Loader"); | |
177 case ChildProcessInfo::UTILITY_PROCESS: | |
178 return ASCIIToUTF16("Utility"); | |
179 case ChildProcessInfo::PROFILE_IMPORT_PROCESS: | |
180 return ASCIIToUTF16("Profile Import"); | |
181 case ChildProcessInfo::ZYGOTE_PROCESS: | |
182 return ASCIIToUTF16("Zygote"); | |
183 case ChildProcessInfo::SANDBOX_HELPER_PROCESS: | |
184 return ASCIIToUTF16("Sandbox Helper"); | |
185 case ChildProcessInfo::NACL_BROKER_PROCESS: | |
186 return ASCIIToUTF16("NaCL Broker"); | |
187 case ChildProcessInfo::GPU_PROCESS: | |
188 return ASCIIToUTF16("GPU"); | |
189 case ChildProcessInfo::PPAPI_PLUGIN_PROCESS: | |
190 return ASCIIToUTF16("Pepper Plugin"); | |
191 case ChildProcessInfo::PPAPI_BROKER_PROCESS: | |
192 return ASCIIToUTF16("Pepper Broker"); | |
193 default: | |
194 return string16(); | |
195 } | |
196 } | |
197 | |
198 HandleType HandleEnumerator::StringToHandleType(string16 type) { | |
199 if (!type.compare(ASCIIToUTF16("Process"))) | |
200 return ProcessHandle; | |
201 else if (!type.compare(ASCIIToUTF16("Thread"))) | |
202 return ThreadHandle; | |
203 else if (!type.compare(ASCIIToUTF16("File"))) | |
204 return FileHandle; | |
205 else if (!type.compare(ASCIIToUTF16("Directory"))) | |
206 return DirectoryHandle; | |
207 else if (!type.compare(ASCIIToUTF16("Key"))) | |
208 return KeyHandle; | |
209 else if (!type.compare(ASCIIToUTF16("WindowStation"))) | |
210 return WindowStationHandle; | |
211 else if (!type.compare(ASCIIToUTF16("Desktop"))) | |
212 return DesktopHandle; | |
213 else if (!type.compare(ASCIIToUTF16("Service"))) | |
214 return ServiceHandle; | |
215 else if (!type.compare(ASCIIToUTF16("Mutex"))) | |
216 return MutexHandle; | |
217 else if (!type.compare(ASCIIToUTF16("Semaphore"))) | |
218 return SemaphoreHandle; | |
219 else if (!type.compare(ASCIIToUTF16("Event"))) | |
220 return EventHandle; | |
221 else if (!type.compare(ASCIIToUTF16("Timer"))) | |
222 return TimerHandle; | |
223 else if (!type.compare(ASCIIToUTF16("NamedPipe"))) | |
224 return NamedPipeHandle; | |
225 else if (!type.compare(ASCIIToUTF16("JobObject"))) | |
226 return JobHandle; | |
227 else if (!type.compare(ASCIIToUTF16("FileMap"))) | |
228 return FileMapHandle; | |
229 return OtherHandle; | |
230 } | |
231 | |
232 string16 HandleEnumerator::GetAccessString(HandleType handle_type, | |
233 ACCESS_MASK access) { | |
cpu_(ooo_6.6-7.5)
2011/06/08 02:23:28
function does not seem to need be member of the cl
Cris Neckar
2011/06/08 18:39:21
Done.
| |
234 string16 output; | |
235 if (access & GENERIC_READ) | |
236 output.append(ASCIIToUTF16("\tGENERIC_READ\n")); | |
237 if (access & GENERIC_WRITE) | |
238 output.append(ASCIIToUTF16("\tGENERIC_WRITE\n")); | |
239 if (access & GENERIC_EXECUTE) | |
240 output.append(ASCIIToUTF16("\tGENERIC_EXECUTE\n")); | |
241 if (access & GENERIC_ALL) | |
242 output.append(ASCIIToUTF16("\tGENERIC_ALL\n")); | |
243 if (access & DELETE) | |
244 output.append(ASCIIToUTF16("\tDELETE\n")); | |
245 if (access & READ_CONTROL) | |
246 output.append(ASCIIToUTF16("\tREAD_CONTROL\n")); | |
247 if (access & WRITE_DAC) | |
248 output.append(ASCIIToUTF16("\tWRITE_DAC\n")); | |
249 if (access & WRITE_OWNER) | |
250 output.append(ASCIIToUTF16("\tWRITE_OWNER\n")); | |
251 if (access & SYNCHRONIZE) | |
252 output.append(ASCIIToUTF16("\tSYNCHRONIZE\n")); | |
253 | |
254 switch (handle_type) { | |
255 case ProcessHandle: | |
256 if (access & PROCESS_CREATE_PROCESS) | |
257 output.append(ASCIIToUTF16("\tPROCESS_CREATE_PROCESS\n")); | |
258 if (access & PROCESS_CREATE_THREAD) | |
259 output.append(ASCIIToUTF16("\tPROCESS_CREATE_THREAD\n")); | |
260 if (access & PROCESS_DUP_HANDLE) | |
261 output.append(ASCIIToUTF16("\tPROCESS_DUP_HANDLE\n")); | |
262 if (access & PROCESS_QUERY_INFORMATION) | |
263 output.append(ASCIIToUTF16("\tPROCESS_QUERY_INFORMATION\n")); | |
264 if (access & PROCESS_QUERY_LIMITED_INFORMATION) | |
265 output.append(ASCIIToUTF16("\tPROCESS_QUERY_LIMITED_INFORMATION\n")); | |
266 if (access & PROCESS_SET_INFORMATION) | |
267 output.append(ASCIIToUTF16("\tPROCESS_SET_INFORMATION\n")); | |
268 if (access & PROCESS_SET_QUOTA) | |
269 output.append(ASCIIToUTF16("\tPROCESS_SET_QUOTA\n")); | |
270 if (access & PROCESS_SUSPEND_RESUME) | |
271 output.append(ASCIIToUTF16("\tPROCESS_SUSPEND_RESUME\n")); | |
272 if (access & PROCESS_TERMINATE) | |
273 output.append(ASCIIToUTF16("\tPROCESS_TERMINATE\n")); | |
274 if (access & PROCESS_VM_OPERATION) | |
275 output.append(ASCIIToUTF16("\tPROCESS_VM_OPERATION\n")); | |
276 if (access & PROCESS_VM_READ) | |
277 output.append(ASCIIToUTF16("\tPROCESS_VM_READ\n")); | |
278 if (access & PROCESS_VM_WRITE) | |
279 output.append(ASCIIToUTF16("\tPROCESS_VM_WRITE\n")); | |
280 break; | |
281 case ThreadHandle: | |
282 if (access & THREAD_DIRECT_IMPERSONATION) | |
283 output.append(ASCIIToUTF16("\tTHREAD_DIRECT_IMPERSONATION\n")); | |
284 if (access & THREAD_GET_CONTEXT) | |
285 output.append(ASCIIToUTF16("\tTHREAD_GET_CONTEXT\n")); | |
286 if (access & THREAD_IMPERSONATE) | |
287 output.append(ASCIIToUTF16("\tTHREAD_IMPERSONATE\n")); | |
288 if (access & THREAD_QUERY_INFORMATION ) | |
289 output.append(ASCIIToUTF16("\tTHREAD_QUERY_INFORMATION\n")); | |
290 if (access & THREAD_QUERY_LIMITED_INFORMATION) | |
291 output.append(ASCIIToUTF16("\tTHREAD_QUERY_LIMITED_INFORMATION\n")); | |
292 if (access & THREAD_SET_CONTEXT) | |
293 output.append(ASCIIToUTF16("\tTHREAD_SET_CONTEXT\n")); | |
294 if (access & THREAD_SET_INFORMATION) | |
295 output.append(ASCIIToUTF16("\tTHREAD_SET_INFORMATION\n")); | |
296 if (access & THREAD_SET_LIMITED_INFORMATION) | |
297 output.append(ASCIIToUTF16("\tTHREAD_SET_LIMITED_INFORMATION\n")); | |
298 if (access & THREAD_SET_THREAD_TOKEN) | |
299 output.append(ASCIIToUTF16("\tTHREAD_SET_THREAD_TOKEN\n")); | |
300 if (access & THREAD_SUSPEND_RESUME) | |
301 output.append(ASCIIToUTF16("\tTHREAD_SUSPEND_RESUME\n")); | |
302 if (access & THREAD_TERMINATE) | |
303 output.append(ASCIIToUTF16("\tTHREAD_TERMINATE\n")); | |
304 break; | |
305 case FileHandle: | |
306 if (access & FILE_APPEND_DATA) | |
307 output.append(ASCIIToUTF16("\tFILE_APPEND_DATA\n")); | |
308 if (access & FILE_EXECUTE) | |
309 output.append(ASCIIToUTF16("\tFILE_EXECUTE\n")); | |
310 if (access & FILE_READ_ATTRIBUTES) | |
311 output.append(ASCIIToUTF16("\tFILE_READ_ATTRIBUTES\n")); | |
312 if (access & FILE_READ_DATA) | |
313 output.append(ASCIIToUTF16("\tFILE_READ_DATA\n")); | |
314 if (access & FILE_READ_EA) | |
315 output.append(ASCIIToUTF16("\tFILE_READ_EA\n")); | |
316 if (access & FILE_WRITE_ATTRIBUTES) | |
317 output.append(ASCIIToUTF16("\tFILE_WRITE_ATTRIBUTES\n")); | |
318 if (access & FILE_WRITE_DATA) | |
319 output.append(ASCIIToUTF16("\tFILE_WRITE_DATA\n")); | |
320 if (access & FILE_WRITE_EA) | |
321 output.append(ASCIIToUTF16("\tFILE_WRITE_EA\n")); | |
322 if (access & FILE_WRITE_EA) | |
323 output.append(ASCIIToUTF16("\tFILE_WRITE_EA\n")); | |
324 break; | |
325 case DirectoryHandle: | |
326 if (access & FILE_ADD_FILE) | |
327 output.append(ASCIIToUTF16("\tFILE_ADD_FILE\n")); | |
328 if (access & FILE_ADD_SUBDIRECTORY) | |
329 output.append(ASCIIToUTF16("\tFILE_ADD_SUBDIRECTORY\n")); | |
330 if (access & FILE_APPEND_DATA) | |
331 output.append(ASCIIToUTF16("\tFILE_APPEND_DATA\n")); | |
332 if (access & FILE_DELETE_CHILD) | |
333 output.append(ASCIIToUTF16("\tFILE_DELETE_CHILD\n")); | |
334 if (access & FILE_LIST_DIRECTORY) | |
335 output.append(ASCIIToUTF16("\tFILE_LIST_DIRECTORY\n")); | |
336 if (access & FILE_READ_DATA) | |
337 output.append(ASCIIToUTF16("\tFILE_READ_DATA\n")); | |
338 if (access & FILE_TRAVERSE) | |
339 output.append(ASCIIToUTF16("\tFILE_TRAVERSE\n")); | |
340 if (access & FILE_WRITE_DATA) | |
341 output.append(ASCIIToUTF16("\tFILE_WRITE_DATA\n")); | |
342 break; | |
343 case KeyHandle: | |
344 if (access & KEY_CREATE_LINK) | |
345 output.append(ASCIIToUTF16("\tKEY_CREATE_LINK\n")); | |
346 if (access & KEY_CREATE_SUB_KEY) | |
347 output.append(ASCIIToUTF16("\tKEY_CREATE_SUB_KEY\n")); | |
348 if (access & KEY_ENUMERATE_SUB_KEYS) | |
349 output.append(ASCIIToUTF16("\tKEY_ENUMERATE_SUB_KEYS\n")); | |
350 if (access & KEY_EXECUTE) | |
351 output.append(ASCIIToUTF16("\tKEY_EXECUTE\n")); | |
352 if (access & KEY_NOTIFY) | |
353 output.append(ASCIIToUTF16("\tKEY_NOTIFY\n")); | |
354 if (access & KEY_QUERY_VALUE) | |
355 output.append(ASCIIToUTF16("\tKEY_QUERY_VALUE\n")); | |
356 if (access & KEY_READ) | |
357 output.append(ASCIIToUTF16("\tKEY_READ\n")); | |
358 if (access & KEY_SET_VALUE) | |
359 output.append(ASCIIToUTF16("\tKEY_SET_VALUE\n")); | |
360 if (access & KEY_WOW64_32KEY) | |
361 output.append(ASCIIToUTF16("\tKEY_WOW64_32KEY\n")); | |
362 if (access & KEY_WOW64_64KEY) | |
363 output.append(ASCIIToUTF16("\tKEY_WOW64_64KEY\n")); | |
364 break; | |
365 case WindowStationHandle: | |
366 if (access & WINSTA_ACCESSCLIPBOARD) | |
367 output.append(ASCIIToUTF16("\tWINSTA_ACCESSCLIPBOARD\n")); | |
368 if (access & WINSTA_ACCESSGLOBALATOMS) | |
369 output.append(ASCIIToUTF16("\tWINSTA_ACCESSGLOBALATOMS\n")); | |
370 if (access & WINSTA_CREATEDESKTOP) | |
371 output.append(ASCIIToUTF16("\tWINSTA_CREATEDESKTOP\n")); | |
372 if (access & WINSTA_ENUMDESKTOPS) | |
373 output.append(ASCIIToUTF16("\tWINSTA_ENUMDESKTOPS\n")); | |
374 if (access & WINSTA_ENUMERATE) | |
375 output.append(ASCIIToUTF16("\tWINSTA_ENUMERATE\n")); | |
376 if (access & WINSTA_EXITWINDOWS) | |
377 output.append(ASCIIToUTF16("\tWINSTA_EXITWINDOWS\n")); | |
378 if (access & WINSTA_READATTRIBUTES) | |
379 output.append(ASCIIToUTF16("\tWINSTA_READATTRIBUTES\n")); | |
380 if (access & WINSTA_READSCREEN) | |
381 output.append(ASCIIToUTF16("\tWINSTA_READSCREEN\n")); | |
382 if (access & WINSTA_WRITEATTRIBUTES) | |
383 output.append(ASCIIToUTF16("\tWINSTA_WRITEATTRIBUTES\n")); | |
384 break; | |
385 case DesktopHandle: | |
386 if (access & DESKTOP_CREATEMENU) | |
387 output.append(ASCIIToUTF16("\tDESKTOP_CREATEMENU\n")); | |
388 if (access & DESKTOP_CREATEWINDOW) | |
389 output.append(ASCIIToUTF16("\tDESKTOP_CREATEWINDOW\n")); | |
390 if (access & DESKTOP_ENUMERATE) | |
391 output.append(ASCIIToUTF16("\tDESKTOP_ENUMERATE\n")); | |
392 if (access & DESKTOP_HOOKCONTROL) | |
393 output.append(ASCIIToUTF16("\tDESKTOP_HOOKCONTROL\n")); | |
394 if (access & DESKTOP_JOURNALPLAYBACK) | |
395 output.append(ASCIIToUTF16("\tDESKTOP_JOURNALPLAYBACK\n")); | |
396 if (access & DESKTOP_JOURNALRECORD) | |
397 output.append(ASCIIToUTF16("\tDESKTOP_JOURNALRECORD\n")); | |
398 if (access & DESKTOP_READOBJECTS) | |
399 output.append(ASCIIToUTF16("\tDESKTOP_READOBJECTS\n")); | |
400 if (access & DESKTOP_SWITCHDESKTOP) | |
401 output.append(ASCIIToUTF16("\tDESKTOP_SWITCHDESKTOP\n")); | |
402 if (access & DESKTOP_WRITEOBJECTS) | |
403 output.append(ASCIIToUTF16("\tDESKTOP_WRITEOBJECTS\n")); | |
404 break; | |
405 case ServiceHandle: | |
406 if (access & SC_MANAGER_CREATE_SERVICE) | |
407 output.append(ASCIIToUTF16("\tSC_MANAGER_CREATE_SERVICE\n")); | |
408 if (access & SC_MANAGER_CONNECT) | |
409 output.append(ASCIIToUTF16("\tSC_MANAGER_CONNECT\n")); | |
410 if (access & SC_MANAGER_ENUMERATE_SERVICE ) | |
411 output.append(ASCIIToUTF16("\tSC_MANAGER_ENUMERATE_SERVICE\n")); | |
412 if (access & SC_MANAGER_LOCK) | |
413 output.append(ASCIIToUTF16("\tSC_MANAGER_LOCK\n")); | |
414 if (access & SC_MANAGER_MODIFY_BOOT_CONFIG ) | |
415 output.append(ASCIIToUTF16("\tSC_MANAGER_MODIFY_BOOT_CONFIG\n")); | |
416 if (access & SC_MANAGER_QUERY_LOCK_STATUS ) | |
417 output.append(ASCIIToUTF16("\tSC_MANAGER_QUERY_LOCK_STATUS\n")); | |
418 break; | |
419 case EventHandle: | |
420 if (access & EVENT_MODIFY_STATE) | |
421 output.append(ASCIIToUTF16("\tEVENT_MODIFY_STATE\n")); | |
422 break; | |
423 case MutexHandle: | |
424 if (access & MUTEX_MODIFY_STATE) | |
425 output.append(ASCIIToUTF16("\tMUTEX_MODIFY_STATE\n")); | |
426 break; | |
427 case SemaphoreHandle: | |
428 if (access & SEMAPHORE_MODIFY_STATE) | |
429 output.append(ASCIIToUTF16("\tSEMAPHORE_MODIFY_STATE\n")); | |
430 break; | |
431 case TimerHandle: | |
432 if (access & TIMER_MODIFY_STATE) | |
433 output.append(ASCIIToUTF16("\tTIMER_MODIFY_STATE\n")); | |
434 if (access & TIMER_QUERY_STATE) | |
435 output.append(ASCIIToUTF16("\tTIMER_QUERY_STATE\n")); | |
436 break; | |
437 case NamedPipeHandle: | |
438 if (access & PIPE_ACCESS_INBOUND) | |
439 output.append(ASCIIToUTF16("\tPIPE_ACCESS_INBOUND\n")); | |
440 if (access & PIPE_ACCESS_OUTBOUND) | |
441 output.append(ASCIIToUTF16("\tPIPE_ACCESS_OUTBOUND\n")); | |
442 break; | |
443 case JobHandle: | |
444 if (access & JOB_OBJECT_ASSIGN_PROCESS) | |
445 output.append(ASCIIToUTF16("\tJOB_OBJECT_ASSIGN_PROCESS\n")); | |
446 if (access & JOB_OBJECT_QUERY) | |
447 output.append(ASCIIToUTF16("\tJOB_OBJECT_QUERY\n")); | |
448 if (access & JOB_OBJECT_SET_ATTRIBUTES) | |
449 output.append(ASCIIToUTF16("\tJOB_OBJECT_SET_ATTRIBUTES\n")); | |
450 if (access & JOB_OBJECT_SET_SECURITY_ATTRIBUTES) | |
451 output.append(ASCIIToUTF16("\tJOB_OBJECT_SET_SECURITY_ATTRIBUTES\n")); | |
452 if (access & JOB_OBJECT_TERMINATE) | |
453 output.append(ASCIIToUTF16("\tJOB_OBJECT_TERMINATE\n")); | |
454 break; | |
455 case FileMapHandle: | |
456 if (access & FILE_MAP_EXECUTE) | |
457 output.append(ASCIIToUTF16("\tFILE_MAP_EXECUTE\n")); | |
458 if (access & FILE_MAP_READ) | |
459 output.append(ASCIIToUTF16("\tFILE_MAP_READ\n")); | |
460 if (access & FILE_MAP_WRITE) | |
461 output.append(ASCIIToUTF16("\tFILE_MAP_WRITE\n")); | |
462 break; | |
463 } | |
464 return output; | |
465 } | |
466 | |
OLD | NEW |