summaryrefslogtreecommitdiff
path: root/usr.sbin
diff options
context:
space:
mode:
authorHenning Brauer <henning@cvs.openbsd.org>2007-03-02 11:37:54 +0000
committerHenning Brauer <henning@cvs.openbsd.org>2007-03-02 11:37:54 +0000
commit359d0ec2d1864d5a8bc7dd8424b4c833969054c7 (patch)
tree9502464652df644bb80d6a16684e2c2232ed87b7 /usr.sbin
parentcbf005ba666d772bc3266b4717b12de55a105d36 (diff)
pull in spaces array overflow fixes from dhclient
the code here is slightly different, but also has the overfow in both cases
Diffstat (limited to 'usr.sbin')
-rw-r--r--usr.sbin/dhcpd/errwarn.c22
1 files changed, 13 insertions, 9 deletions
diff --git a/usr.sbin/dhcpd/errwarn.c b/usr.sbin/dhcpd/errwarn.c
index 9d92d1cde9d..70bc1830594 100644
--- a/usr.sbin/dhcpd/errwarn.c
+++ b/usr.sbin/dhcpd/errwarn.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: errwarn.c,v 1.6 2005/04/18 16:39:25 moritz Exp $ */
+/* $OpenBSD: errwarn.c,v 1.7 2007/03/02 11:37:53 henning Exp $ */
/* Errors and warnings... */
@@ -199,6 +199,7 @@ parse_warn(char *fmt, ...)
" "
" "; /* 80 spaces */
struct iovec iov[6];
+ size_t iovcnt;
do_percentm(mbuf, sizeof(mbuf), fmt);
snprintf(fbuf, sizeof(fbuf), "%s line %d: %s", tlname, lexline, mbuf);
@@ -215,17 +216,20 @@ parse_warn(char *fmt, ...)
iov[2].iov_len = strlen(token_line);
iov[3].iov_base = "\n";
iov[3].iov_len = 1;
- iov[4].iov_base = spaces;
- iov[4].iov_len = lexchar - 1;
- iov[5].iov_base = "^\n";
- iov[5].iov_len = 2;
- writev(STDERR_FILENO, iov, sizeof(iov)/sizeof(iov[0]));
+ iovcnt = 4;
+ if (lexchar < 81) {
+ iov[4].iov_base = spaces;
+ iov[4].iov_len = lexchar - 1;
+ iov[5].iov_base = "^\n";
+ iov[5].iov_len = 2;
+ iovcnt += 2;
+ }
+ writev(STDERR_FILENO, iov, iovcnt);
} else {
syslog(log_priority | LOG_ERR, "%s", mbuf);
syslog(log_priority | LOG_ERR, "%s", token_line);
- if (lexline < 81)
- syslog(log_priority | LOG_ERR,
- "%s^", &spaces[sizeof(spaces) - lexchar]);
+ if (lexchar < 81)
+ syslog(log_priority | LOG_ERR, "%*c", lexchar, '^');
}
warnings_occurred = 1;