diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2014-09-05 11:47:33 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2014-09-05 11:47:33 +0000 |
commit | bea3ef947a51f735d0cebb3099a5a34f44c1dd30 (patch) | |
tree | 7aab1dd8bf9df464da2e57e095895c7de6df6543 /winsup | |
parent | acc511d184cd702e171729771c80e62545f8e0b3 (diff) | |
download | newlib-bea3ef947a51f735d0cebb3099a5a34f44c1dd30.zip newlib-bea3ef947a51f735d0cebb3099a5a34f44c1dd30.tar.gz newlib-bea3ef947a51f735d0cebb3099a5a34f44c1dd30.tar.bz2 |
* exception.h (class exception): Remove unnecessary #ifdef.
* uinfo.cc (client_request_pwdgrp::client_request_pwdgrp): Fix length
counter to include trailing NUL.
* sec_auth.cc (get_user_groups): Add experimental exception handler.
(get_user_local_groups): Ditto.
Diffstat (limited to 'winsup')
-rw-r--r-- | winsup/cygwin/ChangeLog | 9 | ||||
-rw-r--r-- | winsup/cygwin/exception.h | 6 | ||||
-rw-r--r-- | winsup/cygwin/sec_auth.cc | 22 | ||||
-rw-r--r-- | winsup/cygwin/uinfo.cc | 2 |
4 files changed, 28 insertions, 11 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 7b2f2c5..2d682a9 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,5 +1,14 @@ 2014-09-05 Corinna Vinschen <corinna@vinschen.de> + * exception.h (class exception): Remove unnecessary #ifdef. + * uinfo.cc (client_request_pwdgrp::client_request_pwdgrp): Fix length + counter to include trailing NUL. + + * sec_auth.cc (get_user_groups): Add experimental exception handler. + (get_user_local_groups): Ditto. + +2014-09-05 Corinna Vinschen <corinna@vinschen.de> + * uinfo.cc (pwdgrp::fetch_account_from_windows): Handle APPLICATION PACKAGE AUTHORITY SIDs. * winlean.h (DNLEN): Raise to 31. Explain why. diff --git a/winsup/cygwin/exception.h b/winsup/cygwin/exception.h index 9e34799..3686bb0 100644 --- a/winsup/cygwin/exception.h +++ b/winsup/cygwin/exception.h @@ -126,17 +126,15 @@ public: ~exception () __attribute__ ((always_inline)) { _except_list = save; } }; -#else +#else /* __x86_64__ */ #define exception_list void typedef struct _DISPATCHER_CONTEXT *PDISPATCHER_CONTEXT; class exception { -#ifdef __x86_64__ static EXCEPTION_DISPOSITION myfault (EXCEPTION_RECORD *, exception_list *, CONTEXT *, PDISPATCHER_CONTEXT); -#endif static EXCEPTION_DISPOSITION handle (EXCEPTION_RECORD *, exception_list *, CONTEXT *, PDISPATCHER_CONTEXT); public: @@ -162,7 +160,7 @@ public: } }; -#endif /* !__x86_64 */ +#endif /* !__x86_64__ */ class cygwin_exception { diff --git a/winsup/cygwin/sec_auth.cc b/winsup/cygwin/sec_auth.cc index 3615588..eda0f82 100644 --- a/winsup/cygwin/sec_auth.cc +++ b/winsup/cygwin/sec_auth.cc @@ -20,6 +20,7 @@ details. */ #include "fhandler.h" #include "dtable.h" #include "cygheap.h" +#include "exception.h" #include "ntdll.h" #include "tls_pbuf.h" #include <lm.h> @@ -255,9 +256,13 @@ get_user_groups (WCHAR *logonserver, cygsidlist &grp_list, DWORD cnt, tot, len; NET_API_STATUS ret; - /* Look only on logonserver */ - ret = NetUserGetGroups (logonserver, user, 0, (LPBYTE *) &buf, - MAX_PREFERRED_LENGTH, &cnt, &tot); + { + /* Experimental SEH */ + exception protect; + /* Look only on logonserver */ + ret = NetUserGetGroups (logonserver, user, 0, (LPBYTE *) &buf, + MAX_PREFERRED_LENGTH, &cnt, &tot); + } if (ret) { __seterrno_from_win_error (ret); @@ -306,9 +311,14 @@ get_user_local_groups (PWCHAR logonserver, PWCHAR domain, DWORD cnt, tot; NET_API_STATUS ret; - ret = NetUserGetLocalGroups (logonserver, user, 0, LG_INCLUDE_INDIRECT, - (LPBYTE *) &buf, MAX_PREFERRED_LENGTH, - &cnt, &tot); + { + /* Experimental SEH */ + exception protect; + + ret = NetUserGetLocalGroups (logonserver, user, 0, LG_INCLUDE_INDIRECT, + (LPBYTE *) &buf, MAX_PREFERRED_LENGTH, + &cnt, &tot); + } if (ret) { __seterrno_from_win_error (ret); diff --git a/winsup/cygwin/uinfo.cc b/winsup/cygwin/uinfo.cc index 9d6c7df..12d5069 100644 --- a/winsup/cygwin/uinfo.cc +++ b/winsup/cygwin/uinfo.cc @@ -1968,7 +1968,7 @@ client_request_pwdgrp::client_request_pwdgrp (fetch_user_arg_t &arg, bool group) break; case NAME_arg: p = stpcpy (_parameters.in.arg.name, arg.name); - len = p - _parameters.in.arg.name; + len = p - _parameters.in.arg.name + 1; break; case ID_arg: _parameters.in.arg.id = arg.id; |