aboutsummaryrefslogtreecommitdiff
path: root/winsup
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2014-09-05 11:47:33 +0000
committerCorinna Vinschen <corinna@vinschen.de>2014-09-05 11:47:33 +0000
commitbea3ef947a51f735d0cebb3099a5a34f44c1dd30 (patch)
tree7aab1dd8bf9df464da2e57e095895c7de6df6543 /winsup
parentacc511d184cd702e171729771c80e62545f8e0b3 (diff)
downloadnewlib-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/ChangeLog9
-rw-r--r--winsup/cygwin/exception.h6
-rw-r--r--winsup/cygwin/sec_auth.cc22
-rw-r--r--winsup/cygwin/uinfo.cc2
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;