mirror of
https://github.com/Mange/rtl8192eu-linux-driver
synced 2024-12-25 13:31:44 +00:00
4ddd7165fb
At the moment, usbctrl_vendorreq's requesttype parameter must be set to 1 for reading and 0 for writing. It's then converted to the actual bmRequestType for the USB control request. We can simplify the code and avoid this conversion if the caller passes the actual bmRequestType. This patch is an adaptation of commit 788fde031027 ("staging: rtl8188eu: use actual request type as parameter") for the new r8188eu driver. Link: https://lore.kernel.org/r/20210821164859.4351-3-martin@kaiser.cx
150 lines
4.8 KiB
C
150 lines
4.8 KiB
C
/******************************************************************************
|
|
*
|
|
* Copyright(c) 2007 - 2017 Realtek Corporation.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of version 2 of the GNU General Public License as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
* more details.
|
|
*
|
|
*****************************************************************************/
|
|
#ifndef __USB_OPS_H_
|
|
#define __USB_OPS_H_
|
|
|
|
|
|
#define REALTEK_USB_VENQT_READ 0xC0
|
|
#define REALTEK_USB_VENQT_WRITE 0x40
|
|
#define REALTEK_USB_VENQT_CMD_REQ 0x05
|
|
#define REALTEK_USB_VENQT_CMD_IDX 0x00
|
|
#define REALTEK_USB_IN_INT_EP_IDX 1
|
|
|
|
#define ALIGNMENT_UNIT 16
|
|
#define MAX_VENDOR_REQ_CMD_SIZE 254 /* 8188cu SIE Support */
|
|
#define MAX_USB_IO_CTL_SIZE (MAX_VENDOR_REQ_CMD_SIZE + ALIGNMENT_UNIT)
|
|
|
|
#ifdef PLATFORM_LINUX
|
|
#include <usb_ops_linux.h>
|
|
#endif /* PLATFORM_LINUX */
|
|
|
|
#ifdef CONFIG_RTL8188E
|
|
void rtl8188eu_set_hw_type(struct dvobj_priv *pdvobj);
|
|
#ifdef CONFIG_SUPPORT_USB_INT
|
|
void interrupt_handler_8188eu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
|
|
#endif
|
|
#endif
|
|
|
|
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
|
|
void rtl8812au_set_hw_type(struct dvobj_priv *pdvobj);
|
|
#ifdef CONFIG_SUPPORT_USB_INT
|
|
void interrupt_handler_8812au(_adapter *padapter, u16 pkt_len, u8 *pbuf);
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef CONFIG_RTL8814A
|
|
void rtl8814au_set_hw_type(struct dvobj_priv *pdvobj);
|
|
#ifdef CONFIG_SUPPORT_USB_INT
|
|
void interrupt_handler_8814au(_adapter *padapter, u16 pkt_len, u8 *pbuf);
|
|
#endif
|
|
#endif /* CONFIG_RTL8814 */
|
|
|
|
#ifdef CONFIG_RTL8192E
|
|
void rtl8192eu_set_hw_type(struct dvobj_priv *pdvobj);
|
|
#ifdef CONFIG_SUPPORT_USB_INT
|
|
void interrupt_handler_8192eu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#ifdef CONFIG_RTL8188F
|
|
void rtl8188fu_set_hw_type(struct dvobj_priv *pdvobj);
|
|
#ifdef CONFIG_SUPPORT_USB_INT
|
|
void interrupt_handler_8188fu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef CONFIG_RTL8188GTV
|
|
void rtl8188gtvu_set_hw_type(struct dvobj_priv *pdvobj);
|
|
#ifdef CONFIG_SUPPORT_USB_INT
|
|
void interrupt_handler_8188gtvu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef CONFIG_RTL8723B
|
|
void rtl8723bu_set_hw_type(struct dvobj_priv *pdvobj);
|
|
#ifdef CONFIG_SUPPORT_USB_INT
|
|
void interrupt_handler_8723bu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef CONFIG_RTL8703B
|
|
void rtl8703bu_set_hw_type(struct dvobj_priv *pdvobj);
|
|
#ifdef CONFIG_SUPPORT_USB_INT
|
|
void interrupt_handler_8703bu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
|
|
#endif /* CONFIG_SUPPORT_USB_INT */
|
|
#endif /* CONFIG_RTL8703B */
|
|
|
|
void usb_set_intf_ops(_adapter *padapter, struct _io_ops *pops);
|
|
|
|
#ifdef CONFIG_RTL8723D
|
|
void rtl8723du_set_hw_type(struct dvobj_priv *pdvobj);
|
|
void rtl8723du_set_intf_ops(struct _io_ops *pops);
|
|
void rtl8723du_recv_tasklet(void *priv);
|
|
void rtl8723du_xmit_tasklet(void *priv);
|
|
#ifdef CONFIG_SUPPORT_USB_INT
|
|
void interrupt_handler_8723du(_adapter *padapter, u16 pkt_len, u8 *pbuf);
|
|
#endif /* CONFIG_SUPPORT_USB_INT */
|
|
#endif /* CONFIG_RTL8723D */
|
|
|
|
#ifdef CONFIG_RTL8710B
|
|
void rtl8710bu_set_hw_type(struct dvobj_priv *pdvobj);
|
|
void rtl8710bu_set_intf_ops(struct _io_ops *pops);
|
|
void rtl8710bu_recv_tasklet(void *priv);
|
|
void rtl8710bu_xmit_tasklet(void *priv);
|
|
#ifdef CONFIG_SUPPORT_USB_INT
|
|
void interrupt_handler_8710bu(_adapter *padapter, u16 pkt_len, u8 *pbuf);
|
|
#endif /* CONFIG_SUPPORT_USB_INT */
|
|
#endif /* CONFIG_RTL8710B */
|
|
|
|
#ifdef CONFIG_RTL8192F
|
|
void rtl8192fu_set_hw_type(struct dvobj_priv *pdvobj);
|
|
void rtl8192fu_xmit_tasklet(void *priv);
|
|
#ifdef CONFIG_SUPPORT_USB_INT
|
|
void rtl8192fu_interrupt_handler(_adapter *padapter, u16 pkt_len, u8 *pbuf);
|
|
#endif /* CONFIG_SUPPORT_USB_INT */
|
|
#endif /* CONFIG_RTL8192F */
|
|
|
|
enum RTW_USB_SPEED {
|
|
RTW_USB_SPEED_UNKNOWN = 0,
|
|
RTW_USB_SPEED_1_1 = 1,
|
|
RTW_USB_SPEED_2 = 2,
|
|
RTW_USB_SPEED_3 = 3,
|
|
};
|
|
|
|
#define IS_FULL_SPEED_USB(Adapter) (adapter_to_dvobj(Adapter)->usb_speed == RTW_USB_SPEED_1_1)
|
|
#define IS_HIGH_SPEED_USB(Adapter) (adapter_to_dvobj(Adapter)->usb_speed == RTW_USB_SPEED_2)
|
|
#define IS_SUPER_SPEED_USB(Adapter) (adapter_to_dvobj(Adapter)->usb_speed == RTW_USB_SPEED_3)
|
|
|
|
#define USB_SUPER_SPEED_BULK_SIZE 1024 /* usb 3.0 */
|
|
#define USB_HIGH_SPEED_BULK_SIZE 512 /* usb 2.0 */
|
|
#define USB_FULL_SPEED_BULK_SIZE 64 /* usb 1.1 */
|
|
|
|
static inline u8 rtw_usb_bulk_size_boundary(_adapter *padapter, int buf_len)
|
|
{
|
|
u8 rst = _TRUE;
|
|
|
|
if (IS_SUPER_SPEED_USB(padapter))
|
|
rst = (0 == (buf_len) % USB_SUPER_SPEED_BULK_SIZE) ? _TRUE : _FALSE;
|
|
else if (IS_HIGH_SPEED_USB(padapter))
|
|
rst = (0 == (buf_len) % USB_HIGH_SPEED_BULK_SIZE) ? _TRUE : _FALSE;
|
|
else
|
|
rst = (0 == (buf_len) % USB_FULL_SPEED_BULK_SIZE) ? _TRUE : _FALSE;
|
|
return rst;
|
|
}
|
|
|
|
|
|
#endif /* __USB_OPS_H_ */
|