use splnet() around the body of ofnet_read(). this is logically the
receive interrupt handler since it passes received packets to the interface's input handler. that ends up scheduling a network softint and queuing the packet on the interface's receive queue (in that order), so if softnet isn't blocked at this point then softnet() doesn't find the packet until it's triggered again by something else. remove all vesitages of dk_establish().
This commit is contained in:
parent
658ce04ab1
commit
f5191984f6
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: ofnet.c,v 1.24 2002/03/05 04:12:58 itojun Exp $ */
|
/* $NetBSD: ofnet.c,v 1.25 2002/09/18 01:47:08 chs Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 1995, 1996 Wolfgang Solfrank.
|
* Copyright (C) 1995, 1996 Wolfgang Solfrank.
|
||||||
@ -32,7 +32,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
__KERNEL_RCSID(0, "$NetBSD: ofnet.c,v 1.24 2002/03/05 04:12:58 itojun Exp $");
|
__KERNEL_RCSID(0, "$NetBSD: ofnet.c,v 1.25 2002/09/18 01:47:08 chs Exp $");
|
||||||
|
|
||||||
#include "ofnet.h"
|
#include "ofnet.h"
|
||||||
#include "opt_inet.h"
|
#include "opt_inet.h"
|
||||||
@ -166,10 +166,6 @@ ofnet_attach(struct device *parent, struct device *self, void *aux)
|
|||||||
|
|
||||||
if_attach(ifp);
|
if_attach(ifp);
|
||||||
ether_ifattach(ifp, myaddr);
|
ether_ifattach(ifp, myaddr);
|
||||||
|
|
||||||
#ifdef __BROKEN_DK_ESTABLISH
|
|
||||||
dk_establish(0, self); /* XXX */
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static char buf[ETHERMTU + sizeof(struct ether_header)];
|
static char buf[ETHERMTU + sizeof(struct ether_header)];
|
||||||
@ -179,16 +175,17 @@ ofnet_read(struct ofnet_softc *of)
|
|||||||
{
|
{
|
||||||
struct ifnet *ifp = &of->sc_ethercom.ec_if;
|
struct ifnet *ifp = &of->sc_ethercom.ec_if;
|
||||||
struct mbuf *m, **mp, *head;
|
struct mbuf *m, **mp, *head;
|
||||||
int l, len;
|
int s, l, len;
|
||||||
char *bufp;
|
char *bufp;
|
||||||
|
|
||||||
|
s = splnet();
|
||||||
#if NIPKDB_OFN > 0
|
#if NIPKDB_OFN > 0
|
||||||
ipkdbrint(kifp, ifp);
|
ipkdbrint(kifp, ifp);
|
||||||
#endif
|
#endif
|
||||||
while (1) {
|
for (;;) {
|
||||||
if ((len = OF_read(of->sc_ihandle, buf, sizeof buf)) < 0) {
|
if ((len = OF_read(of->sc_ihandle, buf, sizeof buf)) < 0) {
|
||||||
if (len == -2 || len == 0)
|
if (len == -2 || len == 0)
|
||||||
return;
|
break;
|
||||||
ifp->if_ierrors++;
|
ifp->if_ierrors++;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -278,6 +275,7 @@ ofnet_read(struct ofnet_softc *of)
|
|||||||
ifp->if_ipackets++;
|
ifp->if_ipackets++;
|
||||||
(*ifp->if_input)(ifp, head);
|
(*ifp->if_input)(ifp, head);
|
||||||
}
|
}
|
||||||
|
splx(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
Loading…
Reference in New Issue
Block a user