spdk关于nvme模块的实例helloword代码

该文介绍了SPDK作为高性能存储开发工具包,其NVMe模块用于与NVMeSSD交互。提供了一个简单的示例代码,展示如何使用SPDK探测系统中的NVMe控制器,涉及的关键函数有spdk_nvme_probe_init、spdk_nvme_probe_poll_async和spdk_nvme_probe_cleanup。
摘要由CSDN通过智能技术生成

spdk关于nvme模块的实例helloword代码

SPDK

SPDK是一种高性能存储开发工具包,它提供了一组API,使开发人员可以利用现代存储技术来构建低延迟、高吞吐量的应用程序。其中NVMe模块是SPDK中的重要组件之一,它提供了一些API,使开发人员可以更方便地与NVMe SSD进行交互。下面是一个SPDK关于NVMe模块的实例helloworld代码,并且详细讲解一下。

代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <spdk/nvme.h>
static void
probe_cb(void *cb_ctx, const struct spdk_nvme_transport_id *trid,
         struct spdk_nvme_ctrlr_opts *opts)
{
    printf("Found NVMe controller at %!s(MISSING):%!s(MISSING)\n", trid->traddr, trid->trsvcid);
}
int main(int argc, char **argv)
{
    struct spdk_env_opts opts;
    struct spdk_env_opts_init(&opts);
    opts.name = "helloworld";
    spdk_env_init(&opts);
    struct spdk_nvme_probe_ctx *probe_ctx;
    probe_ctx = spdk_nvme_probe_init();
    if (probe_ctx == NULL) {
        fprintf(stderr, "Failed to initialize NVMe probe context\n");
        return 1;
    }
    spdk_nvme_probe_poll_async(probe_ctx, probe_cb, NULL, NULL);
    spdk_nvme_probe_wait(probe_ctx);
    spdk_nvme_probe_cleanup(probe_ctx);
    spdk_env_cleanup();
    return 0;
}

这个代码的作用是探测系统中是否存在NVMe SSD。它的执行流程如下:

  1. 初始化SPDK环境,包括初始化日志、CPU掩码、内存池等。
  2. 初始化NVMe probe的上下文,返回一个probe_ctx指针。
  3. 调用spdk_nvme_probe_poll_async函数开始异步探测NVMe控制器。这个函数会在后台进行探测,并且当探测完成时,会调用probe_cb函数。
  4. 调用spdk_nvme_probe_wait函数等待探测完成。这个函数会阻塞当前线程,直到所有异步探测都完成。
  5. 调用spdk_nvme_probe_cleanup函数清理probe_ctx指针。
  6. 清理SPDK环境。
    在这个代码中,我们使用了三个NVMe相关的函数:
  • spdk_nvme_probe_init:初始化NVMe probe的上下文。
  • spdk_nvme_probe_poll_async:异步探测NVMe控制器。
  • spdk_nvme_probe_cleanup:清理NVMe probe的上下文。

其中,spdk_nvme_probe_poll_async函数是比较重要的一个函数,它接受三个参数:probe_ctx、probe_cb和cb_ctx。其中,probe_ctx是spdk_nvme_probe_init函数返回的probe_ctx指针,probe_cb是一个回调函数,当探测完成时会被调用,cb_ctx是一个回调函数的上下文参数。在这个例子中,我们将cb_ctx设置为NULL,没有使用它。
在probe_cb回调函数中,我们只是简单地输出了探测到的NVMe控制器的地址和服务ID。实际上,我们可以在这个回调函数中执行更多的操作,比如初始化NVMe命名空间、创建I/O队列等。
这个代码虽然很简单,但是它演示了如何使用SPDK的NVMe模块探测系统中的NVMe SSD。这个代码也为后续的NVMe应用程序开发奠定了基础。

