• Paolo Abeni's avatar
    net: add dst_cache support · d365b297
    Paolo Abeni authored
    commit 911362c7 upstream.
    
    This patch add a generic, lockless dst cache implementation.
    The need for lock is avoided updating the dst cache fields
    only in per cpu scope, and requiring that the cache manipulation
    functions are invoked with the local bh disabled.
    
    The refresh_ts and reset_ts fields are used to ensure the cache
    consistency in case of cuncurrent cache update (dst_cache_set*) and
    reset operation (dst_cache_reset).
    
    Consider the following scenario:
    
    CPU1:                                   	CPU2:
      <cache lookup with emtpy cache: it fails>
      <get dst via uncached route lookup>
    						<related configuration changes>
                                            	dst_cache_reset()
      dst_cache_set()
    
    The dst entry set passed to dst_cache_set() should not be used
    for later dst cache lookup, because it's obtained using old
    configuration values.
    
    Since the refresh_ts is updated only on dst_cache lookup, the
    cached value in the above scenario will be discarded on the next
    lookup.
    Signed-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
    Suggested-and-acked-by: default avatarHannes Frederic Sowa <hannes@stressinduktion.org>
    Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
    Signed-off-by: default avatarManoj Boopathi Raj <manojboopathi@google.com>
    Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
    d365b297
dst_cache.h 2.49 KB