From: Corinna Vinschen Date: Mon, 15 Dec 2008 18:05:50 +0000 (+0000) Subject: * setpwd.cc (client_request_setpwd::serve): Don't treat removing X-Git-Tag: newlib-1_17_0~27 X-Git-Url: https://sourceware.org/git/?a=commitdiff_plain;h=faded04e6c1891797b36fd17166ed03ad6de8d28;p=newlib-cygwin.git * setpwd.cc (client_request_setpwd::serve): Don't treat removing non-existant private data as error. --- diff --git a/winsup/cygserver/ChangeLog b/winsup/cygserver/ChangeLog index 04054741b..3f8566fd5 100644 --- a/winsup/cygserver/ChangeLog +++ b/winsup/cygserver/ChangeLog @@ -1,3 +1,8 @@ +2008-12-15 Corinna Vinschen + + * setpwd.cc (client_request_setpwd::serve): Don't treat removing + non-existant private data as error. + 2008-12-15 Corinna Vinschen * setpwd.cc (client_request_setpwd::serve): Explicitely erase password diff --git a/winsup/cygserver/setpwd.cc b/winsup/cygserver/setpwd.cc index 70d96cd57..8125fd25a 100644 --- a/winsup/cygserver/setpwd.cc +++ b/winsup/cygserver/setpwd.cc @@ -92,7 +92,9 @@ client_request_setpwd::serve (transport_layer_base *const conn, status = LsaStorePrivateData (lsa, &key, data.Length ? &data : NULL); if (data.Length) memset (data.Buffer, 0, data.Length); - if (NT_SUCCESS (status)) + /* Success or we're trying to remove a password entry which doesn't exist. */ + if (NT_SUCCESS (status) + || (data.Length == 0 && status == STATUS_OBJECT_NAME_NOT_FOUND)) error_code (0); else error_code (LsaNtStatusToWinError (status));