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 "rtw8852c.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 rtw8852c_usb_info = { 12*10f91d9fSBjoern A. Zeeb .usb_host_request_2 = R_AX_USB_HOST_REQUEST_2_V1, 13*10f91d9fSBjoern A. Zeeb .usb_wlan0_1 = R_AX_USB_WLAN0_1_V1, 14*10f91d9fSBjoern A. Zeeb .hci_func_en = R_AX_HCI_FUNC_EN_V1, 15*10f91d9fSBjoern A. Zeeb .usb3_mac_npi_config_intf_0 = R_AX_USB3_MAC_NPI_CONFIG_INTF_0_V1, 16*10f91d9fSBjoern A. Zeeb .usb_endpoint_0 = R_AX_USB_ENDPOINT_0_V1, 17*10f91d9fSBjoern A. Zeeb .usb_endpoint_2 = R_AX_USB_ENDPOINT_2_V1, 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_8852cu_info = { 32*10f91d9fSBjoern A. Zeeb .chip = &rtw8852c_chip_info, 33*10f91d9fSBjoern A. Zeeb .variant = NULL, 34*10f91d9fSBjoern A. Zeeb .quirks = NULL, 35*10f91d9fSBjoern A. Zeeb .bus = { 36*10f91d9fSBjoern A. Zeeb .usb = &rtw8852c_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_8852cu_id_table[] = { 41*10f91d9fSBjoern A. Zeeb { USB_DEVICE_AND_INTERFACE_INFO(0x0bda, 0xc832, 0xff, 0xff, 0xff), 42*10f91d9fSBjoern A. Zeeb .driver_info = (kernel_ulong_t)&rtw89_8852cu_info }, 43*10f91d9fSBjoern A. Zeeb { USB_DEVICE_AND_INTERFACE_INFO(0x0bda, 0xc85a, 0xff, 0xff, 0xff), 44*10f91d9fSBjoern A. Zeeb .driver_info = (kernel_ulong_t)&rtw89_8852cu_info }, 45*10f91d9fSBjoern A. Zeeb { USB_DEVICE_AND_INTERFACE_INFO(0x0bda, 0xc85d, 0xff, 0xff, 0xff), 46*10f91d9fSBjoern A. Zeeb .driver_info = (kernel_ulong_t)&rtw89_8852cu_info }, 47*10f91d9fSBjoern A. Zeeb { USB_DEVICE_AND_INTERFACE_INFO(0x0db0, 0x991d, 0xff, 0xff, 0xff), 48*10f91d9fSBjoern A. Zeeb .driver_info = (kernel_ulong_t)&rtw89_8852cu_info }, 49*10f91d9fSBjoern A. Zeeb { USB_DEVICE_AND_INTERFACE_INFO(0x35b2, 0x0502, 0xff, 0xff, 0xff), 50*10f91d9fSBjoern A. Zeeb .driver_info = (kernel_ulong_t)&rtw89_8852cu_info }, 51*10f91d9fSBjoern A. Zeeb { USB_DEVICE_AND_INTERFACE_INFO(0x35bc, 0x0101, 0xff, 0xff, 0xff), 52*10f91d9fSBjoern A. Zeeb .driver_info = (kernel_ulong_t)&rtw89_8852cu_info }, 53*10f91d9fSBjoern A. Zeeb { USB_DEVICE_AND_INTERFACE_INFO(0x35bc, 0x0102, 0xff, 0xff, 0xff), 54*10f91d9fSBjoern A. Zeeb .driver_info = (kernel_ulong_t)&rtw89_8852cu_info }, 55*10f91d9fSBjoern A. Zeeb {}, 56*10f91d9fSBjoern A. Zeeb }; 57*10f91d9fSBjoern A. Zeeb MODULE_DEVICE_TABLE(usb, rtw_8852cu_id_table); 58*10f91d9fSBjoern A. Zeeb 59*10f91d9fSBjoern A. Zeeb static struct usb_driver rtw_8852cu_driver = { 60*10f91d9fSBjoern A. Zeeb .name = KBUILD_MODNAME, 61*10f91d9fSBjoern A. Zeeb .id_table = rtw_8852cu_id_table, 62*10f91d9fSBjoern A. Zeeb .probe = rtw89_usb_probe, 63*10f91d9fSBjoern A. Zeeb .disconnect = rtw89_usb_disconnect, 64*10f91d9fSBjoern A. Zeeb }; 65*10f91d9fSBjoern A. Zeeb module_usb_driver(rtw_8852cu_driver); 66*10f91d9fSBjoern A. Zeeb 67*10f91d9fSBjoern A. Zeeb MODULE_AUTHOR("Bitterblue Smith <rtl8821cerfe2@gmail.com>"); 68*10f91d9fSBjoern A. Zeeb MODULE_DESCRIPTION("Realtek 802.11ax wireless 8852CU driver"); 69*10f91d9fSBjoern A. Zeeb MODULE_LICENSE("Dual BSD/GPL"); 70