Hello, On Wed, Apr 11, 2012 at 07:05:42PM +0200, Jan Kara wrote: > > The additional feature for buffered throttle (which never went upstream), > > was synchronous in nature. That is we were actively putting writer to > > sleep on a per cgroup wait queue in the request queue and wake it up when > > it can do further IO based on cgroup limits. > > Hmm, but then there would be similar starvation issues as with my simple > scheme because async IO could always use the whole available bandwidth. > Mixing of sync & async throttling is really problematic... I'm wondering > how useful the async throttling is. Because we will block on request > allocation once there are more than nr_requests pending requests so at that > point throttling becomes sync anyway. I haven't thought about the interface too much yet but, with the synchronous wait at transaction start, we have information both ways - ie. lower layer also knows that there are synchrnous waiters. At the simplest, not allowing any more async IOs when sync writers exist should solve the starvation issue. As for priority inversion through shared request pool, it is a problem which needs to be solved regardless of how async IOs are throttled. I'm not determined to which extent yet tho. Different cgroups definitely need to be on separate pools but do we also want distinguish sync and async and what about ioprio? Maybe we need a bybrid approach with larger common pool and reserved ones for each class? Thanks. -- tejun -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html