Page MenuHomeFreeBSD

mt7601U: Importing if_mtw from OpenBSD
Needs ReviewPublic

Authored by jsm on May 13 2024, 4:44 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 13, 8:43 PM
Unknown Object (File)
Thu, Jan 9, 11:47 AM
Unknown Object (File)
Thu, Jan 9, 11:45 AM
Unknown Object (File)
Thu, Jan 9, 11:20 AM
Unknown Object (File)
Wed, Jan 8, 8:47 PM
Unknown Object (File)
Fri, Jan 3, 1:13 PM
Unknown Object (File)
Wed, Jan 1, 5:45 PM
Unknown Object (File)
Wed, Jan 1, 3:11 PM

Details

Reviewers
None
Group Reviewers
wireless
Summary

Importing if_mtw from OpenBSD

Test Plan

local manual testing

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

jsm requested review of this revision.May 13 2024, 4:44 PM

Also add mtw to /usr/src/sbin/devd/devd.conf it escaped my diff.. The firmware port is at https://people.freebsd.org/~jsm/mt7601u-firmware-kmod.tar.gz (It should have the license file set just for ref for now)

oh, interesting! does 11n work on this driver in openbsd? I see some 11n stuff is commented out here.

I'll add the back reference to the PR: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=247545

And leave my comment here: based on the comments there this driver was written based on GPL-only sources (at least I could not find anything else). For whatever that means I do not know.

share/man/man4/mtw.4
4

Are we sure that is correct?

40

There's a lot of blank lines everywhere...

80

"based on"?

sys/modules/usb/mtw/Makefile
2

Normally we do not add this to Makefiles but if you do can you add the SPDX tag in the first line so it matches the teemplate in /usr/share/examples/etc/bsd-copyright (typed from the top of my head)?

I haven't had time to look at the code, but tested on my Xiaomi mini USB WiFi:

mtw0 on uhub1
mtw0: <MediaTek MI WLAN Adapter, class 0/0, rev 2.01/0.00, addr 3> on usbus0
mtw0: version:0x7601
mtw0: loaded firmware ver 30272.256
mtw0: timeout waiting for MCU to initialize
mtw0: /usr/src/sys/dev/usb/wlan/if_mtw.c:3000 USB_ERR_CANCELLED
device_attach: mtw0 attach returned 6

Unfortunately it doesn't work.

My /boot/loader.conf:
mt7601u_fw_load="YES"
if_mtw_load="YES"

I haven't had time to look at the code, but tested on my Xiaomi mini USB WiFi:

mtw0 on uhub1
mtw0: <MediaTek MI WLAN Adapter, class 0/0, rev 2.01/0.00, addr 3> on usbus0
mtw0: version:0x7601
mtw0: loaded firmware ver 30272.256
mtw0: timeout waiting for MCU to initialize
mtw0: /usr/src/sys/dev/usb/wlan/if_mtw.c:3000 USB_ERR_CANCELLED
device_attach: mtw0 attach returned 6

Unfortunately it doesn't work.

My /boot/loader.conf:
mt7601u_fw_load="YES"
if_mtw_load="YES"

Thanks for testing. I did not manage to get hold of any other devices than a noname one where I never got usb err canceled loading firmware.
. . Is it consistent when unplugging/replugging the device. Can you perhaps post a usbconfig dump and a usbdump. Thanks.

sys/dev/usb/wlan/if_mtw.c
141

This list is too short.

Here's one to add:

ugen0.2: <MediaTek Edimax Wi-Fi> at usbus0, cfg=0 md=HOST spd=HIGH (480Mbps) pwr=ON (160mA)

  bLength = 0x0012 
  bDescriptorType = 0x0001 
  bcdUSB = 0x0201 
  bDeviceClass = 0x0000  <Probed by interface class>
  bDeviceSubClass = 0x0000 
  bDeviceProtocol = 0x0000 
  bMaxPacketSize0 = 0x0040 
  idVendor = 0x7392 
  idProduct = 0x7710 
  bcdDevice = 0x0000 
  iManufacturer = 0x0001  <MediaTek>
  iProduct = 0x0002  <Edimax Wi-Fi>
  iSerialNumber = 0x0003  <1.0>
  bNumConfigurations = 0x0001
147

If you need to do "eject" handling; we added a USB Quirk for that a while ago (I think for a Zyxel) which also has firmware "on board" and shows up as cd0 first and only when that was ejected the wifi device would show up. Found it 9d2d04462d1080f4a4b84f674de90a895ce1bcc1 . Hope that helps.

sys/modules/usb/Makefile
48

There's a blank at the end of the line (now).

linimon retitled this revision from mt7601U to mt7601U: Importing if_mtw from OpenBSD.Jul 5 2024, 11:20 PM
gbe added inline comments.
share/man/man4/mtw.4
78

Please add '.An -nosplit' after the .Sh macro so that the e-mail-addresses are fit on one line.

79

I would think that this should be 'openbsd.org'.

sys/dev/usb/usbdevs
4049

This is already present a couple of lines above... as "RT7601"

