[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1439927741-29580-1-git-send-email-ross.zwisler@linux.intel.com>
Date: Tue, 18 Aug 2015 13:55:34 -0600
From: Ross Zwisler <ross.zwisler@...ux.intel.com>
To: linux-kernel@...r.kernel.org, linux-nvdimm@...ts.01.org,
Dan Williams <dan.j.williams@...el.com>,
Christoph Hellwig <hch@....de>,
Matthew Wilcox <matthew.r.wilcox@...el.com>,
Dave Chinner <david@...morbit.com>
Cc: Ross Zwisler <ross.zwisler@...ux.intel.com>,
"David S. Miller" <davem@...emloft.net>,
"H. Peter Anvin" <hpa@...or.com>,
"Martin K. Petersen" <martin.petersen@...cle.com>,
Uwe Kleine-König
<u.kleine-koenig@...gutronix.de>,
Alexander Viro <viro@...iv.linux.org.uk>,
Ameen Ali <ameenali023@...il.com>,
Andrew Morton <akpm@...ux-foundation.org>,
Arnd Bergmann <arnd@...db.de>,
Benjamin Herrenschmidt <benh@...nel.crashing.org>,
Boaz Harrosh <boaz@...xistor.com>,
Borislav Petkov <bp@...e.de>,
Gerald Schaefer <gerald.schaefer@...ibm.com>,
Greg KH <gregkh@...uxfoundation.org>,
Heiko Carstens <heiko.carstens@...ibm.com>,
Ingo Molnar <mingo@...hat.com>, Jan Kara <jack@...e.cz>,
Jeff Layton <jlayton@...marydata.com>,
Jens Axboe <axboe@...nel.dk>, Jiri Slaby <jslaby@...e.com>,
Joe Perches <joe@...ches.com>,
Jonathan Corbet <corbet@....net>,
Juergen Gross <jgross@...e.com>,
Martin Schwidefsky <schwidefsky@...ibm.com>,
Matthew Wilcox <willy@...ux.intel.com>,
Mauro Carvalho Chehab <mchehab@....samsung.com>,
Michael Ellerman <mpe@...erman.id.au>,
Mike Snitzer <snitzer@...hat.com>,
Miklos Szeredi <mszeredi@...e.cz>,
Ming Lei <ming.lei@...onical.com>,
Omar Sandoval <osandov@...ndov.com>,
Paul Mackerras <paulus@...ba.org>,
Sagi Grimberg <sagig@...lanox.com>, Shaohua Li <shli@...com>,
Tejun Heo <tj@...nel.org>,
Thomas Gleixner <tglx@...utronix.de>,
Toshi Kani <toshi.kani@...com>,
Wolfram Sang <wsa@...-dreams.de>, linux-doc@...r.kernel.org,
linux-fsdevel@...r.kernel.org, linux-s390@...r.kernel.org,
linux390@...ibm.com, linuxppc-dev@...ts.ozlabs.org, x86@...nel.org
Subject: [PATCH v5 0/7] dax: I/O path enhancements
The goal of this series is to enhance the DAX I/O path so that all operations
that store data (I/O writes, zeroing blocks, punching holes, etc.) properly
synchronize the stores to media using the PMEM API. This ensures that the
data DAX is writing is durable on media before the operation completes.
Patches 1-4 are a few random cleanups.
Changes from v4:
- rebased to libnvdimm-for-next branch:
https://git.kernel.org/cgit/linux/kernel/git/nvdimm/nvdimm.git/commit/?h=libnvdimm-for-next
The nvdimm repository doesn't have the DAX PMD changes that are in the -mm
tree. I expect the merge will basically be these two hunks:
@@ -514,7 +528,7 @@ int __dax_pmd_fault(struct vm_area_struct *vma, unsigned long address,
unsigned long pmd_addr = address & PMD_MASK;
bool write = flags & FAULT_FLAG_WRITE;
long length;
- void *kaddr;
+ void __pmem *kaddr;
pgoff_t size, pgoff;
sector_t block, sector;
unsigned long pfn;
@@ -608,7 +622,8 @@ int __dax_pmd_fault(struct vm_area_struct *vma, unsigned long address,
if (buffer_unwritten(&bh) || buffer_new(&bh)) {
int i;
for (i = 0; i < PTRS_PER_PMD; i++)
- clear_page(kaddr + i * PAGE_SIZE);
+ clear_pmem(kaddr + i * PAGE_SIZE, PAGE_SIZE);
+ wmb_pmem();
count_vm_event(PGMAJFAULT);
mem_cgroup_count_vm_event(vma->vm_mm, PGMAJFAULT);
result |= VM_FAULT_MAJOR;
Ross Zwisler (7):
brd: make rd_size static
pmem, x86: move x86 PMEM API to new pmem.h header
pmem: remove layer when calling arch_has_wmb_pmem()
pmem, x86: clean up conditional pmem includes
pmem: add copy_from_iter_pmem() and clear_pmem()
dax: update I/O path to do proper PMEM flushing
pmem, dax: have direct_access use __pmem annotation
Documentation/filesystems/Locking | 3 +-
MAINTAINERS | 1 +
arch/powerpc/sysdev/axonram.c | 7 +-
arch/x86/include/asm/cacheflush.h | 71 -----------------
arch/x86/include/asm/pmem.h | 158 ++++++++++++++++++++++++++++++++++++++
drivers/block/brd.c | 6 +-
drivers/nvdimm/pmem.c | 4 +-
drivers/s390/block/dcssblk.c | 10 ++-
fs/block_dev.c | 2 +-
fs/dax.c | 63 +++++++++------
include/linux/blkdev.h | 8 +-
include/linux/pmem.h | 77 ++++++++++++++++---
12 files changed, 285 insertions(+), 125 deletions(-)
create mode 100644 arch/x86/include/asm/pmem.h
--
2.1.0
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists