Re: [PATCH] Fix mapping->writeback_index to point to the last writtenpage

From: Jun'ichi Nomura
Date: Thu Mar 03 2011 - 20:46:03 EST


On 03/03/11 23:08, Jan Kara wrote:
> On Thu 03-03-11 21:31:19, Wu Fengguang wrote:
>> On Thu, Mar 03, 2011 at 10:26:19AM +0800, Jun'ichi Nomura wrote:
>> > flush-8:0-2743 4606: block_bio_queue: 8,0 W 94899962 + 8
>> > flush-8:0-2743 4606: block_bio_queue: 8,0 W 94899970 + 8
>> > flush-8:0-2743 4606: block_bio_queue: 8,0 W 94899978 + 8
>> > flush-8:0-2743 4606: block_bio_queue: 8,0 W 94899986 + 8
>> > flush-8:0-2743 4606: block_bio_queue: 8,0 W 94899994 + 8
>> ==> > kworker/0:1-11 4606: block_rq_issue: 8,0 W 0 () 94899962 + 40
>> > >> flush-8:0-2743 4606: block_bio_queue: 8,0 W 94898554 + 8
>> ==> > >> flush-8:0-2743 4606: block_rq_issue: 8,0 W 0 () 94898554 + 8
>>
>> I'd expect the wrapped around 94898554+8 to be merged with 94899962+8.
> How could they be merged? They are not continguous...
>
>> Why kworker/0:1-11 is submitting the request early? And the second
>> request is submitted by flush-8:0-2743.
> I'm not sure about that either - but I think that kworker is submitting
> the work when unplug happens while flush ends up doing it when the queue is
> alredy unplugged.

Yes. For the above case, it was unplug.

For other cases, the reason was max_sectors.
Before writeback wraps around, the request has already grown to
max_sectors size (~512KB) and doesn't accept new merge.

Thanks,
--
Jun'ichi Nomura, NEC Corporation
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/