net: wireless: rockchip: add rtl8822be pcie wifi driver
[firefly-linux-kernel-4.4.55.git] / drivers / net / wireless / rockchip_wlan / rtl8822be / include / usb_ops.h
diff --git a/drivers/net/wireless/rockchip_wlan/rtl8822be/include/usb_ops.h b/drivers/net/wireless/rockchip_wlan/rtl8822be/include/usb_ops.h
new file mode 100644 (file)
index 0000000..2ad6b34
--- /dev/null
@@ -0,0 +1,133 @@
+/******************************************************************************
+ *
+ * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
+ *
+ * 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.
+ *
+ * You should have received a copy of the GNU General Public License along with
+ * this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
+ *
+ *
+ ******************************************************************************/
+#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
+
+enum {
+       VENDOR_WRITE = 0x00,
+       VENDOR_READ = 0x01,
+};
+#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_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 */
+
+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;
+       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_ */