* bsd_mutex.cc (win_priority): Move to msleep helper function section.
(set_priority): Ditto. Fix formatting. (_msleep): Cleanup obj formatting. Rearrange obj order.
This commit is contained in:
@@ -1,3 +1,9 @@
|
|||||||
|
2004-02-07 Corinna Vinschen <corinna@vinschen.de>
|
||||||
|
|
||||||
|
* bsd_mutex.cc (win_priority): Move to msleep helper function section.
|
||||||
|
(set_priority): Ditto. Fix formatting.
|
||||||
|
(_msleep): Cleanup obj formatting. Rearrange obj order.
|
||||||
|
|
||||||
2004-02-06 Corinna Vinschen <corinna@vinschen.de>
|
2004-02-06 Corinna Vinschen <corinna@vinschen.de>
|
||||||
|
|
||||||
* bsd_mutex.cc (_msleep): Handle PCATCH using signal_arrived event.
|
* bsd_mutex.cc (_msleep): Handle PCATCH using signal_arrived event.
|
||||||
|
@@ -106,33 +106,6 @@ msleep_event_name (void *ident, char *name)
|
|||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Original description from BSD code:
|
|
||||||
*
|
|
||||||
* General sleep call. Suspends the current process until a wakeup is
|
|
||||||
* performed on the specified identifier. The process will then be made
|
|
||||||
* runnable with the specified priority. Sleeps at most timo/hz seconds
|
|
||||||
* (0 means no timeout). If pri includes PCATCH flag, signals are checked
|
|
||||||
* before and after sleeping, else signals are not checked. Returns 0 if
|
|
||||||
* awakened, EWOULDBLOCK if the timeout expires. If PCATCH is set and a
|
|
||||||
* signal needs to be delivered, ERESTART is returned if the current system
|
|
||||||
* call should be restarted if possible, and EINTR is returned if the system
|
|
||||||
* call should be interrupted by the signal (return EINTR).
|
|
||||||
*
|
|
||||||
* The mutex argument is exited before the caller is suspended, and
|
|
||||||
* entered before msleep returns. If priority includes the PDROP
|
|
||||||
* flag the mutex is not entered before returning.
|
|
||||||
*/
|
|
||||||
static HANDLE msleep_glob_evt;
|
|
||||||
|
|
||||||
void
|
|
||||||
msleep_init (void)
|
|
||||||
{
|
|
||||||
msleep_glob_evt = CreateEvent (NULL, TRUE, FALSE, NULL);
|
|
||||||
if (!msleep_glob_evt)
|
|
||||||
panic ("CreateEvent in msleep_init failed: %E");
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
win_priority (int priority)
|
win_priority (int priority)
|
||||||
{
|
{
|
||||||
@@ -173,6 +146,33 @@ set_priority (int priority)
|
|||||||
return old_prio;
|
return old_prio;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Original description from BSD code:
|
||||||
|
*
|
||||||
|
* General sleep call. Suspends the current process until a wakeup is
|
||||||
|
* performed on the specified identifier. The process will then be made
|
||||||
|
* runnable with the specified priority. Sleeps at most timo/hz seconds
|
||||||
|
* (0 means no timeout). If pri includes PCATCH flag, signals are checked
|
||||||
|
* before and after sleeping, else signals are not checked. Returns 0 if
|
||||||
|
* awakened, EWOULDBLOCK if the timeout expires. If PCATCH is set and a
|
||||||
|
* signal needs to be delivered, ERESTART is returned if the current system
|
||||||
|
* call should be restarted if possible, and EINTR is returned if the system
|
||||||
|
* call should be interrupted by the signal (return EINTR).
|
||||||
|
*
|
||||||
|
* The mutex argument is exited before the caller is suspended, and
|
||||||
|
* entered before msleep returns. If priority includes the PDROP
|
||||||
|
* flag the mutex is not entered before returning.
|
||||||
|
*/
|
||||||
|
static HANDLE msleep_glob_evt;
|
||||||
|
|
||||||
|
void
|
||||||
|
msleep_init (void)
|
||||||
|
{
|
||||||
|
msleep_glob_evt = CreateEvent (NULL, TRUE, FALSE, NULL);
|
||||||
|
if (!msleep_glob_evt)
|
||||||
|
panic ("CreateEvent in msleep_init failed: %E");
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
_msleep (void *ident, struct mtx *mtx, int priority,
|
_msleep (void *ident, struct mtx *mtx, int priority,
|
||||||
const char *wmesg, int timo, struct thread *td)
|
const char *wmesg, int timo, struct thread *td)
|
||||||
@@ -188,7 +188,13 @@ _msleep (void *ident, struct mtx *mtx, int priority,
|
|||||||
if (mtx)
|
if (mtx)
|
||||||
mtx_unlock (mtx);
|
mtx_unlock (mtx);
|
||||||
int old_priority = set_priority (priority);
|
int old_priority = set_priority (priority);
|
||||||
HANDLE obj[4] = { evt, td->client->handle (), msleep_glob_evt, td->client->signal_arrived () };
|
HANDLE obj[4] =
|
||||||
|
{
|
||||||
|
evt,
|
||||||
|
msleep_glob_evt,
|
||||||
|
td->client->handle (),
|
||||||
|
td->client->signal_arrived ()
|
||||||
|
};
|
||||||
/* PCATCH handling. If PCATCH is given and signal_arrived is a valid
|
/* PCATCH handling. If PCATCH is given and signal_arrived is a valid
|
||||||
handle, then it's used in the WaitFor call and EINTR is returned. */
|
handle, then it's used in the WaitFor call and EINTR is returned. */
|
||||||
int obj_cnt = 3;
|
int obj_cnt = 3;
|
||||||
@@ -200,10 +206,10 @@ _msleep (void *ident, struct mtx *mtx, int priority,
|
|||||||
case WAIT_OBJECT_0: /* wakeup() has been called. */
|
case WAIT_OBJECT_0: /* wakeup() has been called. */
|
||||||
ret = 0;
|
ret = 0;
|
||||||
break;
|
break;
|
||||||
case WAIT_OBJECT_0 + 2: /* Shutdown event (triggered by wakeup_all). */
|
case WAIT_OBJECT_0 + 1: /* Shutdown event (triggered by wakeup_all). */
|
||||||
priority |= PDROP;
|
priority |= PDROP;
|
||||||
/*FALLTHRU*/
|
/*FALLTHRU*/
|
||||||
case WAIT_OBJECT_0 + 1: /* The dependent process has exited. */
|
case WAIT_OBJECT_0 + 2: /* The dependent process has exited. */
|
||||||
ret = EIDRM;
|
ret = EIDRM;
|
||||||
break;
|
break;
|
||||||
case WAIT_OBJECT_0 + 3: /* Signal for calling process arrived. */
|
case WAIT_OBJECT_0 + 3: /* Signal for calling process arrived. */
|
||||||
|
Reference in New Issue
Block a user