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