| /* 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__ */ |