Re: [PATCH] SCSI, st: modify tape driver to allow writing immediatefilemarks

From: Kai Makisara
Date: Tue Feb 28 2012 - 14:38:15 EST


On Thu, 9 Feb 2012, Lee Duncan wrote:

> On 02/08/2012 09:19 AM, Kai Makisara wrote:
> > On Tue, 7 Feb 2012, Lee Duncan wrote:
> >
> >> Add an st module option st_nowait_eof which defaults to 0. Setting this
> >> option to 1 tells the st driver not to wait when writing a filemark, which
> >> can result in much faster times on streaming tape drives.
> >>
> >> Legacy applications cannot take advantage of the newer MTWEOFI ioctl, so this
> >> patch gives such applications the ability to write an immediate EOF using the
> >> normal MTWEOF ioctl if they set st_nowait_eof=1.
> >>
> >> Reference: https://bugzilla.novell.com/show_bug.cgi?id=688996
> >>
...
> >
> > Anyway, I don't think this should be implemented as a pure module option.
> > The standard semantics specify that MTWEOF is a synchronization point and
> > this module option breaks that for all users.
>
> The Standard specifies that writing a filemark (i.e. an EOF) is a
> synchronization point if and only if the data is being written in
> immediate mode. In other words, you are not supposed to set both
> immediate writes and immediate EOFs. This is why I didn't overload the
> already-existing "immediate" flag in the driver.
>
Not quite what I mean. The following is from SSC-3 draft:
-
An IMMED bit of zero specifies the device server shall not return status
until the write operation has completed. Any
buffered logical objects shall be written to the medium prior to
completing the command.
-
So, what I mean is that all data in the drive buffer has been written to
tape. This WRITE FILEMARKS command then returns any write errors that
happen while the buffered data is written to tape. With immediate bit set,
you may miss write errors.

> I will add a check to the driver to disallow immediate EOFs if immediate
> writes are requested.
>
This may not be necessary. If someone wants to deliberately take risks,
the driver should not prevent this ;-)

Kai
--
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/