summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTheo de Raadt <deraadt@cvs.openbsd.org>1995-12-27 22:36:19 +0000
committerTheo de Raadt <deraadt@cvs.openbsd.org>1995-12-27 22:36:19 +0000
commit9eaa76f56f533f9a8a2a6e0edbe13805ca00ce8d (patch)
tree050385804b05d0ad8405f9874f8b39f983f38690
parent7aa2a8b8d39e0a806ca665e278c6d5bebd84cf5b (diff)
from netbsd:
Remove old comment regarding trailers. Fix a diagnostic message. Make some variables use fixed-size types. Initialize if_output in fddi_ifattach().
-rw-r--r--sys/net/if_fddisubr.c21
1 files changed, 10 insertions, 11 deletions
diff --git a/sys/net/if_fddisubr.c b/sys/net/if_fddisubr.c
index 4da82a76661..4b95818097d 100644
--- a/sys/net/if_fddisubr.c
+++ b/sys/net/if_fddisubr.c
@@ -1,4 +1,4 @@
-/* $NetBSD: if_fddisubr.c,v 1.2 1995/08/19 04:35:29 cgd Exp $ */
+/* $NetBSD: if_fddisubr.c,v 1.3 1995/12/24 03:32:03 mycroft Exp $ */
/*
* Copyright (c) 1995
@@ -116,8 +116,6 @@ extern struct ifqueue pkintrq;
/*
* FDDI output routine.
* Encapsulate a packet of type family for the local net.
- * Use trailer local net encapsulation if enough data in first
- * packet leaves a multiple of 512 bytes of data in remainder.
* Assumes that ifp is actually pointer to arpcom structure.
*/
int
@@ -127,7 +125,7 @@ fddi_output(ifp, m0, dst, rt0)
struct sockaddr *dst;
struct rtentry *rt0;
{
- short type;
+ u_int16_t type;
int s, error = 0;
u_char edst[6];
register struct mbuf *m = m0;
@@ -261,8 +259,8 @@ fddi_output(ifp, m0, dst, rt0)
for (i=0; i<6; i++)
printf("%x ", edst[i] & 0xff);
printf(" len 0x%x dsap 0x%x ssap 0x%x control 0x%x\n",
- type & 0xff, l->llc_dsap & 0xff, l->llc_ssap &0xff,
- l->llc_control & 0xff);
+ m->m_pkthdr.len, l->llc_dsap & 0xff, l->llc_ssap &0xff,
+ l->llc_control & 0xff);
}
#endif /* LLC_DEBUG */
@@ -321,9 +319,9 @@ fddi_output(ifp, m0, dst, rt0)
senderr(EAFNOSUPPORT);
}
-
if (mcopy)
(void) looutput(ifp, mcopy, dst, rt);
+
if (type != 0) {
register struct llc *l;
M_PREPEND(m, sizeof (struct llc), M_DONTWAIT);
@@ -409,14 +407,14 @@ fddi_input(ifp, fh, m)
#if defined(INET) || defined(NS) || defined(DECNET)
case LLC_SNAP_LSAP:
{
- unsigned fddi_type;
+ u_int16_t etype;
if (l->llc_control != LLC_UI || l->llc_ssap != LLC_SNAP_LSAP)
goto dropanyway;
if (l->llc_snap.org_code[0] != 0 || l->llc_snap.org_code[1] != 0|| l->llc_snap.org_code[2] != 0)
goto dropanyway;
- fddi_type = ntohs(l->llc_snap.ether_type);
+ etype = ntohs(l->llc_snap.ether_type);
m_adj(m, 8);
- switch (fddi_type) {
+ switch (etype) {
#ifdef INET
case ETHERTYPE_IP:
schednetisr(NETISR_IP);
@@ -441,7 +439,7 @@ fddi_input(ifp, fh, m)
break;
#endif
default:
- /* printf("fddi_input: unknown protocol 0x%x\n", fddi_type); */
+ /* printf("fddi_input: unknown protocol 0x%x\n", etype); */
ifp->if_noproto++;
goto dropanyway;
}
@@ -563,6 +561,7 @@ fddi_ifattach(ifp)
ifp->if_addrlen = 6;
ifp->if_hdrlen = 21;
ifp->if_mtu = FDDIMTU;
+ ifp->if_output = fddi_output;
#ifdef __NetBSD__
for (ifa = ifp->if_addrlist.tqh_first; ifa != 0;
ifa = ifa->ifa_list.tqe_next)