return ret;
 
        eni_vdpa = vdpa_alloc_device(struct eni_vdpa, vdpa,
-                                    dev, &eni_vdpa_ops, 1, NULL, false);
+                                    dev, &eni_vdpa_ops, 1, 1, NULL, false);
        if (IS_ERR(eni_vdpa)) {
                ENI_ERR(pdev, "failed to allocate vDPA structure\n");
                return PTR_ERR(eni_vdpa);
 
        pdev = ifcvf_mgmt_dev->pdev;
        dev = &pdev->dev;
        adapter = vdpa_alloc_device(struct ifcvf_adapter, vdpa,
-                                   dev, &ifc_vdpa_ops, 1, name, false);
+                                   dev, &ifc_vdpa_ops, 1, 1, name, false);
        if (IS_ERR(adapter)) {
                IFCVF_ERR(pdev, "Failed to allocate vDPA structure");
                return PTR_ERR(adapter);
 
        return mvdev->generation;
 }
 
-static int mlx5_vdpa_set_map(struct vdpa_device *vdev, struct vhost_iotlb *iotlb)
+static int mlx5_vdpa_set_map(struct vdpa_device *vdev, unsigned int asid,
+                            struct vhost_iotlb *iotlb)
 {
        struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
        struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
        }
 
        ndev = vdpa_alloc_device(struct mlx5_vdpa_net, mvdev.vdev, mdev->device, &mlx5_vdpa_ops,
-                                1, name, false);
+                                1, 1, name, false);
        if (IS_ERR(ndev))
                return PTR_ERR(ndev);
 
 
  * @parent: the parent device
  * @config: the bus operations that is supported by this device
  * @ngroups: number of groups supported by this device
+ * @nas: number of address spaces supported by this device
  * @size: size of the parent structure that contains private data
  * @name: name of the vdpa device; optional.
  * @use_va: indicate whether virtual address must be used by this device
  */
 struct vdpa_device *__vdpa_alloc_device(struct device *parent,
                                        const struct vdpa_config_ops *config,
-                                       unsigned int ngroups,
+                                       unsigned int ngroups, unsigned int nas,
                                        size_t size, const char *name,
                                        bool use_va)
 {
        vdev->features_valid = false;
        vdev->use_va = use_va;
        vdev->ngroups = ngroups;
+       vdev->nas = nas;
 
        if (name)
                err = dev_set_name(&vdev->dev, "%s", name);
 
                ops = &vdpasim_config_ops;
 
        vdpasim = vdpa_alloc_device(struct vdpasim, vdpa, NULL, ops, 1,
-                                   dev_attr->name, false);
+                                   1, dev_attr->name, false);
        if (IS_ERR(vdpasim)) {
                ret = PTR_ERR(vdpasim);
                goto err_alloc;
        return range;
 }
 
