#include <linux/bio.h>
 #include <linux/slab.h>
 #include <linux/kthread.h>
+#include <linux/delay.h>
 
 #include <linux/device-mapper.h>
 
 #define DM_MSG_PREFIX "delay"
 
+#define SLEEP_SHIFT 3
+
 struct delay_class {
        struct dm_dev *dev;
        sector_t start;
        struct work_struct flush_expired_bios;
        struct list_head delayed_bios;
        struct task_struct *worker;
+       unsigned int worker_sleep_us;
        bool may_delay;
 
        struct delay_class read;
                        schedule();
                } else {
                        spin_unlock(&dc->delayed_bios_lock);
+                       fsleep(dc->worker_sleep_us);
                        cond_resched();
                }
        }
 {
        struct delay_c *dc;
        int ret;
-       unsigned int max_delay;
+       unsigned int max_delay, min_delay;
 
        if (argc != 3 && argc != 6 && argc != 9) {
                ti->error = "Requires exactly 3, 6 or 9 arguments";
        ret = delay_class_ctr(ti, &dc->read, argv);
        if (ret)
                goto bad;
-       max_delay = dc->read.delay;
+       min_delay = max_delay = dc->read.delay;
 
        if (argc == 3) {
                ret = delay_class_ctr(ti, &dc->write, argv);
        if (ret)
                goto bad;
        max_delay = max(max_delay, dc->write.delay);
+       min_delay = min_not_zero(min_delay, dc->write.delay);
 
        if (argc == 6) {
                ret = delay_class_ctr(ti, &dc->flush, argv + 3);
        if (ret)
                goto bad;
        max_delay = max(max_delay, dc->flush.delay);
+       min_delay = min_not_zero(min_delay, dc->flush.delay);
 
 out:
        if (max_delay < 50) {
+               if (min_delay >> SLEEP_SHIFT)
+                       dc->worker_sleep_us = 1000;
+               else
+                       dc->worker_sleep_us = (min_delay * 1000) >> SLEEP_SHIFT;
                /*
                 * In case of small requested delays, use kthread instead of
                 * timers and workqueue to achieve better latency.
 
 static struct target_type delay_target = {
        .name        = "delay",
-       .version     = {1, 4, 0},
+       .version     = {1, 5, 0},
        .features    = DM_TARGET_PASSES_INTEGRITY | DM_TARGET_ZONED_HM,
        .module      = THIS_MODULE,
        .ctr         = delay_ctr,