aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband/hw/mthca/mthca_mr.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/infiniband/hw/mthca/mthca_mr.c')
-rw-r--r--drivers/infiniband/hw/mthca/mthca_mr.c28
1 files changed, 24 insertions, 4 deletions
diff --git a/drivers/infiniband/hw/mthca/mthca_mr.c b/drivers/infiniband/hw/mthca/mthca_mr.c
index 6a127a7aca57..ac3265d0bf79 100644
--- a/drivers/infiniband/hw/mthca/mthca_mr.c
+++ b/drivers/infiniband/hw/mthca/mthca_mr.c
@@ -198,20 +198,40 @@ static void mthca_free_mtt(struct mthca_dev *dev, u32 seg, int order,
198 seg + (1 << order) - 1); 198 seg + (1 << order) - 1);
199} 199}
200 200
201static inline u32 tavor_hw_index_to_key(u32 ind)
202{
203 return ind;
204}
205
206static inline u32 tavor_key_to_hw_index(u32 key)
207{
208 return key;
209}
210
211static inline u32 arbel_hw_index_to_key(u32 ind)
212{
213 return (ind >> 24) | (ind << 8);
214}
215
216static inline u32 arbel_key_to_hw_index(u32 key)
217{
218 return (key << 24) | (key >> 8);
219}
220
201static inline u32 hw_index_to_key(struct mthca_dev *dev, u32 ind) 221static inline u32 hw_index_to_key(struct mthca_dev *dev, u32 ind)
202{ 222{
203 if (dev->hca_type == ARBEL_NATIVE) 223 if (dev->hca_type == ARBEL_NATIVE)
204 return (ind >> 24) | (ind << 8); 224 return arbel_hw_index_to_key(ind);
205 else 225 else
206 return ind; 226 return tavor_hw_index_to_key(ind);
207} 227}
208 228
209static inline u32 key_to_hw_index(struct mthca_dev *dev, u32 key) 229static inline u32 key_to_hw_index(struct mthca_dev *dev, u32 key)
210{ 230{
211 if (dev->hca_type == ARBEL_NATIVE) 231 if (dev->hca_type == ARBEL_NATIVE)
212 return (key << 24) | (key >> 8); 232 return arbel_key_to_hw_index(key);
213 else 233 else
214 return key; 234 return tavor_key_to_hw_index(key);
215} 235}
216 236
217int mthca_mr_alloc_notrans(struct mthca_dev *dev, u32 pd, 237int mthca_mr_alloc_notrans(struct mthca_dev *dev, u32 pd,