diff options
author | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2015-10-09 16:13:30 -0400 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2015-10-09 16:13:30 -0400 |
commit | 670aee3fc7ac37ae947f8b582d87b51d5fa36524 (patch) | |
tree | 9885998483d4506208e5aef9c13c8a86adea20bb /fs/dax.c | |
parent | d61e87ac53292a3138b4354b687558973686b6ca (diff) | |
parent | 55582bccdc1e89ecc973c260d46e247df675d4df (diff) |
Merge branches 'pm-devfreq' and 'pm-cpufreq'
* pm-devfreq:
PM / devfreq: fix double kfree
PM / devfreq: Fix governor_store()
* pm-cpufreq:
cpufreq: prevent lockup on reading scaling_available_frequencies
cpufreq: acpi_cpufreq: prevent crash on reading freqdomain_cpus
Diffstat (limited to 'fs/dax.c')
-rw-r--r-- | fs/dax.c | 13 |
1 files changed, 12 insertions, 1 deletions
@@ -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) { |