summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2015-11-12 13:14:08 +0100
committerCorinna Vinschen <corinna@vinschen.de>2015-11-12 13:14:08 +0100
commit914620a7e6be4011fadebc7e1f23ed1d0e9ed4d7 (patch)
treebdc0976e58dbca0f4765b1afa34b5518940de44d
parente6459123e497409a9e3d845c39829a9602ba55a4 (diff)
downloadcygnal-914620a7e6be4011fadebc7e1f23ed1d0e9ed4d7.tar.gz
cygnal-914620a7e6be4011fadebc7e1f23ed1d0e9ed4d7.tar.bz2
cygnal-914620a7e6be4011fadebc7e1f23ed1d0e9ed4d7.zip
flock: Fix hang in object collision case
* flock.cc (lockf_t::create_lock_obj): Correctly recreate lock object attributes anew in each loop. Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
-rw-r--r--winsup/cygwin/ChangeLog5
-rw-r--r--winsup/cygwin/flock.cc4
-rw-r--r--winsup/cygwin/release/2.3.15
3 files changed, 12 insertions, 2 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog
index 8e40c2f31..bdaab408c 100644
--- a/winsup/cygwin/ChangeLog
+++ b/winsup/cygwin/ChangeLog
@@ -1,5 +1,10 @@
2015-11-12 Corinna Vinschen <corinna@vinschen.de>
+ * flock.cc (lockf_t::create_lock_obj): Correctly recreate lock object
+ attributes anew in each loop.
+
+2015-11-12 Corinna Vinschen <corinna@vinschen.de>
+
* init.cc (munge_threadfunc): Don't call NtQueryInformationThread with
ThreadQuerySetWin32StartAddress info class on XP 64 and Server 2003 64.
It crashes.
diff --git a/winsup/cygwin/flock.cc b/winsup/cygwin/flock.cc
index 0ac55485b..f7c04c8e1 100644
--- a/winsup/cygwin/flock.cc
+++ b/winsup/cygwin/flock.cc
@@ -766,12 +766,12 @@ lockf_t::create_lock_obj ()
{
lockfattr_t attr;
NTSTATUS status;
+ PSECURITY_DESCRIPTOR sd_buf = alloca (SD_MIN_SIZE);
POBJECT_ATTRIBUTES lock_obj_attr;
- lock_obj_attr = create_lock_obj_attr (&attr, OBJ_INHERIT,
- alloca (SD_MIN_SIZE));
do
{
+ lock_obj_attr = create_lock_obj_attr (&attr, OBJ_INHERIT, sd_buf);
status = NtCreateEvent (&lf_obj, CYG_EVENT_ACCESS, lock_obj_attr,
NotificationEvent, FALSE);
if (!NT_SUCCESS (status))
diff --git a/winsup/cygwin/release/2.3.1 b/winsup/cygwin/release/2.3.1
index 5299d2304..a552ee812 100644
--- a/winsup/cygwin/release/2.3.1
+++ b/winsup/cygwin/release/2.3.1
@@ -12,3 +12,8 @@ Bug Fixes
- The fix for wine introduced in 2.3.0 crashes in 32 bit Cygwin on 64 bit XP
and 64 bit Server 2003 only. This should work now.
Addresses: https://cygwin.com/ml/cygwin/2015-11/msg00187.html
+
+- The fix to avoid a potential crash in advisory file locking introduced in
+ 2.3.0 waas not entirely correct and failed to work in certain border cases.
+ This should work now.
+ Addresses: https://cygwin.com/ml/cygwin/2015-11/msg00189.html