• Stanislaw Gruszka's avatar
    mt76: fix frag length allocation for usb · c87dff8c
    Stanislaw Gruszka authored
    This is correct fix for c12128ce ("mt76: use a per rx queue page
    fragment cache"). We use wrong length when we allocate segments for
    MCU transmissions, which require bigger segment size than e->buf_size.
    
    Commit 481bb043 ("mt76: usb: make rx page_frag_cache access atomic")
    partially solved the problem or actually mask it by changing
    mt76u_mcu_init_rx() and mt76u_alloc_queues() sequence, so e->buf_size
    become non zero any longer, but still not big enough to handle MCU data.
    
    Patch fixes memory corruption which can manifest itself as random,
    not easy to reproduce crashes, during mt76 driver load or unload.
    
    Fixes: c12128ce ("mt76: use a per rx queue page fragment cache")
    Signed-off-by: default avatarStanislaw Gruszka <sgruszka@redhat.com>
    Signed-off-by: default avatarLorenzo Bianconi <lorenzo.bianconi@redhat.com>
    Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
    c87dff8c
usb.c 20.1 KB