From: Toshi Kani <toshi.kani@hp.com> To: hpa@zytor.com, tglx@linutronix.de, mingo@redhat.com, akpm@linux-foundation.org, arnd@arndb.de Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org, x86@kernel.org, linux-nvdimm@lists.01.org, jgross@suse.com, stefan.bader@canonical.com, luto@amacapital.net, hmh@hmh.eng.br, yigal@plexistor.com, konrad.wilk@oracle.com, Elliott@hp.com, mcgrof@suse.com, hch@lst.de Subject: [PATCH v10 0/12] Support Write-Through mapping on x86 Date: Wed, 27 May 2015 09:18:52 -0600 [thread overview] Message-ID: <1432739944-22633-1-git-send-email-toshi.kani@hp.com> (raw) This patchset adds support of Write-Through (WT) mapping on x86. The study below shows that using WT mapping may be useful for non-volatile memory. http://www.hpl.hp.com/techreports/2012/HPL-2012-236.pdf The patchset consists of the following changes. - Patch 1/12 to 6/12 add ioremap_wt() - Patch 7/12 adds pgprot_writethrough() - Patch 8/12 to 9/12 add set_memory_wt() - Patch 10/12 to 11/12 refactor !pat_enable paths - Patch 12/12 changes the pmem driver to call ioremap_wt() All new/modified interfaces have been tested. --- v10: - Removed ioremap_writethrough(). (Thomas Gleixner) - Clarified and cleaned up multiple comments and functions. (Thomas Gleixner) - Changed ioremap_change_attr() to accept the WT type. v9: - Changed to export the set_xxx_wt() interfaces with GPL. (Ingo Molnar) - Changed is_new_memtype_allowed() to handle WT cases. - Changed arch-specific io.h to define ioremap_wt(). - Changed the pmem driver to use ioremap_wt(). - Rebased to 4.1-rc3 and resolved minor conflicts. v8: - Rebased to 4.0-rc1 and resolved conflicts with 9d34cfdf4 in patch 5/7. v7: - Rebased to 3.19-rc3 as Juergen's patchset for the PAT management has been accepted. v6: - Dropped the patch moving [set|get]_page_memtype() to pat.c since the tip branch already has this change. - Fixed an issue when CONFIG_X86_PAT is not defined. v5: - Clarified comment of why using slot 7. (Andy Lutomirski, Thomas Gleixner) - Moved [set|get]_page_memtype() to pat.c. (Thomas Gleixner) - Removed BUG() from set_page_memtype(). (Thomas Gleixner) v4: - Added set_memory_wt() by adding WT support of regular memory. v3: - Dropped the set_memory_wt() patch. (Andy Lutomirski) - Refactored the !pat_enabled handling. (H. Peter Anvin, Andy Lutomirski) - Added the picture of PTE encoding. (Konrad Rzeszutek Wilk) v2: - Changed WT to use slot 7 of the PAT MSR. (H. Peter Anvin, Andy Lutomirski) - Changed to have conservative checks to exclude all Pentium 2, 3, M, and 4 families. (Ingo Molnar, Henrique de Moraes Holschuh, Andy Lutomirski) - Updated documentation to cover WT interfaces and usages. (Andy Lutomirski, Yigal Korman) --- Toshi Kani (12): 1/12 x86, mm, pat: Set WT to PA7 slot of PAT MSR 2/12 x86, mm, pat: Change reserve_memtype() for WT 3/12 x86, asm: Change is_new_memtype_allowed() for WT 4/12 x86, mm, asm-gen: Add ioremap_wt() for WT 5/12 arch/*/asm/io.h: Add ioremap_wt() to all architectures 6/12 video/fbdev, asm/io.h: Remove ioremap_writethrough() 7/12 x86, mm, pat: Add pgprot_writethrough() for WT 8/12 x86, mm, asm: Add WT support to set_page_memtype() 9/12 x86, mm: Add set_memory_wt() for WT 10/12 x86, mm, pat: Cleanup init flags in pat_init() 11/12 x86, mm, pat: Refactor !pat_enable handling 12/12 drivers/block/pmem: Map NVDIMM with ioremap_wt() --- Documentation/x86/pat.txt | 13 +- arch/arc/include/asm/io.h | 1 + arch/arm/include/asm/io.h | 1 + arch/arm64/include/asm/io.h | 1 + arch/avr32/include/asm/io.h | 1 + arch/frv/include/asm/io.h | 4 +- arch/m32r/include/asm/io.h | 1 + arch/m68k/include/asm/io_mm.h | 4 +- arch/m68k/include/asm/io_no.h | 4 +- arch/metag/include/asm/io.h | 3 + arch/microblaze/include/asm/io.h | 2 +- arch/mn10300/include/asm/io.h | 1 + arch/nios2/include/asm/io.h | 1 + arch/s390/include/asm/io.h | 1 + arch/sparc/include/asm/io_32.h | 1 + arch/sparc/include/asm/io_64.h | 1 + arch/tile/include/asm/io.h | 2 +- arch/x86/include/asm/cacheflush.h | 6 +- arch/x86/include/asm/io.h | 2 + arch/x86/include/asm/pgtable.h | 8 +- arch/x86/include/asm/pgtable_types.h | 3 + arch/x86/mm/init.c | 6 +- arch/x86/mm/iomap_32.c | 12 +- arch/x86/mm/ioremap.c | 29 ++++- arch/x86/mm/pageattr.c | 65 +++++++--- arch/x86/mm/pat.c | 232 +++++++++++++++++++++++------------ arch/xtensa/include/asm/io.h | 1 + drivers/block/pmem.c | 4 +- drivers/video/fbdev/amifb.c | 4 +- drivers/video/fbdev/atafb.c | 3 +- drivers/video/fbdev/hpfb.c | 4 +- include/asm-generic/io.h | 9 ++ include/asm-generic/iomap.h | 4 + include/asm-generic/pgtable.h | 4 + 34 files changed, 311 insertions(+), 127 deletions(-) -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>
WARNING: multiple messages have this Message-ID (diff)
From: Toshi Kani <toshi.kani@hp.com> To: hpa@zytor.com, tglx@linutronix.de, mingo@redhat.com, akpm@linux-foundation.org, arnd@arndb.de Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org, x86@kernel.org, linux-nvdimm@ml01.01.org, jgross@suse.com, stefan.bader@canonical.com, luto@amacapital.net, hmh@hmh.eng.br, yigal@plexistor.com, konrad.wilk@oracle.com, Elliott@hp.com, mcgrof@suse.com, hch@lst.de Subject: [PATCH v10 0/12] Support Write-Through mapping on x86 Date: Wed, 27 May 2015 09:18:52 -0600 [thread overview] Message-ID: <1432739944-22633-1-git-send-email-toshi.kani@hp.com> (raw) This patchset adds support of Write-Through (WT) mapping on x86. The study below shows that using WT mapping may be useful for non-volatile memory. http://www.hpl.hp.com/techreports/2012/HPL-2012-236.pdf The patchset consists of the following changes. - Patch 1/12 to 6/12 add ioremap_wt() - Patch 7/12 adds pgprot_writethrough() - Patch 8/12 to 9/12 add set_memory_wt() - Patch 10/12 to 11/12 refactor !pat_enable paths - Patch 12/12 changes the pmem driver to call ioremap_wt() All new/modified interfaces have been tested. --- v10: - Removed ioremap_writethrough(). (Thomas Gleixner) - Clarified and cleaned up multiple comments and functions. (Thomas Gleixner) - Changed ioremap_change_attr() to accept the WT type. v9: - Changed to export the set_xxx_wt() interfaces with GPL. (Ingo Molnar) - Changed is_new_memtype_allowed() to handle WT cases. - Changed arch-specific io.h to define ioremap_wt(). - Changed the pmem driver to use ioremap_wt(). - Rebased to 4.1-rc3 and resolved minor conflicts. v8: - Rebased to 4.0-rc1 and resolved conflicts with 9d34cfdf4 in patch 5/7. v7: - Rebased to 3.19-rc3 as Juergen's patchset for the PAT management has been accepted. v6: - Dropped the patch moving [set|get]_page_memtype() to pat.c since the tip branch already has this change. - Fixed an issue when CONFIG_X86_PAT is not defined. v5: - Clarified comment of why using slot 7. (Andy Lutomirski, Thomas Gleixner) - Moved [set|get]_page_memtype() to pat.c. (Thomas Gleixner) - Removed BUG() from set_page_memtype(). (Thomas Gleixner) v4: - Added set_memory_wt() by adding WT support of regular memory. v3: - Dropped the set_memory_wt() patch. (Andy Lutomirski) - Refactored the !pat_enabled handling. (H. Peter Anvin, Andy Lutomirski) - Added the picture of PTE encoding. (Konrad Rzeszutek Wilk) v2: - Changed WT to use slot 7 of the PAT MSR. (H. Peter Anvin, Andy Lutomirski) - Changed to have conservative checks to exclude all Pentium 2, 3, M, and 4 families. (Ingo Molnar, Henrique de Moraes Holschuh, Andy Lutomirski) - Updated documentation to cover WT interfaces and usages. (Andy Lutomirski, Yigal Korman) --- Toshi Kani (12): 1/12 x86, mm, pat: Set WT to PA7 slot of PAT MSR 2/12 x86, mm, pat: Change reserve_memtype() for WT 3/12 x86, asm: Change is_new_memtype_allowed() for WT 4/12 x86, mm, asm-gen: Add ioremap_wt() for WT 5/12 arch/*/asm/io.h: Add ioremap_wt() to all architectures 6/12 video/fbdev, asm/io.h: Remove ioremap_writethrough() 7/12 x86, mm, pat: Add pgprot_writethrough() for WT 8/12 x86, mm, asm: Add WT support to set_page_memtype() 9/12 x86, mm: Add set_memory_wt() for WT 10/12 x86, mm, pat: Cleanup init flags in pat_init() 11/12 x86, mm, pat: Refactor !pat_enable handling 12/12 drivers/block/pmem: Map NVDIMM with ioremap_wt() --- Documentation/x86/pat.txt | 13 +- arch/arc/include/asm/io.h | 1 + arch/arm/include/asm/io.h | 1 + arch/arm64/include/asm/io.h | 1 + arch/avr32/include/asm/io.h | 1 + arch/frv/include/asm/io.h | 4 +- arch/m32r/include/asm/io.h | 1 + arch/m68k/include/asm/io_mm.h | 4 +- arch/m68k/include/asm/io_no.h | 4 +- arch/metag/include/asm/io.h | 3 + arch/microblaze/include/asm/io.h | 2 +- arch/mn10300/include/asm/io.h | 1 + arch/nios2/include/asm/io.h | 1 + arch/s390/include/asm/io.h | 1 + arch/sparc/include/asm/io_32.h | 1 + arch/sparc/include/asm/io_64.h | 1 + arch/tile/include/asm/io.h | 2 +- arch/x86/include/asm/cacheflush.h | 6 +- arch/x86/include/asm/io.h | 2 + arch/x86/include/asm/pgtable.h | 8 +- arch/x86/include/asm/pgtable_types.h | 3 + arch/x86/mm/init.c | 6 +- arch/x86/mm/iomap_32.c | 12 +- arch/x86/mm/ioremap.c | 29 ++++- arch/x86/mm/pageattr.c | 65 +++++++--- arch/x86/mm/pat.c | 232 +++++++++++++++++++++++------------ arch/xtensa/include/asm/io.h | 1 + drivers/block/pmem.c | 4 +- drivers/video/fbdev/amifb.c | 4 +- drivers/video/fbdev/atafb.c | 3 +- drivers/video/fbdev/hpfb.c | 4 +- include/asm-generic/io.h | 9 ++ include/asm-generic/iomap.h | 4 + include/asm-generic/pgtable.h | 4 + 34 files changed, 311 insertions(+), 127 deletions(-)
next reply other threads:[~2015-05-27 15:18 UTC|newest] Thread overview: 70+ messages / expand[flat|nested] mbox.gz Atom feed top 2015-05-27 15:18 Toshi Kani [this message] 2015-05-27 15:18 ` [PATCH v10 0/12] Support Write-Through mapping on x86 Toshi Kani 2015-05-27 15:18 ` [PATCH v10 1/12] x86, mm, pat: Set WT to PA7 slot of PAT MSR Toshi Kani 2015-05-27 15:18 ` Toshi Kani 2015-05-27 15:18 ` [PATCH v10 2/12] x86, mm, pat: Change reserve_memtype() for WT Toshi Kani 2015-05-27 15:18 ` Toshi Kani 2015-05-27 15:18 ` [PATCH v10 3/12] x86, asm: Change is_new_memtype_allowed() " Toshi Kani 2015-05-27 15:18 ` Toshi Kani 2015-05-27 15:18 ` [PATCH v10 4/12] x86, mm, asm-gen: Add ioremap_wt() " Toshi Kani 2015-05-27 15:18 ` Toshi Kani 2015-05-27 15:18 ` [PATCH v10 5/12] arch/*/asm/io.h: Add ioremap_wt() to all architectures Toshi Kani 2015-05-27 15:18 ` Toshi Kani 2015-05-27 15:18 ` [PATCH v10 6/12] video/fbdev, asm/io.h: Remove ioremap_writethrough() Toshi Kani 2015-05-27 15:18 ` Toshi Kani 2015-05-27 15:18 ` [PATCH v10 7/12] x86, mm, pat: Add pgprot_writethrough() for WT Toshi Kani 2015-05-27 15:18 ` Toshi Kani 2015-05-27 15:19 ` [PATCH v10 8/12] x86, mm, asm: Add WT support to set_page_memtype() Toshi Kani 2015-05-27 15:19 ` Toshi Kani 2015-05-27 15:19 ` [PATCH v10 9/12] x86, mm: Add set_memory_wt() for WT Toshi Kani 2015-05-27 15:19 ` Toshi Kani 2015-05-27 15:19 ` [PATCH v10 10/12] x86, mm, pat: Cleanup init flags in pat_init() Toshi Kani 2015-05-27 15:19 ` Toshi Kani 2015-05-29 8:59 ` Borislav Petkov 2015-05-29 8:59 ` Borislav Petkov 2015-05-27 15:19 ` [PATCH v10 11/12] x86, mm, pat: Refactor !pat_enabled handling Toshi Kani 2015-05-27 15:19 ` Toshi Kani 2015-05-29 8:58 ` Borislav Petkov 2015-05-29 8:58 ` Borislav Petkov 2015-05-29 14:27 ` Toshi Kani 2015-05-29 14:27 ` Toshi Kani 2015-05-29 15:13 ` Borislav Petkov 2015-05-29 15:13 ` Borislav Petkov 2015-05-29 15:17 ` Toshi Kani 2015-05-29 15:17 ` Toshi Kani 2015-05-27 15:19 ` [PATCH v10 12/12] drivers/block/pmem: Map NVDIMM with ioremap_wt() Toshi Kani 2015-05-27 15:19 ` Toshi Kani 2015-05-29 9:11 ` Borislav Petkov 2015-05-29 9:11 ` Borislav Petkov 2015-05-29 14:43 ` Dan Williams 2015-05-29 14:43 ` Dan Williams 2015-05-29 15:03 ` Toshi Kani 2015-05-29 15:03 ` Toshi Kani 2015-05-29 15:03 ` Toshi Kani 2015-05-29 18:19 ` Dan Williams 2015-05-29 18:19 ` Dan Williams 2015-05-29 18:32 ` Toshi Kani 2015-05-29 18:32 ` Toshi Kani 2015-05-29 18:32 ` Toshi Kani 2015-05-29 19:34 ` Dan Williams 2015-05-29 19:34 ` Dan Williams 2015-05-29 20:10 ` Toshi Kani 2015-05-29 20:10 ` Toshi Kani 2015-05-29 18:34 ` Andy Lutomirski 2015-05-29 18:34 ` Andy Lutomirski 2015-05-29 19:32 ` Dan Williams 2015-05-29 19:32 ` Dan Williams 2015-05-29 21:29 ` Elliott, Robert (Server Storage) 2015-05-29 21:29 ` Elliott, Robert (Server Storage) 2015-05-29 21:29 ` Elliott, Robert (Server Storage) 2015-05-29 21:46 ` Andy Lutomirski 2015-05-29 21:46 ` Andy Lutomirski 2015-05-29 22:24 ` Elliott, Robert (Server Storage) 2015-05-29 22:24 ` Elliott, Robert (Server Storage) 2015-05-29 22:24 ` Elliott, Robert (Server Storage) 2015-05-29 22:32 ` H. Peter Anvin 2015-05-29 22:32 ` H. Peter Anvin 2015-06-01 8:58 ` Ingo Molnar 2015-06-01 8:58 ` Ingo Molnar 2015-06-01 17:10 ` Andy Lutomirski 2015-06-01 17:10 ` Andy Lutomirski
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=1432739944-22633-1-git-send-email-toshi.kani@hp.com \ --to=toshi.kani@hp.com \ --cc=Elliott@hp.com \ --cc=akpm@linux-foundation.org \ --cc=arnd@arndb.de \ --cc=hch@lst.de \ --cc=hmh@hmh.eng.br \ --cc=hpa@zytor.com \ --cc=jgross@suse.com \ --cc=konrad.wilk@oracle.com \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-mm@kvack.org \ --cc=linux-nvdimm@lists.01.org \ --cc=luto@amacapital.net \ --cc=mcgrof@suse.com \ --cc=mingo@redhat.com \ --cc=stefan.bader@canonical.com \ --cc=tglx@linutronix.de \ --cc=x86@kernel.org \ --cc=yigal@plexistor.com \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.