diff options
author | Paul Fox | 2005-07-19 20:37:15 +0000 |
---|---|---|
committer | Paul Fox | 2005-07-19 20:37:15 +0000 |
commit | b270315b2138701cf101f55f675c9445e5c16ba9 (patch) | |
tree | 37e2f30871b1cc70a4ef7eb9289538d7c9e3d9d4 | |
parent | 90161c92139c03fdcc060e472a764af604d25858 (diff) | |
download | busybox-b270315b2138701cf101f55f675c9445e5c16ba9.zip busybox-b270315b2138701cf101f55f675c9445e5c16ba9.tar.gz |
applying fix for:
0000045: traceroute causes an alignment trap due to unaligned buffer on arm
-rw-r--r-- | networking/traceroute.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/networking/traceroute.c b/networking/traceroute.c index 44ffdf0..c691551 100644 --- a/networking/traceroute.c +++ b/networking/traceroute.c @@ -77,6 +77,7 @@ #define MAXPACKET 65535 /* max ip packet size */ +#define MAXPACKET_ICMP 512 #ifndef MAXHOSTNAMELEN #define MAXHOSTNAMELEN 64 #endif @@ -101,7 +102,6 @@ struct opacket { #include "busybox.h" -static u_char packet[512]; /* last inbound (icmp) packet */ static struct opacket *outpacket; /* last output (udp) packet */ static int s; /* receive (icmp) socket file descriptor */ @@ -185,7 +185,7 @@ deltaT(struct timeval *t1p, struct timeval *t2p) } static inline int -wait_for_reply(int sock, struct sockaddr_in *from, int reset_timer) +wait_for_reply(int sock, struct sockaddr_in *from, int reset_timer, u_char *packet, int size) { fd_set fds; static struct timeval wait; @@ -212,7 +212,7 @@ wait_for_reply(int sock, struct sockaddr_in *from, int reset_timer) } if (select(sock+1, &fds, (fd_set *)0, (fd_set *)0, &wait) > 0) - cc=recvfrom(s, (char *)packet, sizeof(packet), 0, + cc=recvfrom(s, (char *)packet, size, 0, (struct sockaddr *)from, &fromlen); return(cc); @@ -339,10 +339,12 @@ traceroute_main(int argc, char *argv[]) struct hostent *hp; struct sockaddr_in from, *to; int ch, i, on, probe, seq, tos, ttl; + u_char *packet; int options = 0; /* socket options */ char *source = 0; int nprobes = 3; + packet = xmalloc (MAXPACKET_ICMP); on = 1; seq = tos = 0; @@ -494,7 +496,7 @@ traceroute_main(int argc, char *argv[]) (void) gettimeofday(&t1, &tz); send_probe(++seq, ttl); reset_timer = 1; - while ((cc = wait_for_reply(s, &from, reset_timer)) != 0) { + while ((cc = wait_for_reply(s, &from, reset_timer, packet, MAXPACKET_ICMP)) != 0) { (void) gettimeofday(&t2, &tz); if ((i = packet_ok(packet, cc, &from, seq))) { reset_timer = 1; |