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 "remoting/host/desktop_session_proxy.h" | 5 #include "remoting/host/desktop_session_proxy.h" |
6 | 6 |
7 #include "base/compiler_specific.h" | 7 #include "base/compiler_specific.h" |
8 #include "base/logging.h" | 8 #include "base/logging.h" |
9 #include "base/platform_file.h" | 9 #include "base/platform_file.h" |
10 #include "base/process/process_handle.h" | 10 #include "base/process/process_handle.h" |
(...skipping 212 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
223 if (!client_session_control_.get()) { | 223 if (!client_session_control_.get()) { |
224 base::CloseProcessHandle(desktop_process); | 224 base::CloseProcessHandle(desktop_process); |
225 return false; | 225 return false; |
226 } | 226 } |
227 | 227 |
228 desktop_process_ = desktop_process; | 228 desktop_process_ = desktop_process; |
229 | 229 |
230 #if defined(OS_WIN) | 230 #if defined(OS_WIN) |
231 // On Windows: |desktop_process| is a valid handle, but |desktop_pipe| needs | 231 // On Windows: |desktop_process| is a valid handle, but |desktop_pipe| needs |
232 // to be duplicated from the desktop process. | 232 // to be duplicated from the desktop process. |
233 HANDLE temp_handle; | 233 base::win::ScopedHandle pipe; |
234 if (!DuplicateHandle(desktop_process_, desktop_pipe, GetCurrentProcess(), | 234 if (!DuplicateHandle(desktop_process_, desktop_pipe, GetCurrentProcess(), |
235 &temp_handle, 0, FALSE, DUPLICATE_SAME_ACCESS)) { | 235 pipe.Receive(), 0, FALSE, DUPLICATE_SAME_ACCESS)) { |
236 LOG_GETLASTERROR(ERROR) << "Failed to duplicate the desktop-to-network" | 236 LOG_GETLASTERROR(ERROR) << "Failed to duplicate the desktop-to-network" |
237 " pipe handle"; | 237 " pipe handle"; |
238 | 238 |
239 desktop_process_ = base::kNullProcessHandle; | 239 desktop_process_ = base::kNullProcessHandle; |
240 base::CloseProcessHandle(desktop_process); | 240 base::CloseProcessHandle(desktop_process); |
241 return false; | 241 return false; |
242 } | 242 } |
243 base::win::ScopedHandle pipe(temp_handle); | |
244 | 243 |
245 IPC::ChannelHandle desktop_channel_handle(pipe); | 244 IPC::ChannelHandle desktop_channel_handle(pipe); |
246 | 245 |
247 #elif defined(OS_POSIX) | 246 #elif defined(OS_POSIX) |
248 // On posix: |desktop_pipe| is a valid file descriptor. | 247 // On posix: |desktop_pipe| is a valid file descriptor. |
249 DCHECK(desktop_pipe.auto_close); | 248 DCHECK(desktop_pipe.auto_close); |
250 | 249 |
251 IPC::ChannelHandle desktop_channel_handle(std::string(), desktop_pipe); | 250 IPC::ChannelHandle desktop_channel_handle(std::string(), desktop_pipe); |
252 | 251 |
253 #else | 252 #else |
(...skipping 290 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
544 } | 543 } |
545 | 544 |
546 // static | 545 // static |
547 void DesktopSessionProxyTraits::Destruct( | 546 void DesktopSessionProxyTraits::Destruct( |
548 const DesktopSessionProxy* desktop_session_proxy) { | 547 const DesktopSessionProxy* desktop_session_proxy) { |
549 desktop_session_proxy->caller_task_runner_->DeleteSoon(FROM_HERE, | 548 desktop_session_proxy->caller_task_runner_->DeleteSoon(FROM_HERE, |
550 desktop_session_proxy); | 549 desktop_session_proxy); |
551 } | 550 } |
552 | 551 |
553 } // namespace remoting | 552 } // namespace remoting |
OLD | NEW |