| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "base/process/launch.h" | 5 #include "base/process/launch.h" |
| 6 | 6 |
| 7 #include <fcntl.h> | 7 #include <fcntl.h> |
| 8 #include <io.h> | 8 #include <io.h> |
| 9 #include <shellapi.h> | 9 #include <shellapi.h> |
| 10 #include <windows.h> | 10 #include <windows.h> |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 56 // that case, we don't want to open CONOUT$, because its output | 56 // that case, we don't want to open CONOUT$, because its output |
| 57 // likely does not go anywhere. | 57 // likely does not go anywhere. |
| 58 // | 58 // |
| 59 // We don't use GetStdHandle() to check stdout/stderr here because | 59 // We don't use GetStdHandle() to check stdout/stderr here because |
| 60 // it can return dangling IDs of handles that were never inherited | 60 // it can return dangling IDs of handles that were never inherited |
| 61 // by this process. These IDs could have been reused by the time | 61 // by this process. These IDs could have been reused by the time |
| 62 // this function is called. The CRT checks the validity of | 62 // this function is called. The CRT checks the validity of |
| 63 // stdout/stderr on startup (before the handle IDs can be reused). | 63 // stdout/stderr on startup (before the handle IDs can be reused). |
| 64 // _fileno(stdout) will return -2 (_NO_CONSOLE_FILENO) if stdout was | 64 // _fileno(stdout) will return -2 (_NO_CONSOLE_FILENO) if stdout was |
| 65 // invalid. | 65 // invalid. |
| 66 if (_fileno(stdout) >= 0 || _fileno(stderr) >= 0) | 66 if (_fileno(stdout) >= 0 || _fileno(stderr) >= 0) { |
| 67 return; | 67 // _fileno was broken for SUBSYSTEM:WINDOWS from VS2010 to VS2012/2013. |
| 68 // http://crbug.com/358267. Confirm that the underlying HANDLE is valid |
| 69 // before aborting. |
| 70 |
| 71 // This causes NaCl tests to hang on XP for reasons unclear, perhaps due |
| 72 // to not being able to inherit handles. Since it's only for debugging, |
| 73 // and redirecting still works, punt for now. |
| 74 if (base::win::GetVersion() < base::win::VERSION_VISTA) |
| 75 return; |
| 76 |
| 77 intptr_t stdout_handle = _get_osfhandle(_fileno(stdout)); |
| 78 intptr_t stderr_handle = _get_osfhandle(_fileno(stderr)); |
| 79 if (stdout_handle >= 0 || stderr_handle >= 0) |
| 80 return; |
| 81 } |
| 68 | 82 |
| 69 if (!AttachConsole(ATTACH_PARENT_PROCESS)) { | 83 if (!AttachConsole(ATTACH_PARENT_PROCESS)) { |
| 70 unsigned int result = GetLastError(); | 84 unsigned int result = GetLastError(); |
| 71 // Was probably already attached. | 85 // Was probably already attached. |
| 72 if (result == ERROR_ACCESS_DENIED) | 86 if (result == ERROR_ACCESS_DENIED) |
| 73 return; | 87 return; |
| 74 // Don't bother creating a new console for each child process if the | 88 // Don't bother creating a new console for each child process if the |
| 75 // parent process is invalid (eg: crashed). | 89 // parent process is invalid (eg: crashed). |
| 76 if (result == ERROR_GEN_FAILURE) | 90 if (result == ERROR_GEN_FAILURE) |
| 77 return; | 91 return; |
| (...skipping 281 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 359 WaitForSingleObject(proc_info.process_handle(), INFINITE); | 373 WaitForSingleObject(proc_info.process_handle(), INFINITE); |
| 360 | 374 |
| 361 return true; | 375 return true; |
| 362 } | 376 } |
| 363 | 377 |
| 364 void RaiseProcessToHighPriority() { | 378 void RaiseProcessToHighPriority() { |
| 365 SetPriorityClass(GetCurrentProcess(), HIGH_PRIORITY_CLASS); | 379 SetPriorityClass(GetCurrentProcess(), HIGH_PRIORITY_CLASS); |
| 366 } | 380 } |
| 367 | 381 |
| 368 } // namespace base | 382 } // namespace base |
| OLD | NEW |