forked from ~ljy/RK356X_SDK_RELEASE

hc
2023-12-09 95099d4622f8cb224d94e314c7a8e0df60b13f87
kernel/drivers/infiniband/hw/hns/hns_roce_hem.h
....@@ -34,8 +34,8 @@
3434 #ifndef _HNS_ROCE_HEM_H
3535 #define _HNS_ROCE_HEM_H
3636
37
-#define HW_SYNC_TIMEOUT_MSECS 500
3837 #define HW_SYNC_SLEEP_TIME_INTERVAL 20
38
+#define HW_SYNC_TIMEOUT_MSECS (25 * HW_SYNC_SLEEP_TIME_INTERVAL)
3939 #define BT_CMD_SYNC_SHIFT 31
4040
4141 enum {
....@@ -44,10 +44,15 @@
4444 HEM_TYPE_MTPT,
4545 HEM_TYPE_CQC,
4646 HEM_TYPE_SRQC,
47
+ HEM_TYPE_SCCC,
48
+ HEM_TYPE_QPC_TIMER,
49
+ HEM_TYPE_CQC_TIMER,
4750
4851 /* UNMAP HEM */
4952 HEM_TYPE_MTT,
5053 HEM_TYPE_CQE,
54
+ HEM_TYPE_SRQWQE,
55
+ HEM_TYPE_IDX,
5156 HEM_TYPE_IRRL,
5257 HEM_TYPE_TRRL,
5358 };
....@@ -97,9 +102,9 @@
97102 u32 buf_chunk_size;
98103 u32 bt_chunk_size;
99104 u32 ba_l0_num;
100
- u32 l0_idx;/* level 0 base address table index */
101
- u32 l1_idx;/* level 1 base address table index */
102
- u32 l2_idx;/* level 2 base address table index */
105
+ u32 l0_idx; /* level 0 base address table index */
106
+ u32 l1_idx; /* level 1 base address table index */
107
+ u32 l2_idx; /* level 2 base address table index */
103108 };
104109
105110 void hns_roce_free_hem(struct hns_roce_dev *hr_dev, struct hns_roce_hem *hem);
....@@ -110,12 +115,6 @@
110115 void *hns_roce_table_find(struct hns_roce_dev *hr_dev,
111116 struct hns_roce_hem_table *table, unsigned long obj,
112117 dma_addr_t *dma_handle);
113
-int hns_roce_table_get_range(struct hns_roce_dev *hr_dev,
114
- struct hns_roce_hem_table *table,
115
- unsigned long start, unsigned long end);
116
-void hns_roce_table_put_range(struct hns_roce_dev *hr_dev,
117
- struct hns_roce_hem_table *table,
118
- unsigned long start, unsigned long end);
119118 int hns_roce_init_hem_table(struct hns_roce_dev *hr_dev,
120119 struct hns_roce_hem_table *table, u32 type,
121120 unsigned long obj_size, unsigned long nobj,
....@@ -128,6 +127,19 @@
128127 struct hns_roce_hem_mhop *mhop);
129128 bool hns_roce_check_whether_mhop(struct hns_roce_dev *hr_dev, u32 type);
130129
130
+void hns_roce_hem_list_init(struct hns_roce_hem_list *hem_list);
131
+int hns_roce_hem_list_calc_root_ba(const struct hns_roce_buf_region *regions,
132
+ int region_cnt, int unit);
133
+int hns_roce_hem_list_request(struct hns_roce_dev *hr_dev,
134
+ struct hns_roce_hem_list *hem_list,
135
+ const struct hns_roce_buf_region *regions,
136
+ int region_cnt, unsigned int bt_pg_shift);
137
+void hns_roce_hem_list_release(struct hns_roce_dev *hr_dev,
138
+ struct hns_roce_hem_list *hem_list);
139
+void *hns_roce_hem_list_find_mtt(struct hns_roce_dev *hr_dev,
140
+ struct hns_roce_hem_list *hem_list,
141
+ int offset, int *mtt_cnt, u64 *phy_addr);
142
+
131143 static inline void hns_roce_hem_first(struct hns_roce_hem *hem,
132144 struct hns_roce_hem_iter *iter)
133145 {