On Mon, Feb 24, 2020 at 10:03:30AM +1100, Dave Chinner wrote: [..] > > > > Hi Jeff, > > > > > > > > New dax zeroing interface (dax_zero_page_range()) can technically pass > > > > a range which is less than a sector. Or which is bigger than a sector > > > > but start and end are not aligned on sector boundaries. > > > > > > Sure, but who will call it with misaligned ranges? > > > > create a file foo.txt of size 4K and then truncate it. > > > > "truncate -s 23 foo.txt". Filesystems try to zero the bytes from 24 to > > 4095. > > This should fail with EIO. Only full page writes should clear the > bad page state, and partial writes should therefore fail because > they do not guarantee the data in the filesystem block is all good. > > If this zeroing was a buffered write to an address with a bad > sector, then the writeback will fail and the user will (eventually) > get an EIO on the file. > > DAX should do the same thing, except because the zeroing is > synchronous (i.e. done directly by the truncate syscall) we can - > and should - return EIO immediately. > > Indeed, with your code, if we then extend the file by truncating up > back to 4k, then the range between 23 and 512 is still bad, even > though we've successfully zeroed it and the user knows it. An > attempt to read anywhere in this range (e.g. 10 bytes at offset 100) > will fail with EIO, but reading 10 bytes at offset 2000 will > succeed. Hi Dave, What is expected if I do "truncate -s 512 foo.txt". Say first sector (0 to 511) is poisoned and rest don't have poison. Should this fail with -EIO. In current implementation it does not. Because all sector aligned I/O we redirect through blkdev_issue_zeroout() and that will happly zero out sector 2-8 without worrying about the state of sector 1. Hence user which tries to read 10 bytes at offset 100, will still fail. This probably should be fixed if we want to retain existing behavior. Anyway, partial page truncate can't ensure that data in rest of the page can be read back successfully. Memory can get poison after the write and hence read after truncate will still fail. Hence, all we are trying to ensure is that if a poison is known at the time of writing partial page, then we should return error to user space. Thanks Vivek