diff options
author | Steven Barth <steven@midlink.org> | 2014-02-02 18:40:50 +0100 |
---|---|---|
committer | Steven Barth <steven@midlink.org> | 2014-02-02 18:40:50 +0100 |
commit | 9817e4983c7d4e28f53b78d4fc6ea1eabed8affe (patch) | |
tree | 3f2b1380a11a2dc1ee32ed1b6f14401e1c820ebe /src/ra.c | |
parent | b4a0f3d74b04074eae21e88fbf5b8f2ddc150f86 (diff) | |
download | odhcp6c-9817e4983c7d4e28f53b78d4fc6ea1eabed8affe.tar.gz |
RA: fix on-link/off-link handling
Diffstat (limited to 'src/ra.c')
-rw-r--r-- | src/ra.c | 10 |
1 files changed, 6 insertions, 4 deletions
@@ -356,16 +356,18 @@ bool ra_process(void) || entry.valid < entry.preferred) continue; - if (pinfo->nd_opt_pi_flags_reserved & ND_OPT_PI_FLAG_ONLINK) - changed |= odhcp6c_update_entry_safe(STATE_RA_ROUTE, &entry, 7200); - if (!(pinfo->nd_opt_pi_flags_reserved & ND_OPT_PI_FLAG_AUTO) || - pinfo->nd_opt_pi_prefix_len != 64) + pinfo->nd_opt_pi_prefix_len != 64) { + if (pinfo->nd_opt_pi_flags_reserved & ND_OPT_PI_FLAG_ONLINK) + changed |= odhcp6c_update_entry_safe(STATE_RA_ROUTE, &entry, 7200); continue; + } entry.target.s6_addr32[2] = lladdr.s6_addr32[2]; entry.target.s6_addr32[3] = lladdr.s6_addr32[3]; + if (!(pinfo->nd_opt_pi_flags_reserved & ND_OPT_PI_FLAG_ONLINK)) + entry.length = 128; changed |= odhcp6c_update_entry_safe(STATE_RA_PREFIX, &entry, 7200); } else if (opt->type == ND_OPT_RECURSIVE_DNS && opt->len > 2) { entry.router = from.sin6_addr; |