Chromium Code Reviews| 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 |