Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(492)

Side by Side Diff: content/browser/handle_enumerator_win.cc

Issue 7054080: Add a flag to print the handles held by a child process when it shuts down. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 9 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698