aboutsummaryrefslogtreecommitdiffstats
path: root/fs/dax.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/dax.c')
-rw-r--r--fs/dax.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/fs/dax.c b/fs/dax.c
index 7ae6df7ea1d2..bcfb14bfc1e4 100644
--- a/fs/dax.c
+++ b/fs/dax.c
@@ -569,8 +569,20 @@ int __dax_pmd_fault(struct vm_area_struct *vma, unsigned long address,
569 if (!buffer_size_valid(&bh) || bh.b_size < PMD_SIZE) 569 if (!buffer_size_valid(&bh) || bh.b_size < PMD_SIZE)
570 goto fallback; 570 goto fallback;
571 571
572 sector = bh.b_blocknr << (blkbits - 9);
573
572 if (buffer_unwritten(&bh) || buffer_new(&bh)) { 574 if (buffer_unwritten(&bh) || buffer_new(&bh)) {
573 int i; 575 int i;
576
577 length = bdev_direct_access(bh.b_bdev, sector, &kaddr, &pfn,
578 bh.b_size);
579 if (length < 0) {
580 result = VM_FAULT_SIGBUS;
581 goto out;
582 }
583 if ((length < PMD_SIZE) || (pfn & PG_PMD_COLOUR))
584 goto fallback;
585
574 for (i = 0; i < PTRS_PER_PMD; i++) 586 for (i = 0; i < PTRS_PER_PMD; i++)
575 clear_pmem(kaddr + i * PAGE_SIZE, PAGE_SIZE); 587 clear_pmem(kaddr + i * PAGE_SIZE, PAGE_SIZE);
576 wmb_pmem(); 588 wmb_pmem();
@@ -623,7 +635,6 @@ int __dax_pmd_fault(struct vm_area_struct *vma, unsigned long address,
623 result = VM_FAULT_NOPAGE; 635 result = VM_FAULT_NOPAGE;
624 spin_unlock(ptl); 636 spin_unlock(ptl);
625 } else { 637 } else {
626 sector = bh.b_blocknr << (blkbits - 9);
627 length = bdev_direct_access(bh.b_bdev, sector, &kaddr, &pfn, 638 length = bdev_direct_access(bh.b_bdev, sector, &kaddr, &pfn,
628 bh.b_size); 639 bh.b_size);
629 if (length < 0) { 640 if (length < 0) {