Convert to host-endian first, *then* use max_t.  Doing it the
other way around is broken on big-endian hosts and this chipset
does occur on pcie cards - it's not always embedded into
motherboard of a little-endian system.

Fixes: c79992fddee2 (via-velocity: Re-enable transmit scatter-gather support)
Cc: sta...@vger.kernel.org
Signed-off-by: Al Viro <v...@zeniv.linux.org.uk>
---
 drivers/net/ethernet/via/via-velocity.c | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)

diff --git a/drivers/net/ethernet/via/via-velocity.c 
b/drivers/net/ethernet/via/via-velocity.c
index 7b6dc6e8d6c0..4156c33d954e 100644
--- a/drivers/net/ethernet/via/via-velocity.c
+++ b/drivers/net/ethernet/via/via-velocity.c
@@ -1733,12 +1733,13 @@ static void velocity_free_tx_buf(struct velocity_info 
*vptr,
                size_t pktlen = max_t(size_t, skb->len, ETH_ZLEN);
 
                /* For scatter-gather */
-               if (skb_shinfo(skb)->nr_frags > 0)
-                       pktlen = max_t(size_t, pktlen,
-                                      td->td_buf[i].size & ~TD_QUEUE);
+               if (skb_shinfo(skb)->nr_frags > 0) {
+                       __le16 sz = td->td_buf[i].size & ~TD_QUEUE;
+                       pktlen = max_t(size_t, pktlen, le16_to_cpu(sz));
+               }
 
                dma_unmap_single(vptr->dev, tdinfo->skb_dma[i],
-                                le16_to_cpu(pktlen), DMA_TO_DEVICE);
+                                pktlen, DMA_TO_DEVICE);
        }
        dev_kfree_skb_irq(skb);
        tdinfo->skb = NULL;
-- 
2.11.0


Reply via email to