-----Original Message----- From: Jeff Moyer [mailto:jmoyer@xxxxxxxxxx] Sent: Wednesday, January 18, 2017 12:48 PM To: Slava Dubeyko <Vyacheslav.Dubeyko@xxxxxxx> Cc: Jan Kara <jack@xxxxxxx>; linux-nvdimm@xxxxxxxxxxxx <linux-nvdimm@xxxxxxxxxxx>; linux-block@xxxxxxxxxxxxxxx; Viacheslav Dubeyko <slava@xxxxxxxxxxx>; Linux FS Devel <linux-fsdevel@xxxxxxxxxxxxxxx>; lsf-pc@xxxxxxxxxxxxxxxxxxxxxxxxxx Subject: Re: [Lsf-pc] [LSF/MM TOPIC] Badblocks checking/representation in filesystems >>> Well, the situation with NVM is more like with DRAM AFAIU. It is >>> quite reliable but given the size the probability *some* cell has degraded is quite high. >>> And similar to DRAM you'll get MCE (Machine Check Exception) when you >>> try to read such cell. As Vishal wrote, the hardware does some >>> background scrubbing and relocates stuff early if needed but nothing is 100%. >> >> My understanding that hardware does the remapping the affected address >> range (64 bytes, for example) but it doesn't move/migrate the stored >> data in this address range. So, it sounds slightly weird. Because it >> means that no guarantee to retrieve the stored data. It sounds that >> file system should be aware about this and has to be heavily protected >> by some replication or erasure coding scheme. Otherwise, if the >> hardware does everything for us (remap the affected address region and >> move data into a new address region) then why does file system need to >> know about the affected address regions? > >The data is lost, that's why you're getting an ECC. It's tantamount to -EIO for a disk block access. I see the three possible cases here: (1) bad block has been discovered (no remap, no recovering) -> data is lost; -EIO for a disk block access, block is always bad; (2) bad block has been discovered and remapped -> data is lost; -EIO for a disk block access. (3) bad block has been discovered, remapped and recovered -> no data is lost. >> Let's imagine that the affected address range will equal to 64 bytes. >> It sounds for me that for the case of block device it will affect the >> whole logical block (4 KB). > > 512 bytes, and yes, that's the granularity at which we track errors in the block layer, so that's the minimum amount of data you lose. I think it depends what granularity hardware supports. It could be 512 bytes, 4 KB, maybe greater. >> The situation is more critical for the case of DAX approach. Correct >> me if I wrong but my understanding is the goal of DAX is to provide >> the direct access to file's memory pages with minimal file system >> overhead. So, it looks like that raising bad block issue on file >> system level will affect a user-space application. Because, finally, >> user-space application will need to process such trouble (bad block >> issue). It sounds for me as really weird situation. What can protect a >> user-space application from encountering the issue with partially >> incorrect memory page? > > Applications need to deal with -EIO today. This is the same sort of thing. > If an application trips over a bad block during a load from persistent memory, > they will get a signal, and they can either handle it or not. > > Have a read through this specification and see if it clears anything up for you: > http://www.snia.org/tech_activities/standards/curr_standards/npm Thank you for sharing this. So, if a user-space application follows to the NVM Programming Model then it will be able to survive by means of catching and processing the exceptions. But these applications have to be implemented yet. Also such applications need in special technique(s) of recovering. It sounds that legacy user-space applications are unable to survive for the NVM.PM.FILE mode in the case of load/store operation's failure. Thanks, Vyacheslav Dubeyko. -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html