goto err;
 
        struct bch_extent_rebalance new_r = bch2_inode_rebalance_opts_get(c, &inode_u);
+       bool rebalance_changed = memcmp(&old_r, &new_r, sizeof(new_r));
 
-       if (memcmp(&old_r, &new_r, sizeof(new_r))) {
+       if (rebalance_changed) {
                ret = bch2_set_rebalance_needs_scan_trans(trans, inode_u.bi_inum);
                if (ret)
                        goto err;
        if (bch2_err_matches(ret, BCH_ERR_transaction_restart))
                goto retry;
 
+       if (rebalance_changed)
+               bch2_rebalance_wakeup(c);
+
        bch2_fs_fatal_err_on(bch2_err_matches(ret, ENOENT), c,
                             "%s: inode %llu:%llu not found when updating",
                             bch2_err_str(ret),
 
                r->state                = BCH_REBALANCE_waiting;
        }
 
-       bch2_kthread_io_clock_wait(clock, r->wait_iotime_end, MAX_SCHEDULE_TIMEOUT);
+       bch2_kthread_io_clock_wait_once(clock, r->wait_iotime_end, MAX_SCHEDULE_TIMEOUT);
 }
 
 static bool bch2_rebalance_enabled(struct bch_fs *c)
        struct bch_fs_rebalance *r = &c->rebalance;
        struct btree_iter rebalance_work_iter, extent_iter = {};
        struct bkey_s_c k;
+       u32 kick = r->kick;
        int ret = 0;
 
        bch2_trans_begin(trans);
        if (!ret &&
            !kthread_should_stop() &&
            !atomic64_read(&r->work_stats.sectors_seen) &&
-           !atomic64_read(&r->scan_stats.sectors_seen)) {
+           !atomic64_read(&r->scan_stats.sectors_seen) &&
+           kick == r->kick) {
                bch2_moving_ctxt_flush_all(ctxt);
                bch2_trans_unlock_long(trans);
                rebalance_wait(c);
 
 
 static inline void bch2_rebalance_wakeup(struct bch_fs *c)
 {
-       struct task_struct *p;
-
-       rcu_read_lock();
-       p = rcu_dereference(c->rebalance.thread);
+       c->rebalance.kick++;
+       guard(rcu)();
+       struct task_struct *p = rcu_dereference(c->rebalance.thread);
        if (p)
                wake_up_process(p);
-       rcu_read_unlock();
 }
 
 void bch2_rebalance_status_to_text(struct printbuf *, struct bch_fs *);
 
 
 struct bch_fs_rebalance {
        struct task_struct __rcu        *thread;
+       u32                             kick;
        struct bch_pd_controller pd;
 
        enum bch_rebalance_states       state;