1
2
3
4#ifndef __MLX5_VDPA_H__
5#define __MLX5_VDPA_H__
6
7#include <linux/etherdevice.h>
8#include <linux/vringh.h>
9#include <linux/vdpa.h>
10#include <linux/mlx5/driver.h>
11
12#define MLX5V_ETH_HARD_MTU (ETH_HLEN + VLAN_HLEN + ETH_FCS_LEN)
13
14struct mlx5_vdpa_direct_mr {
15 u64 start;
16 u64 end;
17 u32 perm;
18 struct mlx5_core_mkey mr;
19 struct sg_table sg_head;
20 int log_size;
21 int nsg;
22 int nent;
23 struct list_head list;
24 u64 offset;
25};
26
27struct mlx5_vdpa_mr {
28 struct mlx5_core_mkey mkey;
29
30
31 struct list_head head;
32 unsigned long num_directs;
33 unsigned long num_klms;
34 bool initialized;
35
36
37 struct mutex mkey_mtx;
38 bool user_mr;
39};
40
41struct mlx5_vdpa_resources {
42 u32 pdn;
43 struct mlx5_uars_page *uar;
44 void __iomem *kick_addr;
45 u64 phys_kick_addr;
46 u16 uid;
47 u32 null_mkey;
48 bool valid;
49};
50
51struct mlx5_control_vq {
52 struct vhost_iotlb *iotlb;
53
54 spinlock_t iommu_lock;
55 struct vringh vring;
56 bool ready;
57 u64 desc_addr;
58 u64 device_addr;
59 u64 driver_addr;
60 struct vdpa_callback event_cb;
61 struct vringh_kiov riov;
62 struct vringh_kiov wiov;
63 unsigned short head;
64};
65
66struct mlx5_ctrl_wq_ent {
67 struct work_struct work;
68 struct mlx5_vdpa_dev *mvdev;
69};
70
71struct mlx5_vdpa_dev {
72 struct vdpa_device vdev;
73 struct mlx5_core_dev *mdev;
74 struct mlx5_vdpa_resources res;
75
76 u64 mlx_features;
77 u64 actual_features;
78 u8 status;
79 u32 max_vqs;
80 u16 max_idx;
81 u32 generation;
82
83 struct mlx5_vdpa_mr mr;
84 struct mlx5_control_vq cvq;
85 struct workqueue_struct *wq;
86};
87
88int mlx5_vdpa_alloc_pd(struct mlx5_vdpa_dev *dev, u32 *pdn, u16 uid);
89int mlx5_vdpa_dealloc_pd(struct mlx5_vdpa_dev *dev, u32 pdn, u16 uid);
90int mlx5_vdpa_get_null_mkey(struct mlx5_vdpa_dev *dev, u32 *null_mkey);
91int mlx5_vdpa_create_tis(struct mlx5_vdpa_dev *mvdev, void *in, u32 *tisn);
92void mlx5_vdpa_destroy_tis(struct mlx5_vdpa_dev *mvdev, u32 tisn);
93int mlx5_vdpa_create_rqt(struct mlx5_vdpa_dev *mvdev, void *in, int inlen, u32 *rqtn);
94int mlx5_vdpa_modify_rqt(struct mlx5_vdpa_dev *mvdev, void *in, int inlen, u32 rqtn);
95void mlx5_vdpa_destroy_rqt(struct mlx5_vdpa_dev *mvdev, u32 rqtn);
96int mlx5_vdpa_create_tir(struct mlx5_vdpa_dev *mvdev, void *in, u32 *tirn);
97void mlx5_vdpa_destroy_tir(struct mlx5_vdpa_dev *mvdev, u32 tirn);
98int mlx5_vdpa_alloc_transport_domain(struct mlx5_vdpa_dev *mvdev, u32 *tdn);
99void mlx5_vdpa_dealloc_transport_domain(struct mlx5_vdpa_dev *mvdev, u32 tdn);
100int mlx5_vdpa_alloc_resources(struct mlx5_vdpa_dev *mvdev);
101void mlx5_vdpa_free_resources(struct mlx5_vdpa_dev *mvdev);
102int mlx5_vdpa_create_mkey(struct mlx5_vdpa_dev *mvdev, struct mlx5_core_mkey *mkey, u32 *in,
103 int inlen);
104int mlx5_vdpa_destroy_mkey(struct mlx5_vdpa_dev *mvdev, struct mlx5_core_mkey *mkey);
105int mlx5_vdpa_handle_set_map(struct mlx5_vdpa_dev *mvdev, struct vhost_iotlb *iotlb,
106 bool *change_map);
107int mlx5_vdpa_create_mr(struct mlx5_vdpa_dev *mvdev, struct vhost_iotlb *iotlb);
108void mlx5_vdpa_destroy_mr(struct mlx5_vdpa_dev *mvdev);
109
110#define mlx5_vdpa_warn(__dev, format, ...) \
111 dev_warn((__dev)->mdev->device, "%s:%d:(pid %d) warning: " format, __func__, __LINE__, \
112 current->pid, ##__VA_ARGS__)
113
114#define mlx5_vdpa_info(__dev, format, ...) \
115 dev_info((__dev)->mdev->device, "%s:%d:(pid %d): " format, __func__, __LINE__, \
116 current->pid, ##__VA_ARGS__)
117
118#define mlx5_vdpa_dbg(__dev, format, ...) \
119 dev_debug((__dev)->mdev->device, "%s:%d:(pid %d): " format, __func__, __LINE__, \
120 current->pid, ##__VA_ARGS__)
121
122#endif
123