diff options
author | jlemon <jlemon@FreeBSD.org> | 2003-03-04 23:19:55 +0000 |
---|---|---|
committer | jlemon <jlemon@FreeBSD.org> | 2003-03-04 23:19:55 +0000 |
commit | 04e28d5a816573d1300b4591306a8785d3ace29c (patch) | |
tree | f304f726e8973253d3e8a87e56119fec0276a61c /sys/net/if_faith.c | |
parent | 45fcac94f475f1d18d50dde4f72eb51ee4abddcc (diff) | |
download | FreeBSD-src-04e28d5a816573d1300b4591306a8785d3ace29c.zip FreeBSD-src-04e28d5a816573d1300b4591306a8785d3ace29c.tar.gz |
Update netisr handling; Each SWI now registers its queue, and all queue
drain routines are done by swi_net, which allows for better queue control
at some future point. Packets may also be directly dispatched to a netisr
instead of queued, this may be of interest at some installations, but
currently defaults to off.
Reviewed by: hsu, silby, jayanth, sam
Sponsored by: DARPA, NAI Labs
Diffstat (limited to 'sys/net/if_faith.c')
-rw-r--r-- | sys/net/if_faith.c | 6 |
1 files changed, 1 insertions, 5 deletions
diff --git a/sys/net/if_faith.c b/sys/net/if_faith.c index 280a041..372786a 100644 --- a/sys/net/if_faith.c +++ b/sys/net/if_faith.c @@ -202,7 +202,6 @@ faithoutput(ifp, m, dst, rt) struct rtentry *rt; { int isr; - struct ifqueue *ifq = 0; if ((m->m_flags & M_PKTHDR) == 0) panic("faithoutput no HDR"); @@ -243,13 +242,11 @@ faithoutput(ifp, m, dst, rt) switch (dst->sa_family) { #ifdef INET case AF_INET: - ifq = &ipintrq; isr = NETISR_IP; break; #endif #ifdef INET6 case AF_INET6: - ifq = &ip6intrq; isr = NETISR_IPV6; break; #endif @@ -263,8 +260,7 @@ faithoutput(ifp, m, dst, rt) m->m_pkthdr.rcvif = ifp; ifp->if_ipackets++; ifp->if_ibytes += m->m_pkthdr.len; - (void) IF_HANDOFF(ifq, m, NULL); - schednetisr(isr); + netisr_dispatch(isr, m); return (0); } |