FreeBSD manual
download PDF document: nvdimm.4.pdf
NVDIMM(4) FreeBSD Kernel Interfaces Manual NVDIMM(4)
NAME
nvdimm - ACPI NVDIMM driver
SYNOPSIS
To load the driver as a module at boot, place the following line in
loader.conf(5):
nvdimm_load="YES"
DESCRIPTION
Note: The nvdimm driver is under development and has some important
limitations described below.
The nvdimm driver provides access to Non-Volatile DIMM (NVDIMM)
persistent memory devices, which are ACPI-enumerated under the root
NVDIMM device with a _HID of ACPI0012 and in the NFIT table.
For each System Physical Address (SPA) Range described by NFIT, a device
node /dev/nvdimm_spaNNN is created, where NNN is the SPA position in the
table. The node can be used to read(2), write(2), or mmap(2) the device.
Also, for each SPA, the geom provider spaNNN is created, which can be
used to create a conventional filesystem (e.g., by newfs(8)) and mount(8)
it as any storage volume. Content accessible by /dev/nvdimm_spaNNN and
/dev/spaNNN is coherent.
The nvdimm driver has support for reading NVDIMM namespaces (if supported
by your hardware and already configured by some other mechanism, e.g., a
BIOS configuration screen). The driver will provide a
/dev/nvdimm_spaNNNnsMMM device node and spaNNNnsMMM geom provider for
each namespace in a SPA, which behave analogously to their full-SPA
cousins described above.
SEE ALSO
acpi(4), GEOM(4), geom(8), mount(8), newfs(8), disk(9)
HISTORY
The nvdimm driver first appeared in FreeBSD 12.0.
AUTHORS
The nvdimm driver was originally written by Konstantin Belousov
<kib@FreeBSD.org>, and then updated by D. Scott Phillips
<scottph@FreeBSD.org>.
BUGS
The nvdimm driver does not utilize the Block Window interface, so if a
write to an NVDIMM is interrupted due to a system crash or power outage,
the corresponding page might be left in a partially updated state.
There is no support for Device-Specific Methods (DSM), used to report and
control device health and wearing.
The driver depends on the pmap_largemap(9) pmap interface, which is
currently only implemented on amd64. The interface can be only
reasonable implemented on 64bit architectures.
FreeBSD 14.2-RELEASE September 5, 2019 FreeBSD 14.2-RELEASE