mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 867dfe3421
			
		
	
	
		867dfe3421
		
	
	
	
	
		
			
			A bugfix just tried to address a randconfig build problem and introduced
a variant of the same problem: with CONFIG_LIBNVDIMM=y and
CONFIG_NVDIMM_DAX=m, the nvdimm module now fails to link:
drivers/nvdimm/built-in.o: In function `to_nd_device_type':
bus.c:(.text+0x1b5d): undefined reference to `is_nd_dax'
drivers/nvdimm/built-in.o: In function `nd_region_notify_driver_action.constprop.2':
region_devs.c:(.text+0x6b6c): undefined reference to `is_nd_dax'
region_devs.c:(.text+0x6b8c): undefined reference to `to_nd_dax'
drivers/nvdimm/built-in.o: In function `nd_region_probe':
region.c:(.text+0x70f3): undefined reference to `nd_dax_create'
drivers/nvdimm/built-in.o: In function `mode_show':
namespace_devs.c:(.text+0xa196): undefined reference to `is_nd_dax'
drivers/nvdimm/built-in.o: In function `nvdimm_namespace_common_probe':
(.text+0xa55f): undefined reference to `is_nd_dax'
drivers/nvdimm/built-in.o: In function `nvdimm_namespace_common_probe':
(.text+0xa56e): undefined reference to `to_nd_dax'
This reverts the earlier fix, making NVDIMM_DAX a 'bool' option again
as it should be (it gets linked into the libnvdimm module). To fix
the original problem, I'm adding a dependency on LIBNVDIMM to
DEV_DAX_PMEM, which ensures we can't have that one built-in if the
rest is a module.
Fixes: 4e65e9381c ("/dev/dax: fix Kconfig dependency build breakage")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Reviewed-by: Ross Zwisler <ross.zwisler@linux.intel.com>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
		
	
			
		
			
				
	
	
		
			32 lines
		
	
	
		
			937 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			32 lines
		
	
	
		
			937 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| menuconfig DEV_DAX
 | |
| 	tristate "DAX: direct access to differentiated memory"
 | |
| 	default m if NVDIMM_DAX
 | |
| 	depends on TRANSPARENT_HUGEPAGE
 | |
| 	help
 | |
| 	  Support raw access to differentiated (persistence, bandwidth,
 | |
| 	  latency...) memory via an mmap(2) capable character
 | |
| 	  device.  Platform firmware or a device driver may identify a
 | |
| 	  platform memory resource that is differentiated from the
 | |
| 	  baseline memory pool.  Mappings of a /dev/daxX.Y device impose
 | |
| 	  restrictions that make the mapping behavior deterministic.
 | |
| 
 | |
| if DEV_DAX
 | |
| 
 | |
| config DEV_DAX_PMEM
 | |
| 	tristate "PMEM DAX: direct access to persistent memory"
 | |
| 	depends on LIBNVDIMM && NVDIMM_DAX
 | |
| 	default DEV_DAX
 | |
| 	help
 | |
| 	  Support raw access to persistent memory.  Note that this
 | |
| 	  driver consumes memory ranges allocated and exported by the
 | |
| 	  libnvdimm sub-system.
 | |
| 
 | |
| 	  Say Y if unsure
 | |
| 
 | |
| config NR_DEV_DAX
 | |
| 	int "Maximum number of Device-DAX instances"
 | |
| 	default 32768
 | |
| 	range 256 2147483647
 | |
| 
 | |
| endif
 |