On Mon, 2008-11-10 at 11:33 +1100, Dave Chinner wrote: > > Yes ... since this is for thin provisioning. Discard is best guess ... > > it doesn't affect integrity if we lose one and from the point of view of > > the array, 99% transmitted is far better than we do today. All that > > happens for a lost discard is that the array keeps a block that the > > filesystem isn't currently using. However, the chances are that it will > > get reused, so it shares a good probability of getting discarded again. > > Ok. Given that a single extent free in XFS could span up to 2^37 bytes, > is it considered acceptible to lose the discard request that this > issued from this transaction? I don't think it is.... Well, given the semantics we've been discussing, ~2^37 of that would go down immediately and upto 2x the discard block size on either side may be retained for misalignment reasons. I don't really see the problem. > > > If so, how do we tell the device > > > that certain ranges have actually been discarded after the crash? > > > Are you expecting them to get replayed by a filesystem during > > > recovery? What if it was a userspace discard from something like > > > mkfs that was lost? How does this interact with sync or other > > > such user level filesystems synchronisation primitives? Does > > > sync_blockdev() flush out pending discard requests? Should fsync? > > > > No .. the syncs are all integrity based. Discard is simple opportunity > > based. > > Given that discard requests modify the stable storage associated > with the filesystem, then shouldn't an integrity synchronisation > issue and complete all pending requests to the underlying storage > device? > > If not, how do we guarantee them to all be flushed on remount-ro > or unmount-before-hot-unplug type of events? Discard is a guarantee from the filesystem but a hint to the storage. All we need to ensure is that we don't discard a sector with data. To do that, discard is alread a barrier (no merging around it). If we retain discards in sd or some other layer, all we have to do is drop the region we see a rewrite for ... this isn't rocket science, its similar to what we do now for barrier transactions. The reason for making them long lived is that we're keeping the pieces the array would have ignored anyway. That's also why dropping them all on the floor on a crash isn't a problem ... this is only best effort. > > > And if the filesystem has to wait for discard requests to complete > > > to guarantee that they are done or can be recovered and replayed > > > after a crash, most filesystems are going to need modification. e.g. > > > XFS would need to prevent the tail of the log moving forward until > > > the discard request associated with a given extent free transaction > > > has been completed. That means we need to be able to specifically > > > flush queued discard requests and we'd need I/O completions to > > > run when they are done to do the filesytem level cleanup work.... > > > > OK, I really don't follow the logic here. Discards have no effect on > > data integrity ... unless you're confusing them with secure deletion? > > Not at all. I'm considering what is needed to allow the filesystem's > discard requests to be replayed during recovery. i.e. what is needed > to allow a filesystem to handle discard requests for thin > provisioning robustly. > > If discard requests are not guaranteed to be issued to the storage > on a crash, then it is up to the filesystem to ensure that it > happens during recovery. That requires discard requests to behave > just like all other types of I/O and definitely requires a mechanism > to flush and wait for all discard requests to complete.... Really, I think you're the one complicating the problem. It's really simple. An array would like to know when a filesystem isn't using a block. What the array does with that information is beyond the scope of the filesystem to know. The guarantee is that it must perform identically whether it acts on this knowledge or not. That makes it a hint, so we don't need to go to extraordinary lengths to make sure we get it exactly right ... we just have to be right for every hint we send down. > > A > > discard merely tells the array that it doesn't need to back this block > > with an actual storage location anymore (until the next write for that > > region comes down). > > Right. But really, it's the filesystem that is saying this, not the > block layer, so if the filesytem wants to be robust, then block > layer can't queue these forever - they have to be issued in a timely > fashion so the filesystem can keep track of which discards have > completed or not.... > > > The ordering worry can be coped with in the same way we do barriers ... > > it's even safer for discards because if we know the block is going to be > > rewritten, we simply discard the discard. > > Ordering is determined by the filesystem - barriers are just a > mechanism the filesystem uses to guarantee I/O ordering. If the > filesystem is tracking discard completion status, then it won't > be issuing I/O over the top of that region as the free transaction > won't be complete until the discard is done.... Not really ... ordering as determined by the barrier containing block stream ... that's why we can do this at the block level. Look at it this way: if we had to rely on filesystem internals for ordering information, fs agnostic block replicators would be impossible. > > > Let's keep the OS level interactions simple - if the array vendors > > > want to keep long queues of requests around before acting on them > > > to aggregate them, then that is an optimisation for them to > > > implement. They already do this with small data writes to NVRAM, so I > > > don't see how this should be treated any differently... > > > > Well, that's Chris' argument, and it has merit. I'm coming from the > > point of view that discards are actually a fundamentally different > > entity from anything else we process. > > >From a filesystem perspective, they are no different to any other > metadata I/O. They need to be tracked to allow robust crash recovery > semantics to be implemented in the filesystem. I agree it could be. My point is that the hint doesn't need to be robust, (as in accurate and complete) merely accurate, which we can ensure at the block level. James -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html