[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <54EE3F04.2000703@redhat.com>
Date: Wed, 25 Feb 2015 13:30:44 -0800
From: Alexander Duyck <alexander.h.duyck@...hat.com>
To: Julian Anastasov <ja@....bg>
CC: netdev@...r.kernel.org, davem@...emloft.net
Subject: Re: [net-next PATCH 2/4] fib_trie: Replace plen with slen in leaf_info
On 02/25/2015 01:15 PM, Julian Anastasov wrote:
> Hello,
>
> On Wed, 25 Feb 2015, Alexander Duyck wrote:
>
>> hlist_for_each_entry_rcu(li, &n->list, hlist) {
>> struct fib_alias *fa;
>>
>> - if ((key ^ n->key) & li->mask_plen)
>> + if (((key ^ n->key) >> li->slen) &&
>> + ((BITS_PER_LONG > KEYLENGTH) || (li->slen != KEYLENGTH)))
>> continue;
> The '(BITS_PER_LONG > KEYLENGTH) ||' part is not
> needed because on 64-bit processor we can still use
> 32-bit register (due to 32-bit t_key type) and to get
> undefined (!0) result from rshift with 32. We do not want
> to continue in this case. Is it really working on 64-bit for
> 0.0.0.0/0 ?
>
> Regards
>
> --
> Julian Anastasov <ja@....bg>
It is working but that may be due to the fact that gcc decided to place
the key in a 64b register.
The last patch in the series probably does a better job of addressing
your concern. It replaces the shift with a comparison to (1ul <<
fa->fa_slen). In that case I believe the BITS_PER_LONG check would then
be appropriate would it not?
- Alex
--
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