diff options
author | Claudio Jeker <claudio@cvs.openbsd.org> | 2006-02-24 20:34:35 +0000 |
---|---|---|
committer | Claudio Jeker <claudio@cvs.openbsd.org> | 2006-02-24 20:34:35 +0000 |
commit | 50f15d0094806b70c20ce93691e8c1bb178f7e17 (patch) | |
tree | 62b2472c71626c8d1a3ddcd30ca39cb06bc999d5 /sys/net | |
parent | e1745cc87d6f8a1f9ff11714c733bbc2f09de7fa (diff) |
Another gem from the the-world-runs-on-i386 departement. Using u_long in
a packet format causes some troubles on 64bit archs. This fixes a sppp(4)
panic I got on alpha and makes cisco HDLC mode actually work. More cleanup
needs to be done post 3.9. OK brad@ looks good canacar@
Diffstat (limited to 'sys/net')
-rw-r--r-- | sys/net/if_sppp.h | 6 | ||||
-rw-r--r-- | sys/net/if_spppsubr.c | 28 |
2 files changed, 17 insertions, 17 deletions
diff --git a/sys/net/if_sppp.h b/sys/net/if_sppp.h index b02f4c3d071..a26e8a427d3 100644 --- a/sys/net/if_sppp.h +++ b/sys/net/if_sppp.h @@ -1,4 +1,4 @@ -/* $OpenBSD: if_sppp.h,v 1.9 2005/03/23 00:26:06 canacar Exp $ */ +/* $OpenBSD: if_sppp.h,v 1.10 2006/02/24 20:34:34 claudio Exp $ */ /* $NetBSD: if_sppp.h,v 1.2.2.1 1999/04/04 06:57:39 explorer Exp $ */ /* @@ -107,8 +107,8 @@ struct sppp { u_int pp_framebytes; /* number of bytes added by hardware framing */ u_short pp_alivecnt; /* keepalive packets counter */ u_short pp_loopcnt; /* loopback detection counter */ - u_long pp_seq; /* local sequence number */ - u_long pp_rseq; /* remote sequence number */ + u_int32_t pp_seq; /* local sequence number */ + u_int32_t pp_rseq; /* remote sequence number */ time_t pp_last_receive; /* peer's last "sign of life" */ time_t pp_last_activity; /* second of last payload data s/r */ enum ppp_phase pp_phase; /* phase we're currently in */ diff --git a/sys/net/if_spppsubr.c b/sys/net/if_spppsubr.c index a39efe142a7..a61cafeece3 100644 --- a/sys/net/if_spppsubr.c +++ b/sys/net/if_spppsubr.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_spppsubr.c,v 1.37 2005/10/07 05:19:34 canacar Exp $ */ +/* $OpenBSD: if_spppsubr.c,v 1.38 2006/02/24 20:34:34 claudio Exp $ */ /* * Synchronous PPP/Cisco link level subroutines. * Keepalive protocol implemented in both Cisco and PPP modes. @@ -222,9 +222,9 @@ struct lcp_header { #define LCP_HEADER_LEN sizeof (struct lcp_header) struct cisco_packet { - u_long type; - u_long par1; - u_long par2; + u_int32_t type; + u_int32_t par1; + u_int32_t par2; u_short rel; u_short time0; u_short time1; @@ -301,7 +301,7 @@ static u_short interactive_ports[8] = { HIDE int sppp_output(struct ifnet *ifp, struct mbuf *m, struct sockaddr *dst, struct rtentry *rt); -HIDE void sppp_cisco_send(struct sppp *sp, int type, long par1, long par2); +HIDE void sppp_cisco_send(struct sppp *sp, u_int32_t type, u_int32_t par1, u_int32_t par2); HIDE void sppp_cisco_input(struct sppp *sp, struct mbuf *m); HIDE void sppp_cp_input(const struct cp *cp, struct sppp *sp, @@ -1089,15 +1089,15 @@ sppp_cisco_input(struct sppp *sp, struct mbuf *m) if (debug) log(LOG_DEBUG, SPP_FMT "cisco input: %d bytes " - "<0x%lx 0x%lx 0x%lx 0x%x 0x%x-0x%x>\n", + "<0x%x 0x%x 0x%x 0x%x 0x%x-0x%x>\n", SPP_ARGS(ifp), m->m_pkthdr.len, - (u_long)ntohl (h->type), (u_long)h->par1, (u_long)h->par2, (u_int)h->rel, + ntohl(h->type), h->par1, h->par2, (u_int)h->rel, (u_int)h->time0, (u_int)h->time1); switch (ntohl (h->type)) { default: if (debug) - addlog(SPP_FMT "cisco unknown packet type: 0x%lx\n", - SPP_ARGS(ifp), (u_long)ntohl (h->type)); + addlog(SPP_FMT "cisco unknown packet type: 0x%x\n", + SPP_ARGS(ifp), ntohl(h->type)); break; case CISCO_ADDR_REPLY: /* Reply on address request, ignore */ @@ -1146,7 +1146,7 @@ sppp_cisco_input(struct sppp *sp, struct mbuf *m) * Send Cisco keepalive packet. */ HIDE void -sppp_cisco_send(struct sppp *sp, int type, long par1, long par2) +sppp_cisco_send(struct sppp *sp, u_int32_t type, u_int32_t par1, u_int32_t par2) { STDDCL; struct ppp_header *h; @@ -1177,10 +1177,10 @@ sppp_cisco_send(struct sppp *sp, int type, long par1, long par2) ch->time1 = htons ((u_short) tv.tv_sec); if (debug) - log(LOG_DEBUG, - SPP_FMT "cisco output: <0x%lx 0x%lx 0x%lx 0x%x 0x%x-0x%x>\n", - SPP_ARGS(ifp), (u_long)ntohl (ch->type), (u_long)ch->par1, - (u_long)ch->par2, (u_int)ch->rel, (u_int)ch->time0, (u_int)ch->time1); + log(LOG_DEBUG, SPP_FMT + "cisco output: <0x%lx 0x%lx 0x%lx 0x%x 0x%x-0x%x>\n", + SPP_ARGS(ifp), ntohl(ch->type), ch->par1, ch->par2, + (u_int)ch->rel, (u_int)ch->time0, (u_int)ch->time1); if (IF_QFULL (&sp->pp_cpq)) { IF_DROP (&sp->pp_fastq); |