On Friday, February 15, 2002 01:21:20 AM +0000 Alan Cox <[EMAIL PROTECTED]> 
wrote:

>> sure we only try to use tag commands when they are turned on for the
>> target, otherwise we can safely assume the drive won't do
>> other writes first.
> 
> Is this guaranteed by the SCSI standards or do you need to issue some
> kind of cache flush as with IDE ?

We're sending the scsi ordered queue tag command, which the spec
says will be written after anything already received by the target,
and before anything it receives later on.  I have no data
at all how well the drives follow the spec ;-)

The IDE changes issue cache flushes before the barrier write,
and then another flush after it, which gives us similar semantics.

> 
>> With -o barrier, this is now:
>> 
>> write X log blocks
>> write 1 commit block
>> wait.
> 
> That will work nicely with the I2O controllers, and possibly (if its
> in the firmware as well as the .h file) the aacraid cards. In those
> cases I can often commit to battery backed ram rather than physical
> media.
> 
> Do you have any idea of driving the cache write through rather than write
> back is likely to help here by evening out the commit wait for a flush?
> 
Controllers that do write back caching should be helped by the reiserfs 
usage changes.  If we pretend they immediately tell the OS a write is 
completed, unpatched reiserfs does this:

write X log blocks
wait on X log blocks (all already complete, so just a CPU loop)
write 1 commit
wait on 1 commit.

With the new code, the controller is more likely to get the commit in 
time to merge the requests.  Hopefully someone who knows more about scsi 
can correct me, but I think the write back controller can ignore the 
ordering rules (since battery backup should promise the request does hit 
media eventually).

I think write through caches should be helped too, as long as they
are smart about how they do the write ordering.  My scsi drive doesn't
seem to be very smart at all, it has been hard to find usage patterns
that show improvement.  So far, only O_SYNC writes really show it.

I think that's what you were asking, sorry if I misunderstood the Q.

-chris

Reply via email to