diff options
author | Henning Brauer <henning@cvs.openbsd.org> | 2003-12-20 20:09:35 +0000 |
---|---|---|
committer | Henning Brauer <henning@cvs.openbsd.org> | 2003-12-20 20:09:35 +0000 |
commit | 32bcb32b20711879f3097d9b7e644c12870527a8 (patch) | |
tree | 49e89a42e46a91c9bdab63fd1f2019fb76be1119 | |
parent | 7d0d2c4f793333beb43e42c8b62ef1d2bc95b159 (diff) |
don't cast imsg.data to struct peer_config, memcpy instead, fixes 64bit
prodded by theo
-rw-r--r-- | usr.sbin/bgpd/session.c | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/usr.sbin/bgpd/session.c b/usr.sbin/bgpd/session.c index 4dbd1d5bc5b..642d95134b9 100644 --- a/usr.sbin/bgpd/session.c +++ b/usr.sbin/bgpd/session.c @@ -1,4 +1,4 @@ -/* $OpenBSD: session.c,v 1.16 2003/12/20 18:32:22 henning Exp $ */ +/* $OpenBSD: session.c,v 1.17 2003/12/20 20:09:34 henning Exp $ */ /* * Copyright (c) 2003 Henning Brauer <henning@openbsd.org> @@ -1206,7 +1206,7 @@ void session_dispatch_imsg(int fd, int idx) { struct imsg imsg; - struct peer_config *pconf; + struct peer_config pconf; struct peer *p, *next; enum reconf_action reconf; @@ -1226,8 +1226,8 @@ session_dispatch_imsg(int fd, int idx) case IMSG_RECONF_PEER: if (idx != PFD_PIPE_MAIN) fatal("reconf request not from parent", 0); - pconf = (struct peer_config *)imsg.data; - p = getpeerbyip(pconf->remote_addr.sin_addr.s_addr); + memcpy(&pconf, imsg.data, sizeof(pconf)); + p = getpeerbyip(pconf.remote_addr.sin_addr.s_addr); if (p == NULL) { if ((p = calloc(1, sizeof(struct peer))) == NULL) @@ -1240,21 +1240,21 @@ session_dispatch_imsg(int fd, int idx) } else reconf = RECONF_KEEP; - if (bcmp(&p->conf.remote_addr, &pconf->remote_addr, + if (bcmp(&p->conf.remote_addr, &pconf.remote_addr, sizeof(struct sockaddr_in))) reconf = RECONF_REINIT; - if (bcmp(&p->conf.local_addr, &pconf->local_addr, + if (bcmp(&p->conf.local_addr, &pconf.local_addr, sizeof(struct sockaddr_in))) reconf = RECONF_REINIT; - if (p->conf.remote_as != pconf->remote_as) + if (p->conf.remote_as != pconf.remote_as) reconf = RECONF_REINIT; - if (p->conf.distance != pconf->distance) + if (p->conf.distance != pconf.distance) reconf = RECONF_REINIT; - memcpy(&p->conf, pconf, sizeof(struct peer_config)); + memcpy(&p->conf, &pconf, sizeof(pconf)); p->conf.reconf_action = reconf; - if (pconf->reconf_action > reconf) - p->conf.reconf_action = pconf->reconf_action; + if (pconf.reconf_action > reconf) + p->conf.reconf_action = pconf.reconf_action; if (p->state >= STATE_OPENSENT) { if (p->holdtime == conf->holdtime && |