Hi On Wed, Mar 07, 2018 at 05:47:34PM +0200, Jamie Stuart wrote: > config wifi-device 'radio0' > option type 'mac80211' > option channel 'auto' To make reproducible testing results I would suggest to setup a channel, (choose one that is the less used by other wireless networks), problem may happen on some channels and not happen on other. > The 30 clients are all Apple iPads (a mixture of iPad mini and mini 2, running iOS 9-11). During this testing period, all clients were simultaneously downloading files from the devices’ sdcard (served via nginx running on the device). Although this is not a typical use-case, it was useful in stress-testing the wireless setup. For such scenario I would suggest hardcode ba_size = 0 and see if that would help. I also attach another patch, can be applied on top of two previous. This one should give RX hardware more time to provide proper BlockACK frame, so hopefully could help with seq mismashes. Stanislaw
diff --git a/drivers/net/wireless/ralink/rt2x00/rt2800lib.c b/drivers/net/wireless/ralink/rt2x00/rt2800lib.c index e68f7f9d48f8..95f20072a219 100644 --- a/drivers/net/wireless/ralink/rt2x00/rt2800lib.c +++ b/drivers/net/wireless/ralink/rt2x00/rt2800lib.c @@ -9286,7 +9286,7 @@ static int rt2800_probe_hw_mode(struct rt2x00_dev *rt2x00dev) spec->ht.cap |= rx_chains << IEEE80211_HT_CAP_RX_STBC_SHIFT; spec->ht.ampdu_factor = 0; - spec->ht.ampdu_density = 4; + spec->ht.ampdu_density = 7; spec->ht.mcs.tx_params = IEEE80211_HT_MCS_TX_DEFINED; if (tx_chains != rx_chains) { spec->ht.mcs.tx_params |= IEEE80211_HT_MCS_TX_RX_DIFF;