[Wine-patches] Do not fail if service database is locked.

Alexander Morozov =?iso-8859-1?q?amorozov_=CE=C1_etersoft=2Eru?=
Пн Апр 27 15:45:06 MSD 2009


У usbhub.sys иногда может не получиться запустить драйвер, так как
в это время происходит запуск сервиса (а именно winedevice.exe Usbhub).
Патч заставляет usbhub.sys попробовать запустить драйвер ещё раз.
----------- следующая часть -----------
From 88d47635cb82a362c910ef92f20e18bd4fe2c30f Mon Sep 17 00:00:00 2001
From: Alexander Morozov <amorozov на etersoft.ru>
Date: Tue, 7 Apr 2009 12:50:12 +0400
Subject: [PATCH] Do not fail if service database is locked.

---
 dlls/ntoskrnl.exe/ntoskrnl.c |   15 ++++++++++++---
 dlls/usbhub.sys/usbhub.c     |   15 ++++++++++++---
 2 files changed, 24 insertions(+), 6 deletions(-)

diff --git a/dlls/ntoskrnl.exe/ntoskrnl.c b/dlls/ntoskrnl.exe/ntoskrnl.c
index e8e9c68..b7cf97b 100644
--- a/dlls/ntoskrnl.exe/ntoskrnl.c
+++ b/dlls/ntoskrnl.exe/ntoskrnl.c
@@ -173,9 +173,18 @@ static BOOL start_service( WCHAR *name )
         return FALSE;
     }
 
-    ret = StartServiceW( service, 0, NULL );
-    if (!ret && ERROR_SERVICE_ALREADY_RUNNING == GetLastError())
-        ret = TRUE;
+    do {
+        ret = StartServiceW( service, 0, NULL );
+        if (!ret)
+        {
+            if (ERROR_SERVICE_ALREADY_RUNNING == GetLastError())
+                ret = TRUE;
+            else if (ERROR_SERVICE_DATABASE_LOCKED == GetLastError())
+                Sleep( 100 );
+            else
+                break;
+        }
+    } while (!ret);
 
     CloseServiceHandle( service );
     CloseServiceHandle( scm );
diff --git a/dlls/usbhub.sys/usbhub.c b/dlls/usbhub.sys/usbhub.c
index 6dae806..a6f80b1 100644
--- a/dlls/usbhub.sys/usbhub.c
+++ b/dlls/usbhub.sys/usbhub.c
@@ -351,9 +351,18 @@ static BOOL start_service( const WCHAR *name )
         return FALSE;
     }
 
-    ret = StartServiceW( service, 0, NULL );
-    if (!ret && ERROR_SERVICE_ALREADY_RUNNING == GetLastError())
-        ret = TRUE;
+    do {
+        ret = StartServiceW( service, 0, NULL );
+        if (!ret)
+        {
+            if (ERROR_SERVICE_ALREADY_RUNNING == GetLastError())
+                ret = TRUE;
+            else if (ERROR_SERVICE_DATABASE_LOCKED == GetLastError())
+                Sleep( 100 );
+            else
+                break;
+        }
+    } while (!ret);
 
     CloseServiceHandle( service );
     CloseServiceHandle( scm );
-- 
1.6.1.3.GIT



Подробная информация о списке рассылки Wine-patches