Give the timer API one last overhaul: this time, use the new callout

API instead of the old timeout/untimeout mechanism.
This commit is contained in:
wpaul 2003-12-25 21:34:16 +00:00
parent cb427b7fa2
commit 0c849a91f9
3 changed files with 11 additions and 17 deletions

View File

@ -753,7 +753,6 @@ ndis_halt_nic(arg)
__stdcall ndis_halt_handler haltfunc;
struct ifnet *ifp;
struct ndis_timer_entry *ne;
struct callout_handle *ch;
sc = arg;
ifp = &sc->arpcom.ac_if;
@ -781,9 +780,7 @@ ndis_halt_nic(arg)
while (!TAILQ_EMPTY(&sc->ndis_block.nmb_timerlist)) {
ne = TAILQ_FIRST(&sc->ndis_block.nmb_timerlist);
TAILQ_REMOVE(&sc->ndis_block.nmb_timerlist, ne, link);
ch = &ne->nte_ch;
if (ch->callout != NULL)
untimeout(ch->callout->c_func, ch->callout->c_arg, *ch);
callout_stop(&ne->nte_ch);
free(ne, M_DEVBUF);
}

View File

@ -1001,7 +1001,7 @@ struct ndis_reference {
typedef struct ndis_reference ndis_reference;
struct ndis_timer_entry {
struct callout_handle nte_ch;
struct callout nte_ch;
ndis_miniport_timer *nte_timer;
TAILQ_ENTRY(ndis_timer_entry) link;
};

View File

@ -883,7 +883,7 @@ ndis_create_timer(timer, handle, func, ctx)
block = (ndis_miniport_block *)handle;
ne = malloc(sizeof(struct ndis_timer_entry), M_DEVBUF, M_NOWAIT);
callout_handle_init(&ne->nte_ch);
callout_init(&ne->nte_ch, CALLOUT_MPSAFE);
TAILQ_INSERT_TAIL(&block->nmb_timerlist, ne, link);
ne->nte_timer = timer;
@ -927,7 +927,7 @@ ndis_set_timer(timer, msecs)
ndis_miniport_timer *timer;
uint32_t msecs;
{
struct callout_handle *ch;
struct callout *ch;
struct timeval tv;
tv.tv_sec = 0;
@ -936,8 +936,7 @@ ndis_set_timer(timer, msecs)
ch = timer->nmt_dpc.nk_deferredctx;
timer->nmt_dpc.nk_sysarg2 = ndis_timercall;
timer->nmt_ktimer.nk_header.dh_sigstate = TRUE;
*ch = timeout((timeout_t *)timer->nmt_dpc.nk_sysarg2, (void *)timer,
tvtohz(&tv));
callout_reset(ch, tvtohz(&tv), timer->nmt_dpc.nk_sysarg2, timer);
return;
}
@ -947,7 +946,7 @@ ndis_tick(arg)
void *arg;
{
ndis_miniport_timer *timer;
struct callout_handle *ch;
struct callout *ch;
__stdcall ndis_timer_function timerfunc;
struct timeval tv;
@ -964,8 +963,7 @@ ndis_tick(arg)
ch = timer->nmt_dpc.nk_deferredctx;
timer->nmt_ktimer.nk_header.dh_sigstate = TRUE;
timer->nmt_dpc.nk_sysarg2 = ndis_tick;
*ch = timeout((timeout_t *)timer->nmt_dpc.nk_sysarg2, timer,
tvtohz(&tv));
callout_reset(ch, tvtohz(&tv), timer->nmt_dpc.nk_sysarg2, timer);
return;
}
@ -975,7 +973,7 @@ ndis_set_periodic_timer(timer, msecs)
ndis_miniport_timer *timer;
uint32_t msecs;
{
struct callout_handle *ch;
struct callout *ch;
struct timeval tv;
tv.tv_sec = 0;
@ -985,8 +983,7 @@ ndis_set_periodic_timer(timer, msecs)
ch = timer->nmt_dpc.nk_deferredctx;
timer->nmt_dpc.nk_sysarg2 = ndis_tick;
timer->nmt_ktimer.nk_header.dh_sigstate = TRUE;
*ch = timeout((timeout_t *)timer->nmt_dpc.nk_sysarg2, timer,
tvtohz(&tv));
callout_reset(ch, tvtohz(&tv), timer->nmt_dpc.nk_sysarg2, timer);
return;
}
@ -996,10 +993,10 @@ ndis_cancel_timer(timer, cancelled)
ndis_miniport_timer *timer;
uint8_t *cancelled;
{
struct callout_handle *ch;
struct callout *ch;
ch = timer->nmt_dpc.nk_deferredctx;
untimeout(ch->callout->c_func, ch->callout->c_arg, *ch);
callout_stop(ch);
*cancelled = timer->nmt_ktimer.nk_header.dh_sigstate;
return;