-static int vdpasim_set_map(struct vdpa_device *vdpa,
+static int vdpasim_set_map(struct vdpa_device *vdpa, unsigned int asid,
                           struct vhost_iotlb *iotlb)
 {
        struct vdpasim *vdpasim = vdpa_to_sim(vdpa);
        return ret;
 }
 
-static int vdpasim_dma_map(struct vdpa_device *vdpa, u64 iova, u64 size,
+static int vdpasim_dma_map(struct vdpa_device *vdpa, unsigned int asid,
+                          u64 iova, u64 size,
                           u64 pa, u32 perm, void *opaque)
 {
        struct vdpasim *vdpasim = vdpa_to_sim(vdpa);
        return ret;
 }
 
-static int vdpasim_dma_unmap(struct vdpa_device *vdpa, u64 iova, u64 size)
+static int vdpasim_dma_unmap(struct vdpa_device *vdpa, unsigned int asid,
+                            u64 iova, u64 size)
 {
        struct vdpasim *vdpasim = vdpa_to_sim(vdpa);
 
 
 }
 
 static int vduse_vdpa_set_map(struct vdpa_device *vdpa,
+                               unsigned int asid,
                                struct vhost_iotlb *iotlb)
 {
        struct vduse_dev *dev = vdpa_to_vduse(vdpa);
                return -EEXIST;
 
        vdev = vdpa_alloc_device(struct vduse_vdpa, vdpa, dev->dev,
-                                &vduse_vdpa_config_ops, 1, name, true);
+                                &vduse_vdpa_config_ops, 1, 1, name, true);
        if (IS_ERR(vdev))
                return PTR_ERR(vdev);
 
 
                return ret;
 
        vp_vdpa = vdpa_alloc_device(struct vp_vdpa, vdpa,
-                                   dev, &vp_vdpa_ops, 1, NULL, false);
+                                   dev, &vp_vdpa_ops, 1, 1, NULL, false);
        if (IS_ERR(vp_vdpa)) {
                dev_err(dev, "vp_vdpa: Failed to allocate vDPA structure\n");
                return PTR_ERR(vp_vdpa);
 
                return r;
 
        if (ops->dma_map) {
-               r = ops->dma_map(vdpa, iova, size, pa, perm, opaque);
+               r = ops->dma_map(vdpa, 0, iova, size, pa, perm, opaque);
        } else if (ops->set_map) {
                if (!v->in_batch)
-                       r = ops->set_map(vdpa, iotlb);
+                       r = ops->set_map(vdpa, 0, iotlb);
        } else {
                r = iommu_map(v->domain, iova, pa, size,
                              perm_to_iommu_flags(perm));
        vhost_vdpa_iotlb_unmap(v, iotlb, iova, iova + size - 1);
 
        if (ops->dma_map) {
-               ops->dma_unmap(vdpa, iova, size);
+               ops->dma_unmap(vdpa, 0, iova, size);
        } else if (ops->set_map) {
                if (!v->in_batch)
-                       ops->set_map(vdpa, iotlb);
+                       ops->set_map(vdpa, 0, iotlb);
        } else {
                iommu_unmap(v->domain, iova, size);
        }
                break;
        case VHOST_IOTLB_BATCH_END:
                if (v->in_batch && ops->set_map)
-                       ops->set_map(vdpa, iotlb);
+                       ops->set_map(vdpa, 0, iotlb);
                v->in_batch = false;
                break;
        default:
        int minor;
        int r;
 
+       /* Only support 1 address space and 1 groups */
+       if (vdpa->ngroups != 1 || vdpa->nas != 1)
+               return -EOPNOTSUPP;
+
        v = kzalloc(sizeof(*v), GFP_KERNEL | __GFP_RETRY_MAYFAIL);
        if (!v)
                return -ENOMEM;
 
  * @cf_lock: Protects get and set access to configuration layout.
  * @index: device index
  * @features_valid: were features initialized? for legacy guests
+ * @ngroups: the number of virtqueue groups
+ * @nas: the number of address spaces
  * @use_va: indicate whether virtual address must be used by this device
  * @nvqs: maximum number of supported virtqueues
  * @mdev: management device pointer; caller must setup when registering device as part
        u32 nvqs;
        struct vdpa_mgmt_dev *mdev;
        unsigned int ngroups;
+       unsigned int nas;
 };
 
 /**
  *                             Needed for device that using device
  *                             specific DMA translation (on-chip IOMMU)
  *                             @vdev: vdpa device
+ *                             @asid: address space identifier
  *                             @iotlb: vhost memory mapping to be
  *                             used by the vDPA
  *                             Returns integer: success (0) or error (< 0)
  *                             specific DMA translation (on-chip IOMMU)
  *                             and preferring incremental map.
  *                             @vdev: vdpa device
+ *                             @asid: address space identifier
  *                             @iova: iova to be mapped
  *                             @size: size of the area
  *                             @pa: physical address for the map
  *                             specific DMA translation (on-chip IOMMU)
  *                             and preferring incremental unmap.
  *                             @vdev: vdpa device
+ *                             @asid: address space identifier
  *                             @iova: iova to be unmapped
  *                             @size: size of the area
  *                             Returns integer: success (0) or error (< 0)
        struct vdpa_iova_range (*get_iova_range)(struct vdpa_device *vdev);
 
        /* DMA ops */
-       int (*set_map)(struct vdpa_device *vdev, struct vhost_iotlb *iotlb);
-       int (*dma_map)(struct vdpa_device *vdev, u64 iova, u64 size,
-                      u64 pa, u32 perm, void *opaque);
-       int (*dma_unmap)(struct vdpa_device *vdev, u64 iova, u64 size);
+       int (*set_map)(struct vdpa_device *vdev, unsigned int asid,
+                      struct vhost_iotlb *iotlb);
+       int (*dma_map)(struct vdpa_device *vdev, unsigned int asid,
+                      u64 iova, u64 size, u64 pa, u32 perm, void *opaque);
+       int (*dma_unmap)(struct vdpa_device *vdev, unsigned int asid,
+                        u64 iova, u64 size);
 
        /* Free device resources */
        void (*free)(struct vdpa_device *vdev);
 
 struct vdpa_device *__vdpa_alloc_device(struct device *parent,
                                        const struct vdpa_config_ops *config,
-                                       unsigned int ngroups,
+                                       unsigned int ngroups, unsigned int nas,
                                        size_t size, const char *name,
                                        bool use_va);
 
  * @parent: the parent device
  * @config: the bus operations that is supported by this device
  * @ngroups: the number of virtqueue groups supported by this device
+ * @nas: the number of address spaces
  * @name: name of the vdpa device
  * @use_va: indicate whether virtual address must be used by this device
  *
  * Return allocated data structure or ERR_PTR upon error
  */
-#define vdpa_alloc_device(dev_struct, member, parent, config, ngroups, name, use_va)   \
+#define vdpa_alloc_device(dev_struct, member, parent, config, ngroups, nas, \
+                         name, use_va) \
                          container_of((__vdpa_alloc_device( \
-                                      parent, config, ngroups, \
-                                      sizeof(dev_struct) + \
+                                      parent, config, ngroups, nas, \
+                                      (sizeof(dev_struct) + \
                                       BUILD_BUG_ON_ZERO(offsetof( \
-                                      dev_struct, member)), name, use_va)), \
+                                      dev_struct, member))), name, use_va)), \
                                       dev_struct, member)
 
 int vdpa_register_device(struct vdpa_device *vdev, u32 nvqs);