mt76: mt76u: introduce MT_DRV_RX_DMA_HDR flag
authorLorenzo Bianconi <lorenzo@kernel.org>
Wed, 15 Jan 2020 10:58:58 +0000 (11:58 +0100)
committerFelix Fietkau <nbd@nbd.name>
Fri, 14 Feb 2020 09:06:06 +0000 (10:06 +0100)
Define MT_DRV_RX_DMA_HDR flag in drv_flag in order to not skip rx frame
dma header since new devices (e.g. mt7663u) reports rx frame info in the
usb dma header

Co-developed-by: Sean Wang <sean.wang@mediatek.com>
Signed-off-by: Sean Wang <sean.wang@mediatek.com>
Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mt76.h
drivers/net/wireless/mediatek/mt76/usb.c

index 0123c279051fdd5cb882d45fb173c6be2100accb..815d084860023aab36764cdb88cbb86546f846ba 100644 (file)
@@ -286,6 +286,7 @@ struct mt76_hw_cap {
 #define MT_DRV_TXWI_NO_FREE            BIT(0)
 #define MT_DRV_TX_ALIGNED4_SKBS                BIT(1)
 #define MT_DRV_SW_RX_AIRTIME           BIT(2)
+#define MT_DRV_RX_DMA_HDR              BIT(3)
 
 struct mt76_driver_ops {
        u32 drv_flags;
index 57d2590165e30c1a1eea2352a44f8c91dfb26f8b..981d8a985557aea48b4cd892ed1a7444eb9d7da5 100644 (file)
@@ -506,14 +506,17 @@ mt76u_get_next_rx_entry(struct mt76_queue *q)
        return urb;
 }
 
-static int mt76u_get_rx_entry_len(u8 *data, u32 data_len)
+static int
+mt76u_get_rx_entry_len(struct mt76_dev *dev, u8 *data,
+                      u32 data_len)
 {
        u16 dma_len, min_len;
 
        dma_len = get_unaligned_le16(data);
-       min_len = MT_DMA_HDR_LEN + MT_RX_RXWI_LEN +
-                 MT_FCE_INFO_LEN;
+       if (dev->drv->drv_flags & MT_DRV_RX_DMA_HDR)
+               return dma_len;
 
+       min_len = MT_DMA_HDR_LEN + MT_RX_RXWI_LEN + MT_FCE_INFO_LEN;
        if (data_len < min_len || !dma_len ||
            dma_len + MT_DMA_HDR_LEN > data_len ||
            (dma_len & 0x3))
@@ -522,11 +525,14 @@ static int mt76u_get_rx_entry_len(u8 *data, u32 data_len)
 }
 
 static struct sk_buff *
-mt76u_build_rx_skb(void *data, int len, int buf_size)
+mt76u_build_rx_skb(struct mt76_dev *dev, void *data,
+                  int len, int buf_size)
 {
+       int head_room, drv_flags = dev->drv->drv_flags;
        struct sk_buff *skb;
 
-       if (SKB_WITH_OVERHEAD(buf_size) < MT_DMA_HDR_LEN + len) {
+       head_room = drv_flags & MT_DRV_RX_DMA_HDR ? 0 : MT_DMA_HDR_LEN;
+       if (SKB_WITH_OVERHEAD(buf_size) < head_room + len) {
                struct page *page;
 
                /* slow path, not enough space for data and
@@ -536,8 +542,8 @@ mt76u_build_rx_skb(void *data, int len, int buf_size)
                if (!skb)
                        return NULL;
 
-               skb_put_data(skb, data + MT_DMA_HDR_LEN, MT_SKB_HEAD_LEN);
-               data += (MT_DMA_HDR_LEN + MT_SKB_HEAD_LEN);
+               skb_put_data(skb, data + head_room, MT_SKB_HEAD_LEN);
+               data += head_room + MT_SKB_HEAD_LEN;
                page = virt_to_head_page(data);
                skb_add_rx_frag(skb, skb_shinfo(skb)->nr_frags,
                                page, data - page_address(page),
@@ -551,7 +557,7 @@ mt76u_build_rx_skb(void *data, int len, int buf_size)
        if (!skb)
                return NULL;
 
-       skb_reserve(skb, MT_DMA_HDR_LEN);
+       skb_reserve(skb, head_room);
        __skb_put(skb, len);
 
        return skb;
@@ -563,18 +569,19 @@ mt76u_process_rx_entry(struct mt76_dev *dev, struct urb *urb,
 {
        u8 *data = urb->num_sgs ? sg_virt(&urb->sg[0]) : urb->transfer_buffer;
        int data_len = urb->num_sgs ? urb->sg[0].length : urb->actual_length;
-       int len, nsgs = 1;
+       int len, nsgs = 1, head_room, drv_flags = dev->drv->drv_flags;
        struct sk_buff *skb;
 
        if (!test_bit(MT76_STATE_INITIALIZED, &dev->phy.state))
                return 0;
 
-       len = mt76u_get_rx_entry_len(data, urb->actual_length);
+       len = mt76u_get_rx_entry_len(dev, data, urb->actual_length);
        if (len < 0)
                return 0;
 
-       data_len = min_t(int, len, data_len - MT_DMA_HDR_LEN);
-       skb = mt76u_build_rx_skb(data, data_len, buf_size);
+       head_room = drv_flags & MT_DRV_RX_DMA_HDR ? 0 : MT_DMA_HDR_LEN;
+       data_len = min_t(int, len, data_len - head_room);
+       skb = mt76u_build_rx_skb(dev, data, data_len, buf_size);
        if (!skb)
                return 0;