hif.h 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638
  1. /*
  2. * Copyright (c) 2013-2016 The Linux Foundation. All rights reserved.
  3. *
  4. * Previously licensed under the ISC license by Qualcomm Atheros, Inc.
  5. *
  6. *
  7. * Permission to use, copy, modify, and/or distribute this software for
  8. * any purpose with or without fee is hereby granted, provided that the
  9. * above copyright notice and this permission notice appear in all
  10. * copies.
  11. *
  12. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  13. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  14. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  15. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  16. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  17. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  18. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  19. * PERFORMANCE OF THIS SOFTWARE.
  20. */
  21. /*
  22. * This file was originally distributed by Qualcomm Atheros, Inc.
  23. * under proprietary terms before Copyright ownership was assigned
  24. * to the Linux Foundation.
  25. */
  26. #ifndef _HIF_H_
  27. #define _HIF_H_
  28. #ifdef __cplusplus
  29. extern "C" {
  30. #endif /* __cplusplus */
  31. /* Header files */
  32. #include <qdf_status.h>
  33. #include "qdf_nbuf.h"
  34. #include "ol_if_athvar.h"
  35. #include <linux/platform_device.h>
  36. #ifdef HIF_PCI
  37. #include <linux/pci.h>
  38. #endif /* HIF_PCI */
  39. #ifdef HIF_USB
  40. #include <linux/usb.h>
  41. #endif /* HIF_USB */
  42. #define ENABLE_MBOX_DUMMY_SPACE_FEATURE 1
  43. typedef struct htc_callbacks HTC_CALLBACKS;
  44. typedef void __iomem *A_target_id_t;
  45. typedef void *hif_handle_t;
  46. #define HIF_TYPE_AR6002 2
  47. #define HIF_TYPE_AR6003 3
  48. #define HIF_TYPE_AR6004 5
  49. #define HIF_TYPE_AR9888 6
  50. #define HIF_TYPE_AR6320 7
  51. #define HIF_TYPE_AR6320V2 8
  52. /* For attaching Peregrine 2.0 board host_reg_tbl only */
  53. #define HIF_TYPE_AR9888V2 9
  54. #define HIF_TYPE_ADRASTEA 10
  55. #define HIF_TYPE_AR900B 11
  56. #define HIF_TYPE_QCA9984 12
  57. #define HIF_TYPE_IPQ4019 13
  58. #define HIF_TYPE_QCA9888 14
  59. /* TARGET definition needs to be abstracted in fw common
  60. * header files, below is the placeholder till WIN codebase
  61. * moved to latest copy of fw common header files.
  62. */
  63. #ifdef CONFIG_WIN
  64. #define TARGET_TYPE_UNKNOWN 0
  65. #define TARGET_TYPE_AR6001 1
  66. #define TARGET_TYPE_AR6002 2
  67. #define TARGET_TYPE_AR6003 3
  68. #define TARGET_TYPE_AR6004 5
  69. #define TARGET_TYPE_AR6006 6
  70. #define TARGET_TYPE_AR9888 7
  71. #define TARGET_TYPE_AR6320 8
  72. #define TARGET_TYPE_AR900B 9
  73. #define TARGET_TYPE_QCA9984 10
  74. #define TARGET_TYPE_IPQ4019 11
  75. #define TARGET_TYPE_QCA9888 12
  76. /* For attach Peregrine 2.0 board target_reg_tbl only */
  77. #define TARGET_TYPE_AR9888V2 13
  78. /* For attach Rome1.0 target_reg_tbl only*/
  79. #define TARGET_TYPE_AR6320V1 14
  80. /* For Rome2.0/2.1 target_reg_tbl ID*/
  81. #define TARGET_TYPE_AR6320V2 15
  82. /* For Rome3.0 target_reg_tbl ID*/
  83. #define TARGET_TYPE_AR6320V3 16
  84. /* For Tufello1.0 target_reg_tbl ID*/
  85. #define TARGET_TYPE_QCA9377V1 17
  86. /* For Adrastea target */
  87. #define TARGET_TYPE_ADRASTEA 19
  88. #endif
  89. struct CE_state;
  90. #define CE_COUNT_MAX 12
  91. #ifdef CONFIG_SLUB_DEBUG_ON
  92. #define QCA_NAPI_BUDGET 64
  93. #define QCA_NAPI_DEF_SCALE 2
  94. #else /* PERF build */
  95. #define QCA_NAPI_BUDGET 64
  96. #define QCA_NAPI_DEF_SCALE 16
  97. #endif /* SLUB_DEBUG_ON */
  98. #define HIF_NAPI_MAX_RECEIVES (QCA_NAPI_BUDGET * QCA_NAPI_DEF_SCALE)
  99. /* NOTE: "napi->scale" can be changed,
  100. but this does not change the number of buckets */
  101. #define QCA_NAPI_NUM_BUCKETS (QCA_NAPI_BUDGET / QCA_NAPI_DEF_SCALE)
  102. struct qca_napi_stat {
  103. uint32_t napi_schedules;
  104. uint32_t napi_polls;
  105. uint32_t napi_completes;
  106. uint32_t napi_workdone;
  107. uint32_t napi_budget_uses[QCA_NAPI_NUM_BUCKETS];
  108. };
  109. /**
  110. * per NAPI instance data structure
  111. * This data structure holds stuff per NAPI instance.
  112. * Note that, in the current implementation, though scale is
  113. * an instance variable, it is set to the same value for all
  114. * instances.
  115. */
  116. struct qca_napi_info {
  117. struct net_device netdev; /* dummy net_dev */
  118. struct napi_struct napi; /* one NAPI Instance per CE in phase I */
  119. uint8_t scale; /* currently same on all instances */
  120. uint8_t id;
  121. struct qca_napi_stat stats[NR_CPUS];
  122. };
  123. /**
  124. * NAPI data-sructure common to all NAPI instances.
  125. *
  126. * A variable of this type will be stored in hif module context.
  127. */
  128. struct qca_napi_data {
  129. /* NOTE: make sure the mutex is inited only at the very beginning
  130. once for the lifetime of the driver. For now, granularity of one
  131. is OK, but we might want to have a better granularity later */
  132. struct mutex mutex;
  133. uint32_t state;
  134. uint32_t ce_map; /* bitmap of created/registered NAPI
  135. instances, indexed by pipe_id,
  136. not used by clients (clients use an
  137. id returned by create) */
  138. struct qca_napi_info napis[CE_COUNT_MAX];
  139. };
  140. /**
  141. * struct hif_config_info - Place Holder for hif confiruation
  142. * @enable_self_recovery: Self Recovery
  143. *
  144. * Structure for holding hif ini parameters.
  145. */
  146. struct hif_config_info {
  147. bool enable_self_recovery;
  148. #ifdef FEATURE_RUNTIME_PM
  149. bool enable_runtime_pm;
  150. u_int32_t runtime_pm_delay;
  151. #endif
  152. };
  153. /**
  154. * struct hif_target_info - Target Information
  155. * @target_version: Target Version
  156. * @target_type: Target Type
  157. * @target_revision: Target Revision
  158. * @soc_version: SOC Version
  159. *
  160. * Structure to hold target information.
  161. */
  162. struct hif_target_info {
  163. uint32_t target_version;
  164. uint32_t target_type;
  165. uint32_t target_revision;
  166. uint32_t soc_version;
  167. };
  168. struct hif_opaque_softc {
  169. };
  170. typedef enum {
  171. HIF_DEVICE_POWER_UP, /* HIF layer should power up interface
  172. * and/or module */
  173. HIF_DEVICE_POWER_DOWN, /* HIF layer should initiate bus-specific
  174. * measures to minimize power */
  175. HIF_DEVICE_POWER_CUT /* HIF layer should initiate bus-specific
  176. * AND/OR platform-specific measures
  177. * to completely power-off the module and
  178. * associated hardware (i.e. cut power
  179. * supplies) */
  180. } HIF_DEVICE_POWER_CHANGE_TYPE;
  181. /**
  182. * enum hif_enable_type: what triggered the enabling of hif
  183. *
  184. * @HIF_ENABLE_TYPE_PROBE: probe triggered enable
  185. * @HIF_ENABLE_TYPE_REINIT: reinit triggered enable
  186. */
  187. enum hif_enable_type {
  188. HIF_ENABLE_TYPE_PROBE,
  189. HIF_ENABLE_TYPE_REINIT,
  190. HIF_ENABLE_TYPE_MAX
  191. };
  192. /**
  193. * enum hif_disable_type: what triggered the disabling of hif
  194. *
  195. * @HIF_DISABLE_TYPE_PROBE_ERROR: probe error triggered disable
  196. * @HIF_DISABLE_TYPE_REINIT_ERROR: reinit error triggered
  197. * disable
  198. * @HIF_DISABLE_TYPE_REMOVE: remove triggered disable
  199. * @HIF_DISABLE_TYPE_SHUTDOWN: shutdown triggered disable
  200. */
  201. enum hif_disable_type {
  202. HIF_DISABLE_TYPE_PROBE_ERROR,
  203. HIF_DISABLE_TYPE_REINIT_ERROR,
  204. HIF_DISABLE_TYPE_REMOVE,
  205. HIF_DISABLE_TYPE_SHUTDOWN,
  206. HIF_DISABLE_TYPE_MAX
  207. };
  208. /**
  209. * enum hif_device_config_opcode: configure mode
  210. *
  211. * @HIF_DEVICE_POWER_STATE: device power state
  212. * @HIF_DEVICE_GET_MBOX_BLOCK_SIZE: get mbox block size
  213. * @HIF_DEVICE_GET_MBOX_ADDR: get mbox block address
  214. * @HIF_DEVICE_GET_PENDING_EVENTS_FUNC: get pending events functions
  215. * @HIF_DEVICE_GET_IRQ_PROC_MODE: get irq proc mode
  216. * @HIF_DEVICE_GET_RECV_EVENT_MASK_UNMASK_FUNC: receive event function
  217. * @HIF_DEVICE_POWER_STATE_CHANGE: change power state
  218. * @HIF_DEVICE_GET_IRQ_YIELD_PARAMS: get yield params
  219. * @HIF_CONFIGURE_QUERY_SCATTER_REQUEST_SUPPORT: configure scatter request
  220. * @HIF_DEVICE_GET_OS_DEVICE: get OS device
  221. * @HIF_DEVICE_DEBUG_BUS_STATE: debug bus state
  222. * @HIF_BMI_DONE: bmi done
  223. * @HIF_DEVICE_SET_TARGET_TYPE: set target type
  224. * @HIF_DEVICE_SET_HTC_CONTEXT: set htc context
  225. * @HIF_DEVICE_GET_HTC_CONTEXT: get htc context
  226. */
  227. enum hif_device_config_opcode {
  228. HIF_DEVICE_POWER_STATE = 0,
  229. HIF_DEVICE_GET_MBOX_BLOCK_SIZE,
  230. HIF_DEVICE_GET_MBOX_ADDR,
  231. HIF_DEVICE_GET_PENDING_EVENTS_FUNC,
  232. HIF_DEVICE_GET_IRQ_PROC_MODE,
  233. HIF_DEVICE_GET_RECV_EVENT_MASK_UNMASK_FUNC,
  234. HIF_DEVICE_POWER_STATE_CHANGE,
  235. HIF_DEVICE_GET_IRQ_YIELD_PARAMS,
  236. HIF_CONFIGURE_QUERY_SCATTER_REQUEST_SUPPORT,
  237. HIF_DEVICE_GET_OS_DEVICE,
  238. HIF_DEVICE_DEBUG_BUS_STATE,
  239. HIF_BMI_DONE,
  240. HIF_DEVICE_SET_TARGET_TYPE,
  241. HIF_DEVICE_SET_HTC_CONTEXT,
  242. HIF_DEVICE_GET_HTC_CONTEXT,
  243. };
  244. #ifdef CONFIG_ATH_PCIE_ACCESS_DEBUG
  245. typedef struct _HID_ACCESS_LOG {
  246. uint32_t seqnum;
  247. bool is_write;
  248. void *addr;
  249. uint32_t value;
  250. } HIF_ACCESS_LOG;
  251. #endif
  252. void hif_reg_write(struct hif_opaque_softc *hif_ctx, uint32_t offset,
  253. uint32_t value);
  254. uint32_t hif_reg_read(struct hif_opaque_softc *hif_ctx, uint32_t offset);
  255. #define HIF_MAX_DEVICES 1
  256. struct htc_callbacks {
  257. void *context; /* context to pass to the dsrhandler
  258. * note : rwCompletionHandler is provided
  259. * the context passed to hif_read_write */
  260. QDF_STATUS(*rwCompletionHandler)(void *rwContext, QDF_STATUS status);
  261. QDF_STATUS(*dsrHandler)(void *context);
  262. };
  263. /**
  264. * struct hif_driver_state_callbacks - Callbacks for HIF to query Driver state
  265. * @context: Private data context
  266. * @set_recovery_in_progress: To Set Driver state for recovery in progress
  267. * @is_recovery_in_progress: Query if driver state is recovery in progress
  268. * @is_load_unload_in_progress: Query if driver state Load/Unload in Progress
  269. * @is_driver_unloading: Query if driver is unloading.
  270. *
  271. * This Structure provides callback pointer for HIF to query hdd for driver
  272. * states.
  273. */
  274. struct hif_driver_state_callbacks {
  275. void *context;
  276. void (*set_recovery_in_progress)(void *context, uint8_t val);
  277. bool (*is_recovery_in_progress)(void *context);
  278. bool (*is_load_unload_in_progress)(void *context);
  279. bool (*is_driver_unloading)(void *context);
  280. };
  281. /* This API detaches the HTC layer from the HIF device */
  282. void hif_detach_htc(struct hif_opaque_softc *scn);
  283. /****************************************************************/
  284. /* BMI and Diag window abstraction */
  285. /****************************************************************/
  286. #define HIF_BMI_EXCHANGE_NO_TIMEOUT ((uint32_t)(0))
  287. #define DIAG_TRANSFER_LIMIT 2048U /* maximum number of bytes that can be
  288. * handled atomically by
  289. * DiagRead/DiagWrite */
  290. /*
  291. * API to handle HIF-specific BMI message exchanges, this API is synchronous
  292. * and only allowed to be called from a context that can block (sleep) */
  293. QDF_STATUS hif_exchange_bmi_msg(struct hif_opaque_softc *scn,
  294. qdf_dma_addr_t cmd, qdf_dma_addr_t rsp,
  295. uint8_t *pSendMessage, uint32_t Length,
  296. uint8_t *pResponseMessage,
  297. uint32_t *pResponseLength, uint32_t TimeoutMS);
  298. /*
  299. * APIs to handle HIF specific diagnostic read accesses. These APIs are
  300. * synchronous and only allowed to be called from a context that
  301. * can block (sleep). They are not high performance APIs.
  302. *
  303. * hif_diag_read_access reads a 4 Byte aligned/length value from a
  304. * Target register or memory word.
  305. *
  306. * hif_diag_read_mem reads an arbitrary length of arbitrarily aligned memory.
  307. */
  308. QDF_STATUS hif_diag_read_access(struct hif_opaque_softc *scn, uint32_t address,
  309. uint32_t *data);
  310. QDF_STATUS hif_diag_read_mem(struct hif_opaque_softc *scn, uint32_t address,
  311. uint8_t *data, int nbytes);
  312. void hif_dump_target_memory(struct hif_opaque_softc *scn, void *ramdump_base,
  313. uint32_t address, uint32_t size);
  314. /*
  315. * APIs to handle HIF specific diagnostic write accesses. These APIs are
  316. * synchronous and only allowed to be called from a context that
  317. * can block (sleep).
  318. * They are not high performance APIs.
  319. *
  320. * hif_diag_write_access writes a 4 Byte aligned/length value to a
  321. * Target register or memory word.
  322. *
  323. * hif_diag_write_mem writes an arbitrary length of arbitrarily aligned memory.
  324. */
  325. QDF_STATUS hif_diag_write_access(struct hif_opaque_softc *scn, uint32_t address,
  326. uint32_t data);
  327. QDF_STATUS hif_diag_write_mem(struct hif_opaque_softc *scn, uint32_t address,
  328. uint8_t *data, int nbytes);
  329. typedef void (*fastpath_msg_handler)(void *, qdf_nbuf_t *, uint32_t);
  330. /*
  331. * Set the FASTPATH_mode_on flag in sc, for use by data path
  332. */
  333. #ifdef WLAN_FEATURE_FASTPATH
  334. void hif_enable_fastpath(struct hif_opaque_softc *hif_ctx);
  335. bool hif_is_fastpath_mode_enabled(struct hif_opaque_softc *hif_ctx);
  336. void *hif_get_ce_handle(struct hif_opaque_softc *hif_ctx, int ret);
  337. int hif_ce_fastpath_cb_register(struct hif_opaque_softc *hif_ctx,
  338. fastpath_msg_handler handler, void *context);
  339. #else
  340. static inline int hif_ce_fastpath_cb_register(struct hif_opaque_softc *hif_ctx,
  341. fastpath_msg_handler handler,
  342. void *context)
  343. {
  344. return QDF_STATUS_E_FAILURE;
  345. }
  346. static inline void *hif_get_ce_handle(struct hif_opaque_softc *hif_ctx, int ret)
  347. {
  348. return NULL;
  349. }
  350. #endif
  351. /*
  352. * Enable/disable CDC max performance workaround
  353. * For max-performace set this to 0
  354. * To allow SoC to enter sleep set this to 1
  355. */
  356. #define CONFIG_DISABLE_CDC_MAX_PERF_WAR 0
  357. void hif_ipa_get_ce_resource(struct hif_opaque_softc *scn,
  358. qdf_dma_addr_t *ce_sr_base_paddr,
  359. uint32_t *ce_sr_ring_size,
  360. qdf_dma_addr_t *ce_reg_paddr);
  361. /**
  362. * @brief List of callbacks - filled in by HTC.
  363. */
  364. struct hif_msg_callbacks {
  365. void *Context;
  366. /**< context meaningful to HTC */
  367. QDF_STATUS (*txCompletionHandler)(void *Context, qdf_nbuf_t wbuf,
  368. uint32_t transferID,
  369. uint32_t toeplitz_hash_result);
  370. QDF_STATUS (*rxCompletionHandler)(void *Context, qdf_nbuf_t wbuf,
  371. uint8_t pipeID);
  372. void (*txResourceAvailHandler)(void *context, uint8_t pipe);
  373. void (*fwEventHandler)(void *context, QDF_STATUS status);
  374. };
  375. enum hif_target_status {
  376. TARGET_STATUS_CONNECTED = 0, /* target connected */
  377. TARGET_STATUS_RESET, /* target got reset */
  378. TARGET_STATUS_EJECT, /* target got ejected */
  379. TARGET_STATUS_SUSPEND /*target got suspend */
  380. };
  381. #define HIF_DATA_ATTR_SET_TX_CLASSIFY(attr, v) \
  382. (attr |= (v & 0x01) << 5)
  383. #define HIF_DATA_ATTR_SET_ENCAPSULATION_TYPE(attr, v) \
  384. (attr |= (v & 0x03) << 6)
  385. #define HIF_DATA_ATTR_SET_ADDR_X_SEARCH_DISABLE(attr, v) \
  386. (attr |= (v & 0x01) << 13)
  387. #define HIF_DATA_ATTR_SET_ADDR_Y_SEARCH_DISABLE(attr, v) \
  388. (attr |= (v & 0x01) << 14)
  389. #define HIF_DATA_ATTR_SET_TOEPLITZ_HASH_ENABLE(attr, v) \
  390. (attr |= (v & 0x01) << 15)
  391. #define HIF_DATA_ATTR_SET_PACKET_OR_RESULT_OFFSET(attr, v) \
  392. (attr |= (v & 0x0FFF) << 16)
  393. #define HIF_DATA_ATTR_SET_ENABLE_11H(attr, v) \
  394. (attr |= (v & 0x01) << 30)
  395. struct hif_ul_pipe_info {
  396. unsigned int nentries;
  397. unsigned int nentries_mask;
  398. unsigned int sw_index;
  399. unsigned int write_index; /* cached copy */
  400. unsigned int hw_index; /* cached copy */
  401. void *base_addr_owner_space; /* Host address space */
  402. qdf_dma_addr_t base_addr_CE_space; /* CE address space */
  403. };
  404. struct hif_dl_pipe_info {
  405. unsigned int nentries;
  406. unsigned int nentries_mask;
  407. unsigned int sw_index;
  408. unsigned int write_index; /* cached copy */
  409. unsigned int hw_index; /* cached copy */
  410. void *base_addr_owner_space; /* Host address space */
  411. qdf_dma_addr_t base_addr_CE_space; /* CE address space */
  412. };
  413. struct hif_pipe_addl_info {
  414. uint32_t pci_mem;
  415. uint32_t ctrl_addr;
  416. struct hif_ul_pipe_info ul_pipe;
  417. struct hif_dl_pipe_info dl_pipe;
  418. };
  419. struct hif_bus_id;
  420. typedef struct hif_bus_id hif_bus_id;
  421. void hif_claim_device(struct hif_opaque_softc *hif_ctx);
  422. QDF_STATUS hif_get_config_item(struct hif_opaque_softc *hif_ctx,
  423. int opcode, void *config, uint32_t config_len);
  424. void hif_set_mailbox_swap(struct hif_opaque_softc *hif_ctx);
  425. void hif_mask_interrupt_call(struct hif_opaque_softc *scn);
  426. void hif_post_init(struct hif_opaque_softc *scn, void *hHTC,
  427. struct hif_msg_callbacks *callbacks);
  428. QDF_STATUS hif_start(struct hif_opaque_softc *scn);
  429. void hif_stop(struct hif_opaque_softc *scn);
  430. void hif_flush_surprise_remove(struct hif_opaque_softc *scn);
  431. void hif_dump(struct hif_opaque_softc *scn, uint8_t CmdId, bool start);
  432. void hif_trigger_dump(struct hif_opaque_softc *hif_ctx,
  433. uint8_t cmd_id, bool start);
  434. QDF_STATUS hif_send_head(struct hif_opaque_softc *scn, uint8_t PipeID,
  435. uint32_t transferID, uint32_t nbytes,
  436. qdf_nbuf_t wbuf, uint32_t data_attr);
  437. void hif_send_complete_check(struct hif_opaque_softc *scn, uint8_t PipeID,
  438. int force);
  439. void hif_shut_down_device(struct hif_opaque_softc *scn);
  440. void hif_get_default_pipe(struct hif_opaque_softc *scn, uint8_t *ULPipe,
  441. uint8_t *DLPipe);
  442. int hif_map_service_to_pipe(struct hif_opaque_softc *scn, uint16_t svc_id,
  443. uint8_t *ul_pipe, uint8_t *dl_pipe, int *ul_is_polled,
  444. int *dl_is_polled);
  445. uint16_t
  446. hif_get_free_queue_number(struct hif_opaque_softc *scn, uint8_t PipeID);
  447. void *hif_get_targetdef(struct hif_opaque_softc *scn);
  448. uint32_t hif_hia_item_address(uint32_t target_type, uint32_t item_offset);
  449. void hif_set_target_sleep(struct hif_opaque_softc *scn, bool sleep_ok,
  450. bool wait_for_it);
  451. int hif_check_fw_reg(struct hif_opaque_softc *scn);
  452. #ifndef HIF_PCI
  453. static inline int hif_check_soc_status(struct hif_opaque_softc *scn)
  454. {
  455. return 0;
  456. }
  457. #else
  458. int hif_check_soc_status(struct hif_opaque_softc *scn);
  459. #endif
  460. void hif_get_hw_info(struct hif_opaque_softc *scn, u32 *version, u32 *revision,
  461. const char **target_name);
  462. void hif_disable_isr(struct hif_opaque_softc *scn);
  463. void hif_reset_soc(struct hif_opaque_softc *scn);
  464. void hif_save_htc_htt_config_endpoint(struct hif_opaque_softc *hif_ctx,
  465. int htc_htt_tx_endpoint);
  466. struct hif_opaque_softc *hif_open(qdf_device_t qdf_ctx, uint32_t mode,
  467. enum qdf_bus_type bus_type,
  468. struct hif_driver_state_callbacks *cbk);
  469. void hif_close(struct hif_opaque_softc *hif_ctx);
  470. QDF_STATUS hif_enable(struct hif_opaque_softc *hif_ctx, struct device *dev,
  471. void *bdev, const hif_bus_id *bid,
  472. enum qdf_bus_type bus_type,
  473. enum hif_enable_type type);
  474. void hif_disable(struct hif_opaque_softc *hif_ctx, enum hif_disable_type type);
  475. void hif_display_stats(struct hif_opaque_softc *hif_ctx);
  476. void hif_clear_stats(struct hif_opaque_softc *hif_ctx);
  477. #ifdef FEATURE_RUNTIME_PM
  478. struct hif_pm_runtime_lock;
  479. int hif_pm_runtime_get(struct hif_opaque_softc *hif_ctx);
  480. void hif_pm_runtime_get_noresume(struct hif_opaque_softc *hif_ctx);
  481. int hif_pm_runtime_put(struct hif_opaque_softc *hif_ctx);
  482. struct hif_pm_runtime_lock *hif_runtime_lock_init(const char *name);
  483. void hif_runtime_lock_deinit(struct hif_opaque_softc *hif_ctx,
  484. struct hif_pm_runtime_lock *lock);
  485. int hif_pm_runtime_prevent_suspend(struct hif_opaque_softc *ol_sc,
  486. struct hif_pm_runtime_lock *lock);
  487. int hif_pm_runtime_allow_suspend(struct hif_opaque_softc *ol_sc,
  488. struct hif_pm_runtime_lock *lock);
  489. int hif_pm_runtime_prevent_suspend_timeout(struct hif_opaque_softc *ol_sc,
  490. struct hif_pm_runtime_lock *lock, unsigned int delay);
  491. #else
  492. struct hif_pm_runtime_lock {
  493. const char *name;
  494. };
  495. static inline void hif_pm_runtime_get_noresume(struct hif_opaque_softc *hif_ctx)
  496. {}
  497. static inline int hif_pm_runtime_get(struct hif_opaque_softc *hif_ctx)
  498. { return 0; }
  499. static inline int hif_pm_runtime_put(struct hif_opaque_softc *hif_ctx)
  500. { return 0; }
  501. static inline struct hif_pm_runtime_lock *hif_runtime_lock_init(
  502. const char *name)
  503. { return NULL; }
  504. static inline void
  505. hif_runtime_lock_deinit(struct hif_opaque_softc *hif_ctx,
  506. struct hif_pm_runtime_lock *lock) {}
  507. static inline int hif_pm_runtime_prevent_suspend(struct hif_opaque_softc *ol_sc,
  508. struct hif_pm_runtime_lock *lock)
  509. { return 0; }
  510. static inline int hif_pm_runtime_allow_suspend(struct hif_opaque_softc *ol_sc,
  511. struct hif_pm_runtime_lock *lock)
  512. { return 0; }
  513. static inline int
  514. hif_pm_runtime_prevent_suspend_timeout(struct hif_opaque_softc *ol_sc,
  515. struct hif_pm_runtime_lock *lock, unsigned int delay)
  516. { return 0; }
  517. #endif
  518. void hif_enable_power_management(struct hif_opaque_softc *hif_ctx,
  519. bool is_packet_log_enabled);
  520. void hif_disable_power_management(struct hif_opaque_softc *hif_ctx);
  521. void hif_vote_link_down(struct hif_opaque_softc *);
  522. void hif_vote_link_up(struct hif_opaque_softc *);
  523. bool hif_can_suspend_link(struct hif_opaque_softc *);
  524. int hif_bus_resume(struct hif_opaque_softc *);
  525. int hif_bus_suspend(struct hif_opaque_softc *);
  526. #ifdef FEATURE_RUNTIME_PM
  527. int hif_pre_runtime_suspend(struct hif_opaque_softc *hif_ctx);
  528. void hif_pre_runtime_resume(struct hif_opaque_softc *hif_ctx);
  529. int hif_runtime_suspend(struct hif_opaque_softc *hif_ctx);
  530. int hif_runtime_resume(struct hif_opaque_softc *hif_ctx);
  531. void hif_process_runtime_suspend_success(struct hif_opaque_softc *);
  532. void hif_process_runtime_suspend_failure(struct hif_opaque_softc *);
  533. void hif_process_runtime_resume_success(struct hif_opaque_softc *);
  534. #endif
  535. int hif_dump_registers(struct hif_opaque_softc *scn);
  536. int ol_copy_ramdump(struct hif_opaque_softc *scn);
  537. void hif_crash_shutdown(struct hif_opaque_softc *hif_ctx);
  538. void hif_get_hw_info(struct hif_opaque_softc *scn, u32 *version, u32 *revision,
  539. const char **target_name);
  540. void hif_lro_flush_cb_register(struct hif_opaque_softc *scn,
  541. void (handler)(void *), void *data);
  542. void hif_lro_flush_cb_deregister(struct hif_opaque_softc *scn);
  543. bool hif_needs_bmi(struct hif_opaque_softc *scn);
  544. enum qdf_bus_type hif_get_bus_type(struct hif_opaque_softc *hif_hdl);
  545. struct hif_target_info *hif_get_target_info_handle(struct hif_opaque_softc *
  546. scn);
  547. struct hif_config_info *hif_get_ini_handle(struct hif_opaque_softc *scn);
  548. struct ramdump_info *hif_get_ramdump_ctx(struct hif_opaque_softc *hif_ctx);
  549. enum hif_target_status hif_get_target_status(struct hif_opaque_softc *hif_ctx);
  550. void hif_set_target_status(struct hif_opaque_softc *hif_ctx, enum
  551. hif_target_status);
  552. void hif_init_ini_config(struct hif_opaque_softc *hif_ctx,
  553. struct hif_config_info *cfg);
  554. void hif_update_tx_ring(struct hif_opaque_softc *osc, u_int32_t num_htt_cmpls);
  555. qdf_nbuf_t hif_batch_send(struct hif_opaque_softc *osc, qdf_nbuf_t msdu,
  556. uint32_t transfer_id, u_int32_t len, uint32_t sendhead);
  557. int hif_send_single(struct hif_opaque_softc *osc, qdf_nbuf_t msdu, uint32_t
  558. transfer_id, u_int32_t len);
  559. int hif_send_fast(struct hif_opaque_softc *osc, qdf_nbuf_t nbuf,
  560. uint32_t transfer_id, uint32_t download_len);
  561. void hif_pkt_dl_len_set(void *hif_sc, unsigned int pkt_download_len);
  562. void hif_ce_war_disable(void);
  563. void hif_ce_war_enable(void);
  564. void hif_disable_interrupt(struct hif_opaque_softc *osc, uint32_t pipe_num);
  565. #ifdef QCA_NSS_WIFI_OFFLOAD_SUPPORT
  566. struct hif_pipe_addl_info *hif_get_addl_pipe_info(struct hif_opaque_softc *osc,
  567. struct hif_pipe_addl_info *hif_info, uint32_t pipe_number);
  568. uint32_t hif_set_nss_wifiol_mode(struct hif_opaque_softc *osc,
  569. uint32_t pipe_num);
  570. int32_t hif_get_nss_wifiol_bypass_nw_process(struct hif_opaque_softc *osc);
  571. #endif /* QCA_NSS_WIFI_OFFLOAD_SUPPORT */
  572. void hif_set_bundle_mode(struct hif_opaque_softc *scn, bool enabled,
  573. int rx_bundle_cnt);
  574. int hif_bus_reset_resume(struct hif_opaque_softc *scn);
  575. #ifdef WLAN_SUSPEND_RESUME_TEST
  576. typedef void (*hdd_fake_resume_callback)(uint32_t val);
  577. void hif_fake_apps_suspend(hdd_fake_resume_callback callback);
  578. #endif
  579. #ifdef __cplusplus
  580. }
  581. #endif
  582. #endif /* _HIF_H_ */