[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date: Thu, 04 Apr 2013 18:48:45 +0200
From: Daniel Borkmann <dborkman@...hat.com>
To: YOSHIFUJI Hideaki <yoshfuji@...ux-ipv6.org>
CC: davem@...emloft.net, netdev@...r.kernel.org,
Hannes Frederic Sowa <hannes@...essinduktion.org>
Subject: Re: [PATCH net-next 1/2] net: ipv6: add tokenized interface identifier
support
On 04/04/2013 06:29 PM, YOSHIFUJI Hideaki wrote:
> Daniel Borkmann wrote:
>> This patch adds support for tokenized IIDs, that allow for
>> administrators to assign well-known host-part addresses to
>> nodes whilst still obtaining global network prefix from
>> Router Advertisements. It is currently in IETF RFC draft
>> status [1]:
>>
>> The primary target for such support is server platforms
>> where addresses are usually manually configured, rather
>> than using DHCPv6 or SLAAC. By using tokenised identifiers,
>> hosts can still determine their network prefix by use of
>> SLAAC, but more readily be automatically renumbered should
>> their network prefix change.
>>
>> [1] http://tools.ietf.org/html/draft-chown-6man-tokenised-ipv6-identifiers-02
>>
>> The implementation is partially based on top of Mark K.
>> Thompson's proof of concept. Successfully tested by myself.
>>
>> Cc: Hannes Frederic Sowa <hannes@...essinduktion.org>
>> Cc: YOSHIFUJI Hideaki <yoshfuji@...ux-ipv6.org>
>> Signed-off-by: Daniel Borkmann <dborkman@...hat.com>
>> ---
[...]
>> if (pinfo->prefix_len == 64) {
>> memcpy(&addr, &pinfo->prefix, 8);
>> - if (ipv6_generate_eui64(addr.s6_addr + 8, dev) &&
>> - ipv6_inherit_eui64(addr.s6_addr + 8, in6_dev)) {
>> +
>> + if (!ipv6_addr_any(&in6_dev->token)) {
>> + read_lock_bh(&in6_dev->lock);
>> + memcpy(addr.s6_addr + 8,
>> + in6_dev->token.s6_addr + 8, 8);
>> + read_unlock_bh(&in6_dev->lock);
>> + } else if (ipv6_generate_eui64(addr.s6_addr + 8, dev) &&
>> + ipv6_inherit_eui64(addr.s6_addr + 8, in6_dev)) {
>> in6_dev_put(in6_dev);
>> return;
>> }
>
> Why not initialize token by interface-identifier and then allow
> users to "override"?
Sure this would simplify this part above ...
... maybe I'm wrong, but then, probably, if someone changes the netdev's
hw address during runtime, we could not keep track of that anymore as
dynamically done in e.g. ipv6_generate_eui64(), since we've already done
the token init at an earlier point in time, no?
With the current patch, we would have a clear separation of both concepts
like ``either you use token iids, or you don't''.
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists