xref: /freebsd/sys/contrib/dev/rtw89/rtw8852au.c (revision 10f91d9ff7b827aac6035e224e6ddc2c79f3a0cd)
1*10f91d9fSBjoern A. Zeeb // SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause
2*10f91d9fSBjoern A. Zeeb /* Copyright(c) 2025  Realtek Corporation
3*10f91d9fSBjoern A. Zeeb  */
4*10f91d9fSBjoern A. Zeeb 
5*10f91d9fSBjoern A. Zeeb #include <linux/module.h>
6*10f91d9fSBjoern A. Zeeb #include <linux/usb.h>
7*10f91d9fSBjoern A. Zeeb #include "rtw8852a.h"
8*10f91d9fSBjoern A. Zeeb #include "reg.h"
9*10f91d9fSBjoern A. Zeeb #include "usb.h"
10*10f91d9fSBjoern A. Zeeb 
11*10f91d9fSBjoern A. Zeeb static const struct rtw89_usb_info rtw8852a_usb_info = {
12*10f91d9fSBjoern A. Zeeb 	.usb_host_request_2		= R_AX_USB_HOST_REQUEST_2,
13*10f91d9fSBjoern A. Zeeb 	.usb_wlan0_1			= R_AX_USB_WLAN0_1,
14*10f91d9fSBjoern A. Zeeb 	.hci_func_en			= R_AX_HCI_FUNC_EN,
15*10f91d9fSBjoern A. Zeeb 	.usb3_mac_npi_config_intf_0	= R_AX_USB3_MAC_NPI_CONFIG_INTF_0,
16*10f91d9fSBjoern A. Zeeb 	.usb_endpoint_0			= R_AX_USB_ENDPOINT_0,
17*10f91d9fSBjoern A. Zeeb 	.usb_endpoint_2			= R_AX_USB_ENDPOINT_2,
18*10f91d9fSBjoern A. Zeeb 	.bulkout_id = {
19*10f91d9fSBjoern A. Zeeb 		[RTW89_DMA_ACH0] = 3,
20*10f91d9fSBjoern A. Zeeb 		[RTW89_DMA_ACH2] = 5,
21*10f91d9fSBjoern A. Zeeb 		[RTW89_DMA_ACH4] = 4,
22*10f91d9fSBjoern A. Zeeb 		[RTW89_DMA_ACH6] = 6,
23*10f91d9fSBjoern A. Zeeb 		[RTW89_DMA_B0MG] = 0,
24*10f91d9fSBjoern A. Zeeb 		[RTW89_DMA_B0HI] = 0,
25*10f91d9fSBjoern A. Zeeb 		[RTW89_DMA_B1MG] = 1,
26*10f91d9fSBjoern A. Zeeb 		[RTW89_DMA_B1HI] = 1,
27*10f91d9fSBjoern A. Zeeb 		[RTW89_DMA_H2C] = 2,
28*10f91d9fSBjoern A. Zeeb 	},
29*10f91d9fSBjoern A. Zeeb };
30*10f91d9fSBjoern A. Zeeb 
31*10f91d9fSBjoern A. Zeeb static const struct rtw89_driver_info rtw89_8852au_info = {
32*10f91d9fSBjoern A. Zeeb 	.chip = &rtw8852a_chip_info,
33*10f91d9fSBjoern A. Zeeb 	.variant = NULL,
34*10f91d9fSBjoern A. Zeeb 	.quirks = NULL,
35*10f91d9fSBjoern A. Zeeb 	.bus = {
36*10f91d9fSBjoern A. Zeeb 		.usb = &rtw8852a_usb_info,
37*10f91d9fSBjoern A. Zeeb 	}
38*10f91d9fSBjoern A. Zeeb };
39*10f91d9fSBjoern A. Zeeb 
40*10f91d9fSBjoern A. Zeeb static const struct usb_device_id rtw_8852au_id_table[] = {
41*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x0411, 0x0312, 0xff, 0xff, 0xff),
42*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
43*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x056e, 0x4020, 0xff, 0xff, 0xff),
44*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
45*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x0b05, 0x1997, 0xff, 0xff, 0xff),
46*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
47*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x0bda, 0x8832, 0xff, 0xff, 0xff),
48*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
49*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x0bda, 0x885a, 0xff, 0xff, 0xff),
50*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
51*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x0bda, 0x885c, 0xff, 0xff, 0xff),
52*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
53*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x2001, 0x3321, 0xff, 0xff, 0xff),
54*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
55*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x2001, 0x332c, 0xff, 0xff, 0xff),
56*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
57*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x2357, 0x013f, 0xff, 0xff, 0xff),
58*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
59*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x2357, 0x0140, 0xff, 0xff, 0xff),
60*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
61*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x2357, 0x0141, 0xff, 0xff, 0xff),
62*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
63*10f91d9fSBjoern A. Zeeb 	{ USB_DEVICE_AND_INTERFACE_INFO(0x3625, 0x010f, 0xff, 0xff, 0xff),
64*10f91d9fSBjoern A. Zeeb 	  .driver_info = (kernel_ulong_t)&rtw89_8852au_info },
65*10f91d9fSBjoern A. Zeeb 	{},
66*10f91d9fSBjoern A. Zeeb };
67*10f91d9fSBjoern A. Zeeb MODULE_DEVICE_TABLE(usb, rtw_8852au_id_table);
68*10f91d9fSBjoern A. Zeeb 
69*10f91d9fSBjoern A. Zeeb static struct usb_driver rtw_8852au_driver = {
70*10f91d9fSBjoern A. Zeeb 	.name = KBUILD_MODNAME,
71*10f91d9fSBjoern A. Zeeb 	.id_table = rtw_8852au_id_table,
72*10f91d9fSBjoern A. Zeeb 	.probe = rtw89_usb_probe,
73*10f91d9fSBjoern A. Zeeb 	.disconnect = rtw89_usb_disconnect,
74*10f91d9fSBjoern A. Zeeb };
75*10f91d9fSBjoern A. Zeeb module_usb_driver(rtw_8852au_driver);
76*10f91d9fSBjoern A. Zeeb 
77*10f91d9fSBjoern A. Zeeb MODULE_AUTHOR("Bitterblue Smith <rtl8821cerfe2@gmail.com>");
78*10f91d9fSBjoern A. Zeeb MODULE_DESCRIPTION("Realtek 802.11ax wireless 8852AU driver");
79*10f91d9fSBjoern A. Zeeb MODULE_LICENSE("Dual BSD/GPL");
80