summaryrefslogtreecommitdiff
path: root/usr.sbin/sensorsd/sensorsd.c
diff options
context:
space:
mode:
authorHans-Joerg Hoexer <hshoexer@cvs.openbsd.org>2005-04-20 21:08:46 +0000
committerHans-Joerg Hoexer <hshoexer@cvs.openbsd.org>2005-04-20 21:08:46 +0000
commit5dba608b70a7ae8016a0e5fb77bd200394dc1eee (patch)
treea75fe4452f1ecaa8b48df1bd2be1522ddaeb0d9c /usr.sbin/sensorsd/sensorsd.c
parentea8d348e682efe80891f6f5675f378742b4400de (diff)
fix buffer overrun introduced with my previous commit. Found and fixed by
moritz@; while around take care of snprintf return values help and ok moritz@, henning@
Diffstat (limited to 'usr.sbin/sensorsd/sensorsd.c')
-rw-r--r--usr.sbin/sensorsd/sensorsd.c23
1 files changed, 11 insertions, 12 deletions
diff --git a/usr.sbin/sensorsd/sensorsd.c b/usr.sbin/sensorsd/sensorsd.c
index e9641cb070c..8274361fd39 100644
--- a/usr.sbin/sensorsd/sensorsd.c
+++ b/usr.sbin/sensorsd/sensorsd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sensorsd.c,v 1.13 2005/04/01 22:15:40 deraadt Exp $ */
+/* $OpenBSD: sensorsd.c,v 1.14 2005/04/20 21:08:45 hshoexer Exp $ */
/*
* Copyright (c) 2003 Henning Brauer <henning@openbsd.org>
@@ -255,37 +255,36 @@ report(time_t last_report)
switch (cmd[i]) {
case '1':
- r = snprintf(&buf[n], len, "%d",
+ r = snprintf(&buf[n], len - n, "%d",
limit->num);
break;
case '2':
- r = snprintf(&buf[n], len, "%s",
+ r = snprintf(&buf[n], len - n, "%s",
print_sensor(limit->type,
limit->last_val));
break;
case '3':
- r = snprintf(&buf[n], len, "%s",
+ r = snprintf(&buf[n], len - n, "%s",
print_sensor(limit->type,
limit->lower));
break;
case '4':
- r = snprintf(&buf[n], len, "%s",
+ r = snprintf(&buf[n], len - n, "%s",
print_sensor(limit->type,
limit->upper));
break;
default:
- r = snprintf(&buf[n], len, "%%%c",
+ r = snprintf(&buf[n], len - n, "%%%c",
cmd[i]);
break;
}
- if (r > len) {
- buf[n] = '\0';
- break;
+ if (r < 0 || (r >= len - n)) {
+ syslog(LOG_CRIT, "could not parse "
+ "command");
+ return;
}
- if (r > 0) {
- len -= r;
+ if (r > 0)
n += r;
- }
}
if (buf[0])
execute(buf);