1 /* SPDX-License-Identifier: BSD-3-Clause-Clear */
2 /*
3 * Copyright (c) 2019-2020 The Linux Foundation. All rights reserved.
4 */
5
6 #ifndef _HIF_H_
7 #define _HIF_H_
8
9 #include "core.h"
10
11 struct ath11k_hif_ops {
12 u32 (*read32)(struct ath11k_base *sc, u32 address);
13 void (*write32)(struct ath11k_base *sc, u32 address, u32 data);
14 void (*irq_enable)(struct ath11k_base *sc);
15 void (*irq_disable)(struct ath11k_base *sc);
16 int (*start)(struct ath11k_base *sc);
17 void (*stop)(struct ath11k_base *sc);
18 int (*power_up)(struct ath11k_base *sc);
19 void (*power_down)(struct ath11k_base *sc);
20 int (*suspend)(struct ath11k_base *ab);
21 int (*resume)(struct ath11k_base *ab);
22 int (*map_service_to_pipe)(struct ath11k_base *sc, u16 service_id,
23 u8 *ul_pipe, u8 *dl_pipe);
24 int (*get_user_msi_vector)(struct ath11k_base *ab, char *user_name,
25 int *num_vectors, u32 *user_base_data,
26 u32 *base_vector);
27 void (*get_msi_address)(struct ath11k_base *ab, u32 *msi_addr_lo,
28 u32 *msi_addr_hi);
29 void (*ce_irq_enable)(struct ath11k_base *ab);
30 void (*ce_irq_disable)(struct ath11k_base *ab);
31 void (*get_ce_msi_idx)(struct ath11k_base *ab, u32 ce_id, u32 *msi_idx);
32 };
33
ath11k_hif_ce_irq_enable(struct ath11k_base * ab)34 static inline void ath11k_hif_ce_irq_enable(struct ath11k_base *ab)
35 {
36 if (ab->hif.ops->ce_irq_enable)
37 ab->hif.ops->ce_irq_enable(ab);
38 }
39
ath11k_hif_ce_irq_disable(struct ath11k_base * ab)40 static inline void ath11k_hif_ce_irq_disable(struct ath11k_base *ab)
41 {
42 if (ab->hif.ops->ce_irq_disable)
43 ab->hif.ops->ce_irq_disable(ab);
44 }
45
ath11k_hif_start(struct ath11k_base * sc)46 static inline int ath11k_hif_start(struct ath11k_base *sc)
47 {
48 return sc->hif.ops->start(sc);
49 }
50
ath11k_hif_stop(struct ath11k_base * sc)51 static inline void ath11k_hif_stop(struct ath11k_base *sc)
52 {
53 sc->hif.ops->stop(sc);
54 }
55
ath11k_hif_irq_enable(struct ath11k_base * sc)56 static inline void ath11k_hif_irq_enable(struct ath11k_base *sc)
57 {
58 sc->hif.ops->irq_enable(sc);
59 }
60
ath11k_hif_irq_disable(struct ath11k_base * sc)61 static inline void ath11k_hif_irq_disable(struct ath11k_base *sc)
62 {
63 sc->hif.ops->irq_disable(sc);
64 }
65
ath11k_hif_power_up(struct ath11k_base * sc)66 static inline int ath11k_hif_power_up(struct ath11k_base *sc)
67 {
68 return sc->hif.ops->power_up(sc);
69 }
70
ath11k_hif_power_down(struct ath11k_base * sc)71 static inline void ath11k_hif_power_down(struct ath11k_base *sc)
72 {
73 sc->hif.ops->power_down(sc);
74 }
75
ath11k_hif_suspend(struct ath11k_base * ab)76 static inline int ath11k_hif_suspend(struct ath11k_base *ab)
77 {
78 if (ab->hif.ops->suspend)
79 return ab->hif.ops->suspend(ab);
80
81 return 0;
82 }
83
ath11k_hif_resume(struct ath11k_base * ab)84 static inline int ath11k_hif_resume(struct ath11k_base *ab)
85 {
86 if (ab->hif.ops->resume)
87 return ab->hif.ops->resume(ab);
88
89 return 0;
90 }
91
ath11k_hif_read32(struct ath11k_base * sc,u32 address)92 static inline u32 ath11k_hif_read32(struct ath11k_base *sc, u32 address)
93 {
94 return sc->hif.ops->read32(sc, address);
95 }
96
ath11k_hif_write32(struct ath11k_base * sc,u32 address,u32 data)97 static inline void ath11k_hif_write32(struct ath11k_base *sc, u32 address, u32 data)
98 {
99 sc->hif.ops->write32(sc, address, data);
100 }
101
ath11k_hif_map_service_to_pipe(struct ath11k_base * sc,u16 service_id,u8 * ul_pipe,u8 * dl_pipe)102 static inline int ath11k_hif_map_service_to_pipe(struct ath11k_base *sc, u16 service_id,
103 u8 *ul_pipe, u8 *dl_pipe)
104 {
105 return sc->hif.ops->map_service_to_pipe(sc, service_id, ul_pipe, dl_pipe);
106 }
107
ath11k_get_user_msi_vector(struct ath11k_base * ab,char * user_name,int * num_vectors,u32 * user_base_data,u32 * base_vector)108 static inline int ath11k_get_user_msi_vector(struct ath11k_base *ab, char *user_name,
109 int *num_vectors, u32 *user_base_data,
110 u32 *base_vector)
111 {
112 if (!ab->hif.ops->get_user_msi_vector)
113 return -EOPNOTSUPP;
114
115 return ab->hif.ops->get_user_msi_vector(ab, user_name, num_vectors,
116 user_base_data,
117 base_vector);
118 }
119
ath11k_get_msi_address(struct ath11k_base * ab,u32 * msi_addr_lo,u32 * msi_addr_hi)120 static inline void ath11k_get_msi_address(struct ath11k_base *ab, u32 *msi_addr_lo,
121 u32 *msi_addr_hi)
122 {
123 if (!ab->hif.ops->get_msi_address)
124 return;
125
126 ab->hif.ops->get_msi_address(ab, msi_addr_lo, msi_addr_hi);
127 }
128
ath11k_get_ce_msi_idx(struct ath11k_base * ab,u32 ce_id,u32 * msi_data_idx)129 static inline void ath11k_get_ce_msi_idx(struct ath11k_base *ab, u32 ce_id,
130 u32 *msi_data_idx)
131 {
132 if (ab->hif.ops->get_ce_msi_idx)
133 ab->hif.ops->get_ce_msi_idx(ab, ce_id, msi_data_idx);
134 else
135 *msi_data_idx = ce_id;
136 }
137 #endif /* _HIF_H_ */
138