[PATCH 5/5] wifi: mt76: mt7927u: enable USB RX aggregation

Lorenzo Bianconi lorenzo at kernel.org
Mon Jun 15 00:10:31 PDT 2026


> From: Sean Wang <sean.wang at mediatek.com>
> 
> Enable USB RX aggregation on MT7927u with vendor driver parameters for
> alignment, padding and buffer size. According to the vendor driver, the
> hardware should run RX aggregation with USB SG disabled.
> 
> Signed-off-by: Sean Wang <sean.wang at mediatek.com>
> ---
>  drivers/net/wireless/mediatek/mt76/mt7925/usb.c |  6 +++++-
>  drivers/net/wireless/mediatek/mt76/usb.c        | 11 +++++++++++
>  2 files changed, 16 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/net/wireless/mediatek/mt76/mt7925/usb.c b/drivers/net/wireless/mediatek/mt76/mt7925/usb.c
> index a0bfe6f09ae4..42d13bc6ebbc 100644
> --- a/drivers/net/wireless/mediatek/mt76/mt7925/usb.c
> +++ b/drivers/net/wireless/mediatek/mt76/mt7925/usb.c
> @@ -5,7 +5,6 @@
>  #include <linux/module.h>
>  #include <linux/sizes.h>
>  #include <linux/usb.h>
> -
>  #include "mt7925.h"
>  #include "mcu.h"
>  #include "mac.h"
> @@ -235,6 +234,11 @@ static int mt7925u_probe(struct usb_interface *usb_intf,
>  		mdev->rev = (0x7927 << 16) | (mdev->rev & 0xff);
>  	}
>  
> +	if (is_mt7927(mdev))
> +		mt76u_enable_rx_aggr(mdev, MT7927_USB_RX_AGGR_ALIGN,
> +				     MT7927_USB_RX_AGGR_PADDING,
> +				     MT7927_USB_RX_AGGR_BUF_SIZE);

This seems to me something like a NETIF_F_GRO_HW. Should the user be able to
toggle it via ethtool?

Regards,
Lorenzo

> +
>  	if (mt76_get_field(dev, MT_CONN_ON_MISC, MT_TOP_MISC2_FW_N9_RDY)) {
>  		ret = mt792xu_wfsys_reset(dev);
>  		if (ret)
> diff --git a/drivers/net/wireless/mediatek/mt76/usb.c b/drivers/net/wireless/mediatek/mt76/usb.c
> index 10ad2b024985..f0df510904c5 100644
> --- a/drivers/net/wireless/mediatek/mt76/usb.c
> +++ b/drivers/net/wireless/mediatek/mt76/usb.c
> @@ -1300,6 +1300,17 @@ static const struct mt76_queue_ops usb_queue_ops = {
>  	.kick = mt76u_tx_kick,
>  };
>  
> +void mt76u_enable_rx_aggr(struct mt76_dev *dev, int align, int padding,
> +			  int buf_size)
> +{
> +	dev->usb.sg_en = false;
> +	dev->usb.rx_aggr.enable = true;
> +	dev->usb.rx_aggr.align = align;
> +	dev->usb.rx_aggr.padding = padding;
> +	dev->usb.rx_aggr.buf_size = buf_size;
> +}
> +EXPORT_SYMBOL_GPL(mt76u_enable_rx_aggr);
> +
>  int __mt76u_init(struct mt76_dev *dev, struct usb_interface *intf,
>  		 struct mt76_bus_ops *ops)
>  {
> -- 
> 2.43.0
> 
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 228 bytes
Desc: not available
URL: <http://lists.infradead.org/pipermail/linux-mediatek/attachments/20260615/48bcc3d2/attachment.sig>


More information about the Linux-mediatek mailing list