From 0be639e68a52b6633f9d81ea7249dbc10598a5dd Mon Sep 17 00:00:00 2001 From: jluce50 Date: Tue, 3 Mar 2015 14:07:18 -0600 Subject: [PATCH] Close thread handle after suspend/resume (per MSDN ms684335) --- .../Native/WindowsProcessManager.cs | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/MediaBrowser.ServerApplication/Native/WindowsProcessManager.cs b/MediaBrowser.ServerApplication/Native/WindowsProcessManager.cs index f3497aef55..413e192398 100644 --- a/MediaBrowser.ServerApplication/Native/WindowsProcessManager.cs +++ b/MediaBrowser.ServerApplication/Native/WindowsProcessManager.cs @@ -29,8 +29,11 @@ namespace MediaBrowser.ServerApplication.Native static extern IntPtr OpenThread(ThreadAccess dwDesiredAccess, bool bInheritHandle, uint dwThreadId); [DllImport("kernel32.dll")] static extern uint SuspendThread(IntPtr hThread); - [DllImport("kernel32.dll")] - static extern int ResumeThread(IntPtr hThread); + [DllImport("kernel32.dll")] + static extern int ResumeThread(IntPtr hThread); + [DllImport("kernel32.dll")] + [return: MarshalAs(UnmanagedType.Bool)] + public static extern bool CloseHandle(IntPtr hObject); public static void Suspend(this Process process) { @@ -41,7 +44,8 @@ namespace MediaBrowser.ServerApplication.Native { break; } - SuspendThread(pOpenThread); + SuspendThread(pOpenThread); + CloseHandle(pOpenThread); } } public static void Resume(this Process process) @@ -52,8 +56,9 @@ namespace MediaBrowser.ServerApplication.Native if (pOpenThread == IntPtr.Zero) { break; - } - ResumeThread(pOpenThread); + } + ResumeThread(pOpenThread); + CloseHandle(pOpenThread); } } public static void Print(this Process process)