Path: blob/main/sys/contrib/dev/iwlwifi/fw/api/sf.h
48425 views
/* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */1/*2* Copyright (C) 2012-2014 Intel Corporation3* Copyright (C) 2013-2015 Intel Mobile Communications GmbH4* Copyright (C) 2016-2017 Intel Deutschland GmbH5*/6#ifndef __iwl_fw_api_sf_h__7#define __iwl_fw_api_sf_h__89/* Smart Fifo state */10enum iwl_sf_state {11SF_LONG_DELAY_ON = 0, /* should never be called by driver */12SF_FULL_ON,13SF_UNINIT,14SF_INIT_OFF,15SF_HW_NUM_STATES16};1718/* Smart Fifo possible scenario */19enum iwl_sf_scenario {20SF_SCENARIO_SINGLE_UNICAST,21SF_SCENARIO_AGG_UNICAST,22SF_SCENARIO_MULTICAST,23SF_SCENARIO_BA_RESP,24SF_SCENARIO_TX_RESP,25SF_NUM_SCENARIO26};2728#define SF_TRANSIENT_STATES_NUMBER 2 /* SF_LONG_DELAY_ON and SF_FULL_ON */29#define SF_NUM_TIMEOUT_TYPES 2 /* Aging timer and Idle timer */3031/* smart FIFO default values */32#define SF_W_MARK_SISO 614433#define SF_W_MARK_MIMO2 819234#define SF_W_MARK_MIMO3 614435#define SF_W_MARK_LEGACY 409636#define SF_W_MARK_SCAN 40963738/* SF Scenarios timers for default configuration (aligned to 32 uSec) */39#define SF_SINGLE_UNICAST_IDLE_TIMER_DEF 160 /* 150 uSec */40#define SF_SINGLE_UNICAST_AGING_TIMER_DEF 400 /* 0.4 mSec */41#define SF_AGG_UNICAST_IDLE_TIMER_DEF 160 /* 150 uSec */42#define SF_AGG_UNICAST_AGING_TIMER_DEF 400 /* 0.4 mSec */43#define SF_MCAST_IDLE_TIMER_DEF 160 /* 150 mSec */44#define SF_MCAST_AGING_TIMER_DEF 400 /* 0.4 mSec */45#define SF_BA_IDLE_TIMER_DEF 160 /* 150 uSec */46#define SF_BA_AGING_TIMER_DEF 400 /* 0.4 mSec */47#define SF_TX_RE_IDLE_TIMER_DEF 160 /* 150 uSec */48#define SF_TX_RE_AGING_TIMER_DEF 400 /* 0.4 mSec */4950/* SF Scenarios timers for BSS MAC configuration (aligned to 32 uSec) */51#define SF_SINGLE_UNICAST_IDLE_TIMER 320 /* 300 uSec */52#define SF_SINGLE_UNICAST_AGING_TIMER 2016 /* 2 mSec */53#define SF_AGG_UNICAST_IDLE_TIMER 320 /* 300 uSec */54#define SF_AGG_UNICAST_AGING_TIMER 2016 /* 2 mSec */55#define SF_MCAST_IDLE_TIMER 2016 /* 2 mSec */56#define SF_MCAST_AGING_TIMER 10016 /* 10 mSec */57#define SF_BA_IDLE_TIMER 320 /* 300 uSec */58#define SF_BA_AGING_TIMER 2016 /* 2 mSec */59#define SF_TX_RE_IDLE_TIMER 320 /* 300 uSec */60#define SF_TX_RE_AGING_TIMER 2016 /* 2 mSec */6162#define SF_LONG_DELAY_AGING_TIMER 1000000 /* 1 Sec */6364#define SF_CFG_DUMMY_NOTIF_OFF BIT(16)6566/**67* struct iwl_sf_cfg_cmd - Smart Fifo configuration command.68* @state: smart fifo state, types listed in &enum iwl_sf_state.69* @watermark: Minimum allowed available free space in RXF for transient state.70* @long_delay_timeouts: aging and idle timer values for each scenario71* in long delay state.72* @full_on_timeouts: timer values for each scenario in full on state.73*/74struct iwl_sf_cfg_cmd {75__le32 state;76__le32 watermark[SF_TRANSIENT_STATES_NUMBER];77__le32 long_delay_timeouts[SF_NUM_SCENARIO][SF_NUM_TIMEOUT_TYPES];78__le32 full_on_timeouts[SF_NUM_SCENARIO][SF_NUM_TIMEOUT_TYPES];79} __packed; /* SF_CFG_API_S_VER_2 */8081#endif /* __iwl_fw_api_sf_h__ */828384