/* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */1/*2* Copyright (C) 2005-2014, 2020-2021, 2023, 2025 Intel Corporation3* Copyright (C) 2013-2014 Intel Mobile Communications GmbH4*/5#ifndef __iwl_drv_h__6#define __iwl_drv_h__7#include <linux/export.h>8#include <kunit/visibility.h>910/* for all modules */11#define DRV_NAME "iwlwifi"1213/* radio config bits (actual values from NVM definition) */14#define NVM_RF_CFG_DASH_MSK(x) (x & 0x3) /* bits 0-1 */15#define NVM_RF_CFG_STEP_MSK(x) ((x >> 2) & 0x3) /* bits 2-3 */16#define NVM_RF_CFG_TYPE_MSK(x) ((x >> 4) & 0x3) /* bits 4-5 */17#define NVM_RF_CFG_PNUM_MSK(x) ((x >> 6) & 0x3) /* bits 6-7 */18#define NVM_RF_CFG_TX_ANT_MSK(x) ((x >> 8) & 0xF) /* bits 8-11 */19#define NVM_RF_CFG_RX_ANT_MSK(x) ((x >> 12) & 0xF) /* bits 12-15 */2021#define EXT_NVM_RF_CFG_FLAVOR_MSK(x) ((x) & 0xF)22#define EXT_NVM_RF_CFG_DASH_MSK(x) (((x) >> 4) & 0xF)23#define EXT_NVM_RF_CFG_STEP_MSK(x) (((x) >> 8) & 0xF)24#define EXT_NVM_RF_CFG_TYPE_MSK(x) (((x) >> 12) & 0xFFF)25#define EXT_NVM_RF_CFG_TX_ANT_MSK(x) (((x) >> 24) & 0xF)26#define EXT_NVM_RF_CFG_RX_ANT_MSK(x) (((x) >> 28) & 0xF)2728/**29* DOC: Driver system flows - drv component30*31* This component implements the system flows such as bus enumeration, bus32* removal. Bus dependent parts of system flows (such as iwl_pci_probe) are in33* bus specific files (transport files). This is the code that is common among34* different buses.35*36* This component is also in charge of managing the several implementations of37* the wifi flows: it will allow to have several fw API implementation. These38* different implementations will differ in the way they implement mac80211's39* handlers too.4041* The init flow wrt to the drv component looks like this:42* 1) The bus specific component is called from module_init43* 2) The bus specific component registers the bus driver44* 3) The bus driver calls the probe function45* 4) The bus specific component configures the bus46* 5) The bus specific component calls to the drv bus agnostic part47* (iwl_drv_start)48* 6) iwl_drv_start fetches the fw ASYNC, iwl_req_fw_callback49* 7) iwl_req_fw_callback parses the fw file50* 8) iwl_req_fw_callback starts the wifi implementation to matches the fw51*/5253struct iwl_drv;54struct iwl_trans;55struct iwl_rf_cfg;56/**57* iwl_drv_start - start the drv58*59* @trans: the transport60*61* starts the driver: fetches the firmware. This should be called by bus62* specific system flows implementations. For example, the bus specific probe63* function should do bus related operations only, and then call to this64* function. It returns the driver object or %NULL if an error occurred.65*/66struct iwl_drv *iwl_drv_start(struct iwl_trans *trans);6768/**69* iwl_drv_stop - stop the drv70*71* @drv:72*73* Stop the driver. This should be called by bus specific system flows74* implementations. For example, the bus specific remove function should first75* call this function and then do the bus related operations only.76*/77void iwl_drv_stop(struct iwl_drv *drv);7879/*80* exported symbol management81*82* The driver can be split into multiple modules, in which case some symbols83* must be exported for the sub-modules. However, if it's not split and84* everything is built-in, then we can avoid that.85*/86#ifdef CONFIG_IWLWIFI_OPMODE_MODULAR87#define IWL_EXPORT_SYMBOL(sym) EXPORT_SYMBOL_NS_GPL(sym, "IWLWIFI")88#else89#define IWL_EXPORT_SYMBOL(sym)90#endif9192#if IS_ENABLED(CONFIG_IWLWIFI_KUNIT_TESTS)93#define EXPORT_SYMBOL_IF_IWLWIFI_KUNIT(sym) EXPORT_SYMBOL_IF_KUNIT(sym)94#define VISIBLE_IF_IWLWIFI_KUNIT95#else96#define EXPORT_SYMBOL_IF_IWLWIFI_KUNIT(sym)97#define VISIBLE_IF_IWLWIFI_KUNIT static98#endif99100/* max retry for init flow */101#define IWL_MAX_INIT_RETRY 2102103#define FW_NAME_PRE_BUFSIZE 64104struct iwl_trans;105const char *iwl_drv_get_fwname_pre(struct iwl_trans *trans, char *buf);106107#endif /* __iwl_drv_h__ */108109110