On Tue, Mar 15, 2016 at 3:42 PM, Darrick J. Wong <darrick.wong@xxxxxxxxxx> wrote: > After much discussion, it seems that the fallocate feature flag > FALLOC_FL_ZERO_RANGE maps nicely to SCSI WRITE SAME; and the feature > FALLOC_FL_PUNCH_HOLE maps nicely to the devices that have been > whitelisted for zeroing SCSI UNMAP. Punch still requires that > FALLOC_FL_KEEP_SIZE is set. A length that goes past the end of the > device will be clamped to the device size if KEEP_SIZE is set; or will > return -EINVAL if not. Both start and length must be aligned to the > device's logical block size. > > Since the semantics of fallocate are fairly well established already, > wire up the two pieces. The other fallocate variants (collapse range, > insert range, and allocate blocks) are not supported. I'd like to see fallocate (block allocation) extend down to DM thinp. This more traditional use of fallocate would be useful for ensuring ENOSPC won't occur -- especially important if the FS has committed space in response to fallocate. As of now fallocate doesn't inform DM thinp at all. Curious why you decided not to wire it up? But I'm not sure what "it" (the "allocate blocks" variant) even is given falloc.h doesn't show anything like "_ALLOCATE_BLOCKS"... It would require a new block interface to pass the fallocate extent down. But it seems bizarre to implement "some of" fallocate but not the most widely used case for fallocate. Mike -- To unsubscribe from this list: send the line "unsubscribe linux-api" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html