diff options
author | Daniel Hartmeier <dhartmei@cvs.openbsd.org> | 2003-04-08 01:06:45 +0000 |
---|---|---|
committer | Daniel Hartmeier <dhartmei@cvs.openbsd.org> | 2003-04-08 01:06:45 +0000 |
commit | 57eb0c0822af3cab5795c90eb92e6cc86d57a335 (patch) | |
tree | 07cfc6d64886e605f7713f8e6900e3845d1041e9 /usr.sbin | |
parent | d88665c24ed240c730ab7a5fe09053d0336f7a6b (diff) |
strlcpy, pass length to function. ok tdeval@, deraadt@
Diffstat (limited to 'usr.sbin')
-rw-r--r-- | usr.sbin/mrouted/vif.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/usr.sbin/mrouted/vif.c b/usr.sbin/mrouted/vif.c index 1c7978858dc..d0546e5e7d7 100644 --- a/usr.sbin/mrouted/vif.c +++ b/usr.sbin/mrouted/vif.c @@ -40,7 +40,7 @@ static void start_vif2(vifi_t vifi); static void stop_vif(vifi_t vifi); static void age_old_hosts(void); static void send_probe_on_vif(struct uvif *v); -static int info_version(char *p); +static int info_version(char *p, int); static void DelVif(void *arg); static int SetTimer(int vifi, struct listaddr *g); static int DeleteTimer(int id); @@ -903,7 +903,7 @@ accept_info_request(u_int32_t src, u_int32_t dst, char *p, int datalen) len = 0; switch (*p) { case DVMRP_INFO_VERSION: - len = info_version(q); + len = info_version(q, (u_char *)send_buf + RECV_BUF_SIZE - q); break; case DVMRP_INFO_NEIGHBORS: @@ -928,18 +928,19 @@ accept_info_request(u_int32_t src, u_int32_t dst, char *p, int datalen) * Information response -- return version string */ static int -info_version(char *p) +info_version(char *p, int len) { - int len; extern char versionstring[]; + if (len < 5) + return (0); *p++ = DVMRP_INFO_VERSION; p++; /* skip over length */ *p++ = 0; /* zero out */ *p++ = 0; /* reserved fields */ - strcpy(p, versionstring); /* XXX strncpy!!! */ + strlcpy(p, versionstring, len - 4); - len = strlen(versionstring); + len = strlen(p); return ((len + 3) / 4); } |