Retrieve the capabilities needed to find the cache.

Signed-off-by: Dr. David Alan Gilbert <[email protected]>
---
 fs/fuse/virtio_fs.c            | 15 +++++++++++++++
 include/uapi/linux/virtio_fs.h |  3 +++
 2 files changed, 18 insertions(+)

diff --git a/fs/fuse/virtio_fs.c b/fs/fuse/virtio_fs.c
index cd916943205e..60d496c16841 100644
--- a/fs/fuse/virtio_fs.c
+++ b/fs/fuse/virtio_fs.c
@@ -520,6 +520,8 @@ static int virtio_fs_setup_dax(struct virtio_device *vdev, 
struct virtio_fs *fs)
        phys_addr_t phys_addr;
        size_t len;
        int ret;
+       u8 have_cache, cache_bar;
+       u64 cache_offset, cache_len;
 
        if (!IS_ENABLED(CONFIG_DAX_DRIVER))
                return 0;
@@ -535,6 +537,19 @@ static int virtio_fs_setup_dax(struct virtio_device *vdev, 
struct virtio_fs *fs)
        if (ret < 0)
                return ret;
 
+       have_cache = virtio_pci_find_shm_cap(pci_dev,
+                       VIRTIO_FS_PCI_SHMCAP_ID_CACHE, &cache_bar,
+                       &cache_offset, &cache_len);
+
+       if (!have_cache) {
+               dev_err(&vdev->dev, "%s: No cache capability\n",
+                       __func__);
+               return -ENXIO;
+       } else {
+               dev_notice(&vdev->dev, "Cache bar: %d len: 0x%llx @ 0x%llx\n",
+                               cache_bar, cache_len, cache_offset);
+        }
+
        /* TODO handle case where device doesn't expose BAR? */
        ret = pci_request_region(pci_dev, VIRTIO_FS_WINDOW_BAR,
                                 "virtio-fs-window");
diff --git a/include/uapi/linux/virtio_fs.h b/include/uapi/linux/virtio_fs.h
index 48f3590dcfbe..65a9d4a0dac0 100644
--- a/include/uapi/linux/virtio_fs.h
+++ b/include/uapi/linux/virtio_fs.h
@@ -38,4 +38,7 @@ struct virtio_fs_config {
        __u32 num_queues;
 } __attribute__((packed));
 
+/* For the id field in virtio_pci_shm_cap */
+#define VIRTIO_FS_PCI_SHMCAP_ID_CACHE 0
+
 #endif /* _UAPI_LINUX_VIRTIO_FS_H */
-- 
2.13.6

Reply via email to