Introduction
Intel® Optane™ persistent memory (PMem) is a disruptive technology that creates a new tier between memory and storage. Intel Optane™ PMem modules support two modes: Memory Mode for volatile use cases and App Direct Mode that provides byte-addressable persistent storage.
In this portion of the Quickstart Guide to Provisioning Pmem, we describe some methods of provisioning PMem using ipmctl and ndctl utilities within a Linux environment.
- ipmctl utility is necessary for discovering Intel Optane persistent memory module resources, creating goals and regions, updating the firmware, and debugging issues.
- ndctl utility is used to configure the namespaces
This quick start guide (QSG) has three sections:
- Quick Start Guide Part 1: Persistent Memory Provisioning Introduction
- Quick Start Guide Part 2: Provisioning for Intel® Optane™ Persistent Memory on Linux
- Quick Start Guide Part 3: Provisioning for Intel® Optane™ Persistent Memory on Microsoft Windows
Linux Support for Intel Optane Persistent Memory
Most Linux distributions support persistent memory. A list of Compatible Operating System OS for Intel® Optane™ Persistent Memory details if Memory Mode, AppDirect, or Mixed-Mode are supported.
Kernel Support
The Linux NVDIMM/PMem drivers are enabled by default, starting with Linux mainline kernel 4.2. We recommend mainline kernel version 4.19 or later to deliver Reliability, Availability and Serviceability (RAS) features required by the Persistent Memory Development Kit (PMDK).
Custom Kernel Support
Whether you use the default kernel provided by your distro, compile your own, or install a Kernel from another source, it is worth confirming that your supports PMem. The following example was captured on a v5.8 kernel and showed how to verify what features are available and enabled or disabled in that kernel. The results will vary depending on the kernel version.
Software: Non-volatile Device Control (ndctl)
The vendor-neutral ndctl command is used to manage namespaces. The utility is designed to work with NVDIMMs from different vendors, including Intel Optane PMem.
ndctl supports the following functionality:
- Show PMem module information
- Manage namespaces and configuration labels
- Monitor health
- Manage security - passphrases and secure erase
- Error injection and testing
For more information, refer to the ndctl User Guide.
Installing ndctl
The ndctl utility is available in most Linux package repositories, or you can download and compile the source code, which is available on the ndctl GitHub project page.
For example, in Ubuntu Linux, you can do:
Further information can be found in Installing NDCTL and DAXTL documentation.
Getting Help
The full list of commands is available by running `ndctl --list-cmds.` Each of the commands is documented in the man pages and accessible through the `ndctl help` interface.
For a comprehensive review of this utility and to get further assistance, access the following resources:
- pmem.io
- NDCTL User Guide
- Google PMem Group
- #pmem Slack Channel – Join Here
IPMCTL
ipmctl is an open source utility created and maintained by Intel to manage Intel® Optane™ persistent memory modules. The ipmctl tool is available for both Linux and Windows. Refer to the ipmctl GitHub project for more information.
Installing ipmctl
Detailed step-by-step instructions can be found in Installing IPMCTL documentation. On most Linux environments, you need to use the package manager to install the ipmctl package and dependencies, for example:
Getting Help
A full list of commands is available by running 'man ipmctl' or 'ipmctl help' from the command line.
For a comprehensive review of this utility and to get further assistance, access the following resources :
- ipmctl user guide
- pmem.io
- Google PMem Group
- #pmem Slack Channel – Join Here
Tutorial: Provisioning Persistent Memory
This tutorial provides instructions for configuring and managing Intel® Optane™ persistent memory (PMem) modules in Memory Mode, App Direct Mode, or mixed mode on a Linux host. After using ipmctl to discover and provision the modules into either Memory or App Direct mode, we will use the Non-volatile Device Control (ndctl) utility to finish the configuration. All the commands described in this section are demonstrated on a two-socket system with 6 Terabytes (TB) of PMem, and 384 gigabytes (GB) of DDR4 DRAM.
Note All ndctl and icmptl snippets and screenshots below are from a server running Ubuntu 20.0.4 and ipmctl snippets are from ipmctl v2.x
Prerequisites
For Provisioning Intel PMem, the following is needed:
- Intel Optane PMem Modules are installed
- The ipmctl utility is used to configure and manage PMem modules.
- To determine if ipmctl is already installed, type 'which ipmctl' into the terminal window.
- If ipmctl is not installed, refer to the Installing ipmctl user guide.
- The ndctl utility is used to manage the regions and namespaces.
- To determine if ndctl is already installed, type 'which ndctl' into the terminal window.
- If ndctl is not installed, refer to the Installing ndctl user guide.
Step 1: PMem Discovery
This tutorial considers that an operating mode is pre-configured by the system provider. New systems are commonly pre-configured in App Direct Mode or Memory Mode based on the customer requirement.
- ipmctl show -dimm command displays the PMem modules discovered in the system and verifies that software can communicate with them. Among other information, this command outputs each DIMM ID, capacity, health state, and firmware version. The PMem module firmware and BIOS releases are available from the system provider
- ipmctl show -topology command identifies which memory slots the DDR and PMem modules are installed in
- ipmctl show -memoryresources will report information about the current configuration if it has been configured. If no configuration has been created, ipmctl will return a message similar to "One or more PMem modules have invalid PCD data. A platform reboot is recommended to restore valid PCD data, then try again." In the output below, the MemoryCapacity and AppDirectCapacity values are used to determine if the system was configured in Memory mode, App Direct Mode, or mixed mode, here are a few examples:
- If the system is in Memory Mode, you will see something like this (see Volatile row):
- If the system is in AppDirect, you will see something like this (see App Direct Row):
MemoryType | DDR | PMemModule | Total ========================================================== Volatile | 189.500 GiB | 0.000 GiB | 189.500 GiB AppDirect | - | 1512.000 GiB | 1512.000 GiB Cache | 0.000 GiB | - | 0.000 GiB Inaccessible | 2.500 GiB | 5.066 GiB | 7.566 GiB Physical | 192.000 GiB | 1517.066 GiB | 1709.066 GiB
- If the system is in Mixed Mode (50/50), you will see something like this (see volatile and AppDirect rows):
MemoryType | DDR | PMemModule | Total ========================================================== Volatile | 189.500 GiB | 758.000 GiB | 758.000 GiB AppDirect | - | 758.000 GiB | 758.000 GiB Cache | 0.000 GiB | - | 0.000 GiB Inaccessible | 2.500 GiB | 5.066 GiB | 7.566 GiB Physical | 192.000 GiB | 1517.066 GiB | 1709.066 GiB
- If the system is in Memory Mode, you will see something like this (see Volatile row):
Step 2: Determine a Configuration Goal
At this point, if your system is configured as you need it, consider the following step as just information. However, if you need to make changes to the configuration, this section explains the basics. If you need to change the platform configuration, such as Memory mode to App Direct Mode, see appendix A on resetting the system.
When setting a goal, we set the Intel Optane PMem modules to be used in one of the three standard modes; Memory Mode, App Direct, and mixed. Once the mode is set, the system needs to be rebooted for the changes to go into effect.
The first thing you need to do is decide which of the three modes you require and run the appropriate configuration command
- Memory Mode - 100% of PMem capacity across sockets can be provisioned in Memory mode, as described below. In this example, 100% of the available PMem capacity is to be provisioned in Memory mode. You can always use the -f option to overwrite any existing goal. The system must comply with recommended DRAM to PMem capacity ratios. At a minimum, a system must have at least a 1:4 ratio and no more than 1:16 per CPU socket. For example, a system with 192GB of PMem should have at least 768GB of PMem. A warning may be reported by ipmctl and the BIOS at boot time if the configuration does not meet the requirements.
- App Direct Mode - PMem can be provisioned in App Direct Mode with interleaving enabled or disabled. As described in the QSG Guide Part 1, interleaving increases the throughput of reads and writes to PMem.
- Mixed Modes - A percentage of PMem capacity can be provisioned in Memory mode, as described below. Any remaining PMem capacity can either be reserved or used to create an AppDirect region.
Step 3: Configure your Platform
At this point, we have three options, choose the sub-tutorial below to configure your system.
Memory Mode Example
In this example, 100% of the available PMem capacity is to be provisioned in Memory Mode.
- Enter the following on the command line ipmctl create -goal memorymode=100
- A reboot is required to process new memory allocation goals.
App Direct Example
In this example, we configure the system into App Direct Mode.
- Enter the following on the command line ipmctl create -goal persistentmemorytype=appdirect
- A reboot is required to process new memory allocation goals.
Mixed Mode Example
In this example, 60% of the available PMem capacity is to be provisioned in Memory Mode.
- Enter the following on the command line ipmctl create -goal memorymode=60
- A reboot is required to process new memory allocation goals.
Step 4: Provisioning of Intel Optane Persistent Memory Namespaces
Having provisioned your system in one of the three modes, we now need to create the namespaces(s) for App Direct Mode and mixed-mode. If your device was configured in memory mode (ex: ipmctl create -goal memorymode=100), your device is fully configured and ready for use.
Prerequisites
The system is in App Direct or mixed mode as described in the tutorial within the: Quick Start Guide Part 1: Provisioning Basics for Intel® Optane™ Persistent Memory
Tutorial: How to create a namespace
Now we need to create a namespace for the application(s) to run. The namespace size can be any percentage of the overall PMem memory capacity of the installed PMem modules. Please run the following commands to configure the system.
- We need to identify if we want to configure the entire PMem capacity or a portion.
- If needing a single namespace across all regions use the following command: sudo ndctl create-namespace
- If designating only a portion of the persistent memory capacity: We need to run a command such as sudo ndctll create-namespace -m fsdax -s 54G
- Lets first understand what the command is trying to achieve
- Argument details
- fsdax - Creates a new namespace in fsdax mode. The size of the namespace is 50GiB, minus the size of the metadata. Other modes supported include sector, devdax, and raw.
- 54G - This allocates 50 GiB to this namespace. You can use any amount up to the full capacity.
- Remember: when in Mixed mode, the full capacity is reduced accordingly, due to the allocation of x% into memory mode
- Argument Results
- This command creates a new /dev/pmem{X[.Y]} device
- The X value represents the region of the namespace. The namespace defaults to zero (0).
- When working with multiple namespaces within a region, the naming convention is pmem{X.Y} where Y represents a sequentially increasing integer value for the new namespace.
- The first namespace is pmem0 Next, we verify if the namespace was created
- Argument details
- Lets first understand what the command is trying to achieve
- If needing a single namespace across all regions use the following command: sudo ndctl create-namespace
- Enter the following on the command line ls -l /dev/pmem* to verify if the namespace was created.
- Enter the following on the command line ndctl create-namespace -n "MyApp" for tagging purposes.
- Tagging the namespace with a friendly name/ description using the -n argument is particularly useful when provisioning space for multiple end-users or applications or to identify a namespace with for production or test/dev environments
Note replace MyApp with your choice of a name
- Enter the following on the command line sudo ndctl create-namespace, to designate the remaining pmem capacity.
Note Only run this command after all the required regions are created, as shown above.
- Enter the following on the command line ndctl list -N, to see the list of all the namespaces created:
- Enter the following on the command line ls -l /dev/pmem*, to check out the Persistent Memory device created.
- Enter the following on the command line mkfs.ext4 -f /dev/pmem1 to create the file system and mount it on the PMem device.
- Enter the following on the command line mkdir /mnt/myPMem to create a mount point.
- Enter the following on the command line mount -o dax /dev/pmem1 /mnt/myPMem to mount the file system with the-o dax option.
- The system is now ready to be used by the application.
Resources:
- Google PMem Group
- ipmctl user guide
- ndctl User Guide
- ipmctl and ndctl Cheat Sheet
- pmem.io
- PMem Getting Started Guide
- #pmem Slack Channel – Join Here
This concludes the tutorial for provisioning PMem within Linux. See below for a link to other articles in this series.
- Quick Start Guide Part 1: Persistent Memory Provisioning Introduction
- Quick Start Guide Part 3: Provisioning for Intel® Optane™ Persistent Memory on Microsoft Windows
Appendix: How to factory reset the persistent memory
Warning This information is supplemental only and is not necessary for the tutorial above. This is a permanent action. All data will be lost.
Quick Method
- sudo ndctl destroy-namespace -f all
- OS> ipmctl delete -f -dimm -pcd’
- Deletes the Goal aka PCD (Platform Config Data)
- Reboot the system
Long Method
- Log in under sudo
- ndctl list -N
- Get a list of namespaces
- Unmount the file system from the namespace needing to be removed
- Disable namespaces (repeat steps for all namespaces required)
Warning Disabling a namespace while it is mounted or in use results in undefined behavior by the application(s) using the namespace. Always stop any applications and unmount file systems in fsdax mode before disabling a namespace.
- ndctl disable-namespace
- ndctl destroy-namespace
- Destroy the namespace
- ipmctl delete -f -dimm -pcd
- Delete the Goal aka PCD (Platform Config Data)
- Reboot the system