Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
6c9fd859
Commit
6c9fd859
authored
Feb 21, 2007
by
Kristofer.Pettersson@naruto
Browse files
Options
Browse Files
Download
Plain Diff
Merge naruto.:C:/cpp/bug25042/my50-bug25042
into naruto.:C:/cpp/mysql-5.1-runtime
parents
61b624eb
cd0a43f5
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
122 additions
and
39 deletions
+122
-39
include/my_pthread.h
include/my_pthread.h
+11
-1
mysys/my_wincond.c
mysys/my_wincond.c
+111
-38
No files found.
include/my_pthread.h
View file @
6c9fd859
...
@@ -69,7 +69,17 @@ typedef struct st_pthread_link {
...
@@ -69,7 +69,17 @@ typedef struct st_pthread_link {
typedef
struct
{
typedef
struct
{
uint32
waiting
;
uint32
waiting
;
HANDLE
semaphore
;
CRITICAL_SECTION
lock_waiting
;
enum
{
SIGNAL
=
0
,
BROADCAST
=
1
,
MAX_EVENTS
=
2
}
EVENTS
;
HANDLE
events
[
MAX_EVENTS
];
HANDLE
broadcast_block_event
;
}
pthread_cond_t
;
}
pthread_cond_t
;
...
...
mysys/my_wincond.c
View file @
6c9fd859
...
@@ -27,27 +27,48 @@
...
@@ -27,27 +27,48 @@
int
pthread_cond_init
(
pthread_cond_t
*
cond
,
const
pthread_condattr_t
*
attr
)
int
pthread_cond_init
(
pthread_cond_t
*
cond
,
const
pthread_condattr_t
*
attr
)
{
{
cond
->
waiting
=
0
;
cond
->
waiting
=
0
;
cond
->
semaphore
=
CreateSemaphore
(
NULL
,
0
,
0x7FFFFFFF
,
NullS
);
InitializeCriticalSection
(
&
cond
->
lock_waiting
);
if
(
!
cond
->
semaphore
)
cond
->
events
[
SIGNAL
]
=
CreateEvent
(
NULL
,
/* no security */
FALSE
,
/* auto-reset event */
FALSE
,
/* non-signaled initially */
NULL
);
/* unnamed */
/* Create a manual-reset event. */
cond
->
events
[
BROADCAST
]
=
CreateEvent
(
NULL
,
/* no security */
TRUE
,
/* manual-reset */
FALSE
,
/* non-signaled initially */
NULL
);
/* unnamed */
cond
->
broadcast_block_event
=
CreateEvent
(
NULL
,
/* no security */
TRUE
,
/* manual-reset */
TRUE
,
/* signaled initially */
NULL
);
/* unnamed */
if
(
cond
->
events
[
SIGNAL
]
==
NULL
||
cond
->
events
[
BROADCAST
]
==
NULL
||
cond
->
broadcast_block_event
==
NULL
)
return
ENOMEM
;
return
ENOMEM
;
return
0
;
return
0
;
}
}
int
pthread_cond_destroy
(
pthread_cond_t
*
cond
)
int
pthread_cond_destroy
(
pthread_cond_t
*
cond
)
{
{
return
CloseHandle
(
cond
->
semaphore
)
?
0
:
EINVAL
;
DeleteCriticalSection
(
&
cond
->
lock_waiting
);
if
(
CloseHandle
(
cond
->
events
[
SIGNAL
])
==
0
||
CloseHandle
(
cond
->
events
[
BROADCAST
])
==
0
||
CloseHandle
(
cond
->
broadcast_block_event
)
==
0
)
return
EINVAL
;
return
0
;
}
}
int
pthread_cond_wait
(
pthread_cond_t
*
cond
,
pthread_mutex_t
*
mutex
)
int
pthread_cond_wait
(
pthread_cond_t
*
cond
,
pthread_mutex_t
*
mutex
)
{
{
InterlockedIncrement
(
&
cond
->
waiting
);
return
pthread_cond_timedwait
(
cond
,
mutex
,
NULL
);
LeaveCriticalSection
(
mutex
);
WaitForSingleObject
(
cond
->
semaphore
,
INFINITE
);
InterlockedDecrement
(
&
cond
->
waiting
);
EnterCriticalSection
(
mutex
);
return
0
;
}
}
...
@@ -58,6 +79,8 @@ int pthread_cond_timedwait(pthread_cond_t *cond, pthread_mutex_t *mutex,
...
@@ -58,6 +79,8 @@ int pthread_cond_timedwait(pthread_cond_t *cond, pthread_mutex_t *mutex,
long
timeout
;
long
timeout
;
union
ft64
now
;
union
ft64
now
;
if
(
abstime
!=
NULL
)
{
GetSystemTimeAsFileTime
(
&
now
.
ft
);
GetSystemTimeAsFileTime
(
&
now
.
ft
);
/*
/*
...
@@ -78,31 +101,81 @@ int pthread_cond_timedwait(pthread_cond_t *cond, pthread_mutex_t *mutex,
...
@@ -78,31 +101,81 @@ int pthread_cond_timedwait(pthread_cond_t *cond, pthread_mutex_t *mutex,
if
(
timeout
>
abstime
->
max_timeout_msec
)
if
(
timeout
>
abstime
->
max_timeout_msec
)
timeout
=
abstime
->
max_timeout_msec
;
timeout
=
abstime
->
max_timeout_msec
;
InterlockedIncrement
(
&
cond
->
waiting
);
}
else
{
/* No time specified; don't expire */
timeout
=
INFINITE
;
}
/*
Block access if previous broadcast hasn't finished.
This is just for safety and should normally not
affect the total time spent in this function.
*/
WaitForSingleObject
(
cond
->
broadcast_block_event
,
INFINITE
);
EnterCriticalSection
(
&
cond
->
lock_waiting
);
cond
->
waiting
++
;
LeaveCriticalSection
(
&
cond
->
lock_waiting
);
LeaveCriticalSection
(
mutex
);
LeaveCriticalSection
(
mutex
);
result
=
WaitForSingleObject
(
cond
->
semaphore
,
timeout
);
InterlockedDecrement
(
&
cond
->
waiting
);
result
=
WaitForMultipleObjects
(
2
,
cond
->
events
,
FALSE
,
timeout
);
EnterCriticalSection
(
&
cond
->
lock_waiting
);
cond
->
waiting
--
;
if
(
cond
->
waiting
==
0
&&
result
==
(
WAIT_OBJECT_0
+
BROADCAST
))
{
/*
We're the last waiter to be notified or to stop waiting, so
reset the manual event.
*/
/* Close broadcast gate */
ResetEvent
(
cond
->
events
[
BROADCAST
]);
/* Open block gate */
SetEvent
(
cond
->
broadcast_block_event
);
}
LeaveCriticalSection
(
&
cond
->
lock_waiting
);
EnterCriticalSection
(
mutex
);
EnterCriticalSection
(
mutex
);
return
result
==
WAIT_TIMEOUT
?
ETIMEDOUT
:
0
;
return
result
==
WAIT_TIMEOUT
?
ETIMEDOUT
:
0
;
}
}
int
pthread_cond_signal
(
pthread_cond_t
*
cond
)
int
pthread_cond_signal
(
pthread_cond_t
*
cond
)
{
{
long
prev_count
;
EnterCriticalSection
(
&
cond
->
lock_waiting
);
if
(
cond
->
waiting
)
ReleaseSemaphore
(
cond
->
semaphore
,
1
,
&
prev_count
);
if
(
cond
->
waiting
>
0
)
SetEvent
(
cond
->
events
[
SIGNAL
]);
LeaveCriticalSection
(
&
cond
->
lock_waiting
);
return
0
;
return
0
;
}
}
int
pthread_cond_broadcast
(
pthread_cond_t
*
cond
)
int
pthread_cond_broadcast
(
pthread_cond_t
*
cond
)
{
{
long
prev_count
;
EnterCriticalSection
(
&
cond
->
lock_waiting
);
if
(
cond
->
waiting
)
/*
ReleaseSemaphore
(
cond
->
semaphore
,
cond
->
waiting
,
&
prev_count
);
The mutex protect us from broadcasting if
return
0
;
there isn't any thread waiting to open the
block gate after this call has closed it.
*/
if
(
cond
->
waiting
>
0
)
{
/* Close block gate */
ResetEvent
(
cond
->
broadcast_block_event
);
/* Open broadcast gate */
SetEvent
(
cond
->
events
[
BROADCAST
]);
}
LeaveCriticalSection
(
&
cond
->
lock_waiting
);
return
0
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment