Update for new callout interface.

This commit is contained in:
Justin T. Gibbs 1997-09-21 22:02:25 +00:00
parent ab36c06737
commit 6c951b4441
20 changed files with 108 additions and 71 deletions

View File

@ -27,7 +27,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
* $Id$
* $Id: if_fxp.c,v 1.39 1997/09/05 10:23:54 davidg Exp $
*/
/*
@ -515,6 +515,7 @@ fxp_attach(config_id, unit)
if (sc == NULL)
return;
bzero(sc, sizeof(struct fxp_softc));
callout_handle_init(&sc->stat_ch);
s = splimp();
@ -1112,7 +1113,7 @@ fxp_stop(sc)
/*
* Cancel stats updater.
*/
untimeout(fxp_stats_update, sc);
untimeout(fxp_stats_update, sc, sc->stat_ch);
/*
* Issue software reset
@ -1337,7 +1338,7 @@ fxp_init(xsc)
/*
* Start stats updater.
*/
timeout(fxp_stats_update, sc, hz);
sc->stat_ch = timeout(fxp_stats_update, sc, hz);
}
void

View File

@ -27,7 +27,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
* $Id$
* $Id: if_fxpvar.h,v 1.1 1997/09/05 10:23:58 davidg Exp $
*/
/*
@ -53,6 +53,7 @@ struct fxp_softc {
struct mbuf *rfa_headm; /* first mbuf in receive frame area */
struct mbuf *rfa_tailm; /* last mbuf in receive frame area */
struct fxp_stats *fxp_stats; /* Pointer to interface stats */
struct callout_handle stat_ch; /* Handle for canceling our stat timeout */
int tx_queued; /* # of active TxCB's */
int promisc_mode; /* promiscuous mode enabled */
int phy_primary_addr; /* address of primary PHY */

View File

@ -39,7 +39,7 @@
* IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
*
* $Id$
* $Id: if_pppvar.h,v 1.8 1997/08/19 14:10:45 peter Exp $
*/
/*
@ -55,6 +55,7 @@
struct ppp_softc {
struct ifnet sc_if; /* network-visible interface */
/*hi*/ u_int sc_flags; /* control/status bits; see if_ppp.h */
struct callout_handle sc_ch; /* Used for scheduling timeouts */
void *sc_devp; /* pointer to device-dep structure */
void (*sc_start) __P((struct ppp_softc *)); /* start output proc */
void (*sc_ctlp) __P((struct ppp_softc *)); /* rcvd control pkt */

View File

@ -31,7 +31,7 @@
* SUCH DAMAGE.
*
* @(#)if_sl.c 8.6 (Berkeley) 2/1/94
* $Id: if_sl.c,v 1.58 1997/08/02 14:32:39 bde Exp $
* $Id: if_sl.c,v 1.59 1997/08/13 14:57:14 ache Exp $
*/
/*
@ -332,11 +332,11 @@ slclose(tp,flag)
if (sc != NULL) {
if (sc->sc_outfill) {
sc->sc_outfill = 0;
untimeout(sl_outfill, sc);
untimeout(sl_outfill, sc, sc->sc_ofhandle);
}
if (sc->sc_keepalive) {
sc->sc_keepalive = 0;
untimeout(sl_keepalive, sc);
untimeout(sl_keepalive, sc, sc->sc_kahandle);
}
if_down(&sc->sc_if);
sc->sc_flags &= SC_STATIC;
@ -408,10 +408,13 @@ sltioctl(tp, cmd, data, flag, p)
sc->sc_keepalive = *(u_int *)data * hz;
if (sc->sc_keepalive) {
sc->sc_flags |= SC_KEEPALIVE;
timeout(sl_keepalive, sc, sc->sc_keepalive);
sc->sc_kahandle = timeout(sl_keepalive, sc,
sc->sc_keepalive);
} else {
sc->sc_flags &= ~SC_KEEPALIVE;
untimeout(sl_keepalive, sc);
if ((sc->sc_flags & SC_KEEPALIVE) != 0) {
untimeout(sl_keepalive, sc, sc->sc_kahandle);
sc->sc_flags &= ~SC_KEEPALIVE;
}
}
break;
@ -423,10 +426,13 @@ sltioctl(tp, cmd, data, flag, p)
sc->sc_outfill = *(u_int *)data * hz;
if (sc->sc_outfill) {
sc->sc_flags |= SC_OUTWAIT;
timeout(sl_outfill, sc, sc->sc_outfill);
sc->sc_ofhandle = timeout(sl_outfill, sc,
sc->sc_outfill);
} else {
sc->sc_flags &= ~SC_OUTWAIT;
untimeout(sl_outfill, sc);
if ((sc->sc_flags & SC_OUTWAIT) != 0) {
untimeout(sl_outfill, sc, sc->sc_ofhandle);
sc->sc_flags &= ~SC_OUTWAIT;
}
}
break;
@ -1005,10 +1011,9 @@ sl_keepalive(chan)
pgsignal (sc->sc_ttyp->t_pgrp, SIGURG, 1);
else
sc->sc_flags |= SC_KEEPALIVE;
timeout(sl_keepalive, sc, sc->sc_keepalive);
sc->sc_kahandle = timeout(sl_keepalive, sc, sc->sc_keepalive);
} else {
sc->sc_flags &= ~SC_KEEPALIVE;
untimeout(sl_keepalive, sc);
}
}
@ -1029,10 +1034,9 @@ sl_outfill(chan)
splx (s);
} else
sc->sc_flags |= SC_OUTWAIT;
timeout(sl_outfill, sc, sc->sc_outfill);
sc->sc_ofhandle = timeout(sl_outfill, sc, sc->sc_outfill);
} else {
sc->sc_flags &= ~SC_OUTWAIT;
untimeout(sl_outfill, sc);
}
}

View File

@ -32,12 +32,14 @@
*
* @(#)if_slvar.h 8.3 (Berkeley) 2/1/94
*
* $Id$
* $Id: if_slvar.h,v 1.13 1997/02/22 09:41:06 peter Exp $
*/
#ifndef _NET_IF_SLVAR_H_
#define _NET_IF_SLVAR_H_
#include <sys/callout.h>
/*
* Definitions for SLIP interface data structures
*
@ -57,7 +59,13 @@ struct sl_softc {
long sc_abortcount; /* number of abort escape chars */
long sc_starttime; /* time of first abort in window */
u_int sc_keepalive; /* time to decide link hang */
u_int sc_outfill; /* time to send FRAME_END when output idle */
u_int sc_outfill; /* time to send FRAME_END when output idle */
/*
* Handles for scheduling outfill and
* keepalive timeouts.
*/
struct callout_handle sc_ofhandle;
struct callout_handle sc_kahandle;
#ifdef INET /* XXX */
struct slcompress sc_comp; /* tcp compression data */
#endif

View File

@ -16,7 +16,7 @@
*
* From: Version 1.7, Wed Jun 7 22:12:02 MSD 1995
*
* $Id: if_sppp.h,v 1.5 1997/05/19 22:03:08 joerg Exp $
* $Id: if_sppp.h,v 1.6 1997/05/22 22:15:39 joerg Exp $
*/
#ifndef _NET_IF_HDLC_H_
@ -75,6 +75,7 @@ struct sppp {
u_char confid[IDX_COUNT]; /* id of last configuration request */
int rst_counter[IDX_COUNT]; /* restart counter */
int fail_counter[IDX_COUNT]; /* negotiation failure counter */
struct callout_handle ch[IDX_COUNT];
struct slcp lcp; /* LCP params */
struct sipcp ipcp; /* IPCP params */
/*

View File

@ -17,7 +17,7 @@
*
* From: Version 1.9, Wed Oct 4 18:58:15 MSK 1995
*
* $Id: if_spppsubr.c,v 1.25 1997/08/12 05:22:54 kjc Exp $
* $Id: if_spppsubr.c,v 1.26 1997/09/02 01:18:37 bde Exp $
*/
#include <sys/param.h>
@ -265,6 +265,7 @@ static const char *sppp_phase_name(enum ppp_phase phase);
static const char *sppp_proto_name(u_short proto);
static void sppp_keepalive(void *dummy);
static struct callout_handle keepalive_ch;
static void sppp_qflush(struct ifqueue *ifq);
static void sppp_get_ip_addrs(struct sppp *sp, u_long *src, u_long *dst);
@ -627,7 +628,7 @@ sppp_attach(struct ifnet *ifp)
/* Initialize keepalive handler. */
if (! spppq)
timeout (sppp_keepalive, 0, hz * 10);
keepalive_ch = timeout (sppp_keepalive, 0, hz * 10);
/* Insert new entry into the keepalive list. */
sp->pp_next = spppq;
@ -664,10 +665,10 @@ sppp_detach(struct ifnet *ifp)
/* Stop keepalive handler. */
if (! spppq)
untimeout (sppp_keepalive, 0);
untimeout (sppp_keepalive, 0, keepalive_ch);
for (i = 0; i < IDX_COUNT; i++)
untimeout((cps[i])->TO, (void *)sp);
untimeout((cps[i])->TO, (void *)sp, sp->ch[i]);
}
/*
@ -1522,7 +1523,8 @@ sppp_to_event(const struct cp *cp, struct sppp *sp)
case STATE_STOPPING:
sppp_cp_send(sp, cp->proto, TERM_REQ, ++sp->pp_seq,
0, 0);
timeout(cp->TO, (void *)sp, sp->lcp.timeout);
sp->ch[cp->protoidx] = timeout(cp->TO, (void *)sp,
sp->lcp.timeout);
break;
case STATE_REQ_SENT:
case STATE_ACK_RCVD:
@ -1532,7 +1534,8 @@ sppp_to_event(const struct cp *cp, struct sppp *sp)
break;
case STATE_ACK_SENT:
(cp->scr)(sp);
timeout(cp->TO, (void *)sp, sp->lcp.timeout);
sp->ch[cp->protoidx] = timeout(cp->TO, (void *)sp,
sp->lcp.timeout);
break;
}
@ -1548,7 +1551,7 @@ sppp_cp_change_state(const struct cp *cp, struct sppp *sp, int newstate)
{
sp->state[cp->protoidx] = newstate;
untimeout(cp->TO, (void *)sp);
untimeout(cp->TO, (void *)sp, sp->ch[cp->protoidx]);
switch (newstate) {
case STATE_INITIAL:
case STATE_STARTING:
@ -1561,7 +1564,8 @@ sppp_cp_change_state(const struct cp *cp, struct sppp *sp, int newstate)
case STATE_REQ_SENT:
case STATE_ACK_RCVD:
case STATE_ACK_SENT:
timeout(cp->TO, (void *)sp, sp->lcp.timeout);
sp->ch[cp->protoidx] = timeout(cp->TO, (void *)sp,
sp->lcp.timeout);
break;
}
}
@ -1581,6 +1585,7 @@ sppp_lcp_init(struct sppp *sp)
sp->fail_counter[IDX_LCP] = 0;
sp->lcp.protos = 0;
sp->lcp.mru = sp->lcp.their_mru = PP_MTU;
callout_handle_init(&sp->ch[IDX_LCP]);
/*
* Initialize counters and timeout values. Note that we don't
@ -2111,6 +2116,7 @@ sppp_ipcp_init(struct sppp *sp)
sp->ipcp.flags = 0;
sp->state[IDX_IPCP] = STATE_INITIAL;
sp->fail_counter[IDX_IPCP] = 0;
callout_handle_init(&sp->ch[IDX_IPCP]);
}
static void
@ -2577,7 +2583,7 @@ sppp_keepalive(void *dummy)
}
}
splx(s);
timeout(sppp_keepalive, 0, hz * 10);
keepalive_ch = timeout(sppp_keepalive, 0, hz * 10);
}
/*

View File

@ -70,7 +70,7 @@
* Paul Mackerras (paulus@cs.anu.edu.au).
*/
/* $Id: ppp_tty.c,v 1.22 1997/08/19 14:10:47 peter Exp $ */
/* $Id: ppp_tty.c,v 1.23 1997/08/22 11:34:08 peter Exp $ */
#include "ppp.h"
#if NPPP > 0
@ -322,7 +322,7 @@ pppasyncrelinq(sc)
sc->sc_m = NULL;
}
if (sc->sc_flags & SC_TIMEOUT) {
untimeout(ppp_timeout, (void *) sc);
untimeout(ppp_timeout, (void *) sc, sc->sc_ch);
sc->sc_flags &= ~SC_TIMEOUT;
}
splx(s);
@ -758,7 +758,7 @@ pppasyncstart(sc)
* drained the t_outq.
*/
if (!idle && (sc->sc_flags & SC_TIMEOUT) == 0) {
timeout(ppp_timeout, (void *) sc, 1);
sc->sc_ch = timeout(ppp_timeout, (void *) sc, 1);
sc->sc_flags |= SC_TIMEOUT;
}

View File

@ -64,13 +64,16 @@ u_char aarp_org_code[ 3 ] = {
0x00, 0x00, 0x00,
};
static struct callout_handle aarptimer_ch =
CALLOUT_HANDLE_INITIALIZER(&aarptimer_ch);
static void
aarptimer(void *ignored)
{
struct aarptab *aat;
int i, s;
timeout( aarptimer, (caddr_t)0, AARPT_AGE * hz );
aarptimer_ch = timeout( aarptimer, (caddr_t)0, AARPT_AGE * hz );
aat = aarptab;
for ( i = 0; i < AARPTAB_SIZE; i++, aat++ ) {
if ( aat->aat_flags == 0 || ( aat->aat_flags & ATF_PERM ))
@ -362,7 +365,7 @@ at_aarpinput( struct arpcom *ac, struct mbuf *m)
* probed for the same address we'd like to use. Change the
* address we're probing for.
*/
untimeout( aarpprobe, ac );
untimeout( aarpprobe, ac, aa->aa_ch );
wakeup( aa );
m_freem( m );
return;
@ -488,7 +491,7 @@ aarptnew( addr )
if ( first ) {
first = 0;
timeout( aarptimer, (caddr_t)0, hz );
aarptimer_ch = timeout( aarptimer, (caddr_t)0, hz );
}
aat = &aarptab[ AARPTAB_HASH( *addr ) * AARPTAB_BSIZ ];
for ( n = 0; n < AARPTAB_BSIZ; n++, aat++ ) {
@ -547,7 +550,7 @@ aarpprobe( void *arg )
wakeup( aa );
return;
} else {
timeout( aarpprobe, (caddr_t)ac, hz / 5 );
aa->aa_ch = timeout( aarpprobe, (caddr_t)ac, hz / 5 );
}
if (( m = m_gethdr( M_DONTWAIT, MT_DATA )) == NULL ) {
@ -612,7 +615,7 @@ aarp_clean(void)
struct aarptab *aat;
int i;
untimeout( aarptimer, 0 );
untimeout( aarptimer, 0, aarptimer_ch );
for ( i = 0, aat = aarptab; i < AARPTAB_SIZE; i++, aat++ ) {
if ( aat->aat_hold ) {
m_freem( aat->aat_hold );

View File

@ -520,7 +520,7 @@ at_ifinit( ifp, aa, sat )
* start off the probes as an asynchronous activity.
* though why wait 200mSec?
*/
timeout( aarpprobe, (caddr_t)ifp, hz / 5 );
aa->aa_ch = timeout( aarpprobe, (caddr_t)ifp, hz / 5 );
if ( tsleep( aa, PPAUSE|PCATCH, "at_ifinit", 0 )) {
/*
* theoretically we shouldn't time out here

View File

@ -28,16 +28,17 @@
* but also the legal networks on the interface.
*/
struct at_ifaddr {
struct ifaddr aa_ifa;
struct ifaddr aa_ifa;
# define aa_ifp aa_ifa.ifa_ifp
struct sockaddr_at aa_addr;
struct sockaddr_at aa_broadaddr;
struct sockaddr_at aa_addr;
struct sockaddr_at aa_broadaddr;
# define aa_dstaddr aa_broadaddr;
struct sockaddr_at aa_netmask;
int aa_flags;
u_short aa_firstnet, aa_lastnet;
int aa_probcnt;
struct at_ifaddr *aa_next;
struct sockaddr_at aa_netmask;
int aa_flags;
u_short aa_firstnet, aa_lastnet;
int aa_probcnt;
struct callout_handle aa_ch;
struct at_ifaddr *aa_next;
};
struct at_aliasreq {

View File

@ -9,7 +9,7 @@
* Modified by Bill Fenner, PARC, April 1995
*
* MROUTING Revision: 3.5
* $Id: ip_mroute.c,v 1.39 1997/03/24 11:33:28 bde Exp $
* $Id: ip_mroute.c,v 1.40 1997/07/19 20:07:07 fenner Exp $
*/
#include "opt_mrouting.h"
@ -226,6 +226,8 @@ static u_int mrtdebug = 0; /* debug level */
static u_int tbfdebug = 0; /* tbf debug level */
static u_int rsvpdebug = 0; /* rsvp debug level */
static struct callout_handle expire_upcalls_ch;
#define EXPIRE_TIMEOUT (hz / 4) /* 4x / second */
#define UPCALL_EXPIRE 6 /* number of timeouts */
@ -540,7 +542,7 @@ ip_mrouter_init(so, m)
pim_assert = 0;
timeout(expire_upcalls, (caddr_t)NULL, EXPIRE_TIMEOUT);
expire_upcalls_ch = timeout(expire_upcalls, (caddr_t)NULL, EXPIRE_TIMEOUT);
if (mrtdebug)
log(LOG_DEBUG, "ip_mrouter_init\n");
@ -584,7 +586,7 @@ X_ip_mrouter_done()
numvifs = 0;
pim_assert = 0;
untimeout(expire_upcalls, (caddr_t)NULL);
untimeout(expire_upcalls, (caddr_t)NULL, expire_upcalls_ch);
/*
* Free all multicast forwarding cache entries.
@ -1376,7 +1378,7 @@ expire_upcalls(void *unused)
}
}
splx(s);
timeout(expire_upcalls, (caddr_t)NULL, EXPIRE_TIMEOUT);
expire_upcalls_ch = timeout(expire_upcalls, (caddr_t)NULL, EXPIRE_TIMEOUT);
}
/*

View File

@ -218,7 +218,7 @@ pccard_remove_controller(struct slot_ctrl *cp)
if (sp->ctrl == cp) {
pccard_slots[sp->slot] = 0;
if (sp->insert_seq)
untimeout(inserted, (void *)sp);
untimeout(inserted, (void *)sp, sp->insert_ch);
/*
* Unload the drivers attached to this slot.
*/
@ -318,7 +318,7 @@ disable_slot(struct slot *sp)
}
}
/* Power off the slot 1/2 second after remove of the card */
timeout(power_off_slot, (caddr_t)sp, hz / 2);
sp->poff_ch = timeout(power_off_slot, (caddr_t)sp, hz / 2);
sp->pwr_off_pending = 1;
/* De-activate all contexts. */
@ -626,9 +626,10 @@ inserted(void *arg)
*/
sp->pwr.vcc = 50;
sp->pwr.vpp = 0;
untimeout(power_off_slot, (caddr_t)sp);
if (sp->pwr_off_pending)
if (sp->pwr_off_pending) {
untimeout(power_off_slot, (caddr_t)sp, sp->poff_ch);
sp->ctrl->disable(sp);
}
sp->pwr_off_pending = 0;
sp->ctrl->power(sp);
printf("Card inserted, slot %d\n", sp->slot);
@ -663,7 +664,7 @@ pccard_event(struct slot *sp, enum card_event event)
if (sp->insert_seq) {
sp->insert_seq = 0;
untimeout(inserted, (void *)sp);
untimeout(inserted, (void *)sp, sp->insert_ch);
}
switch(event) {
case card_removed:
@ -686,7 +687,7 @@ pccard_event(struct slot *sp, enum card_event event)
break;
case card_inserted:
sp->insert_seq = 1;
timeout(inserted, (void *)sp, hz/4);
sp->insert_ch = timeout(inserted, (void *)sp, hz/4);
if (beepok)
sysbeep(PCCARD_BEEP_PITCH0, PCCARD_BEEP_DURATION0);
beepok = 0;

View File

@ -128,6 +128,8 @@ static void pcic_resume(struct slot *);
static void pcic_disable __P((struct slot *));
static void pcic_mapirq __P((struct slot *, int));
static timeout_t pcictimeout;
static struct callout_handle pcictimeout_ch
= CALLOUT_HANDLE_INITIALIZER(&pcictimeout_ch);
#ifdef LKM
static int pcic_handle __P((struct lkm_table *lkmtp, int cmd));
#endif
@ -307,7 +309,7 @@ pcic_unload(struct lkm_table *lkmtp, int cmd)
int slot;
struct pcic_slot *sp = pcic_slots;
untimeout(pcictimeout,0);
untimeout(pcictimeout,0, pcictimeout_ch);
if (pcic_irq) {
for (slot = 0; slot < PCIC_MAX_SLOTS; slot++, sp++) {
if (sp->slotp)
@ -848,7 +850,7 @@ pcic_probe(void)
}
#endif /* PC98 */
if (validslots)
timeout(pcictimeout,0,hz/2);
pcictimeout_ch = timeout(pcictimeout,0,hz/2);
return(validslots);
}
@ -1109,7 +1111,7 @@ pcic_disable(struct slot *slotp)
static void
pcictimeout(void *chan)
{
timeout(pcictimeout,0,hz/2);
pcictimeout_ch = timeout(pcictimeout,0,hz/2);
pcicintr(0);
}

View File

@ -120,6 +120,8 @@ struct slot {
* flags.
*/
unsigned int insert_seq; /* Firing up under the card */
struct callout_handle insert_ch;/* Insert event timeout handle */
struct callout_handle poff_ch; /* Power Off timeout handle */
enum cardstate state, laststate; /* Current/last card states */
struct selinfo selp; /* Info for select */

View File

@ -27,7 +27,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
* $Id$
* $Id: if_fxp.c,v 1.39 1997/09/05 10:23:54 davidg Exp $
*/
/*
@ -515,6 +515,7 @@ fxp_attach(config_id, unit)
if (sc == NULL)
return;
bzero(sc, sizeof(struct fxp_softc));
callout_handle_init(&sc->stat_ch);
s = splimp();
@ -1112,7 +1113,7 @@ fxp_stop(sc)
/*
* Cancel stats updater.
*/
untimeout(fxp_stats_update, sc);
untimeout(fxp_stats_update, sc, sc->stat_ch);
/*
* Issue software reset
@ -1337,7 +1338,7 @@ fxp_init(xsc)
/*
* Start stats updater.
*/
timeout(fxp_stats_update, sc, hz);
sc->stat_ch = timeout(fxp_stats_update, sc, hz);
}
void

View File

@ -27,7 +27,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
* $Id$
* $Id: if_fxpvar.h,v 1.1 1997/09/05 10:23:58 davidg Exp $
*/
/*
@ -53,6 +53,7 @@ struct fxp_softc {
struct mbuf *rfa_headm; /* first mbuf in receive frame area */
struct mbuf *rfa_tailm; /* last mbuf in receive frame area */
struct fxp_stats *fxp_stats; /* Pointer to interface stats */
struct callout_handle stat_ch; /* Handle for canceling our stat timeout */
int tx_queued; /* # of active TxCB's */
int promisc_mode; /* promiscuous mode enabled */
int phy_primary_addr; /* address of primary PHY */

View File

@ -1,6 +1,6 @@
/**************************************************************************
**
** $Id: ncr.c,v 1.109 1997/09/09 21:52:31 se Exp $
** $Id: ncr.c,v 1.110 1997/09/10 20:46:11 se Exp $
**
** Device driver for the NCR 53C810 PCI-SCSI-Controller.
**
@ -1113,6 +1113,7 @@ struct ncb {
u_short ticks;
u_short latetime;
u_long lasttime;
struct callout_handle timeout_ch;
/*-----------------------------------------------
** Debug and profiling
@ -1340,7 +1341,7 @@ static void ncr_attach (pcici_t tag, int unit);
static char ident[] =
"\n$Id: ncr.c,v 1.109 1997/09/09 21:52:31 se Exp $\n";
"\n$Id: ncr.c,v 1.110 1997/09/10 20:46:11 se Exp $\n";
static const u_long ncr_version = NCR_VERSION * 11
+ (u_long) sizeof (struct ncb) * 7
@ -5534,7 +5535,7 @@ static void ncr_timeout (void *arg)
splx (oldspl);
}
timeout (ncr_timeout, (caddr_t) np, step ? step : 1);
np->timeout_ch = timeout (ncr_timeout, (caddr_t) np, step ? step : 1);
if (INB(nc_istat) & (INTF|SIP|DIP)) {
@ -5895,7 +5896,7 @@ void ncr_exception (ncb_p np)
if (i%16==15) printf (".\n");
};
untimeout (ncr_timeout, (caddr_t) np);
untimeout (ncr_timeout, (caddr_t) np, np->timeout_ch);
printf ("%s: halted!\n", ncr_name(np));
/*

View File

@ -1080,8 +1080,6 @@ SRBdone( PACB pACB, PDCB pDCB, PSRB pSRB )
ULONG swlval;
pcmd = pSRB->pcmd;
if( !(pcmd->flags & SCSI_NOMASK) )
untimeout(DC390_timeout, (caddr_t) pSRB);
plink = pcmd->sc_link;
status = pSRB->TargetStatus;
if(pSRB->SRBFlag & AUTO_REQSENSE)

View File

@ -119,6 +119,10 @@ static void EnableMsgOut2( PACB pACB, PSRB pSRB );
static void EnableMsgOut( PACB pACB, PSRB pSRB );
static void DC390_InvalidCmd( PACB pACB );
/*
* XXX No timeouts are scheduled in this driver as the timeout handler
* doesn't do anything yet!!!
*/
static void DC390_timeout( void *arg1);
static void DC390_reset (PACB pACB);
static PUCHAR phystovirt( PSRB pSRB, ULONG xferCnt );
@ -694,7 +698,6 @@ trmamd_scsi_cmd ( PSCSICMD cmd )
{
flags = splbio();
SendSRB( pcmd, pACB, pSRB );
timeout(DC390_timeout, (caddr_t)pSRB, (pcmd->timeout * hz)/1000);
splx(flags);
return( SUCCESSFULLY_QUEUED);
}