if_pci.h 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. /*
  2. * Copyright (c) 2013-2019 The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for
  5. * any purpose with or without fee is hereby granted, provided that the
  6. * above copyright notice and this permission notice appear in all
  7. * copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  10. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  11. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  12. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  13. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  14. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  15. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  16. * PERFORMANCE OF THIS SOFTWARE.
  17. */
  18. #ifndef __ATH_PCI_H__
  19. #define __ATH_PCI_H__
  20. #include <linux/version.h>
  21. #include <linux/semaphore.h>
  22. #include <linux/interrupt.h>
  23. #define ATH_DBG_DEFAULT 0
  24. #define DRAM_SIZE 0x000a8000
  25. #include "hif.h"
  26. #include "cepci.h"
  27. #include "ce_main.h"
  28. #ifdef FORCE_WAKE
  29. /* Register to wake the UMAC from power collapse */
  30. #define PCIE_SOC_PCIE_REG_PCIE_SCRATCH_0_SOC_PCIE_REG 0x4040
  31. /* Register used for handshake mechanism to validate UMAC is awake */
  32. #define PCIE_PCIE_LOCAL_REG_PCIE_SOC_WAKE_PCIE_LOCAL_REG 0x3004
  33. /* Timeout duration to validate UMAC wake status */
  34. #ifdef HAL_CONFIG_SLUB_DEBUG_ON
  35. #define FORCE_WAKE_DELAY_TIMEOUT_MS 100
  36. #else
  37. #define FORCE_WAKE_DELAY_TIMEOUT_MS 50
  38. #endif /* HAL_CONFIG_SLUB_DEBUG_ON */
  39. /* Validate UMAC status every 5ms */
  40. #define FORCE_WAKE_DELAY_MS 5
  41. #endif /* FORCE_WAKE */
  42. #ifdef QCA_HIF_HIA_EXTND
  43. extern int32_t frac, intval, ar900b_20_targ_clk, qca9888_20_targ_clk;
  44. #endif
  45. /* An address (e.g. of a buffer) in Copy Engine space. */
  46. #define HIF_MAX_TASKLET_NUM 11
  47. struct hif_tasklet_entry {
  48. uint8_t id; /* 0 - 9: maps to CE, 10: fw */
  49. void *hif_handler; /* struct hif_pci_softc */
  50. };
  51. /**
  52. * enum hif_pm_runtime_state - Driver States for Runtime Power Management
  53. * HIF_PM_RUNTIME_STATE_NONE: runtime pm is off
  54. * HIF_PM_RUNTIME_STATE_ON: runtime pm is active and link is active
  55. * HIF_PM_RUNTIME_STATE_RESUMING: a runtime resume is in progress
  56. * HIF_PM_RUNTIME_STATE_SUSPENDING: a runtime suspend is in progress
  57. * HIF_PM_RUNTIME_STATE_SUSPENDED: the driver is runtime suspended
  58. */
  59. enum hif_pm_runtime_state {
  60. HIF_PM_RUNTIME_STATE_NONE,
  61. HIF_PM_RUNTIME_STATE_ON,
  62. HIF_PM_RUNTIME_STATE_RESUMING,
  63. HIF_PM_RUNTIME_STATE_SUSPENDING,
  64. HIF_PM_RUNTIME_STATE_SUSPENDED,
  65. };
  66. #ifdef FEATURE_RUNTIME_PM
  67. /**
  68. * struct hif_pm_runtime_lock - data structure for preventing runtime suspend
  69. * @list - global list of runtime locks
  70. * @active - true if this lock is preventing suspend
  71. * @name - character string for tracking this lock
  72. */
  73. struct hif_pm_runtime_lock {
  74. struct list_head list;
  75. bool active;
  76. uint32_t timeout;
  77. const char *name;
  78. };
  79. /* Debugging stats for Runtime PM */
  80. struct hif_pci_pm_stats {
  81. u32 suspended;
  82. u32 suspend_err;
  83. u32 resumed;
  84. u32 runtime_get;
  85. u32 runtime_put;
  86. u32 request_resume;
  87. u32 allow_suspend;
  88. u32 prevent_suspend;
  89. u32 prevent_suspend_timeout;
  90. u32 allow_suspend_timeout;
  91. u32 runtime_get_err;
  92. void *last_resume_caller;
  93. void *last_busy_marker;
  94. qdf_time_t last_busy_timestamp;
  95. unsigned long suspend_jiffies;
  96. };
  97. #endif
  98. /**
  99. * struct hif_msi_info - Structure to hold msi info
  100. * @magic: cookie
  101. * @magic_da: dma address
  102. * @dmaContext: dma address
  103. *
  104. * Structure to hold MSI information for PCIe interrupts
  105. */
  106. struct hif_msi_info {
  107. void *magic;
  108. dma_addr_t magic_da;
  109. OS_DMA_MEM_CONTEXT(dmacontext);
  110. };
  111. /**
  112. * struct hif_pci_stats - Account for hif pci based statistics
  113. * @mhi_force_wake_request_vote: vote for mhi
  114. * @mhi_force_wake_failure: mhi force wake failure
  115. * @mhi_force_wake_success: mhi force wake success
  116. * @soc_force_wake_register_write_success: write to soc wake
  117. * @soc_force_wake_failure: soc force wake failure
  118. * @soc_force_wake_success: soc force wake success
  119. * @mhi_force_wake_release_success: mhi force wake release success
  120. * @soc_force_wake_release_success: soc force wake release
  121. */
  122. struct hif_pci_stats {
  123. uint32_t mhi_force_wake_request_vote;
  124. uint32_t mhi_force_wake_failure;
  125. uint32_t mhi_force_wake_success;
  126. uint32_t soc_force_wake_register_write_success;
  127. uint32_t soc_force_wake_failure;
  128. uint32_t soc_force_wake_success;
  129. uint32_t mhi_force_wake_release_failure;
  130. uint32_t mhi_force_wake_release_success;
  131. uint32_t soc_force_wake_release_success;
  132. };
  133. struct hif_pci_softc {
  134. struct HIF_CE_state ce_sc;
  135. void __iomem *mem; /* PCI address. */
  136. size_t mem_len;
  137. struct device *dev; /* For efficiency, should be first in struct */
  138. struct pci_dev *pdev;
  139. int num_msi_intrs; /* number of MSI interrupts granted */
  140. /* 0 --> using legacy PCI line interrupts */
  141. struct tasklet_struct intr_tq; /* tasklet */
  142. struct hif_msi_info msi_info;
  143. int ce_msi_irq_num[CE_COUNT_MAX];
  144. int irq;
  145. int irq_event;
  146. int cacheline_sz;
  147. u16 devid;
  148. struct hif_tasklet_entry tasklet_entries[HIF_MAX_TASKLET_NUM];
  149. bool pci_enabled;
  150. bool use_register_windowing;
  151. uint32_t register_window;
  152. qdf_spinlock_t register_access_lock;
  153. qdf_spinlock_t irq_lock;
  154. qdf_work_t reschedule_tasklet_work;
  155. uint32_t lcr_val;
  156. #ifdef FEATURE_RUNTIME_PM
  157. atomic_t pm_state;
  158. atomic_t monitor_wake_intr;
  159. uint32_t prevent_suspend_cnt;
  160. struct hif_pci_pm_stats pm_stats;
  161. struct work_struct pm_work;
  162. spinlock_t runtime_lock;
  163. qdf_timer_t runtime_timer;
  164. struct list_head prevent_suspend_list;
  165. unsigned long runtime_timer_expires;
  166. qdf_runtime_lock_t prevent_linkdown_lock;
  167. atomic_t pm_dp_rx_busy;
  168. qdf_time_t dp_last_busy_timestamp;
  169. #ifdef WLAN_OPEN_SOURCE
  170. struct dentry *pm_dentry;
  171. #endif
  172. #endif
  173. int (*hif_enable_pci)(struct hif_pci_softc *sc, struct pci_dev *pdev,
  174. const struct pci_device_id *id);
  175. void (*hif_pci_deinit)(struct hif_pci_softc *sc);
  176. void (*hif_pci_get_soc_info)(struct hif_pci_softc *sc,
  177. struct device *dev);
  178. struct hif_pci_stats stats;
  179. };
  180. bool hif_pci_targ_is_present(struct hif_softc *scn, void *__iomem *mem);
  181. int hif_configure_irq(struct hif_softc *sc);
  182. void hif_pci_cancel_deferred_target_sleep(struct hif_softc *scn);
  183. void wlan_tasklet(unsigned long data);
  184. irqreturn_t hif_pci_legacy_ce_interrupt_handler(int irq, void *arg);
  185. int hif_pci_addr_in_boundary(struct hif_softc *scn, uint32_t offset);
  186. /*
  187. * A firmware interrupt to the Host is indicated by the
  188. * low bit of SCRATCH_3_ADDRESS being set.
  189. */
  190. #define FW_EVENT_PENDING_REG_ADDRESS SCRATCH_3_ADDRESS
  191. /*
  192. * Typically, MSI Interrupts are used with PCIe. To force use of legacy
  193. * "ABCD" PCI line interrupts rather than MSI, define
  194. * FORCE_LEGACY_PCI_INTERRUPTS.
  195. * Even when NOT forced, the driver may attempt to use legacy PCI interrupts
  196. * MSI allocation fails
  197. */
  198. #define LEGACY_INTERRUPTS(sc) ((sc)->num_msi_intrs == 0)
  199. /*
  200. * There may be some pending tx frames during platform suspend.
  201. * Suspend operation should be delayed until those tx frames are
  202. * transferred from the host to target. This macro specifies how
  203. * long suspend thread has to sleep before checking pending tx
  204. * frame count.
  205. */
  206. #define OL_ATH_TX_DRAIN_WAIT_DELAY 50 /* ms */
  207. #define HIF_CE_DRAIN_WAIT_DELAY 10 /* ms */
  208. /*
  209. * Wait time (in unit of OL_ATH_TX_DRAIN_WAIT_DELAY) for pending
  210. * tx frame completion before suspend. Refer: hif_pci_suspend()
  211. */
  212. #ifndef QCA_WIFI_3_0_EMU
  213. #define OL_ATH_TX_DRAIN_WAIT_CNT 10
  214. #else
  215. #define OL_ATH_TX_DRAIN_WAIT_CNT 60
  216. #endif
  217. #ifdef FORCE_WAKE
  218. /**
  219. * hif_print_pci_stats() - Display HIF PCI stats
  220. * @hif_ctx - HIF pci handle
  221. *
  222. * Return: None
  223. */
  224. void hif_print_pci_stats(struct hif_pci_softc *pci_scn);
  225. #else
  226. static inline
  227. void hif_print_pci_stats(struct hif_pci_softc *pci_scn)
  228. {
  229. }
  230. #endif /* FORCE_WAKE */
  231. #ifdef FEATURE_RUNTIME_PM
  232. #include <linux/pm_runtime.h>
  233. static inline int hif_pm_request_resume(struct device *dev)
  234. {
  235. return pm_request_resume(dev);
  236. }
  237. static inline int __hif_pm_runtime_get(struct device *dev)
  238. {
  239. return pm_runtime_get(dev);
  240. }
  241. static inline int hif_pm_runtime_put_auto(struct device *dev)
  242. {
  243. return pm_runtime_put_autosuspend(dev);
  244. }
  245. static inline int hif_pm_runtime_resume(struct device *dev)
  246. {
  247. return pm_runtime_resume(dev);
  248. }
  249. #endif /* FEATURE_RUNTIME_PM */
  250. #endif /* __ATH_PCI_H__ */