summaryrefslogtreecommitdiff
path: root/usr.sbin/hoststated
diff options
context:
space:
mode:
authorReyk Floeter <reyk@cvs.openbsd.org>2007-01-09 03:32:57 +0000
committerReyk Floeter <reyk@cvs.openbsd.org>2007-01-09 03:32:57 +0000
commitcd8506253e59a8ce53fa253524f81cc8dc6b792d (patch)
treec2b432fdd554410badafccca8a20d506a6e773e8 /usr.sbin/hoststated
parent8705be850471d6a8551be4548fb6a48ddcba04f2 (diff)
use the correct buffer sizes.
(this code needs some more work to implement a better icmp handling, but this will fix a serious bug for now)
Diffstat (limited to 'usr.sbin/hoststated')
-rw-r--r--usr.sbin/hoststated/check_icmp.c32
-rw-r--r--usr.sbin/hoststated/hoststated.h3
2 files changed, 16 insertions, 19 deletions
diff --git a/usr.sbin/hoststated/check_icmp.c b/usr.sbin/hoststated/check_icmp.c
index d48222910cf..fb7692eac5e 100644
--- a/usr.sbin/hoststated/check_icmp.c
+++ b/usr.sbin/hoststated/check_icmp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: check_icmp.c,v 1.8 2007/01/09 00:45:32 deraadt Exp $ */
+/* $OpenBSD: check_icmp.c,v 1.9 2007/01/09 03:32:56 reyk Exp $ */
/*
* Copyright (c) 2006 Pierre-Yves Ritschard <pyr@spootnik.org>
@@ -125,8 +125,7 @@ send_icmp6(struct ctl_icmp_event *cie, struct host *host)
struct sockaddr *to;
struct icmp6_hdr *icp;
ssize_t i;
- int datalen = (64 - 8);
- u_char packet[datalen];
+ u_char packet[ICMP_BUF_SIZE];
cie->has_icmp6 = 1;
to = (struct sockaddr *)&host->ss;
@@ -139,9 +138,9 @@ send_icmp6(struct ctl_icmp_event *cie, struct host *host)
memcpy((packet + sizeof(*icp)), &host->id, sizeof(host->id));
- i = sendto(cie->icmp6_sock, packet, datalen + 8, 0, to,
+ i = sendto(cie->icmp6_sock, packet, sizeof(packet), 0, to,
sizeof(struct sockaddr_in6));
- if (i < 0 || i != datalen + 8) {
+ if (i < 0 || i != sizeof(packet)) {
host->up = HOST_DOWN;
hce_notify_done(host, "send_icmp6: cannot send");
return;
@@ -154,8 +153,7 @@ send_icmp4(struct ctl_icmp_event *cie, struct host *host)
struct sockaddr *to;
struct icmp *icp;
ssize_t i;
- int datalen = (64 - 8);
- u_char packet[datalen];
+ u_char packet[ICMP_BUF_SIZE];
cie->has_icmp4 = 1;
to = (struct sockaddr *)&host->ss;
@@ -168,11 +166,11 @@ send_icmp4(struct ctl_icmp_event *cie, struct host *host)
icp->icmp_cksum = 0;
memcpy(icp->icmp_data, &host->id, sizeof(host->id));
- icp->icmp_cksum = in_cksum((u_short *)icp, datalen + 8);
+ icp->icmp_cksum = in_cksum((u_short *)icp, sizeof(packet));
- i = sendto(cie->icmp_sock, packet, datalen + 8, 0, to,
+ i = sendto(cie->icmp_sock, packet, sizeof(packet), 0, to,
sizeof(struct sockaddr_in));
- if (i < 0 || i != datalen + 8) {
+ if (i < 0 || i != sizeof(packet)) {
host->up = HOST_DOWN;
hce_notify_done(host, "send_icmp4: cannot send");
}
@@ -182,8 +180,7 @@ void
recv_icmp6(int s, short event, void *arg)
{
struct ctl_icmp_event *cie = arg;
- int datalen = (64 - 8);
- u_char packet[datalen];
+ u_char packet[ICMP_BUF_SIZE];
socklen_t len;
struct sockaddr_storage ss;
struct icmp6_hdr *icp;
@@ -218,8 +215,8 @@ recv_icmp6(int s, short event, void *arg)
bzero(&packet, sizeof(packet));
bzero(&ss, sizeof(ss));
len = sizeof(struct sockaddr_in6);
- i = recvfrom(s, packet, datalen + 8, 0, (struct sockaddr *)&ss, &len);
- if (i < 0 || i != datalen + 8) {
+ i = recvfrom(s, packet, sizeof(packet), 0, (struct sockaddr *)&ss, &len);
+ if (i < 0 || i != sizeof(packet)) {
log_warn("recv_icmp6: did not receive valid ping");
return;
}
@@ -251,11 +248,10 @@ recv_icmp6(int s, short event, void *arg)
void
recv_icmp4(int s, short event, void *arg)
{
- int datalen = (64 - 8);
socklen_t len;
struct icmp *icp;
struct ctl_icmp_event *cie = arg;
- u_char packet[datalen];
+ u_char packet[ICMP_BUF_SIZE];
struct host *host;
struct table *table;
ssize_t i;
@@ -289,8 +285,8 @@ recv_icmp4(int s, short event, void *arg)
len = sizeof(struct sockaddr_in);
bzero(&packet, sizeof(packet));
bzero(&ss, sizeof(ss));
- i = recvfrom(s, packet, datalen + 8, 0, (struct sockaddr *)&ss, &len);
- if (i < 0 || i != (datalen + 8)) {
+ i = recvfrom(s, packet, sizeof(packet), 0, (struct sockaddr *)&ss, &len);
+ if (i < 0 || i != sizeof(packet)) {
log_warn("recv_icmp4: did not receive valid ping");
return;
}
diff --git a/usr.sbin/hoststated/hoststated.h b/usr.sbin/hoststated/hoststated.h
index ada7240601c..8f1137e6be1 100644
--- a/usr.sbin/hoststated/hoststated.h
+++ b/usr.sbin/hoststated/hoststated.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: hoststated.h,v 1.11 2007/01/08 20:46:18 reyk Exp $ */
+/* $OpenBSD: hoststated.h,v 1.12 2007/01/09 03:32:56 reyk Exp $ */
/*
* Copyright (c) 2006 Pierre-Yves Ritschard <pyr@spootnik.org>
@@ -34,6 +34,7 @@
#define SMALL_READ_BUF_SIZE 1024
#define READ_BUF_SIZE 65535
+#define ICMP_BUF_SIZE 64
/* buffer */
struct buf {