#ifndef LUSTRE_NVFS_H #define LUSTRE_NVFS_H #include #include #include #include #include #include #include #include struct nvfs_dma_rw_ops { unsigned long long ft_bmap; /* feature bitmap */ int (*nvfs_blk_rq_map_sg) (struct request_queue *q, struct request *req, struct scatterlist *sglist); int (*nvfs_dma_map_sg_attrs) (struct device *device, struct scatterlist *sglist, int nents, enum dma_data_direction dma_dir, unsigned long attrs); int (*nvfs_dma_unmap_sg) (struct device *device, struct scatterlist *sglist, int nents, enum dma_data_direction dma_dir); bool (*nvfs_is_gpu_page) (struct page *); unsigned int (*nvfs_gpu_index) (struct page *page); unsigned int (*nvfs_device_priority) (struct device *dev, unsigned int dev_index); }; /* feature list for dma_ops, values indicate bit pos */ enum ft_bits { nvfs_ft_prep_sglist = 1ULL << 0, nvfs_ft_map_sglist = 1ULL << 1, nvfs_ft_is_gpu_page = 1ULL << 2, nvfs_ft_device_priority = 1ULL << 3, }; /* check features for use in registration with vendor drivers */ #define NVIDIA_FS_CHECK_FT_SGLIST_PREP(ops) \ ((ops)->ft_bmap & nvfs_ft_prep_sglist) #define NVIDIA_FS_CHECK_FT_SGLIST_DMA(ops) \ ((ops)->ft_bmap & nvfs_ft_map_sglist) #define NVIDIA_FS_CHECK_FT_GPU_PAGE(ops) \ ((ops)->ft_bmap & nvfs_ft_is_gpu_page) #define NVIDIA_FS_CHECK_FT_DEVICE_PRIORITY(ops) \ ((ops)->ft_bmap & nvfs_ft_device_priority) #endif /* LUSTRE_NVFS_H */