diff options
author | Jacek Masiulaniec <jacekm@cvs.openbsd.org> | 2009-12-10 14:57:52 +0000 |
---|---|---|
committer | Jacek Masiulaniec <jacekm@cvs.openbsd.org> | 2009-12-10 14:57:52 +0000 |
commit | 14db1f30170bf884d33c731c4e22dfeb66fa9d51 (patch) | |
tree | d9a8bb707c787686d1bccdd8a4612296d8dc3597 /usr.sbin/smtpd/parse.y | |
parent | 4fede28a92d9c09c7f7fb1bd302a350fc565e013 (diff) |
Fix few read overruns found by parfait.
Nudge by deraadt@
Diffstat (limited to 'usr.sbin/smtpd/parse.y')
-rw-r--r-- | usr.sbin/smtpd/parse.y | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/usr.sbin/smtpd/parse.y b/usr.sbin/smtpd/parse.y index 49b20da15b6..fe640223817 100644 --- a/usr.sbin/smtpd/parse.y +++ b/usr.sbin/smtpd/parse.y @@ -1,4 +1,4 @@ -/* $OpenBSD: parse.y,v 1.49 2009/12/06 00:27:31 jacekm Exp $ */ +/* $OpenBSD: parse.y,v 1.50 2009/12/10 14:57:51 jacekm Exp $ */ /* * Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org> @@ -436,7 +436,7 @@ stringel : STRING { if (bits != -1) { ssin.sin_family = AF_INET; me->me_key.med_addr.bits = bits; - me->me_key.med_addr.ss = *(struct sockaddr_storage *)&ssin; + memcpy(&me->me_key.med_addr.ss, &ssin, sizeof(ssin)); me->me_key.med_addr.ss.ss_len = sizeof(struct sockaddr_in); } else { @@ -446,7 +446,7 @@ stringel : STRING { err(1, "inet_net_pton"); ssin6.sin6_family = AF_INET6; me->me_key.med_addr.bits = bits; - me->me_key.med_addr.ss = *(struct sockaddr_storage *)&ssin6; + memcpy(&me->me_key.med_addr.ss, &ssin6, sizeof(ssin6)); me->me_key.med_addr.ss.ss_len = sizeof(struct sockaddr_in6); } } @@ -455,13 +455,13 @@ stringel : STRING { if (inet_pton(AF_INET, $1, &ssin.sin_addr) == 1) { ssin.sin_family = AF_INET; me->me_key.med_addr.bits = 0; - me->me_key.med_addr.ss = *(struct sockaddr_storage *)&ssin; + memcpy(&me->me_key.med_addr.ss, &ssin, sizeof(ssin)); me->me_key.med_addr.ss.ss_len = sizeof(struct sockaddr_in); } else if (inet_pton(AF_INET6, $1, &ssin6.sin6_addr) == 1) { ssin6.sin6_family = AF_INET6; me->me_key.med_addr.bits = 0; - me->me_key.med_addr.ss = *(struct sockaddr_storage *)&ssin6; + memcpy(&me->me_key.med_addr.ss, &ssin6, sizeof(ssin6)); me->me_key.med_addr.ss.ss_len = sizeof(struct sockaddr_in6); } else { @@ -520,7 +520,7 @@ mapref : STRING { if (bits != -1) { ssin.sin_family = AF_INET; me->me_key.med_addr.bits = bits; - me->me_key.med_addr.ss = *(struct sockaddr_storage *)&ssin; + memcpy(&me->me_key.med_addr.ss, &ssin, sizeof(ssin)); me->me_key.med_addr.ss.ss_len = sizeof(struct sockaddr_in); } else { @@ -530,7 +530,7 @@ mapref : STRING { err(1, "inet_net_pton"); ssin6.sin6_family = AF_INET6; me->me_key.med_addr.bits = bits; - me->me_key.med_addr.ss = *(struct sockaddr_storage *)&ssin6; + memcpy(&me->me_key.med_addr.ss, &ssin6, sizeof(ssin6)); me->me_key.med_addr.ss.ss_len = sizeof(struct sockaddr_in6); } } @@ -539,13 +539,13 @@ mapref : STRING { if (inet_pton(AF_INET, $1, &ssin.sin_addr) == 1) { ssin.sin_family = AF_INET; me->me_key.med_addr.bits = 0; - me->me_key.med_addr.ss = *(struct sockaddr_storage *)&ssin; + memcpy(&me->me_key.med_addr.ss, &ssin, sizeof(ssin)); me->me_key.med_addr.ss.ss_len = sizeof(struct sockaddr_in); } else if (inet_pton(AF_INET6, $1, &ssin6.sin6_addr) == 1) { ssin6.sin6_family = AF_INET6; me->me_key.med_addr.bits = 0; - me->me_key.med_addr.ss = *(struct sockaddr_storage *)&ssin6; + memcpy(&me->me_key.med_addr.ss, &ssin6, sizeof(ssin6)); me->me_key.med_addr.ss.ss_len = sizeof(struct sockaddr_in6); } else { |