2
0

0719-v6.0-net-lantiq_xrx200-restore-buffer-if-memory-allocatio.patch 999 B

123456789101112131415161718192021222324252627
  1. From c9c3b1775f80fa21f5bff874027d2ccb10f5d90c Mon Sep 17 00:00:00 2001
  2. From: Aleksander Jan Bajkowski <[email protected]>
  3. Date: Wed, 24 Aug 2022 23:54:08 +0200
  4. Subject: [PATCH] net: lantiq_xrx200: restore buffer if memory allocation
  5. failed
  6. In a situation where memory allocation fails, an invalid buffer address
  7. is stored. When this descriptor is used again, the system panics in the
  8. build_skb() function when accessing memory.
  9. Fixes: 7ea6cd16f159 ("lantiq: net: fix duplicated skb in rx descriptor ring")
  10. Signed-off-by: Aleksander Jan Bajkowski <[email protected]>
  11. Signed-off-by: Jakub Kicinski <[email protected]>
  12. ---
  13. drivers/net/ethernet/lantiq_xrx200.c | 1 +
  14. 1 file changed, 1 insertion(+)
  15. --- a/drivers/net/ethernet/lantiq_xrx200.c
  16. +++ b/drivers/net/ethernet/lantiq_xrx200.c
  17. @@ -193,6 +193,7 @@ static int xrx200_alloc_buf(struct xrx20
  18. ch->rx_buff[ch->dma.desc] = alloc(priv->rx_skb_size);
  19. if (!ch->rx_buff[ch->dma.desc]) {
  20. + ch->rx_buff[ch->dma.desc] = buf;
  21. ret = -ENOMEM;
  22. goto skip;
  23. }