some ht 20 support. fix ratectl and no need for the short transfer usb hack to avoid device timeout.

Had it successfully running on

Dec 29 21:48:12 bcm kernel: ugen0.2: <MediaTek 802.11 n WLAN> at usbus0
Dec 29 21:48:12 bcm kernel: mtw0 on uhub0
Dec 29 21:48:12 bcm kernel: mtw0: <MediaTek 802.11 n WLAN, class 0/0, rev 2.01/0.00, addr 4> on usbus0
Dec 29 21:48:12 bcm kernel: mtw0: version:0x7601
Dec 29 21:48:12 bcm kernel: mtw0: firmware size:45412
Dec 29 21:48:12 bcm kernel: mtw0: loaded firmware ver 30272.256
Dec 29 21:48:12 bcm kernel: mtw0: mcu reaady 1
Dec 29 21:48:12 bcm kernel: mtw0: EEPROM RF rev=0x7601 chains=1T1R
Dec 29 21:48:12 bcm kernel: mtw0: EEPROM rev=0, FAE=13
Dec 29 21:48:12 bcm kernel: mtw0: EEPROM CFG 0x1004
Dec 29 21:48:12 bcm kernel: mtw0: frequency offset 0x5f

for a while, though "ifconfig wlan0 destroy" whilst associated was enough to panic the host. I've not yet investigated this.

share/man/man4/mtw.4
66
sys/dev/usb/wlan/if_mtw.c
21

No longer needed

64–66

I don't think you need this

135

Add a blank line before this one

304–309

It looks like you have the same defines (named MTW_RIDX_CCK1 etc) in if_mtwreg.h which is arguably the correct place as it's with the rt2860_rates array that they need to stay in sync with. However the RT2860_RIDX_* and MTW_RIDX_* are used interchangeably. Move the comment to that file, delete these RT2860_RIDX_* defines from here, and use MTW_RIDX_* everywhere.

312–321

This #define already exists (same name, better formatting) in if_mtwreg.h, delete it from here

326–328

Leftover comment from run(4)?

540

Remove this blank line

625

This looks wrong, Linux gets the ASIC version from MT_ASIC_VER register not MTW_MAC_VER_ID (and bases quite a few later tests on the ASIC version rather than the MAC version). I suspect this may not matter for the MT7601 but might for the MT7610/MT7612.

662

The manpage says only station mode is supported? From a quick test monitor mode doesn't seem to work for me

669

I don't think the hardware supports IEEE80211_C_FF

670

Bad intentation

674

mtw_ampdu_enable() is marked TODO so probably not good to announce support yet

678–680

It doesn't look like there's code anywhere to support these yet either?

681

_S is a shift value and shouldn't be OR'd in like this.

682

I don't think you support SMPS either?

1200

You have the MTW_LOCK held at this point (from mtw_attach() line 597) so get a lock order reversal here. firmware_get(4) says it must not be called with any locks held.

1762

Linux drivers/net/wireless/mediatek/mt7601u/mcu.h has a table of command names, it would be good to use something similar rather than magic numbers (e.g. 16 = CMD_LED_MODE)

1886

Bad intentation

3101–3102

run(4) leftovers?

3134

I suspect this should be MTW_PHY_HT unless GF is needed?

3248–3251

Bad indentation, excess blank lines

3256

Bad indentation

3720

MTW_UNLOCK needed here?

3976

This is different from OpenBSD behaviour (which has the for() as an empty loop) and I suspect it's wrong here. OpenBSD matches Linux.

4188–4189

Leftover from run(4)?

4774
sys/modules/usb/run/Makefile
34

Looks like this is unrelated

I'd like to urge a little caution with the formatting changes. If they are from the porting, do it. If they are leftovers from run, but still in OpenBSD, I'd suggest fixing those with a round trip through upstream. If upstream is unresponsive, I'd be tempted to do them as a followup commit so future imports would be easier. We have some good docs in the git history about why there appear to be gratuitous diffs with upstream. These would be hard to capture in the initial commit message.

It's looking better, can you delete some of the if_run function definitions that aren't in the openbsd rtw driver?

sys/dev/usb/wlan/if_mtw.c
232

are these all holdovers from if_run or something? can you just toss em?

I think I got most of Gavins, comments, also I got monitor mode working, and put that into the man page. I set force short xfer to 0 again in the TX_BE but I am not sure it relates to device timeouts, I got one under non heavy load. Before ht mode it solved consistent device timeouts.

mostly style. removed some comments, and device_printf, tries to reset on detach for better firmware reloading, but not consistently solving the reinitialization problem.

6499c6499

< @@ -0,0 +1,4668 @@

@@ -0,0 +1,4672 @@

7118c7118,7122

< + ic->ic_htcaps = IEEE80211_HTC_HT;

+ ic->ic_htcaps = IEEE80211_HTC_HT
+ | IEEE80211_HTC_AMPDU
+ | IEEE80211_HTC_AMSDU
+ | IEEE80211_HTCAP_MAXAMSDU_3839
+ | IEEE80211_HTCAP_SMPS_OFF;