]> git.baikalelectronics.ru Git - kernel.git/commit
libnvdimm, e820: make CONFIG_X86_PMEM_LEGACY a tristate option
authorDan Williams <dan.j.williams@intel.com>
Wed, 19 Aug 2015 04:34:34 +0000 (00:34 -0400)
committerDan Williams <dan.j.williams@intel.com>
Wed, 19 Aug 2015 04:34:34 +0000 (00:34 -0400)
commit7d001475102faf4133d49c4ef129d2958e4fc6b3
tree1ace57d407ece741401f7b8878f1b2d85e990004
parente2108d4e4bc7b51215ee8e86b066272e3f4587e7
libnvdimm, e820: make CONFIG_X86_PMEM_LEGACY a tristate option

We currently register a platform device for e820 type-12 memory and
register a nvdimm bus beneath it.  Registering the platform device
triggers the device-core machinery to probe for a driver, but that
search currently comes up empty.  Building the nvdimm-bus registration
into the e820_pmem platform device registration in this way forces
libnvdimm to be built-in.  Instead, convert the built-in portion of
CONFIG_X86_PMEM_LEGACY to simply register a platform device and move the
rest of the logic to the driver for e820_pmem, for the following
reasons:

1/ Letting e820_pmem support be a module allows building and testing
   libnvdimm.ko changes without rebooting

2/ All the normal policy around modules can be applied to e820_pmem
   (unbind to disable and/or blacklisting the module from loading by
   default)

3/ Moving the driver to a generic location and converting it to scan
   "iomem_resource" rather than "e820.map" means any other architecture can
   take advantage of this simple nvdimm resource discovery mechanism by
   registering a resource named "Persistent Memory (legacy)"

Cc: Christoph Hellwig <hch@lst.de>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
arch/x86/Kconfig
arch/x86/include/uapi/asm/e820.h
arch/x86/kernel/Makefile
arch/x86/kernel/pmem.c
drivers/nvdimm/Makefile
drivers/nvdimm/e820.c [new file with mode: 0644]
tools/testing/nvdimm/Kbuild