1488570ebSJim Harris /* SPDX-License-Identifier: BSD-3-Clause
2*a6dbe372Spaul luse * Copyright (C) 2018 Intel Corporation.
381551144SXiaodong Liu * All rights reserved.
481551144SXiaodong Liu */
581551144SXiaodong Liu
681551144SXiaodong Liu #include "spdk/stdinc.h"
781551144SXiaodong Liu
881551144SXiaodong Liu #include "spdk/nvme.h"
981551144SXiaodong Liu #include "spdk/env.h"
1081551144SXiaodong Liu #include "spdk/env_dpdk.h"
116af0c997SXiaodong Liu #include <rte_config.h>
1281551144SXiaodong Liu #include <rte_eal.h>
1381551144SXiaodong Liu
1481551144SXiaodong Liu #define MAX_DEVS 64
1581551144SXiaodong Liu
1681551144SXiaodong Liu struct dev {
1781551144SXiaodong Liu struct spdk_nvme_ctrlr *ctrlr;
1881551144SXiaodong Liu struct spdk_nvme_ns *ns;
1981551144SXiaodong Liu struct spdk_nvme_qpair *qpair;
2081551144SXiaodong Liu char name[SPDK_NVMF_TRADDR_MAX_LEN + 1];
2181551144SXiaodong Liu };
2281551144SXiaodong Liu
2381551144SXiaodong Liu static struct dev g_nvme_devs[MAX_DEVS];
2481551144SXiaodong Liu static int g_num_devs = 0;
2581551144SXiaodong Liu static int g_failed = 0;
2681551144SXiaodong Liu
2781551144SXiaodong Liu static bool
probe_cb(void * cb_ctx,const struct spdk_nvme_transport_id * trid,struct spdk_nvme_ctrlr_opts * opts)2881551144SXiaodong Liu probe_cb(void *cb_ctx, const struct spdk_nvme_transport_id *trid,
2981551144SXiaodong Liu struct spdk_nvme_ctrlr_opts *opts)
3081551144SXiaodong Liu {
3181551144SXiaodong Liu printf("Attaching to %s\n", trid->traddr);
3281551144SXiaodong Liu
3381551144SXiaodong Liu return true;
3481551144SXiaodong Liu }
3581551144SXiaodong Liu
3681551144SXiaodong Liu static void
attach_cb(void * cb_ctx,const struct spdk_nvme_transport_id * trid,struct spdk_nvme_ctrlr * ctrlr,const struct spdk_nvme_ctrlr_opts * opts)3781551144SXiaodong Liu attach_cb(void *cb_ctx, const struct spdk_nvme_transport_id *trid,
3881551144SXiaodong Liu struct spdk_nvme_ctrlr *ctrlr, const struct spdk_nvme_ctrlr_opts *opts)
3981551144SXiaodong Liu {
4081551144SXiaodong Liu struct dev *dev;
4181551144SXiaodong Liu uint32_t nsid;
4281551144SXiaodong Liu
4381551144SXiaodong Liu /* add to dev list */
4481551144SXiaodong Liu dev = &g_nvme_devs[g_num_devs++];
4581551144SXiaodong Liu if (g_num_devs >= MAX_DEVS) {
4681551144SXiaodong Liu return;
4781551144SXiaodong Liu }
4881551144SXiaodong Liu
4981551144SXiaodong Liu dev->ctrlr = ctrlr;
5081551144SXiaodong Liu nsid = spdk_nvme_ctrlr_get_first_active_ns(ctrlr);
5181551144SXiaodong Liu dev->ns = spdk_nvme_ctrlr_get_ns(ctrlr, nsid);
52521bd911SMaciej Szwed
5381551144SXiaodong Liu dev->qpair = spdk_nvme_ctrlr_alloc_io_qpair(ctrlr, NULL, 0);
5481551144SXiaodong Liu if (dev->qpair == NULL) {
5581551144SXiaodong Liu g_failed = 1;
5681551144SXiaodong Liu return;
5781551144SXiaodong Liu }
5881551144SXiaodong Liu
5981551144SXiaodong Liu snprintf(dev->name, sizeof(dev->name), "%s",
6081551144SXiaodong Liu trid->traddr);
6181551144SXiaodong Liu
6281551144SXiaodong Liu printf("Attached to %s\n", dev->name);
6381551144SXiaodong Liu }
6481551144SXiaodong Liu
6581551144SXiaodong Liu int
main(int argc,char ** argv)6681551144SXiaodong Liu main(int argc, char **argv)
6781551144SXiaodong Liu {
6881551144SXiaodong Liu int ret;
6981551144SXiaodong Liu int i;
7021844100SShuhei Matsumoto struct spdk_nvme_detach_ctx *detach_ctx = NULL;
7181551144SXiaodong Liu
7281551144SXiaodong Liu printf("Starting DPDK initialization...\n");
7381551144SXiaodong Liu ret = rte_eal_init(argc, argv);
7481551144SXiaodong Liu if (ret < 0) {
7581551144SXiaodong Liu fprintf(stderr, "Failed to initialize DPDK\n");
7681551144SXiaodong Liu return -1;
7781551144SXiaodong Liu }
7881551144SXiaodong Liu
7981551144SXiaodong Liu printf("Starting SPDK post initialization...\n");
80396c445cSJim Harris ret = spdk_env_dpdk_post_init(false);
8181551144SXiaodong Liu if (ret < 0) {
8281551144SXiaodong Liu fprintf(stderr, "Failed to initialize SPDK\n");
8381551144SXiaodong Liu return -1;
8481551144SXiaodong Liu }
8581551144SXiaodong Liu
8681551144SXiaodong Liu printf("SPDK NVMe probe\n");
8781551144SXiaodong Liu if (spdk_nvme_probe(NULL, NULL, probe_cb, attach_cb, NULL) != 0) {
8881551144SXiaodong Liu fprintf(stderr, "spdk_nvme_probe() failed\n");
8981551144SXiaodong Liu return 1;
9081551144SXiaodong Liu }
9181551144SXiaodong Liu
9281551144SXiaodong Liu printf("Cleaning up...\n");
9381551144SXiaodong Liu for (i = 0; i < g_num_devs; i++) {
9481551144SXiaodong Liu struct dev *dev = &g_nvme_devs[i];
9521844100SShuhei Matsumoto spdk_nvme_detach_async(dev->ctrlr, &detach_ctx);
9621844100SShuhei Matsumoto }
9721844100SShuhei Matsumoto
9821844100SShuhei Matsumoto if (detach_ctx) {
9921844100SShuhei Matsumoto spdk_nvme_detach_poll(detach_ctx);
10081551144SXiaodong Liu }
10181551144SXiaodong Liu
10281551144SXiaodong Liu return g_failed;
10381551144SXiaodong Liu }
104