Re: LSF/MM Schedule and improving discard support

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



>>>>> "Bart" == Bart Van Assche <bart.vanassche@xxxxxxxxxxx> writes:

Bart,

Bart> There is something that should be discussed further, namely what
Bart> the behavior of the BLKDISCARD and BLKSECDISCARD ioctls should be
Bart> if the start and/or end sectors are not aligned on a discard
Bart> boundary. Should such requests fail with an error code, should the
Bart> non-aligned head and tail be zeroed or should the non-aligned
Bart> parts be left unmodified?

I think the problem with your changes is that they mix upward and
downward-facing behaviors.

>From a filesystem/ioctl perspective, BLKDISCARD is a hint. We should not be
rounding off or aligning anything. DM or the thin provisioned device may
or may not ignore parts of the request. Their business. And since
discard is there to alleviate write amplification, it absolutely should
never cause any media writing to happen.

BLKZEROOUT, on the other hand, needs to provide hard guarantees. It is
up to the filesystem or ioctl caller to indicate whether allocation or
deallocation is preferred in this case. And then that should get turned
into a mix of WRITE, WRITE SAME or DISCARD commands based on alignment,
granularity and discard_zeroes_data reported by the device.

Darrick has been trying to clean all this up and I would like to see the
explicit distinction between allocate(anchor), deallocate(discard/unmap)
and zeroout (write same, unmap) in the upward-facing interfaces. And
then have those interfaces use WRITE SAME, DISCARD and ANCHOR to
implement their functionality based on the parameters reported by the
underlying device.

-- 
Martin K. Petersen	Oracle Linux Engineering
--
To unsubscribe from this list: send the line "unsubscribe linux-block" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux RAID]     [Linux SCSI]     [Linux ATA RAID]     [IDE]     [Linux Wireless]     [Linux Kernel]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Device Mapper]

  Powered by Linux