diff options
author | brian <brian@cvs.openbsd.org> | 2001-09-04 22:12:33 +0000 |
---|---|---|
committer | brian <brian@cvs.openbsd.org> | 2001-09-04 22:12:33 +0000 |
commit | 483195325aa7e1f3422f393376569fdb8af780b4 (patch) | |
tree | f3c260d8e351a867645dc320ac60fec27bd610c5 | |
parent | 1f405e98ca3615cb932acdc57bfc8adf9596aebe (diff) |
Consider alignment requirements when moving data about.
Mostly submitted by: kamath@cesa.opbu.xerox.com
-rw-r--r-- | usr.sbin/ppp/ppp/mppe.c | 39 |
1 files changed, 21 insertions, 18 deletions
diff --git a/usr.sbin/ppp/ppp/mppe.c b/usr.sbin/ppp/ppp/mppe.c index 293d77a2ae4..1d3b0bfcb6c 100644 --- a/usr.sbin/ppp/ppp/mppe.c +++ b/usr.sbin/ppp/ppp/mppe.c @@ -23,7 +23,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $OpenBSD: mppe.c,v 1.9 2001/08/27 17:54:35 brian Exp $ + * $OpenBSD: mppe.c,v 1.10 2001/09/04 22:12:32 brian Exp $ */ #include <sys/types.h> @@ -54,6 +54,7 @@ #include "chap_ms.h" #include "proto.h" #include "mppe.h" +#include "ua.h" /* * Documentation: @@ -190,7 +191,7 @@ MPPEOutput(void *v, struct ccp *ccp, struct link *l, int pri, u_short *proto, } /* Set MPPE packet prefix */ - *(u_short *)rp = htons(prefix); + ua_htons(&prefix, rp); /* Save encrypted protocol number */ nproto = htons(*proto); @@ -364,10 +365,11 @@ static const char * MPPEDispOpts(struct lcp_opt *o) { static char buf[70]; - u_int32_t val = ntohl(*(u_int32_t *)o->data); + u_int32_t val; char ch; int len; + ua_ntohl(o->data, &val); snprintf(buf, sizeof buf, "value 0x%08x ", (unsigned)val); len = strlen(buf); if (!(val & MPPE_OPT_BITMASK)) { @@ -457,18 +459,19 @@ MPPE_ConfigVal(const struct ccp_config *cfg) static void MPPEInitOptsOutput(struct lcp_opt *o, const struct ccp_config *cfg) { - u_int32_t *p = (u_int32_t *)o->data; + u_int32_t mval; o->len = 6; if (!MPPE_MasterKeyValid) { log_Printf(LogCCP, "MPPE: MasterKey is invalid," " MPPE is available only with CHAP81 authentication\n"); - *p = htonl(0x0); + ua_htonl(0x0, o->data); return; } - *p = htonl(MPPE_ConfigVal(cfg)); + mval = MPPE_ConfigVal(cfg); + ua_htonl(&mval, o->data); } /* @@ -477,9 +480,9 @@ MPPEInitOptsOutput(struct lcp_opt *o, const struct ccp_config *cfg) static int MPPESetOptsOutput(struct lcp_opt *o, const struct ccp_config *cfg) { - u_int32_t *p = (u_int32_t *)o->data; - u_int32_t peer = ntohl(*p); - u_int32_t mval; + u_int32_t mval, peer; + + ua_ntohl(o->data, &peer); if (!MPPE_MasterKeyValid) /* Treat their NAK as a REJ */ @@ -504,7 +507,7 @@ MPPESetOptsOutput(struct lcp_opt *o, const struct ccp_config *cfg) mval |= (peer & MPPE_OPT_STATELESS); } - *p = htonl(mval); + ua_htonl(&mval, o->data); return MODE_ACK; } @@ -515,14 +518,14 @@ MPPESetOptsOutput(struct lcp_opt *o, const struct ccp_config *cfg) static int MPPESetOptsInput(struct lcp_opt *o, const struct ccp_config *cfg) { - u_int32_t *p = (u_int32_t *)(o->data); - u_int32_t peer = ntohl(*p); - u_int32_t mval; + u_int32_t mval, peer; int res = MODE_ACK; + ua_ntohl(o->data, &peer); if (!MPPE_MasterKeyValid) { - if (*p != 0x0) { - *p = 0x0; + if (peer != 0) { + peer = 0; + ua_htonl(&peer, o->data); return MODE_NAK; } else return MODE_ACK; @@ -552,7 +555,7 @@ MPPESetOptsInput(struct lcp_opt *o, const struct ccp_config *cfg) /* If we've got a configured number of keybits - the peer must use that */ if (cfg->mppe.keybits) { - *p = htonl(mval); + ua_htonl(&mval, o->data); return peer == mval ? res : MODE_NAK; } @@ -576,7 +579,7 @@ MPPESetOptsInput(struct lcp_opt *o, const struct ccp_config *cfg) mval |= MPPE_OPT_40BIT; else mval |= MPPE_OPT_128BIT; - *p = htonl(mval); + ua_htonl(&mval, o->data); return res; } @@ -588,7 +591,7 @@ MPPE_InitState(struct lcp_opt *o) u_int32_t val; if ((mp = calloc(1, sizeof *mp)) != NULL) { - val = ntohl(*(u_int32_t *)o->data); + ua_ntohl(o->data, &val); switch (val & MPPE_OPT_BITMASK) { case MPPE_OPT_128BIT: |