|
@@ -307,3 +307,49 @@ void mlx4_db_free(struct mlx4_dev *dev, struct mlx4_db *db)
|
|
|
mutex_unlock(&priv->pgdir_mutex);
|
|
|
}
|
|
|
EXPORT_SYMBOL_GPL(mlx4_db_free);
|
|
|
+
|
|
|
+int mlx4_alloc_hwq_res(struct mlx4_dev *dev, struct mlx4_hwq_resources *wqres,
|
|
|
+ int size, int max_direct)
|
|
|
+{
|
|
|
+ int err;
|
|
|
+
|
|
|
+ err = mlx4_db_alloc(dev, &wqres->db, 1);
|
|
|
+ if (err)
|
|
|
+ return err;
|
|
|
+
|
|
|
+ *wqres->db.db = 0;
|
|
|
+
|
|
|
+ err = mlx4_buf_alloc(dev, size, max_direct, &wqres->buf);
|
|
|
+ if (err)
|
|
|
+ goto err_db;
|
|
|
+
|
|
|
+ err = mlx4_mtt_init(dev, wqres->buf.npages, wqres->buf.page_shift,
|
|
|
+ &wqres->mtt);
|
|
|
+ if (err)
|
|
|
+ goto err_buf;
|
|
|
+
|
|
|
+ err = mlx4_buf_write_mtt(dev, &wqres->mtt, &wqres->buf);
|
|
|
+ if (err)
|
|
|
+ goto err_mtt;
|
|
|
+
|
|
|
+ return 0;
|
|
|
+
|
|
|
+err_mtt:
|
|
|
+ mlx4_mtt_cleanup(dev, &wqres->mtt);
|
|
|
+err_buf:
|
|
|
+ mlx4_buf_free(dev, size, &wqres->buf);
|
|
|
+err_db:
|
|
|
+ mlx4_db_free(dev, &wqres->db);
|
|
|
+
|
|
|
+ return err;
|
|
|
+}
|
|
|
+EXPORT_SYMBOL_GPL(mlx4_alloc_hwq_res);
|
|
|
+
|
|
|
+void mlx4_free_hwq_res(struct mlx4_dev *dev, struct mlx4_hwq_resources *wqres,
|
|
|
+ int size)
|
|
|
+{
|
|
|
+ mlx4_mtt_cleanup(dev, &wqres->mtt);
|
|
|
+ mlx4_buf_free(dev, size, &wqres->buf);
|
|
|
+ mlx4_db_free(dev, &wqres->db);
|
|
|
+}
|
|
|
+EXPORT_SYMBOL_GPL(mlx4_free_hwq_res);
|