Re: [PATCH] 2.4.x write barriers (updated for ext3)

From: Chris Mason (mason@suse.com)
Date: Sun Mar 03 2002 - 22:34:07 EST


On Sunday, March 03, 2002 11:11:44 PM +0100 Daniel Phillips <phillips@bonn-fries.net> wrote:

> I have a standing offer from at least one engineer to make firmware changes
> to the drives if it makes Linux work better. So a reasonable plan is: first
> know what's ideal, second ask for it. Coupled with that, we'd need a way of
> identifying drives that don't work in the ideal way, and require a fallback.
>
> In my opinion, the only correct behavior is a write barrier that completes
> when data is on the platter, and that does this even when write-back is
> enabled.

With a battery backup, we want the raid controller (or whatever) to
pretend the barrier is done right away. It should be as safe, and
allow the target to merge the writes.

> Surely this is not rocket science at the disk firmware level. Is
> this or is this not the way ordered tags were supposed to work?

There are many issues at play in this thread, here's an attempt at
a summary (please correct any mistakes).

1) The drivers would need to be changed to properly keep tag ordering
in place on resets, and error conditions.

2) ordered tags force ordering of all writes the drive is processing.
For some workloads, it will be forced to order stuff the journal code
doesn't care about at all, perhaps leading to lower performance than
the simple wait_on_buffer() we're using now.

2a) Are the filesystems asking for something impossible? Can drives
really write block N and N+1, making sure to commit N to media before
N+1 (including an abort on N+1 if N fails), but still keeping up a
nice seek free stream of writes?

3) Some drives may not be very smart about ordered tags. We need
to figure out which is faster, using the ordered tag or using a
simple cache flush (when writeback is on). The good news about
the cache flush is that it doesn't require major surgery in the
scsi error handlers.

4) If some scsi drives come with writeback on by default, do they also
turn it on under high load like IDE drives do?

>
>> Clearly, there would also have to be a mechanism to flush the cache on
>> unmount, so if this were done by ioctl, would you prefer that the filesystem
>> be in charge of flushing the cache on barrier writes, or would you like the sd
>> device to do it transparently?
>
> The filesystem should just say 'this request is a write barrier' and the
> lower layers, whether that's scsi or bio, should do what's necessary to make
> it come true.

That's the goal. The current 2.4 patch differentiates between ordered
barriers and flush barriers just so I can make the flush the default
on IDE, and enable the ordered stuff when I want to experiment on scsi.

-chris

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



This archive was generated by hypermail 2b29 : Thu Mar 07 2002 - 21:00:30 EST