aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBernhard Reutner-Fischer <rep.dot.nop@gmail.com>2006-03-31 18:13:42 +0000
committerBernhard Reutner-Fischer <rep.dot.nop@gmail.com>2006-03-31 18:13:42 +0000
commit2766eedde85f092153a2affb2d3da491e2670982 (patch)
tree6dbc5fe0f29d0864b79259f1f5d310c762d026a5
parente47c4cbd4d3d5c186a497e52106282a9cb0c371d (diff)
downloadbusybox-w32-2766eedde85f092153a2affb2d3da491e2670982.tar.gz
busybox-w32-2766eedde85f092153a2affb2d3da491e2670982.tar.bz2
busybox-w32-2766eedde85f092153a2affb2d3da491e2670982.zip
- use RESERVE_CONFIG_BUFFER. For defconfig this gives:
text data bss dec hex filename 3627 4 120 3751 ea7 networking/arping.o.oorig 3548 4 96 3648 e40 networking/arping.o.r14710 3520 4 96 3620 e24 networking/arping.o
-rw-r--r--networking/arping.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/networking/arping.c b/networking/arping.c
index 782b61b64..4f1a2e2c5 100644
--- a/networking/arping.c
+++ b/networking/arping.c
@@ -71,7 +71,7 @@ static int send_pack(int sock, struct in_addr *src_addr,
71{ 71{
72 int err; 72 int err;
73 struct timeval now; 73 struct timeval now;
74 unsigned char buf[256]; 74 RESERVE_CONFIG_UBUFFER(buf, 256);
75 struct arphdr *ah = (struct arphdr *) buf; 75 struct arphdr *ah = (struct arphdr *) buf;
76 unsigned char *p = (unsigned char *) (ah + 1); 76 unsigned char *p = (unsigned char *) (ah + 1);
77 77
@@ -105,6 +105,7 @@ static int send_pack(int sock, struct in_addr *src_addr,
105 if (!(cfg&unicasting)) 105 if (!(cfg&unicasting))
106 brd_sent++; 106 brd_sent++;
107 } 107 }
108 RELEASE_CONFIG_BUFFER(buf);
108 return err; 109 return err;
109} 110}
110 111
@@ -456,12 +457,12 @@ int arping_main(int argc, char **argv)
456 457
457 while (1) { 458 while (1) {
458 sigset_t sset, osset; 459 sigset_t sset, osset;
459 unsigned char packet[4096]; 460 RESERVE_CONFIG_UBUFFER(packet, 4096);
460 struct sockaddr_ll from; 461 struct sockaddr_ll from;
461 socklen_t alen = sizeof(from); 462 socklen_t alen = sizeof(from);
462 int cc; 463 int cc;
463 464
464 if ((cc = recvfrom(s, packet, sizeof(packet), 0, 465 if ((cc = recvfrom(s, packet, 4096, 0,
465 (struct sockaddr *) &from, &alen)) < 0) { 466 (struct sockaddr *) &from, &alen)) < 0) {
466 perror("recvfrom"); 467 perror("recvfrom");
467 continue; 468 continue;
@@ -472,5 +473,6 @@ int arping_main(int argc, char **argv)
472 sigprocmask(SIG_BLOCK, &sset, &osset); 473 sigprocmask(SIG_BLOCK, &sset, &osset);
473 recv_pack(packet, cc, &from); 474 recv_pack(packet, cc, &from);
474 sigprocmask(SIG_SETMASK, &osset, NULL); 475 sigprocmask(SIG_SETMASK, &osset, NULL);
476 RELEASE_CONFIG_BUFFER(packet);
475 } 477 }
476} 478}