• Netanel Belgazal's avatar
    net: ena: add support for out of order rx buffers refill · 4bf25eec
    Netanel Belgazal authored
    BugLink: http://bugs.launchpad.net/bugs/1701575
    
    ENA driver post Rx buffers through the Rx submission queue
    for the ENA device to fill them with receive packets.
    Each Rx buffer is marked with req_id in the Rx descriptor.
    
    Newer ENA devices could consume the posted Rx buffer in out of order,
    and as result the corresponding Rx completion queue will have Rx
    completion descriptors with non contiguous req_id(s)
    
    In this change the driver holds two rings.
    The first ring (called free_rx_ids) is a mapping ring.
    It holds all the unused request ids.
    The values in this ring are from 0 to ring_size -1.
    
    When the driver wants to allocate a new Rx buffer it uses the head of
    free_rx_ids and uses it's value as the index for rx_buffer_info ring.
    The req_id is also written to the Rx descriptor
    
    Upon Rx completion,
    The driver took the req_id from the completion descriptor and uses it
    as index in rx_buffer_info.
    The req_id is then return to the free_rx_ids ring.
    
    This patch also adds statistics to inform when the driver receive out
    of range or unused req_id.
    
    Note:
    free_rx_ids is only accessible from the napi handler, so no locking is
    required
    Signed-off-by: default avatarNetanel Belgazal <netanel@amazon.com>
    Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
    (cherry picked from commit ad974bae net-next)
    Signed-off-by: default avatarKamal Mostafa <kamal@canonical.com>
    Acked-by: default avatarSeth Forshee <seth.forshee@canonical.com>
    Acked-by: default avatarBrad Figg <brad.figg@canonical.com>
    4bf25eec
ena_netdev.h 8.6 KB