summaryrefslogtreecommitdiff
path: root/drivers/base/dd.c
diff options
context:
space:
mode:
authorJane Chu <jane.chu@oracle.com>2022-05-13 15:13:20 -0700
committerDan Williams <dan.j.williams@intel.com>2022-05-16 13:38:19 -0700
commitf42e8e5088b9e791c8f7ac661f68e29a4996a4e3 (patch)
treee335ac2703aa90988d00b5f5a56f335e4e77e70b /drivers/base/dd.c
parent9409c9b6709e59866ed3540b5d7f5291439e4833 (diff)
downloadlwn-f42e8e5088b9e791c8f7ac661f68e29a4996a4e3.tar.gz
lwn-f42e8e5088b9e791c8f7ac661f68e29a4996a4e3.zip
pmem: implement pmem_recovery_write()
The recovery write thread started out as a normal pwrite thread and when the filesystem was told about potential media error in the range, filesystem turns the normal pwrite to a dax_recovery_write. The recovery write consists of clearing media poison, clearing page HWPoison bit, reenable page-wide read-write permission, flush the caches and finally write. A competing pread thread will be held off during the recovery process since data read back might not be valid, and this is achieved by clearing the badblock records after the recovery write is complete. Competing recovery write threads are already serialized by writer lock held by dax_iomap_rw(). Signed-off-by: Jane Chu <jane.chu@oracle.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Link: https://lore.kernel.org/r/165247997655.53156.8381418704988035976.stgit@dwillia2-desk3.amr.corp.intel.com Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Diffstat (limited to 'drivers/base/dd.c')
0 files changed, 0 insertions, 0 deletions