Re: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem
* Elliott, Robert (Server Storage) wrote: > > -Original Message- > > From: Linux-nvdimm [mailto:linux-nvdimm-boun...@lists.01.org] On Behalf Of > > Dan Williams > > Sent: Friday, April 17, 2015 8:35 PM > > To: linux-nvd...@lists.01.org > > Subject: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem > > > ... > > create mode 100644 drivers/block/nd/acpi.c > > create mode 100644 drivers/block/nd/blk.c > > create mode 100644 drivers/block/nd/bus.c > > create mode 100644 drivers/block/nd/core.c > ... > > The kernel already has lots of files with these names: > 5 acpi.c > 10 bus.c > 66 core.c > > I often use ctags like this: > vim -t core.c > but that doesn’t immediately work with common filenames - it > presents a list of all 66 files to choose from. > > Also, blk.c is a name one might expect to see in the block/ > directory (e.g., next to blk.h). > > An nd_ prefix on all the filenames would help. It's really stupid to duplicate information that is present in the pathname. To type: vim -t nd/core.c should be the same as: vim -t nd_core.c Thanks, Ingo -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem
On Wed, Apr 22, 2015 at 12:06 PM, Elliott, Robert (Server Storage) wrote: >> -Original Message- >> From: Linux-nvdimm [mailto:linux-nvdimm-boun...@lists.01.org] On Behalf Of >> Dan Williams >> Sent: Friday, April 17, 2015 8:35 PM >> To: linux-nvd...@lists.01.org >> Subject: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem >> > ... >> create mode 100644 drivers/block/nd/acpi.c >> create mode 100644 drivers/block/nd/blk.c >> create mode 100644 drivers/block/nd/bus.c >> create mode 100644 drivers/block/nd/core.c > ... > > The kernel already has lots of files with these names: > 5 acpi.c > 10 bus.c > 66 core.c > > I often use ctags like this: > vim -t core.c > but that doesn’t immediately work with common filenames - it > presents a list of all 66 files to choose from. > > Also, blk.c is a name one might expect to see in the block/ > directory (e.g., next to blk.h). > > An nd_ prefix on all the filenames would help. > I picked up the "don't duplicate the directory name in the source file name" approach from a review comment from Linus on a SCSI driver a long time back (iirc). I'm not motivated to stop that practice now. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
RE: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem
> -Original Message- > From: Linux-nvdimm [mailto:linux-nvdimm-boun...@lists.01.org] On Behalf Of > Dan Williams > Sent: Friday, April 17, 2015 8:35 PM > To: linux-nvd...@lists.01.org > Subject: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem > ... > create mode 100644 drivers/block/nd/acpi.c > create mode 100644 drivers/block/nd/blk.c > create mode 100644 drivers/block/nd/bus.c > create mode 100644 drivers/block/nd/core.c ... The kernel already has lots of files with these names: 5 acpi.c 10 bus.c 66 core.c I often use ctags like this: vim -t core.c but that doesn’t immediately work with common filenames - it presents a list of all 66 files to choose from. Also, blk.c is a name one might expect to see in the block/ directory (e.g., next to blk.h). An nd_ prefix on all the filenames would help. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
RE: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem
-Original Message- From: Linux-nvdimm [mailto:linux-nvdimm-boun...@lists.01.org] On Behalf Of Dan Williams Sent: Friday, April 17, 2015 8:35 PM To: linux-nvd...@lists.01.org Subject: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem ... create mode 100644 drivers/block/nd/acpi.c create mode 100644 drivers/block/nd/blk.c create mode 100644 drivers/block/nd/bus.c create mode 100644 drivers/block/nd/core.c ... The kernel already has lots of files with these names: 5 acpi.c 10 bus.c 66 core.c I often use ctags like this: vim -t core.c but that doesn’t immediately work with common filenames - it presents a list of all 66 files to choose from. Also, blk.c is a name one might expect to see in the block/ directory (e.g., next to blk.h). An nd_ prefix on all the filenames would help. -- To unsubscribe from this list: send the line unsubscribe linux-kernel in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem
On Wed, Apr 22, 2015 at 12:06 PM, Elliott, Robert (Server Storage) elli...@hp.com wrote: -Original Message- From: Linux-nvdimm [mailto:linux-nvdimm-boun...@lists.01.org] On Behalf Of Dan Williams Sent: Friday, April 17, 2015 8:35 PM To: linux-nvd...@lists.01.org Subject: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem ... create mode 100644 drivers/block/nd/acpi.c create mode 100644 drivers/block/nd/blk.c create mode 100644 drivers/block/nd/bus.c create mode 100644 drivers/block/nd/core.c ... The kernel already has lots of files with these names: 5 acpi.c 10 bus.c 66 core.c I often use ctags like this: vim -t core.c but that doesn’t immediately work with common filenames - it presents a list of all 66 files to choose from. Also, blk.c is a name one might expect to see in the block/ directory (e.g., next to blk.h). An nd_ prefix on all the filenames would help. I picked up the don't duplicate the directory name in the source file name approach from a review comment from Linus on a SCSI driver a long time back (iirc). I'm not motivated to stop that practice now. -- To unsubscribe from this list: send the line unsubscribe linux-kernel in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem
* Elliott, Robert (Server Storage) elli...@hp.com wrote: -Original Message- From: Linux-nvdimm [mailto:linux-nvdimm-boun...@lists.01.org] On Behalf Of Dan Williams Sent: Friday, April 17, 2015 8:35 PM To: linux-nvd...@lists.01.org Subject: [Linux-nvdimm] [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem ... create mode 100644 drivers/block/nd/acpi.c create mode 100644 drivers/block/nd/blk.c create mode 100644 drivers/block/nd/bus.c create mode 100644 drivers/block/nd/core.c ... The kernel already has lots of files with these names: 5 acpi.c 10 bus.c 66 core.c I often use ctags like this: vim -t core.c but that doesn’t immediately work with common filenames - it presents a list of all 66 files to choose from. Also, blk.c is a name one might expect to see in the block/ directory (e.g., next to blk.h). An nd_ prefix on all the filenames would help. It's really stupid to duplicate information that is present in the pathname. To type: vim -t nd/core.c should be the same as: vim -t nd_core.c Thanks, Ingo -- To unsubscribe from this list: send the line unsubscribe linux-kernel in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem
On Fri, Apr 17, 2015 at 6:35 PM, Dan Williams wrote: > Since 2010 Intel has included non-volatile memory support on a few > storage-focused platforms with a feature named ADR (Asynchronous DRAM > Refresh). These platforms were mostly targeted at custom applications > and never enjoyed standard discovery mechanisms for platform firmware > to advertise non-volatile memory capabilities. This now changes with > the publication of version 6 of the ACPI specification [1] and its > inclusion of a new table for describing platform memory capabilities. > The NVDIMM Firmware Interface Table (NFIT), along with new EFI and E820 > memory types, enumerates persistent memory ranges, memory-mapped-I/O > apertures, physical memory devices (DIMMs), and their associated > properties. > > The ND-subsystem wraps a Linux device driver model around the objects > and address boundaries defined in the specification and introduces 3 new > drivers. > > nd_pmem: NFIT enabled version of the existing 'pmem' driver [2] > nd_blk: mmio aperture method for accessing persistent storage > nd_btt: give persistent memory disk semantics (atomic sector update) > > See the documentation in patch2 for more details, and there is > supplemental documentation on pmem.io [4]. Please review, and > patches welcome... > > For kicking the tires, this release is accompanied by a userspace > management library 'ndctl' that includes unit tests (make check) for all > of the kernel ABIs. The nfit_test.ko module can be used to explore a > sample NFIT topology. > > [1]: http://www.uefi.org/sites/default/files/resources/ACPI_6.0.pdf > [2]: https://git.kernel.org/cgit/linux/kernel/git/tip/tip.git/log/?h=x86/pmem > [3]: https://github.com/pmem/ndctl > [4]: http://pmem.io/documents/ nd.git and ndctl.git trees are now up to date. I'll aim to keep nd.git non-rebasing, but what eventually goes upstream is likely to be a re-flowed patch set. ndctl.git won't rebase. nd.git: git://git.kernel.org/pub/scm/linux/kernel/git/djbw/nvdimm.git nd ndctl.git: https://github.com/pmem/ndctl.git -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem
On Fri, Apr 17, 2015 at 6:35 PM, Dan Williams dan.j.willi...@intel.com wrote: Since 2010 Intel has included non-volatile memory support on a few storage-focused platforms with a feature named ADR (Asynchronous DRAM Refresh). These platforms were mostly targeted at custom applications and never enjoyed standard discovery mechanisms for platform firmware to advertise non-volatile memory capabilities. This now changes with the publication of version 6 of the ACPI specification [1] and its inclusion of a new table for describing platform memory capabilities. The NVDIMM Firmware Interface Table (NFIT), along with new EFI and E820 memory types, enumerates persistent memory ranges, memory-mapped-I/O apertures, physical memory devices (DIMMs), and their associated properties. The ND-subsystem wraps a Linux device driver model around the objects and address boundaries defined in the specification and introduces 3 new drivers. nd_pmem: NFIT enabled version of the existing 'pmem' driver [2] nd_blk: mmio aperture method for accessing persistent storage nd_btt: give persistent memory disk semantics (atomic sector update) See the documentation in patch2 for more details, and there is supplemental documentation on pmem.io [4]. Please review, and patches welcome... For kicking the tires, this release is accompanied by a userspace management library 'ndctl' that includes unit tests (make check) for all of the kernel ABIs. The nfit_test.ko module can be used to explore a sample NFIT topology. [1]: http://www.uefi.org/sites/default/files/resources/ACPI_6.0.pdf [2]: https://git.kernel.org/cgit/linux/kernel/git/tip/tip.git/log/?h=x86/pmem [3]: https://github.com/pmem/ndctl [4]: http://pmem.io/documents/ nd.git and ndctl.git trees are now up to date. I'll aim to keep nd.git non-rebasing, but what eventually goes upstream is likely to be a re-flowed patch set. ndctl.git won't rebase. nd.git: git://git.kernel.org/pub/scm/linux/kernel/git/djbw/nvdimm.git nd ndctl.git: https://github.com/pmem/ndctl.git -- To unsubscribe from this list: send the line unsubscribe linux-kernel in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
[PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem
Since 2010 Intel has included non-volatile memory support on a few storage-focused platforms with a feature named ADR (Asynchronous DRAM Refresh). These platforms were mostly targeted at custom applications and never enjoyed standard discovery mechanisms for platform firmware to advertise non-volatile memory capabilities. This now changes with the publication of version 6 of the ACPI specification [1] and its inclusion of a new table for describing platform memory capabilities. The NVDIMM Firmware Interface Table (NFIT), along with new EFI and E820 memory types, enumerates persistent memory ranges, memory-mapped-I/O apertures, physical memory devices (DIMMs), and their associated properties. The ND-subsystem wraps a Linux device driver model around the objects and address boundaries defined in the specification and introduces 3 new drivers. nd_pmem: NFIT enabled version of the existing 'pmem' driver [2] nd_blk: mmio aperture method for accessing persistent storage nd_btt: give persistent memory disk semantics (atomic sector update) See the documentation in patch2 for more details, and there is supplemental documentation on pmem.io [4]. Please review, and patches welcome... For kicking the tires, this release is accompanied by a userspace management library 'ndctl' that includes unit tests (make check) for all of the kernel ABIs. The nfit_test.ko module can be used to explore a sample NFIT topology. [1]: http://www.uefi.org/sites/default/files/resources/ACPI_6.0.pdf [2]: https://git.kernel.org/cgit/linux/kernel/git/tip/tip.git/log/?h=x86/pmem [3]: https://github.com/pmem/ndctl [4]: http://pmem.io/documents/ -- Dan for the NFIT driver development team Andy Rudoff, Matthew Wilcox, Ross Zwisler, and Vishal Verma --- Dan Williams (19): e820, efi: add ACPI 6.0 persistent memory types ND NFIT-Defined/NVIDIMM Subsystem nd_acpi: initial core implementation and nfit skeleton nd: create an 'nd_bus' from an 'nfit_desc' nfit-test: manufactured NFITs for interface development nd: ndctl class device, and nd bus attributes nd: dimm devices (nfit "memory-devices") nd: ndctl.h, the nd ioctl abi nd_dimm: dimm driver and base nd-bus device-driver infrastructure nd: regions (block-data-window, persistent memory, volatile memory) nd_region: support for legacy nvdimms nd_pmem: add NFIT support to the pmem driver nd: add interleave-set state-tracking infrastructure nd: namespace indices: read and validate nd: pmem label sets and namespace instantiation. nd: blk labels and namespace instantiation nd: write pmem label set nd: write blk label set nd: infrastructure for btt devices Ross Zwisler (1): nd_blk: nfit blk driver Vishal Verma (1): nd_btt: atomic sector updates Documentation/blockdev/btt.txt| 273 ++ Documentation/blockdev/nd.txt | 867 +++ MAINTAINERS | 34 + arch/arm64/kernel/efi.c |1 arch/ia64/kernel/efi.c|1 arch/x86/boot/compressed/eboot.c |4 arch/x86/include/uapi/asm/e820.h |1 arch/x86/kernel/e820.c| 25 - arch/x86/platform/efi/efi.c |3 drivers/block/Kconfig | 13 drivers/block/Makefile|2 drivers/block/nd/Kconfig | 130 +++ drivers/block/nd/Makefile | 39 + drivers/block/nd/acpi.c | 443 ++ drivers/block/nd/blk.c| 269 ++ drivers/block/nd/btt.c| 1423 +++ drivers/block/nd/btt.h| 185 drivers/block/nd/btt_devs.c | 443 ++ drivers/block/nd/bus.c| 703 +++ drivers/block/nd/core.c | 963 + drivers/block/nd/dimm.c | 126 +++ drivers/block/nd/dimm_devs.c | 701 +++ drivers/block/nd/label.c | 925 drivers/block/nd/label.h | 143 +++ drivers/block/nd/namespace_devs.c | 1697 + drivers/block/nd/nd-private.h | 203 drivers/block/nd/nd.h | 310 +++ drivers/block/nd/nfit.h | 238 + drivers/block/nd/pmem.c | 122 ++- drivers/block/nd/region.c | 95 ++ drivers/block/nd/region_devs.c| 1196 ++ drivers/block/nd/test/Makefile|5 drivers/block/nd/test/iomap.c | 199 drivers/block/nd/test/nfit.c | 1018 ++ drivers/block/nd/test/nfit_test.h | 37 + include/linux/efi.h |3 include/linux/nd.h| 98 ++ include/uapi/linux/Kbuild |1 include/uapi/linux/ndctl.h| 199 39 files changed, 13102 insertions(+), 36 deletions(-) create mode 100644 Documentation/blockdev/btt.txt create mode 100644 Documentation/blockdev/nd.txt create mode 100644
[PATCH 00/21] ND: NFIT-Defined / NVDIMM Subsystem
Since 2010 Intel has included non-volatile memory support on a few storage-focused platforms with a feature named ADR (Asynchronous DRAM Refresh). These platforms were mostly targeted at custom applications and never enjoyed standard discovery mechanisms for platform firmware to advertise non-volatile memory capabilities. This now changes with the publication of version 6 of the ACPI specification [1] and its inclusion of a new table for describing platform memory capabilities. The NVDIMM Firmware Interface Table (NFIT), along with new EFI and E820 memory types, enumerates persistent memory ranges, memory-mapped-I/O apertures, physical memory devices (DIMMs), and their associated properties. The ND-subsystem wraps a Linux device driver model around the objects and address boundaries defined in the specification and introduces 3 new drivers. nd_pmem: NFIT enabled version of the existing 'pmem' driver [2] nd_blk: mmio aperture method for accessing persistent storage nd_btt: give persistent memory disk semantics (atomic sector update) See the documentation in patch2 for more details, and there is supplemental documentation on pmem.io [4]. Please review, and patches welcome... For kicking the tires, this release is accompanied by a userspace management library 'ndctl' that includes unit tests (make check) for all of the kernel ABIs. The nfit_test.ko module can be used to explore a sample NFIT topology. [1]: http://www.uefi.org/sites/default/files/resources/ACPI_6.0.pdf [2]: https://git.kernel.org/cgit/linux/kernel/git/tip/tip.git/log/?h=x86/pmem [3]: https://github.com/pmem/ndctl [4]: http://pmem.io/documents/ -- Dan for the NFIT driver development team Andy Rudoff, Matthew Wilcox, Ross Zwisler, and Vishal Verma --- Dan Williams (19): e820, efi: add ACPI 6.0 persistent memory types ND NFIT-Defined/NVIDIMM Subsystem nd_acpi: initial core implementation and nfit skeleton nd: create an 'nd_bus' from an 'nfit_desc' nfit-test: manufactured NFITs for interface development nd: ndctl class device, and nd bus attributes nd: dimm devices (nfit memory-devices) nd: ndctl.h, the nd ioctl abi nd_dimm: dimm driver and base nd-bus device-driver infrastructure nd: regions (block-data-window, persistent memory, volatile memory) nd_region: support for legacy nvdimms nd_pmem: add NFIT support to the pmem driver nd: add interleave-set state-tracking infrastructure nd: namespace indices: read and validate nd: pmem label sets and namespace instantiation. nd: blk labels and namespace instantiation nd: write pmem label set nd: write blk label set nd: infrastructure for btt devices Ross Zwisler (1): nd_blk: nfit blk driver Vishal Verma (1): nd_btt: atomic sector updates Documentation/blockdev/btt.txt| 273 ++ Documentation/blockdev/nd.txt | 867 +++ MAINTAINERS | 34 + arch/arm64/kernel/efi.c |1 arch/ia64/kernel/efi.c|1 arch/x86/boot/compressed/eboot.c |4 arch/x86/include/uapi/asm/e820.h |1 arch/x86/kernel/e820.c| 25 - arch/x86/platform/efi/efi.c |3 drivers/block/Kconfig | 13 drivers/block/Makefile|2 drivers/block/nd/Kconfig | 130 +++ drivers/block/nd/Makefile | 39 + drivers/block/nd/acpi.c | 443 ++ drivers/block/nd/blk.c| 269 ++ drivers/block/nd/btt.c| 1423 +++ drivers/block/nd/btt.h| 185 drivers/block/nd/btt_devs.c | 443 ++ drivers/block/nd/bus.c| 703 +++ drivers/block/nd/core.c | 963 + drivers/block/nd/dimm.c | 126 +++ drivers/block/nd/dimm_devs.c | 701 +++ drivers/block/nd/label.c | 925 drivers/block/nd/label.h | 143 +++ drivers/block/nd/namespace_devs.c | 1697 + drivers/block/nd/nd-private.h | 203 drivers/block/nd/nd.h | 310 +++ drivers/block/nd/nfit.h | 238 + drivers/block/nd/pmem.c | 122 ++- drivers/block/nd/region.c | 95 ++ drivers/block/nd/region_devs.c| 1196 ++ drivers/block/nd/test/Makefile|5 drivers/block/nd/test/iomap.c | 199 drivers/block/nd/test/nfit.c | 1018 ++ drivers/block/nd/test/nfit_test.h | 37 + include/linux/efi.h |3 include/linux/nd.h| 98 ++ include/uapi/linux/Kbuild |1 include/uapi/linux/ndctl.h| 199 39 files changed, 13102 insertions(+), 36 deletions(-) create mode 100644 Documentation/blockdev/btt.txt create mode 100644 Documentation/blockdev/nd.txt create mode 100644