推荐一个零声学院免费公开课程,个人觉得老师讲得不错,分享给大家:Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK等技术内容,立即学习

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
SPDK(存储性能开发套件)官方文档中文版。 第一章 简介 1 1.1.什么是SPDK? 1 1.2.入门 1 1.3. Vagrant开发环境 3 1.4.更新日志(略) 6 第二章 概念 6 2.1. 用户空间驱动程序** 6 2.2. 来自用户空间的DMA** 7 2.3. 消息传递和并发** 9 2.4. NAND Flash SSD内部 13 2.5. 将I / O提交到NVMe设备** 15 2.5.1 NVMe规范 15 2.5.2 SPDK NVMe驱动程序I / O路径 15 2.6. 使用Vhost-user进行虚拟化I / O. 16 2.6.1 介绍 16 2.6.2 QEMU 17 2.6.3 设备初始化 18 2.6.4 I / O路径 19 2.6.5 SPDK优化 20 2.7. SPDK目录结构概述 20 2.8. SPDK移植指南 22 第三章 用户指南 22 3.1. 系统配置用户指南 22 3.1.1 IOMMU配置 22 3.2. SPDK应用程序概述 23 3.2.1 配置SPDK应用程序 23 3.3. iSCSI Target 26 3.3.1. iSCSI Target入门指南 26 3.3.2. 通过配置文件配置iSCSI Target 27 3.3.3. 通过RPC方法配置iSCSI Target 28 3.3.4. 配置iSCSI启动器 29 3.3.5. rpc配置示例*** 30 3.3.6. iSCSI 热插拔 32 3.4. NVMe over Fabrics Target 32 3.5. Vhost Target(略) 37 3.6 块设备用户指南 38 3.6.1 bdev介绍 38 3.6.2 通用RPC命令 38 3.6.3 Ceph RBD 39 3.6.4 压缩虚拟Bdev模块 40 3.6.5 加密虚拟Bdev模块 41 3.6.6 延迟vbdev模块 41 3.6.7 GPT(GUID分区表) 42 3.6.8 iSCSI bdev 43 3.6.9 Linux AIO bdev 43 3.6.10 OCF虚拟bdev 43 3.6.11 Malloc bdev 44 3.6.12 NULL bdev 44 3.6.13 NVMe bdev 44 3.6.14 逻辑卷Lvol 45 3.6.15 RAID 46 3.6.16 Passthru 46 3.6.17 Pmem 46 3.6.18 Virtio Block 47 3.6.19 Virtio SCSI 47 3.7 BlobFS(Blobstore文件系统) 48 3.7.1 RocksDB集成 48 3.7.2 FUSE插件 49 3.8 JSON-RPC方法(略) 49 第四章 程序员指南 49 4.1. Blobstore程序员指南 49 4.1.1 介绍 50 4.1.2 运作理论 50 4.1.3 设计注意事项 52 4.1.4 例子 54 4.1.5配置 54 4.1.6 组件细节 54 4.2. 块设备层编程指南 56 4.3 编写自定义块设备模块 58 4.3.1 介绍 58 4.3.2 创建一个新模块 59 4.3.3创建虚拟Bdev 60 4.4 NVMe over Fabrics目标编程指南 61 4.4.1 介绍 61 4.4.2 原语结构体 61 4.4.3 基础函数 62 4.4.4访问控制 62 4.4.5发现子系统 62 4.4.6 传输 63 4.4.7选择线程模型 63 4.4.8 跨CPU核心扩展 63 4.4.9 零拷贝支持 63 4.4.10 RDMA 63 4.5 Flash传输层 64 4.5.1 术语 64 4.5.2 使用方法 67 4.6 GDB宏用户指南 69 4.6.1 介绍 69 4.6.2 加载gdb宏 71 4.6.3 使用gdb数据目录 72 4.6.4 使用.gdbinit加载宏 72 4.6.5 为什么我们需要显式调用spdk_load_macros 72 4.6.6 以上可用的宏总结 73 4.6.7 添加新宏 73 4.7 SPDK “Reduce”块压缩算法 73 4.7.1 介绍 73 4.7.2 例子 74 4.8 通知库 78 第五章 基本信息 79 5.1 事件框架 79 5.1.1 事件框架设计注意事项 80 5.1.2 SPDK事件框架组件 80 5.1.3 应用框架 80 5.2 逻辑卷 81 5.2.1 术语 81 5.2.2 配置逻辑卷 84 5.3 矢量数据包处理(略) 86 第六章 杂项 86 6.1 介绍 86 6.2 NVMe的P2P API 86 6.3 确定设备支持 87 6.4 P2P问题 87 第七章 驱动程序 88 7.1 NVMe驱动程序*** 88 7.1.1 介绍 88 7.1.2 例子 88 7.1.3 公共接口 89 7.1.4 NVMe驱动程序设计 89 7.1.5 NVMe over Fabrics主机支持 91 7.1.6 NVMe多进程 91 7.1.7 NVMe Hotplug 92 7.2 I/OAT驱动程序 93 7.2.1 公共接口 93 7.2.2 关键功能 93 7.3 Virtio驱动程序 93 7.3.1 介绍 93 7.3.2 2MB大页面 93 第八章 工具 94 8.1 SPDK CLI 94 8.1.1 安装所需的依赖项 94 8.1.2 运行SPDK应用程序实例 94 8.1.3 运行SPDK CLI 94 8.1.4 可选 - 创建Python虚拟环境 94 8.2 nvme-CLI 95 8.2.1 nvme-cli with SPDK入门指南 95 8.2.2 使用场景 95 第九章 性能测试报告(略) 96 第十章NVMe-oF Target跟踪点*** 96 10.1 介绍 96 10.2 启用跟踪点 97 10.3 捕获事件的快照 97 10.4 捕获足够的跟踪事件 98 10.5 添加新的跟踪点 99
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我也要当昏君

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值