#include <linux/vhost_types.h>
#include <linux/vdpa.h>
#include <linux/gcd.h>
#include <linux/string.h>
#include <linux/mlx5/qp.h>
#include "mlx5_vdpa.h"
#define MLX5_DIV_ROUND_UP_POW2(_n, _s) …
static int get_octo_len(u64 len, int page_shift)
{ … }
static void mlx5_set_access_mode(void *mkc, int mode)
{ … }
static void populate_mtts(struct mlx5_vdpa_direct_mr *mr, __be64 *mtt)
{ … }
struct mlx5_create_mkey_mem { … };
struct mlx5_destroy_mkey_mem { … };
static void fill_create_direct_mr(struct mlx5_vdpa_dev *mvdev,
struct mlx5_vdpa_direct_mr *mr,
struct mlx5_create_mkey_mem *mem)
{ … }
static void create_direct_mr_end(struct mlx5_vdpa_dev *mvdev,
struct mlx5_vdpa_direct_mr *mr,
struct mlx5_create_mkey_mem *mem)
{ … }
static void fill_destroy_direct_mr(struct mlx5_vdpa_dev *mvdev,
struct mlx5_vdpa_direct_mr *mr,
struct mlx5_destroy_mkey_mem *mem)
{ … }
static void destroy_direct_mr(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_direct_mr *mr)
{ … }
static u64 map_start(struct vhost_iotlb_map *map, struct mlx5_vdpa_direct_mr *mr)
{ … }
static u64 map_end(struct vhost_iotlb_map *map, struct mlx5_vdpa_direct_mr *mr)
{ … }
static u64 maplen(struct vhost_iotlb_map *map, struct mlx5_vdpa_direct_mr *mr)
{ … }
#define MLX5_VDPA_INVALID_START_ADDR …
#define MLX5_VDPA_INVALID_LEN …
static u64 indir_start_addr(struct mlx5_vdpa_mr *mkey)
{ … }
static u64 indir_len(struct mlx5_vdpa_mr *mkey)
{ … }
#define LOG_MAX_KLM_SIZE …
#define MAX_KLM_SIZE …
static u32 klm_bcount(u64 size)
{ … }
static void fill_indir(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_mr *mkey, void *in)
{ … }
static int klm_byte_size(int nklms)
{ … }
#define MLX5_VDPA_MTT_ALIGN …
static int create_direct_keys(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_mr *mr)
{ … }
DEFINE_FREE(…)
DEFINE_FREE(…)
static int destroy_direct_keys(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_mr *mr)
{ … }
static int create_indirect_key(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_mr *mr)
{ … }
static void destroy_indirect_key(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_mr *mkey)
{ … }
static int map_direct_mr(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_direct_mr *mr,
struct vhost_iotlb *iotlb)
{ … }
static void unmap_direct_mr(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_direct_mr *mr)
{ … }
static int add_direct_chain(struct mlx5_vdpa_dev *mvdev,
struct mlx5_vdpa_mr *mr,
u64 start,
u64 size,
u8 perm,
struct vhost_iotlb *iotlb)
{ … }
static int create_user_mr(struct mlx5_vdpa_dev *mvdev,
struct mlx5_vdpa_mr *mr,
struct vhost_iotlb *iotlb)
{ … }
static int create_dma_mr(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_mr *mr)
{ … }
static void destroy_dma_mr(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_mr *mr)
{ … }
static int dup_iotlb(struct vhost_iotlb *dst, struct vhost_iotlb *src)
{ … }
static void prune_iotlb(struct vhost_iotlb *iotlb)
{ … }
static void destroy_user_mr(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_mr *mr)
{ … }
static void _mlx5_vdpa_destroy_mr(struct mlx5_vdpa_dev *mvdev, struct mlx5_vdpa_mr *mr)
{ … }
#define MLX5_VDPA_MR_GC_TRIGGER_MS …
static void mlx5_vdpa_mr_gc_handler(struct work_struct *work)
{ … }
static void _mlx5_vdpa_put_mr(struct mlx5_vdpa_dev *mvdev,
struct mlx5_vdpa_mr *mr)
{ … }
void mlx5_vdpa_put_mr(struct mlx5_vdpa_dev *mvdev,
struct mlx5_vdpa_mr *mr)
{ … }
static void _mlx5_vdpa_get_mr(struct mlx5_vdpa_dev *mvdev,
struct mlx5_vdpa_mr *mr)
{ … }
void mlx5_vdpa_get_mr(struct mlx5_vdpa_dev *mvdev,
struct mlx5_vdpa_mr *mr)
{ … }
void mlx5_vdpa_update_mr(struct mlx5_vdpa_dev *mvdev,
struct mlx5_vdpa_mr *new_mr,
unsigned int asid)
{ … }
static void mlx5_vdpa_show_mr_leaks(struct mlx5_vdpa_dev *mvdev)
{ … }
void mlx5_vdpa_clean_mrs(struct mlx5_vdpa_dev *mvdev)
{ … }
static int _mlx5_vdpa_create_mr(struct mlx5_vdpa_dev *mvdev,
struct mlx5_vdpa_mr *mr,
struct vhost_iotlb *iotlb)
{ … }
struct mlx5_vdpa_mr *mlx5_vdpa_create_mr(struct mlx5_vdpa_dev *mvdev,
struct vhost_iotlb *iotlb)
{ … }
int mlx5_vdpa_update_cvq_iotlb(struct mlx5_vdpa_dev *mvdev,
struct vhost_iotlb *iotlb,
unsigned int asid)
{ … }
int mlx5_vdpa_create_dma_mr(struct mlx5_vdpa_dev *mvdev)
{ … }
int mlx5_vdpa_reset_mr(struct mlx5_vdpa_dev *mvdev, unsigned int asid)
{ … }
int mlx5_vdpa_init_mr_resources(struct mlx5_vdpa_dev *mvdev)
{ … }
void mlx5_vdpa_destroy_mr_resources(struct mlx5_vdpa_dev *mvdev)
{ … }