|  | /* SPDX-License-Identifier: GPL-2.0-only */ | 
|  | /* | 
|  | * This file is part of wl18xx | 
|  | * | 
|  | * Copyright (C) 2011 Texas Instruments Inc. | 
|  | */ | 
|  |  | 
|  | #ifndef __WL18XX_PRIV_H__ | 
|  | #define __WL18XX_PRIV_H__ | 
|  |  | 
|  | #include "conf.h" | 
|  |  | 
|  | /* minimum FW required for driver */ | 
|  | #define WL18XX_CHIP_VER		8 | 
|  | #define WL18XX_IFTYPE_VER	9 | 
|  | #define WL18XX_MAJOR_VER	WLCORE_FW_VER_IGNORE | 
|  | #define WL18XX_SUBTYPE_VER	WLCORE_FW_VER_IGNORE | 
|  | #define WL18XX_MINOR_VER	58 | 
|  |  | 
|  | #define WL18XX_CMD_MAX_SIZE          740 | 
|  |  | 
|  | #define WL18XX_AGGR_BUFFER_SIZE		(13 * PAGE_SIZE) | 
|  |  | 
|  | #define WL18XX_NUM_TX_DESCRIPTORS 32 | 
|  | #define WL18XX_NUM_RX_DESCRIPTORS 32 | 
|  |  | 
|  | #define WL18XX_NUM_MAC_ADDRESSES 2 | 
|  |  | 
|  | #define WL18XX_RX_BA_MAX_SESSIONS 13 | 
|  |  | 
|  | #define WL18XX_MAX_AP_STATIONS 10 | 
|  | #define WL18XX_MAX_LINKS 16 | 
|  |  | 
|  | struct wl18xx_priv { | 
|  | /* buffer for sending commands to FW */ | 
|  | u8 cmd_buf[WL18XX_CMD_MAX_SIZE]; | 
|  |  | 
|  | struct wl18xx_priv_conf conf; | 
|  |  | 
|  | /* Index of last released Tx desc in FW */ | 
|  | u8 last_fw_rls_idx; | 
|  |  | 
|  | /* number of keys requiring extra spare mem-blocks */ | 
|  | int extra_spare_key_count; | 
|  | }; | 
|  |  | 
|  | #define WL18XX_FW_MAX_TX_STATUS_DESC 33 | 
|  |  | 
|  | struct wl18xx_fw_status_priv { | 
|  | /* | 
|  | * Index in released_tx_desc for first byte that holds | 
|  | * released tx host desc | 
|  | */ | 
|  | u8 fw_release_idx; | 
|  |  | 
|  | /* | 
|  | * Array of host Tx descriptors, where fw_release_idx | 
|  | * indicated the first released idx. | 
|  | */ | 
|  | u8 released_tx_desc[WL18XX_FW_MAX_TX_STATUS_DESC]; | 
|  |  | 
|  | /* A bitmap representing the currently suspended links. The suspend | 
|  | * is short lived, for multi-channel Tx requirements. | 
|  | */ | 
|  | __le32 link_suspend_bitmap; | 
|  |  | 
|  | /* packet threshold for an "almost empty" AC, | 
|  | * for Tx schedulng purposes | 
|  | */ | 
|  | u8 tx_ac_threshold; | 
|  |  | 
|  | /* number of packets to queue up for a link in PS */ | 
|  | u8 tx_ps_threshold; | 
|  |  | 
|  | /* number of packet to queue up for a suspended link */ | 
|  | u8 tx_suspend_threshold; | 
|  |  | 
|  | /* Should have less than this number of packets in queue of a slow | 
|  | * link to qualify as high priority link | 
|  | */ | 
|  | u8 tx_slow_link_prio_threshold; | 
|  |  | 
|  | /* Should have less than this number of packets in queue of a fast | 
|  | * link to qualify as high priority link | 
|  | */ | 
|  | u8 tx_fast_link_prio_threshold; | 
|  |  | 
|  | /* Should have less than this number of packets in queue of a slow | 
|  | * link before we stop queuing up packets for it. | 
|  | */ | 
|  | u8 tx_slow_stop_threshold; | 
|  |  | 
|  | /* Should have less than this number of packets in queue of a fast | 
|  | * link before we stop queuing up packets for it. | 
|  | */ | 
|  | u8 tx_fast_stop_threshold; | 
|  |  | 
|  | u8 padding[3]; | 
|  | }; | 
|  |  | 
|  | struct wl18xx_fw_packet_counters { | 
|  | /* Cumulative counter of released packets per AC */ | 
|  | u8 tx_released_pkts[NUM_TX_QUEUES]; | 
|  |  | 
|  | /* Cumulative counter of freed packets per HLID */ | 
|  | u8 tx_lnk_free_pkts[WL18XX_MAX_LINKS]; | 
|  |  | 
|  | /* Cumulative counter of released Voice memory blocks */ | 
|  | u8 tx_voice_released_blks; | 
|  |  | 
|  | /* Tx rate of the last transmitted packet */ | 
|  | u8 tx_last_rate; | 
|  |  | 
|  | /* Tx rate or Tx rate estimate pre-calculated by fw in mbps units */ | 
|  | u8 tx_last_rate_mbps; | 
|  |  | 
|  | /* hlid for which the rates were reported */ | 
|  | u8 hlid; | 
|  | } __packed; | 
|  |  | 
|  | /* FW status registers */ | 
|  | struct wl18xx_fw_status { | 
|  | __le32 intr; | 
|  | u8  fw_rx_counter; | 
|  | u8  drv_rx_counter; | 
|  | u8  reserved; | 
|  | u8  tx_results_counter; | 
|  | __le32 rx_pkt_descs[WL18XX_NUM_RX_DESCRIPTORS]; | 
|  |  | 
|  | __le32 fw_localtime; | 
|  |  | 
|  | /* | 
|  | * A bitmap (where each bit represents a single HLID) | 
|  | * to indicate if the station is in PS mode. | 
|  | */ | 
|  | __le32 link_ps_bitmap; | 
|  |  | 
|  | /* | 
|  | * A bitmap (where each bit represents a single HLID) to indicate | 
|  | * if the station is in Fast mode | 
|  | */ | 
|  | __le32 link_fast_bitmap; | 
|  |  | 
|  | /* Cumulative counter of total released mem blocks since FW-reset */ | 
|  | __le32 total_released_blks; | 
|  |  | 
|  | /* Size (in Memory Blocks) of TX pool */ | 
|  | __le32 tx_total; | 
|  |  | 
|  | struct wl18xx_fw_packet_counters counters; | 
|  |  | 
|  | __le32 log_start_addr; | 
|  |  | 
|  | /* Private status to be used by the lower drivers */ | 
|  | struct wl18xx_fw_status_priv priv; | 
|  | } __packed; | 
|  |  | 
|  | #define WL18XX_PHY_VERSION_MAX_LEN 20 | 
|  |  | 
|  | struct wl18xx_static_data_priv { | 
|  | char phy_version[WL18XX_PHY_VERSION_MAX_LEN]; | 
|  | }; | 
|  |  | 
|  | struct wl18xx_clk_cfg { | 
|  | u32 n; | 
|  | u32 m; | 
|  | u32 p; | 
|  | u32 q; | 
|  | bool swallow; | 
|  | }; | 
|  |  | 
|  | enum { | 
|  | CLOCK_CONFIG_16_2_M	= 1, | 
|  | CLOCK_CONFIG_16_368_M, | 
|  | CLOCK_CONFIG_16_8_M, | 
|  | CLOCK_CONFIG_19_2_M, | 
|  | CLOCK_CONFIG_26_M, | 
|  | CLOCK_CONFIG_32_736_M, | 
|  | CLOCK_CONFIG_33_6_M, | 
|  | CLOCK_CONFIG_38_468_M, | 
|  | CLOCK_CONFIG_52_M, | 
|  |  | 
|  | NUM_CLOCK_CONFIGS, | 
|  | }; | 
|  |  | 
|  | #endif /* __WL18XX_PRIV_H__ */ |