/****************************************************************************** * * Copyright(c) 2007 - 2012 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 * * ******************************************************************************/ /*------------------------------------------------------------------------------- For type defines and data structure defines --------------------------------------------------------------------------------*/ #ifndef __DRV_TYPES_H__ #define __DRV_TYPES_H__ #include #include #include #include enum _NIC_VERSION { RTL8711_NIC, RTL8712_NIC, RTL8713_NIC, RTL8716_NIC }; #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #ifdef CONFIG_DRVEXT_MODULE #include #endif #ifdef CONFIG_BR_EXT #include #endif // CONFIG_BR_EXT #include "ioctl_cfg80211.h" #define SPEC_DEV_ID_NONE BIT(0) #define SPEC_DEV_ID_DISABLE_HT BIT(1) #define SPEC_DEV_ID_ENABLE_PS BIT(2) #define SPEC_DEV_ID_RF_CONFIG_1T1R BIT(3) #define SPEC_DEV_ID_RF_CONFIG_2T2R BIT(4) #define SPEC_DEV_ID_ASSIGN_IFNAME BIT(5) struct specific_device_id{ u32 flags; u16 idVendor; u16 idProduct; }; struct registry_priv { u8 chip_version; u8 rfintfs; u8 lbkmode; u8 hci; NDIS_802_11_SSID ssid; u8 network_mode; //infra, ad-hoc, auto u8 channel;//ad-hoc support requirement u8 wireless_mode;//A, B, G, auto u8 scan_mode;//active, passive u8 radio_enable; u8 preamble;//long, short, auto u8 vrtl_carrier_sense;//Enable, Disable, Auto u8 vcs_type;//RTS/CTS, CTS-to-self u16 rts_thresh; u16 frag_thresh; u8 adhoc_tx_pwr; u8 soft_ap; u8 power_mgnt; u8 ips_mode; u8 smart_ps; u8 long_retry_lmt; u8 short_retry_lmt; u16 busy_thresh; u8 ack_policy; u8 mp_mode; u8 software_encrypt; u8 software_decrypt; u8 acm_method; //UAPSD u8 wmm_enable; u8 uapsd_enable; u8 uapsd_max_sp; u8 uapsd_acbk_en; u8 uapsd_acbe_en; u8 uapsd_acvi_en; u8 uapsd_acvo_en; struct wlan_bssid_ex dev_network; u8 ht_enable; u8 cbw40_enable; u8 ampdu_enable;//for tx u8 rx_stbc; u8 ampdu_amsdu;//A-MPDU Supports A-MSDU is permitted u8 lowrate_two_xmit; u8 rf_config ; u8 low_power ; u8 wifi_spec;// !turbo_mode u8 channel_plan; #ifdef CONFIG_BT_COEXIST u8 btcoex; u8 bt_iso; u8 bt_sco; u8 bt_ampdu; #endif bool bAcceptAddbaReq; u8 antdiv_cfg; u8 antdiv_type; u8 usbss_enable;//0:disable,1:enable u8 hwpdn_mode;//0:disable,1:enable,2:decide by EFUSE config u8 hwpwrp_detect;//0:disable,1:enable u8 hw_wps_pbc;//0:disable,1:enable u8 max_roaming_times; // the max number driver will try to roaming u8 fw_iol; //enable iol without other concern #ifdef CONFIG_80211D u8 enable80211d; #endif u8 ifname[16]; u8 if2name[16]; u8 notch_filter; u8 regulatory_tid; u8 qos_opt_enable; }; //For registry parameters #define RGTRY_OFT(field) ((ULONG)FIELD_OFFSET(struct registry_priv,field)) #define RGTRY_SZ(field) sizeof(((struct registry_priv*) 0)->field) #define BSSID_OFT(field) ((ULONG)FIELD_OFFSET(struct wlan_bssid_ex,field)) #define BSSID_SZ(field) sizeof(((struct wlan_bssid_ex *) 0)->field) #define is_primary_adapter(adapter) (1) #define GET_PRIMARY_ADAPTER(padapter) (((struct adapter *)padapter)->dvobj->if1) #define GET_IFACE_NUMS(padapter) (((struct adapter *)padapter)->dvobj->iface_nums) #define GET_ADAPTER(padapter, iface_id) (((struct adapter *)padapter)->dvobj->padapters[iface_id]) enum _IFACE_ID { IFACE_ID0, //maping to PRIMARY_ADAPTER IFACE_ID1, //maping to SECONDARY_ADAPTER IFACE_ID2, IFACE_ID3, IFACE_ID_MAX, }; struct dvobj_priv { struct adapter *if1; //PRIMARY_ADAPTER struct adapter *if2; //SECONDARY_ADAPTER s32 processing_dev_remove; //for local/global synchronization _mutex hw_init_mutex; _mutex h2c_fwcmd_mutex; _mutex setch_mutex; _mutex setbw_mutex; unsigned char oper_channel; //saved channel info when call set_channel_bw unsigned char oper_bwmode; unsigned char oper_ch_offset;//PRIME_CHNL_OFFSET u32 on_oper_ch_time; struct adapter *padapters[IFACE_ID_MAX]; u8 iface_nums; // total number of ifaces used runtime //For 92D, DMDP have 2 interface. u8 InterfaceNumber; u8 NumInterfaces; //In /Out Pipe information int RtInPipe[2]; int RtOutPipe[3]; u8 Queue2Pipe[HW_QUEUE_ENTRY];//for out pipe mapping u8 irq_alloc; ATOMIC_T continual_io_error; struct pwrctrl_priv pwrctl_priv; /*-------- below is for SDIO INTERFACE --------*/ #ifdef INTF_DATA INTF_DATA intf_data; #endif /*-------- below is for USB INTERFACE --------*/ u8 nr_endpoint; u8 ishighspeed; u8 RtNumInPipes; u8 RtNumOutPipes; int ep_num[5]; //endpoint number int RegUsbSS; _sema usb_suspend_sema; _mutex usb_vendor_req_mutex; u8 *usb_alloc_vendor_req_buf; u8 *usb_vendor_req_buf; struct usb_interface *pusbintf; struct usb_device *pusbdev; }; #define dvobj_to_pwrctl(dvobj) (&(dvobj->pwrctl_priv)) #define pwrctl_to_dvobj(pwrctl) container_of(pwrctl, struct dvobj_priv, pwrctl_priv) static struct device *dvobj_to_dev(struct dvobj_priv *dvobj) { /* todo: get interface type from dvobj and the return the dev accordingly */ return &dvobj->pusbintf->dev; } enum _IFACE_TYPE { IFACE_PORT0, //mapping to port0 for C/D series chips IFACE_PORT1, //mapping to port1 for C/D series chip MAX_IFACE_PORT, }; enum _ADAPTER_TYPE { PRIMARY_ADAPTER, SECONDARY_ADAPTER, MAX_ADAPTER, }; typedef enum _DRIVER_STATE{ DRIVER_NORMAL = 0, DRIVER_DISAPPEAR = 1, DRIVER_REPLACE_DONGLE = 2, }DRIVER_STATE; #ifdef CONFIG_INTEL_PROXIM struct proxim { bool proxim_support; bool proxim_on; void *proximity_priv; int (*proxim_rx)(struct adapter *padapter, union recv_frame *precv_frame); u8 (*proxim_get_var)(struct adapter* padapter, u8 type); }; #endif //CONFIG_INTEL_PROXIM #ifdef CONFIG_MAC_LOOPBACK_DRIVER typedef struct loopbackdata { _sema sema; _thread_hdl_ lbkthread; u8 bstop; u32 cnt; u16 size; u16 txsize; u8 txbuf[0x8000]; u16 rxsize; u8 rxbuf[0x8000]; u8 msg[100]; }LOOPBACKDATA, *PLOOPBACKDATA; #endif struct adapter { int DriverState;// for disable driver using module, use dongle to replace module. int pid[3];//process id from UI, 0:wps, 1:hostapd, 2:dhcpcd int bDongle;//build-in module or external dongle u16 chip_type; u16 HardwareType; u16 interface_type;//USB,SDIO,SPI,PCI struct dvobj_priv *dvobj; struct mlme_priv mlmepriv; struct mlme_ext_priv mlmeextpriv; struct cmd_priv cmdpriv; struct evt_priv evtpriv; //struct io_queue *pio_queue; struct io_priv iopriv; struct xmit_priv xmitpriv; struct recv_priv recvpriv; struct sta_priv stapriv; struct security_priv securitypriv; _lock security_key_mutex; // add for CONFIG_IEEE80211W, none 11w also can use struct registry_priv registrypriv; struct eeprom_priv eeprompriv; struct led_priv ledpriv; #if defined(CONFIG_CHECK_BT_HANG) && defined(CONFIG_BT_COEXIST) //Check BT status for BT Hung. struct workqueue_struct *priv_checkbt_wq; struct delayed_work checkbt_work; #endif #ifdef CONFIG_DRVEXT_MODULE struct drvext_priv drvextpriv; #endif #ifdef CONFIG_AP_MODE struct hostapd_priv *phostapdpriv; #endif #ifdef CONFIG_P2P struct cfg80211_wifidirect_info cfg80211_wdinfo; #endif //CONFIG_P2P u32 setband; struct wifidirect_info wdinfo; #ifdef CONFIG_P2P struct wifi_display_info wfd_info; #endif //CONFIG_P2P void * HalData; u32 hal_data_sz; struct hal_ops HalFunc; s32 bDriverStopped; s32 bSurpriseRemoved; s32 bCardDisableWOHSM; u32 IsrContent; u32 ImrContent; u8 EepromAddressSize; u8 hw_init_completed; u8 bDriverIsGoingToUnload; u8 init_adpt_in_progress; u8 bHaltInProgress; _thread_hdl_ cmdThread; _thread_hdl_ evtThread; _thread_hdl_ xmitThread; _thread_hdl_ recvThread; void (*intf_start)(struct adapter * adapter); void (*intf_stop)(struct adapter * adapter); _nic_hdl pnetdev; // used by rtw_rereg_nd_name related function struct rereg_nd_name_data { _nic_hdl old_pnetdev; char old_ifname[IFNAMSIZ]; u8 old_ips_mode; u8 old_bRegUseLed; } rereg_nd_name_priv; int bup; struct net_device_stats stats; struct iw_statistics iwstats; struct proc_dir_entry *dir_dev;// for proc directory struct proc_dir_entry *dir_odm; struct wireless_dev *rtw_wdev; int net_closed; u8 bFWReady; u8 bBTFWReady; u8 bReadPortCancel; u8 bWritePortCancel; u8 bRxRSSIDisplay; // Added by Albert 2012/10/26 // The driver will show up the desired channel number when this flag is 1. u8 bNotifyChannelChange; #ifdef CONFIG_P2P // Added by Albert 2012/12/06 // The driver will show the current P2P status when the upper application reads it. u8 bShowGetP2PState; #endif #ifdef CONFIG_AUTOSUSPEND u8 bDisableAutosuspend; #endif struct adapter *pbuddy_adapter; //extend to support multi interface //IFACE_ID0 is equals to PRIMARY_ADAPTER //IFACE_ID1 is equals to SECONDARY_ADAPTER u8 iface_id; #ifdef CONFIG_BR_EXT _lock br_ext_lock; //unsigned int macclone_completed; struct nat25_network_db_entry *nethash[NAT25_HASH_SIZE]; int pppoe_connection_in_progress; unsigned char pppoe_addr[MACADDRLEN]; unsigned char scdb_mac[MACADDRLEN]; unsigned char scdb_ip[4]; struct nat25_network_db_entry *scdb_entry; unsigned char br_mac[MACADDRLEN]; unsigned char br_ip[4]; struct br_ext_info ethBrExtInfo; #endif // CONFIG_BR_EXT #ifdef CONFIG_INTEL_PROXIM /* intel Proximity, should be alloc mem * in intel Proximity module and can only * be used in intel Proximity mode */ struct proxim proximity; #endif //CONFIG_INTEL_PROXIM #ifdef CONFIG_MAC_LOOPBACK_DRIVER PLOOPBACKDATA ploopback; #endif u8 fix_rate; unsigned char in_cta_test; }; #define adapter_to_dvobj(adapter) (adapter->dvobj) #define adapter_to_pwrctl(adapter) (&(adapter->dvobj->pwrctl_priv)) int rtw_handle_dualmac(struct adapter *adapter, bool init); __inline static u8 *myid(struct eeprom_priv *peepriv) { return (peepriv->mac_addr); } #endif //__DRV_TYPES_H__