162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * This file contains definitions for mwifiex USB interface driver. 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright 2011-2020 NXP 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci#ifndef _MWIFIEX_USB_H 962306a36Sopenharmony_ci#define _MWIFIEX_USB_H 1062306a36Sopenharmony_ci 1162306a36Sopenharmony_ci#include <linux/completion.h> 1262306a36Sopenharmony_ci#include <linux/usb.h> 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci#define USB8XXX_VID 0x1286 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci#define USB8766_PID_1 0x2041 1762306a36Sopenharmony_ci#define USB8766_PID_2 0x2042 1862306a36Sopenharmony_ci#define USB8797_PID_1 0x2043 1962306a36Sopenharmony_ci#define USB8797_PID_2 0x2044 2062306a36Sopenharmony_ci#define USB8801_PID_1 0x2049 2162306a36Sopenharmony_ci#define USB8801_PID_2 0x204a 2262306a36Sopenharmony_ci#define USB8997_PID_1 0x2052 2362306a36Sopenharmony_ci#define USB8997_PID_2 0x204e 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci#define USB8XXX_FW_DNLD 1 2762306a36Sopenharmony_ci#define USB8XXX_FW_READY 2 2862306a36Sopenharmony_ci#define USB8XXX_FW_MAX_RETRY 3 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_ci#define MWIFIEX_TX_DATA_PORT 2 3162306a36Sopenharmony_ci#define MWIFIEX_TX_DATA_URB 6 3262306a36Sopenharmony_ci#define MWIFIEX_RX_DATA_URB 6 3362306a36Sopenharmony_ci#define MWIFIEX_USB_TIMEOUT 100 3462306a36Sopenharmony_ci 3562306a36Sopenharmony_ci#define USB8766_DEFAULT_FW_NAME "mrvl/usb8766_uapsta.bin" 3662306a36Sopenharmony_ci#define USB8797_DEFAULT_FW_NAME "mrvl/usb8797_uapsta.bin" 3762306a36Sopenharmony_ci#define USB8801_DEFAULT_FW_NAME "mrvl/usb8801_uapsta.bin" 3862306a36Sopenharmony_ci#define USB8997_DEFAULT_FW_NAME "mrvl/usbusb8997_combo_v4.bin" 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci#define FW_DNLD_TX_BUF_SIZE 620 4162306a36Sopenharmony_ci#define FW_DNLD_RX_BUF_SIZE 2048 4262306a36Sopenharmony_ci#define FW_HAS_LAST_BLOCK 0x00000004 4362306a36Sopenharmony_ci#define FW_CMD_7 0x00000007 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_ci#define FW_DATA_XMIT_SIZE \ 4662306a36Sopenharmony_ci (sizeof(struct fw_header) + dlen + sizeof(u32)) 4762306a36Sopenharmony_ci 4862306a36Sopenharmony_cistruct urb_context { 4962306a36Sopenharmony_ci struct mwifiex_adapter *adapter; 5062306a36Sopenharmony_ci struct sk_buff *skb; 5162306a36Sopenharmony_ci struct urb *urb; 5262306a36Sopenharmony_ci u8 ep; 5362306a36Sopenharmony_ci}; 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci#define MWIFIEX_USB_TX_AGGR_TMO_MIN 1 5662306a36Sopenharmony_ci#define MWIFIEX_USB_TX_AGGR_TMO_MAX 4 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_cistruct tx_aggr_tmr_cnxt { 5962306a36Sopenharmony_ci struct mwifiex_adapter *adapter; 6062306a36Sopenharmony_ci struct usb_tx_data_port *port; 6162306a36Sopenharmony_ci struct timer_list hold_timer; 6262306a36Sopenharmony_ci bool is_hold_timer_set; 6362306a36Sopenharmony_ci u32 hold_tmo_msecs; 6462306a36Sopenharmony_ci}; 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_cistruct usb_tx_aggr { 6762306a36Sopenharmony_ci struct sk_buff_head aggr_list; 6862306a36Sopenharmony_ci int aggr_len; 6962306a36Sopenharmony_ci int aggr_num; 7062306a36Sopenharmony_ci struct tx_aggr_tmr_cnxt timer_cnxt; 7162306a36Sopenharmony_ci}; 7262306a36Sopenharmony_ci 7362306a36Sopenharmony_cistruct usb_tx_data_port { 7462306a36Sopenharmony_ci u8 tx_data_ep; 7562306a36Sopenharmony_ci u8 block_status; 7662306a36Sopenharmony_ci atomic_t tx_data_urb_pending; 7762306a36Sopenharmony_ci int tx_data_ix; 7862306a36Sopenharmony_ci struct urb_context tx_data_list[MWIFIEX_TX_DATA_URB]; 7962306a36Sopenharmony_ci /* usb tx aggregation*/ 8062306a36Sopenharmony_ci struct usb_tx_aggr tx_aggr; 8162306a36Sopenharmony_ci struct sk_buff *skb_aggr[MWIFIEX_TX_DATA_URB]; 8262306a36Sopenharmony_ci /* lock for protect tx aggregation data path*/ 8362306a36Sopenharmony_ci spinlock_t tx_aggr_lock; 8462306a36Sopenharmony_ci}; 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_cistruct usb_card_rec { 8762306a36Sopenharmony_ci struct mwifiex_adapter *adapter; 8862306a36Sopenharmony_ci struct usb_device *udev; 8962306a36Sopenharmony_ci struct usb_interface *intf; 9062306a36Sopenharmony_ci struct completion fw_done; 9162306a36Sopenharmony_ci u8 rx_cmd_ep; 9262306a36Sopenharmony_ci struct urb_context rx_cmd; 9362306a36Sopenharmony_ci atomic_t rx_cmd_urb_pending; 9462306a36Sopenharmony_ci struct urb_context rx_data_list[MWIFIEX_RX_DATA_URB]; 9562306a36Sopenharmony_ci u8 usb_boot_state; 9662306a36Sopenharmony_ci u8 rx_data_ep; 9762306a36Sopenharmony_ci atomic_t rx_data_urb_pending; 9862306a36Sopenharmony_ci u8 tx_cmd_ep; 9962306a36Sopenharmony_ci atomic_t tx_cmd_urb_pending; 10062306a36Sopenharmony_ci int bulk_out_maxpktsize; 10162306a36Sopenharmony_ci struct urb_context tx_cmd; 10262306a36Sopenharmony_ci u8 mc_resync_flag; 10362306a36Sopenharmony_ci struct usb_tx_data_port port[MWIFIEX_TX_DATA_PORT]; 10462306a36Sopenharmony_ci int rx_cmd_ep_type; 10562306a36Sopenharmony_ci u8 rx_cmd_interval; 10662306a36Sopenharmony_ci int tx_cmd_ep_type; 10762306a36Sopenharmony_ci u8 tx_cmd_interval; 10862306a36Sopenharmony_ci}; 10962306a36Sopenharmony_ci 11062306a36Sopenharmony_cistruct fw_header { 11162306a36Sopenharmony_ci __le32 dnld_cmd; 11262306a36Sopenharmony_ci __le32 base_addr; 11362306a36Sopenharmony_ci __le32 data_len; 11462306a36Sopenharmony_ci __le32 crc; 11562306a36Sopenharmony_ci}; 11662306a36Sopenharmony_ci 11762306a36Sopenharmony_cistruct fw_sync_header { 11862306a36Sopenharmony_ci __le32 cmd; 11962306a36Sopenharmony_ci __le32 seq_num; 12062306a36Sopenharmony_ci} __packed; 12162306a36Sopenharmony_ci 12262306a36Sopenharmony_cistruct fw_data { 12362306a36Sopenharmony_ci struct fw_header fw_hdr; 12462306a36Sopenharmony_ci __le32 seq_num; 12562306a36Sopenharmony_ci u8 data[]; 12662306a36Sopenharmony_ci} __packed; 12762306a36Sopenharmony_ci 12862306a36Sopenharmony_ci#endif /*_MWIFIEX_USB_H */ 129