summaryrefslogtreecommitdiff
path: root/src/ra.c
diff options
context:
space:
mode:
authorSteven Barth <steven@midlink.org>2016-01-31 16:18:16 +0100
committerSteven Barth <steven@midlink.org>2016-01-31 16:18:16 +0100
commitec7f4701b348f5c4c3191ca83ecd8453c431c432 (patch)
tree27dd72af2ae6987703d78eccac80d380f8a26638 /src/ra.c
parent3609bab1361ed3f92e19f7309dd6e7fd64bc4083 (diff)
parentca0693fe09d59a95192c4ad86492f05dfadbbf10 (diff)
downloadodhcp6c-ec7f4701b348f5c4c3191ca83ecd8453c431c432.tar.gz
Merge pull request #44 from bwhacks/alignment-fixes
Alignment fixes
Diffstat (limited to 'src/ra.c')
-rw-r--r--src/ra.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/ra.c b/src/ra.c
index 1c121e6..dd5962a 100644
--- a/src/ra.c
+++ b/src/ra.c
@@ -274,7 +274,8 @@ bool ra_process(void)
{
bool found = false;
bool changed = false;
- uint8_t buf[1500], cmsg_buf[128];
+ uint8_t buf[1500] __aligned(4);
+ uint8_t cmsg_buf[128] __aligned(__alignof__(struct cmsghdr));
struct nd_router_advert *adv = (struct nd_router_advert*)buf;
struct odhcp6c_entry *entry = alloca(sizeof(*entry) + 256);
const struct in6_addr any = IN6ADDR_ANY_INIT;
@@ -444,8 +445,9 @@ bool ra_process(void)
size_t ra_dns_len;
uint8_t *start = odhcp6c_get_state(states[i], &ra_dns_len);
for (struct odhcp6c_entry *c = (struct odhcp6c_entry*)start;
- (uint8_t*)c < &start[ra_dns_len] && &c->auxtarget[c->auxlen] <= &start[ra_dns_len];
- c = (struct odhcp6c_entry*)(&c->auxtarget[c->auxlen]))
+ (uint8_t*)c < &start[ra_dns_len] &&
+ (uint8_t*)odhcp6c_next_entry(c) <= &start[ra_dns_len];
+ c = odhcp6c_next_entry(c))
if (IN6_ARE_ADDR_EQUAL(&c->router, &from.sin6_addr) &&
c->valid > router_valid)
c->valid = router_valid;