[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <94D0CD8314A33A4D9D801C0FE68B40295A92F392@G9W0745.americas.hpqcorp.net>
Date: Fri, 29 May 2015 21:29:53 +0000
From: "Elliott, Robert (Server Storage)" <Elliott@...com>
To: Andy Lutomirski <luto@...capital.net>,
Dan Williams <dan.j.williams@...el.com>
CC: "Kani, Toshimitsu" <toshi.kani@...com>,
Borislav Petkov <bp@...en8.de>,
Ross Zwisler <ross.zwisler@...ux.intel.com>,
"H. Peter Anvin" <hpa@...or.com>,
Thomas Gleixner <tglx@...utronix.de>,
Ingo Molnar <mingo@...hat.com>,
Andrew Morton <akpm@...ux-foundation.org>,
Arnd Bergmann <arnd@...db.de>,
"linux-mm@...ck.org" <linux-mm@...ck.org>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
X86 ML <x86@...nel.org>,
"linux-nvdimm@...ts.01.org" <linux-nvdimm@...ts.01.org>,
Juergen Gross <jgross@...e.com>,
Stefan Bader <stefan.bader@...onical.com>,
Henrique de Moraes Holschuh <hmh@....eng.br>,
Yigal Korman <yigal@...xistor.com>,
Konrad Rzeszutek Wilk <konrad.wilk@...cle.com>,
"Luis Rodriguez" <mcgrof@...e.com>, Christoph Hellwig <hch@....de>,
Matthew Wilcox <willy@...ux.intel.com>
Subject: RE: [PATCH v10 12/12] drivers/block/pmem: Map NVDIMM with
ioremap_wt()
> -----Original Message-----
> From: Andy Lutomirski [mailto:luto@...capital.net]
> Sent: Friday, May 29, 2015 1:35 PM
...
> Whoa, there! Why would we use non-temporal stores to WB memory to
> access persistent memory? I can see two reasons not to:
Data written to a block storage device (here, the NVDIMM) is unlikely
to be read or written again any time soon. It's not like the code
and data that a program has in memory, where there might be a loop
accessing the location every CPU clock; it's storage I/O to
historically very slow (relative to the CPU clock speed) devices.
The source buffer for that data might be frequently accessed,
but not the NVDIMM storage itself.
Non-temporal stores avoid wasting cache space on these "one-time"
accesses. The same applies for reads and non-temporal loads.
Keep the CPU data cache lines free for the application.
DAX and mmap() do change that; the application is now free to
store frequently accessed data structures directly in persistent
memory. But, that's not available if btt is used, and
application loads and stores won't go through the memcpy()
calls inside pmem anyway. The non-temporal instructions are
cache coherent, so data integrity won't get confused by them
if I/O going through pmem's block storage APIs happens
to overlap with the application's mmap() regions.
---
Robert Elliott, HP Server Storage
Powered by blists - more mailing lists