/* * Definitions for ioctls to access DHD iovars. * Based on wlioctl.h (for Broadcom 802.11abg driver). * (Moves towards generic ioctls for BCM drivers/iovars.) * * Definitions subject to change without notice. * * Copyright (C) 2020, Broadcom. * * Unless you and Broadcom execute a separate written software license * agreement governing use of this software, this software is licensed to you * under the terms of the GNU General Public License version 2 (the "GPL"), * available at http://www.broadcom.com/licenses/GPLv2.php, with the * following added to such license: * * As a special exception, the copyright holders of this software give you * permission to link this software with independent modules, and to copy and * distribute the resulting executable under terms of your choice, provided that * you also meet, for each linked independent module, the terms and conditions of * the license of that module. An independent module is a module which is not * derived from this software. The special exception does not apply to any * modifications of the software. * * * <> */ #ifndef _dhdioctl_h_ #define _dhdioctl_h_ #include /* Linux network driver ioctl encoding */ typedef struct dhd_ioctl { uint32 cmd; /* common ioctl definition */ void *buf; /* pointer to user buffer */ uint32 len; /* length of user buffer */ uint32 set; /* get or set request boolean (optional) */ uint32 used; /* bytes read or written (optional) */ uint32 needed; /* bytes needed (optional) */ uint32 driver; /* to identify target driver */ } dhd_ioctl_t; /* Underlying BUS definition */ enum { BUS_TYPE_USB = 0, /* for USB dongles */ BUS_TYPE_SDIO, /* for SDIO dongles */ BUS_TYPE_PCIE /* for PCIE dongles */ }; typedef enum { DMA_XFER_SUCCESS = 0, DMA_XFER_IN_PROGRESS, DMA_XFER_FAILED } dma_xfer_status_t; typedef enum d11_lpbk_type { M2M_DMA_LPBK = 0, D11_LPBK = 1, BMC_LPBK = 2, M2M_NON_DMA_LPBK = 3, D11_HOST_MEM_LPBK = 4, BMC_HOST_MEM_LPBK = 5, M2M_WRITE_TO_RAM = 6, M2M_READ_FROM_RAM = 7, D11_WRITE_TO_RAM = 8, D11_READ_FROM_RAM = 9, MAX_LPBK = 10 } dma_xfer_type_t; typedef struct dmaxfer_info { uint16 version; uint16 length; dma_xfer_status_t status; dma_xfer_type_t type; uint src_delay; uint dest_delay; uint should_wait; uint core_num; int error_code; uint32 num_bytes; uint64 time_taken; uint64 tput; } dma_xfer_info_t; #define DHD_DMAXFER_VERSION 0x1 #define DHD_FILENAME_MAX 64 #define DHD_PATHNAME_MAX 128 #ifdef EFI struct control_signal_ops { uint32 signal; uint32 val; }; enum { WL_REG_ON = 0, DEVICE_WAKE = 1, TIME_SYNC = 2 }; typedef struct wifi_properties { uint8 version; uint32 vendor; uint32 model; uint8 mac_addr[6]; uint32 chip_revision; uint8 silicon_revision; uint8 is_powered; uint8 is_sleeping; char module_revision[16]; /* null terminated string */ uint8 is_fw_loaded; char fw_filename[DHD_FILENAME_MAX]; /* null terminated string */ char nvram_filename[DHD_FILENAME_MAX]; /* null terminated string */ uint8 channel; uint8 module_sn[6]; } wifi_properties_t; #define DHD_WIFI_PROPERTIES_VERSION 0x1 #define DHD_OTP_SIZE_WORDS 912 typedef struct intr_poll_data { uint16 version; uint16 length; uint32 type; uint32 value; } intr_poll_t; typedef enum intr_poll_data_type { INTR_POLL_DATA_PERIOD = 0, INTR_POLL_DATA_NUM_PKTS_THRESH, INTR_POLL_DATA_PKT_INTVL_THRESH } intr_poll_type_t; #define DHD_INTR_POLL_VERSION 0x1u #endif /* EFI */ typedef struct tput_test { uint16 version; uint16 length; uint8 direction; uint8 tput_test_running; uint8 mac_sta[6]; uint8 mac_ap[6]; uint8 PAD[2]; uint32 payload_size; uint32 num_pkts; uint32 timeout_ms; uint32 flags; uint32 pkts_good; uint32 pkts_bad; uint32 pkts_cmpl; uint64 time_ms; uint64 tput_bps; } tput_test_t; typedef enum { TPUT_DIR_TX = 0, TPUT_DIR_RX } tput_dir_t; /* * Current supported roles considered for policy management are AP, P2P and NAN. * Hence max value is limited to 3. */ #define DHD_MAX_IFACE_PRIORITY 3u typedef enum dhd_iftype { DHD_IF_TYPE_STA = 0, DHD_IF_TYPE_AP = 1, #ifdef DHD_AWDL DHD_IF_TYPE_AWDL = 2, #endif /* DHD_AWDL */ DHD_IF_TYPE_NAN_NMI = 3, DHD_IF_TYPE_NAN = 4, DHD_IF_TYPE_P2P_GO = 5, DHD_IF_TYPE_P2P_GC = 6, DHD_IF_TYPE_P2P_DISC = 7, DHD_IF_TYPE_IBSS = 8, DHD_IF_TYPE_MONITOR = 9, DHD_IF_TYPE_AIBSS = 10, DHD_IF_TYPE_MAX } dhd_iftype_t; typedef struct dhd_iface_mgmt_data { uint8 policy; uint8 priority[DHD_IF_TYPE_MAX]; } dhd_iface_mgmt_data_t; typedef enum dhd_iface_mgmt_policy { DHD_IF_POLICY_DEFAULT = 0, DHD_IF_POLICY_FCFS = 1, DHD_IF_POLICY_LP = 2, DHD_IF_POLICY_ROLE_PRIORITY = 3, DHD_IF_POLICY_CUSTOM = 4, DHD_IF_POLICY_INVALID = 5 } dhd_iface_mgmt_policy_t; #define TPUT_TEST_T_VER 1 #define TPUT_TEST_T_LEN 68 #define TPUT_TEST_MIN_PAYLOAD_SIZE 16 #define TPUT_TEST_USE_ETHERNET_HDR 0x1 #define TPUT_TEST_USE_802_11_HDR 0x2 /* per-driver magic numbers */ #define DHD_IOCTL_MAGIC 0x00444944 /* bump this number if you change the ioctl interface */ #define DHD_IOCTL_VERSION 1 /* * Increase the DHD_IOCTL_MAXLEN to 16K for supporting download of NVRAM files of size * > 8K. In the existing implementation when NVRAM is to be downloaded via the "vars" * DHD IOVAR, the NVRAM is copied to the DHD Driver memory. Later on when "dwnldstate" is * invoked with FALSE option, the NVRAM gets copied from the DHD driver to the Dongle * memory. The simple way to support this feature without modifying the DHD application, * driver logic is to increase the DHD_IOCTL_MAXLEN size. This macro defines the "size" * of the buffer in which data is exchanged between the DHD App and DHD driver. */ #define DHD_IOCTL_MAXLEN (16384) /* max length ioctl buffer required */ #define DHD_IOCTL_SMLEN 256 /* "small" length ioctl buffer required */ /* * For cases where 16K buf is not sufficient. * Ex:- DHD dump output beffer is more than 16K. */ #define DHD_IOCTL_MAXLEN_32K (32768u) /* common ioctl definitions */ #define DHD_GET_MAGIC 0 #define DHD_GET_VERSION 1 #define DHD_GET_VAR 2 #define DHD_SET_VAR 3 /* message levels */ #define DHD_ERROR_VAL 0x0001 #define DHD_TRACE_VAL 0x0002 #define DHD_INFO_VAL 0x0004 #define DHD_DATA_VAL 0x0008 #define DHD_CTL_VAL 0x0010 #define DHD_TIMER_VAL 0x0020 #define DHD_HDRS_VAL 0x0040 #define DHD_BYTES_VAL 0x0080 #define DHD_INTR_VAL 0x0100 #define DHD_LOG_VAL 0x0200 #define DHD_GLOM_VAL 0x0400 #define DHD_EVENT_VAL 0x0800 #define DHD_BTA_VAL 0x1000 #if defined(NDIS) && (NDISVER >= 0x0630) && defined(BCMDONGLEHOST) #define DHD_SCAN_VAL 0x2000 #else #define DHD_ISCAN_VAL 0x2000 #endif #define DHD_ARPOE_VAL 0x4000 #define DHD_REORDER_VAL 0x8000 #define DHD_NOCHECKDIED_VAL 0x20000 /* UTF WAR */ #define DHD_PNO_VAL 0x80000 #define DHD_RTT_VAL 0x100000 #define DHD_MSGTRACE_VAL 0x200000 #define DHD_FWLOG_VAL 0x400000 #define DHD_DBGIF_VAL 0x800000 #ifdef DHD_PCIE_RUNTIMEPM #define DHD_RPM_VAL 0x1000000 #else #define DHD_RPM_VAL DHD_ERROR_VAL #endif /* DHD_PCIE_NATIVE_RUNTIMEPM */ #define DHD_PKT_MON_VAL 0x2000000 #define DHD_PKT_MON_DUMP_VAL 0x4000000 #define DHD_ERROR_MEM_VAL 0x8000000 #define DHD_DNGL_IOVAR_SET_VAL 0x10000000 /**< logs the setting of dongle iovars */ #define DHD_LPBKDTDUMP_VAL 0x20000000 #define DHD_PRSRV_MEM_VAL 0x40000000 #define DHD_IOVAR_MEM_VAL 0x80000000 #define DHD_ANDROID_VAL 0x10000 #define DHD_IW_VAL 0x20000 #define DHD_CFG_VAL 0x40000 #define DHD_CONFIG_VAL 0x80000 #define DHD_DUMP_VAL 0x100000 #define DUMP_EAPOL_VAL 0x0001 #define DUMP_ARP_VAL 0x0002 #define DUMP_DHCP_VAL 0x0004 #define DUMP_ICMP_VAL 0x0008 #define DUMP_DNS_VAL 0x0010 #define DUMP_TRX_VAL 0x0080 #ifdef SDTEST /* For pktgen iovar */ typedef struct dhd_pktgen { uint32 version; /* To allow structure change tracking */ uint32 freq; /* Max ticks between tx/rx attempts */ uint32 count; /* Test packets to send/rcv each attempt */ uint32 print; /* Print counts every attempts */ uint32 total; /* Total packets (or bursts) */ uint32 minlen; /* Minimum length of packets to send */ uint32 maxlen; /* Maximum length of packets to send */ uint32 numsent; /* Count of test packets sent */ uint32 numrcvd; /* Count of test packets received */ uint32 numfail; /* Count of test send failures */ uint32 mode; /* Test mode (type of test packets) */ uint32 stop; /* Stop after this many tx failures */ } dhd_pktgen_t; /* Version in case structure changes */ #define DHD_PKTGEN_VERSION 2 /* Type of test packets to use */ #define DHD_PKTGEN_ECHO 1 /* Send echo requests */ #define DHD_PKTGEN_SEND 2 /* Send discard packets */ #define DHD_PKTGEN_RXBURST 3 /* Request dongle send N packets */ #define DHD_PKTGEN_RECV 4 /* Continuous rx from continuous tx dongle */ #endif /* SDTEST */ /* Enter idle immediately (no timeout) */ #define DHD_IDLE_IMMEDIATE (-1) /* Values for idleclock iovar: other values are the sd_divisor to use when idle */ #define DHD_IDLE_ACTIVE 0 /* Do not request any SD clock change when idle */ #define DHD_IDLE_STOP (-1) /* Request SD clock be stopped (and use SD1 mode) */ enum dhd_maclist_xtlv_type { DHD_MACLIST_XTLV_R = 0x1, DHD_MACLIST_XTLV_X = 0x2, DHD_SVMPLIST_XTLV = 0x3 }; typedef struct _dhd_maclist_t { uint16 version; /* Version */ uint16 bytes_len; /* Total bytes length of lists, XTLV headers and paddings */ uint8 plist[1]; /* Pointer to the first list */ } dhd_maclist_t; typedef struct _dhd_pd11regs_param { uint16 start_idx; uint8 verbose; uint8 pad; uint8 plist[1]; } dhd_pd11regs_param; typedef struct _dhd_pd11regs_buf { uint16 idx; uint8 pad[2]; uint8 pbuf[1]; } dhd_pd11regs_buf; /* BT logging and memory dump */ #define BT_LOG_BUF_MAX_SIZE (DHD_IOCTL_MAXLEN - (2 * sizeof(int))) #define BT_LOG_BUF_NOT_AVAILABLE 0 #define BT_LOG_NEXT_BUF_NOT_AVAIL 1 #define BT_LOG_NEXT_BUF_AVAIL 2 #define BT_LOG_NOT_READY 3 typedef struct bt_log_buf_info { int availability; int size; char buf[BT_LOG_BUF_MAX_SIZE]; } bt_log_buf_info_t; /* request BT memory in chunks */ typedef struct bt_mem_req { int offset; /* offset from BT memory start */ int buf_size; /* buffer size per chunk */ } bt_mem_req_t; typedef struct fw_download_info { uint32 fw_start_addr; uint32 fw_size; uint32 fw_entry_pt; char fw_signature_fname[DHD_FILENAME_MAX]; char bootloader_fname[DHD_FILENAME_MAX]; uint32 bootloader_start_addr; char fw_path[DHD_PATHNAME_MAX]; } fw_download_info_t; /* max dest supported */ #define DEBUG_BUF_DEST_MAX 4 /* debug buf dest stat */ typedef struct debug_buf_dest_stat { uint32 stat[DEBUG_BUF_DEST_MAX]; } debug_buf_dest_stat_t; #ifdef DHD_PKTTS /* max pktts flow config supported */ #define PKTTS_CONFIG_MAX 8 #define PKTTS_OFFSET_INVALID ((uint32)(~0)) /* pktts flow configuration */ typedef struct pktts_flow { uint16 ver; /**< version of this struct */ uint16 len; /**< length in bytes of this structure */ uint32 src_ip; /**< source ip address */ uint32 dst_ip; /**< destination ip address */ uint32 src_port; /**< source port */ uint32 dst_port; /**< destination port */ uint32 proto; /**< protocol */ uint32 ip_prec; /**< ip precedence */ uint32 pkt_offset; /**< offset from data[0] (TCP/UDP payload) */ uint32 chksum; /**< 5 tuple checksum */ } pktts_flow_t; #define BCM_TS_MAGIC 0xB055B055 #define BCM_TS_MAGIC_V2 0xB055B056 #define BCM_TS_TX 1u #define BCM_TS_RX 2u #define BCM_TS_UTX 3u /* ucode tx timestamps */ #define PKTTS_MAX_FWTX 4u #define PKTTS_MAX_UCTX 5u #define PKTTS_MAX_UCCNT 8u #define PKTTS_MAX_FWRX 2u /* Firmware timestamp header */ typedef struct bcm_to_info_hdr { uint magic; /**< magic word */ uint type; /**< tx/rx type */ uint flowid; /**< 5 tuple checksum */ uint prec; /**< ip precedence (IP_PREC) */ uint8 xbytes[16]; /**< 16bytes info from pkt offset */ } bcm_to_info_hdr_t; /* Firmware tx timestamp payload structure */ typedef struct bcm_to_info_tx_ts { bcm_to_info_hdr_t hdr; uint64 dhdt0; /**< system time - DHDT0 */ uint64 dhdt5; /**< system time - DHDT5 */ uint fwts[PKTTS_MAX_FWTX]; /**< fw timestamp - FWT0..FWT4 */ uint ucts[PKTTS_MAX_UCTX]; /**< uc timestamp - UCT0..UCT4 */ uint uccnt[PKTTS_MAX_UCCNT]; /**< uc counters */ } bcm_to_info_tx_ts_t; /* Firmware rx timestamp payload structure */ typedef struct bcm_to_info_rx_ts { bcm_to_info_hdr_t hdr; uint64 dhdr3; /**< system time - DHDR3 */ uint fwts[PKTTS_MAX_FWRX]; /**< fw timestamp - FWT0, FWT1 */ } bcm_to_info_rx_ts_t; #endif /* DHD_PKTTS */ /* devreset */ #define DHD_DEVRESET_VERSION 1 typedef struct devreset_info { uint16 version; uint16 length; uint16 mode; int16 status; } devreset_info_t; #ifdef DHD_TX_PROFILE #define DHD_TX_PROFILE_VERSION 1 /* tx_profile structure for tagging */ typedef struct dhd_tx_profile_protocol { uint16 version; uint8 profile_index; uint8 layer; uint32 protocol_number; uint16 src_port; uint16 dest_port; } dhd_tx_profile_protocol_t; #define DHD_TX_PROFILE_DATA_LINK_LAYER (2u) /* data link layer protocols */ #define DHD_TX_PROFILE_NETWORK_LAYER (3u) /* network layer protocols */ #define DHD_MAX_PROFILE_INDEX (7u) /* three bits are available to encode the tx profile index in the rate field in host_txbuf_post_t */ #define DHD_MAX_PROFILES (1u) /* ucode only supports 1 profile atm */ #endif /* defined(DHD_TX_PROFILE) */ #endif /* _dhdioctl_h_ */