To pass though discard_range() to the underlying drivers add a
discard_range hook to struct cdev_operations.

Signed-off-by: Sascha Hauer <s.ha...@pengutronix.de>
---
 fs/devfs.c       | 21 +++++++++++++++++++++
 include/driver.h |  1 +
 2 files changed, 22 insertions(+)

diff --git a/fs/devfs.c b/fs/devfs.c
index d088c1a66c..e1893d1bd0 100644
--- a/fs/devfs.c
+++ b/fs/devfs.c
@@ -94,6 +94,26 @@ static int devfs_protect(struct device_d *_dev, FILE *f, 
size_t count, loff_t of
        return cdev->ops->protect(cdev, count, offset + cdev->offset, prot);
 }
 
+static int devfs_discard_range(struct device_d *dev, FILE *f, loff_t count,
+                              loff_t offset)
+{
+       struct cdev *cdev = f->priv;
+
+       if (!cdev->ops->discard_range)
+               return -ENOSYS;
+
+       if (cdev->flags & DEVFS_PARTITION_READONLY)
+               return -EPERM;
+
+       if (offset >= cdev->size)
+               return 0;
+
+       if (count + offset > cdev->size)
+               count = cdev->size - offset;
+
+       return cdev->ops->discard_range(cdev, count, offset + cdev->offset);
+}
+
 static int devfs_memmap(struct device_d *_dev, FILE *f, void **map, int flags)
 {
        struct cdev *cdev = f->priv;
@@ -329,6 +349,7 @@ static struct fs_driver_d devfs_driver = {
        .truncate  = devfs_truncate,
        .erase     = devfs_erase,
        .protect   = devfs_protect,
+       .discard_range = devfs_discard_range,
        .memmap    = devfs_memmap,
        .flags     = FS_DRIVER_NO_DEV,
        .drv = {
diff --git a/include/driver.h b/include/driver.h
index ad59ce90c3..f379b0cc73 100644
--- a/include/driver.h
+++ b/include/driver.h
@@ -439,6 +439,7 @@ struct cdev_operations {
        int (*flush)(struct cdev*);
        int (*erase)(struct cdev*, loff_t count, loff_t offset);
        int (*protect)(struct cdev*, size_t count, loff_t offset, int prot);
+       int (*discard_range)(struct cdev*, loff_t count, loff_t offset);
        int (*memmap)(struct cdev*, void **map, int flags);
        int (*truncate)(struct cdev*, size_t size);
 };
-- 
2.24.0


_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox

Reply via email to