From 2255a4d814c083de5226e6e9e490b105788261f9 Mon Sep 17 00:00:00 2001 From: "matt.d" Date: Mon, 3 Jun 2024 14:46:04 -0700 Subject: [PATCH] Add support for integrated kernel driver If an env. var "INTEGRATED_DRIVER" is set to `true` (or similar) then modify the behavior of dss_host.py: 1. Never unload nvme or nvme-core drivers 2. Use modprobe instead of insmod for nvme-fabrics, nvme-tcp, and nvme-rdma 3. Do not modprobe nvme unnecessarilly (in `remove` function) Additionally, I implemented a fix where we are indiscriminately attempting to process all nvme subsystems. Now we are only processing RDMA subsystems. --- host/scripts/dss_host.py | 48 ++++++++++++++++++++++++++-------------- 1 file changed, 32 insertions(+), 16 deletions(-) diff --git a/host/scripts/dss_host.py b/host/scripts/dss_host.py index 41786926..965741b6 100755 --- a/host/scripts/dss_host.py +++ b/host/scripts/dss_host.py @@ -238,16 +238,25 @@ def install_kernel_driver(align): # Check if the kernel modules were built kernel_modules = ["nvme-core.ko", "nvme-fabrics.ko", "nvme-tcp.ko", "nvme-rdma.ko"] - for module in kernel_modules: - if not os.path.exists(module): - os.chdir(cwd) - raise IOError("File not found: " + os.path.join(os.getcwd(), module) + ", did you forget to run config_driver?") + if not integrated_driver: + for module in kernel_modules: + if not os.path.exists(module): + os.chdir(cwd) + raise IOError("File not found: " + os.path.join(os.getcwd(), module) + ", did you forget to run config_driver?") disconnect_cmd = "nvme disconnect-all" - rmmod = "modprobe -r nvme-tcp nvme-rdma nvme-fabrics nvme nvme-core" + rmmod = "modprobe -r nvme-tcp nvme-rdma nvme-fabrics" + # Append nvme and nvme-core if not integrated kernel driver + if not integrated_driver: + rmmod += " nvme nvme-core" # rmmod = "rmmod nvme; rmmod nvme-tcp; rmmod nvme-rdma; rmmod nvme-fabrics; rmmod nvme-core;" - insmod = "insmod ./nvme-core.ko mem_align=%d io_timeout=300 admin_timeout=300; insmod ./nvme-fabrics.ko; \ + + # Use insmod if not integrated kernel driver + if not integrated_driver: + insmod = "insmod ./nvme-core.ko mem_align=%d io_timeout=300 admin_timeout=300; insmod ./nvme-fabrics.ko; \ insmod ./nvme-tcp.ko; insmod ./nvme-rdma.ko" % (align) + else: + insmod = "modprobe nvme-fabrics nvme-tcp nvme-rdma" ret, do, err = exec_cmd(disconnect_cmd) if ret != 0: @@ -445,13 +454,14 @@ def subnet_drive_map(): for dev in subsys["Paths"]: name = '/dev/' + dev["Name"] + 'n1' transport = dev["Transport"] - addr = re.search(r"traddr=(\S+)", dev["Address"]).group(1) - subnet = getSubnet(addr) + if transport == "rdma": + addr = re.search(r"traddr=(\S+)", dev["Address"]).group(1) + subnet = getSubnet(addr) - if subnet not in subnet_device_map: - subnet_device_map[subnet] = [] - subnet_device_map[subnet].append(name) - addrs.append(addr) + if subnet not in subnet_device_map: + subnet_device_map[subnet] = [] + subnet_device_map[subnet].append(name) + addrs.append(addr) # We have IP octets now. Get interface and numa information for that octet. for octet in subnet_device_map.keys(): @@ -1058,10 +1068,12 @@ def remove(self): exec_cmd("rmmod nvme_tcp") exec_cmd("rmmod nvme_rdma") exec_cmd("rmmod nvme_fabrics") - exec_cmd("rmmod nvme") - exec_cmd("rmmod nvme_core") - # Load stock nvme driver - exec_cmd("modprobe nvme") + # Only rmmod if not integrated kernel driver + if not integrated_driver: + exec_cmd("rmmod nvme") + exec_cmd("rmmod nvme_core") + # Load stock nvme driver + exec_cmd("modprobe nvme") if __name__ == '__main__': @@ -1071,6 +1083,10 @@ def remove(self): # reload(sys) # sys.setdefaultencoding('utf8') + # Set global bool for integrated kernel driver + global integrated_driver + integrated_driver = os.getenv('INTEGRATED_DRIVER', 'False').lower() == 'true' + g_path = os.getcwd() print("Make sure this script is executed from nkv-sdk/bin diretory, running command under path:%s" % (g_path))