applying fix for:
0000045: traceroute causes an alignment trap due to unaligned buffer on arm
This commit is contained in:
parent
90161c9213
commit
b270315b21
@ -77,6 +77,7 @@
|
|||||||
|
|
||||||
|
|
||||||
#define MAXPACKET 65535 /* max ip packet size */
|
#define MAXPACKET 65535 /* max ip packet size */
|
||||||
|
#define MAXPACKET_ICMP 512
|
||||||
#ifndef MAXHOSTNAMELEN
|
#ifndef MAXHOSTNAMELEN
|
||||||
#define MAXHOSTNAMELEN 64
|
#define MAXHOSTNAMELEN 64
|
||||||
#endif
|
#endif
|
||||||
@ -101,7 +102,6 @@ struct opacket {
|
|||||||
|
|
||||||
#include "busybox.h"
|
#include "busybox.h"
|
||||||
|
|
||||||
static u_char packet[512]; /* last inbound (icmp) packet */
|
|
||||||
static struct opacket *outpacket; /* last output (udp) packet */
|
static struct opacket *outpacket; /* last output (udp) packet */
|
||||||
|
|
||||||
static int s; /* receive (icmp) socket file descriptor */
|
static int s; /* receive (icmp) socket file descriptor */
|
||||||
@ -185,7 +185,7 @@ deltaT(struct timeval *t1p, struct timeval *t2p)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static inline int
|
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;
|
fd_set fds;
|
||||||
static struct timeval wait;
|
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)
|
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);
|
(struct sockaddr *)from, &fromlen);
|
||||||
|
|
||||||
return(cc);
|
return(cc);
|
||||||
@ -339,10 +339,12 @@ traceroute_main(int argc, char *argv[])
|
|||||||
struct hostent *hp;
|
struct hostent *hp;
|
||||||
struct sockaddr_in from, *to;
|
struct sockaddr_in from, *to;
|
||||||
int ch, i, on, probe, seq, tos, ttl;
|
int ch, i, on, probe, seq, tos, ttl;
|
||||||
|
u_char *packet;
|
||||||
|
|
||||||
int options = 0; /* socket options */
|
int options = 0; /* socket options */
|
||||||
char *source = 0;
|
char *source = 0;
|
||||||
int nprobes = 3;
|
int nprobes = 3;
|
||||||
|
packet = xmalloc (MAXPACKET_ICMP);
|
||||||
|
|
||||||
on = 1;
|
on = 1;
|
||||||
seq = tos = 0;
|
seq = tos = 0;
|
||||||
@ -494,7 +496,7 @@ traceroute_main(int argc, char *argv[])
|
|||||||
(void) gettimeofday(&t1, &tz);
|
(void) gettimeofday(&t1, &tz);
|
||||||
send_probe(++seq, ttl);
|
send_probe(++seq, ttl);
|
||||||
reset_timer = 1;
|
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);
|
(void) gettimeofday(&t2, &tz);
|
||||||
if ((i = packet_ok(packet, cc, &from, seq))) {
|
if ((i = packet_ok(packet, cc, &from, seq))) {
|
||||||
reset_timer = 1;
|
reset_timer = 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user