Lines Matching +full:- +full:i
15 * - Redistributions of source code must retain the above
19 * - Redistributions in binary form must reproduce the above
81 int i, j; in mthca_make_profile() local
85 return -ENOMEM; in mthca_make_profile()
87 profile[MTHCA_RES_QP].size = dev_lim->qpc_entry_sz; in mthca_make_profile()
88 profile[MTHCA_RES_EEC].size = dev_lim->eec_entry_sz; in mthca_make_profile()
89 profile[MTHCA_RES_SRQ].size = dev_lim->srq_entry_sz; in mthca_make_profile()
90 profile[MTHCA_RES_CQ].size = dev_lim->cqc_entry_sz; in mthca_make_profile()
91 profile[MTHCA_RES_EQP].size = dev_lim->eqpc_entry_sz; in mthca_make_profile()
92 profile[MTHCA_RES_EEEC].size = dev_lim->eeec_entry_sz; in mthca_make_profile()
93 profile[MTHCA_RES_EQ].size = dev_lim->eqc_entry_sz; in mthca_make_profile()
96 profile[MTHCA_RES_MPT].size = dev_lim->mpt_entry_sz; in mthca_make_profile()
97 profile[MTHCA_RES_MTT].size = dev->limits.mtt_seg_size; in mthca_make_profile()
98 profile[MTHCA_RES_UAR].size = dev_lim->uar_scratch_entry_sz; in mthca_make_profile()
100 profile[MTHCA_RES_UARC].size = request->uarc_size; in mthca_make_profile()
102 profile[MTHCA_RES_QP].num = request->num_qp; in mthca_make_profile()
103 profile[MTHCA_RES_SRQ].num = request->num_srq; in mthca_make_profile()
104 profile[MTHCA_RES_EQP].num = request->num_qp; in mthca_make_profile()
105 profile[MTHCA_RES_RDB].num = request->num_qp * request->rdb_per_qp; in mthca_make_profile()
106 profile[MTHCA_RES_CQ].num = request->num_cq; in mthca_make_profile()
108 profile[MTHCA_RES_MCG].num = request->num_mcg; in mthca_make_profile()
109 profile[MTHCA_RES_MPT].num = request->num_mpt; in mthca_make_profile()
110 profile[MTHCA_RES_MTT].num = request->num_mtt; in mthca_make_profile()
111 profile[MTHCA_RES_UAR].num = request->num_uar; in mthca_make_profile()
112 profile[MTHCA_RES_UARC].num = request->num_uar; in mthca_make_profile()
113 profile[MTHCA_RES_UDAV].num = request->num_udav; in mthca_make_profile()
115 for (i = 0; i < MTHCA_RES_NUM; ++i) { in mthca_make_profile()
116 profile[i].type = i; in mthca_make_profile()
117 profile[i].log_num = max(ffs(profile[i].num) - 1, 0); in mthca_make_profile()
118 profile[i].size *= profile[i].num; in mthca_make_profile()
120 profile[i].size = max(profile[i].size, (u64) PAGE_SIZE); in mthca_make_profile()
125 mem_avail = dev_lim->hca.arbel.max_icm_sz; in mthca_make_profile()
127 mem_base = dev->ddr_start; in mthca_make_profile()
128 mem_avail = dev->fw.tavor.fw_start - dev->ddr_start; in mthca_make_profile()
137 for (i = MTHCA_RES_NUM; i > 0; --i) in mthca_make_profile()
138 for (j = 1; j < i; ++j) { in mthca_make_profile()
139 if (profile[j].size > profile[j - 1].size) { in mthca_make_profile()
141 profile[j] = profile[j - 1]; in mthca_make_profile()
142 profile[j - 1] = tmp; in mthca_make_profile()
146 for (i = 0; i < MTHCA_RES_NUM; ++i) { in mthca_make_profile()
147 if (profile[i].size) { in mthca_make_profile()
148 profile[i].start = mem_base + total_size; in mthca_make_profile()
149 total_size += profile[i].size; in mthca_make_profile()
157 return -ENOMEM; in mthca_make_profile()
160 if (profile[i].size) in mthca_make_profile()
161 mthca_dbg(dev, "profile[%2d]--%2d/%2d @ 0x%16llx " in mthca_make_profile()
163 i, profile[i].type, profile[i].log_num, in mthca_make_profile()
164 (unsigned long long) profile[i].start, in mthca_make_profile()
165 (unsigned long long) profile[i].size); in mthca_make_profile()
174 (int) ((mem_avail - total_size) >> 10)); in mthca_make_profile()
176 for (i = 0; i < MTHCA_RES_NUM; ++i) { in mthca_make_profile()
177 switch (profile[i].type) { in mthca_make_profile()
179 dev->limits.num_qps = profile[i].num; in mthca_make_profile()
180 init_hca->qpc_base = profile[i].start; in mthca_make_profile()
181 init_hca->log_num_qps = profile[i].log_num; in mthca_make_profile()
184 dev->limits.num_eecs = profile[i].num; in mthca_make_profile()
185 init_hca->eec_base = profile[i].start; in mthca_make_profile()
186 init_hca->log_num_eecs = profile[i].log_num; in mthca_make_profile()
189 dev->limits.num_srqs = profile[i].num; in mthca_make_profile()
190 init_hca->srqc_base = profile[i].start; in mthca_make_profile()
191 init_hca->log_num_srqs = profile[i].log_num; in mthca_make_profile()
194 dev->limits.num_cqs = profile[i].num; in mthca_make_profile()
195 init_hca->cqc_base = profile[i].start; in mthca_make_profile()
196 init_hca->log_num_cqs = profile[i].log_num; in mthca_make_profile()
199 init_hca->eqpc_base = profile[i].start; in mthca_make_profile()
202 init_hca->eeec_base = profile[i].start; in mthca_make_profile()
205 dev->limits.num_eqs = profile[i].num; in mthca_make_profile()
206 init_hca->eqc_base = profile[i].start; in mthca_make_profile()
207 init_hca->log_num_eqs = profile[i].log_num; in mthca_make_profile()
210 for (dev->qp_table.rdb_shift = 0; in mthca_make_profile()
211 request->num_qp << dev->qp_table.rdb_shift < profile[i].num; in mthca_make_profile()
212 ++dev->qp_table.rdb_shift) in mthca_make_profile()
214 dev->qp_table.rdb_base = (u32) profile[i].start; in mthca_make_profile()
215 init_hca->rdb_base = profile[i].start; in mthca_make_profile()
218 dev->limits.num_mgms = profile[i].num >> 1; in mthca_make_profile()
219 dev->limits.num_amgms = profile[i].num >> 1; in mthca_make_profile()
220 init_hca->mc_base = profile[i].start; in mthca_make_profile()
221 init_hca->log_mc_entry_sz = ffs(MTHCA_MGM_ENTRY_SIZE) - 1; in mthca_make_profile()
222 init_hca->log_mc_table_sz = profile[i].log_num; in mthca_make_profile()
223 init_hca->mc_hash_sz = 1 << (profile[i].log_num - 1); in mthca_make_profile()
226 dev->limits.num_mpts = profile[i].num; in mthca_make_profile()
227 dev->mr_table.mpt_base = profile[i].start; in mthca_make_profile()
228 init_hca->mpt_base = profile[i].start; in mthca_make_profile()
229 init_hca->log_mpt_sz = profile[i].log_num; in mthca_make_profile()
232 dev->limits.num_mtt_segs = profile[i].num; in mthca_make_profile()
233 dev->mr_table.mtt_base = profile[i].start; in mthca_make_profile()
234 init_hca->mtt_base = profile[i].start; in mthca_make_profile()
235 init_hca->mtt_seg_sz = ffs(dev->limits.mtt_seg_size) - 7; in mthca_make_profile()
238 dev->limits.num_uars = profile[i].num; in mthca_make_profile()
239 init_hca->uar_scratch_base = profile[i].start; in mthca_make_profile()
242 dev->av_table.ddr_av_base = profile[i].start; in mthca_make_profile()
243 dev->av_table.num_ddr_avs = profile[i].num; in mthca_make_profile()
246 dev->uar_table.uarc_size = request->uarc_size; in mthca_make_profile()
247 dev->uar_table.uarc_base = profile[i].start; in mthca_make_profile()
248 init_hca->uarc_base = profile[i].start; in mthca_make_profile()
249 init_hca->log_uarc_sz = ffs(request->uarc_size) - 13; in mthca_make_profile()
250 init_hca->log_uar_sz = ffs(request->num_uar) - 1; in mthca_make_profile()
261 dev->limits.num_pds = MTHCA_NUM_PDS; in mthca_make_profile()
263 if (dev->mthca_flags & MTHCA_FLAG_SINAI_OPT && in mthca_make_profile()
264 init_hca->log_mpt_sz > 23) { in mthca_make_profile()
266 init_hca->log_mpt_sz); in mthca_make_profile()
268 dev->mthca_flags &= ~MTHCA_FLAG_SINAI_OPT; in mthca_make_profile()
279 dev->limits.fmr_reserved_mtts = 0; in mthca_make_profile()
281 dev->limits.fmr_reserved_mtts = request->fmr_reserved_mtts; in mthca_make_profile()