summaryrefslogtreecommitdiff
path: root/sys/net
diff options
context:
space:
mode:
authorClaudio Jeker <claudio@cvs.openbsd.org>2006-02-24 20:34:35 +0000
committerClaudio Jeker <claudio@cvs.openbsd.org>2006-02-24 20:34:35 +0000
commit50f15d0094806b70c20ce93691e8c1bb178f7e17 (patch)
tree62b2472c71626c8d1a3ddcd30ca39cb06bc999d5 /sys/net
parente1745cc87d6f8a1f9ff11714c733bbc2f09de7fa (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.h6
-rw-r--r--sys/net/if_spppsubr.c28
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);