static void log_test(void) { int rc = 0; rc = spdk_set_log_facility("test"); CU_ASSERT(rc == -1); rc = spdk_set_log_facility("local7"); CU_ASSERT(rc == 0); rc = spdk_set_log_priority("test"); CU_ASSERT(rc == -1); rc = spdk_set_log_priority("debug"); CU_ASSERT(rc == 0); #ifdef DEBUG CU_ASSERT(spdk_log_get_trace_flag("debug") == false); spdk_log_set_trace_flag("debug"); CU_ASSERT(spdk_log_get_trace_flag("debug") == true); spdk_log_clear_trace_flag("debug"); CU_ASSERT(spdk_log_get_trace_flag("debug") == false); #endif spdk_open_log(); spdk_log_set_trace_flag("debug"); SPDK_WARNLOG("log warning unit test\n"); SPDK_TRACELOG(SPDK_TRACE_DEBUG, "log trace test\n"); SPDK_TRACEDUMP(SPDK_TRACE_DEBUG, "log trace dump test:", "trace dump", 10); spdk_trace_dump("spdk dump test:", "spdk dump", 9); spdk_close_log(); }
static void spdk_rpc_set_trace_flag(struct spdk_jsonrpc_server_conn *conn, const struct spdk_json_val *params, const struct spdk_json_val *id) { struct rpc_trace_flag req = {}; struct spdk_json_write_ctx *w; if (spdk_json_decode_object(params, rpc_trace_flag_decoders, sizeof(rpc_trace_flag_decoders) / sizeof(*rpc_trace_flag_decoders), &req)) { SPDK_TRACELOG(SPDK_TRACE_DEBUG, "spdk_json_decode_object failed\n"); goto invalid; } if (req.flag == 0) { SPDK_TRACELOG(SPDK_TRACE_DEBUG, "flag was 0\n"); goto invalid; } spdk_log_set_trace_flag(req.flag); free_rpc_trace_flag(&req); if (id == NULL) { return; } w = spdk_jsonrpc_begin_result(conn, id); spdk_json_write_bool(w, true); spdk_jsonrpc_end_result(conn, w); return; invalid: spdk_jsonrpc_send_error_response(conn, id, SPDK_JSONRPC_ERROR_INVALID_PARAMS, "Invalid parameters"); free_rpc_trace_flag(&req); }
int main(int argc, char **argv) { int ch; int rc; struct spdk_app_opts opts = {}; /* default value in opts */ spdk_app_opts_init(&opts); opts.name = "nvmf"; opts.config_file = SPDK_NVMF_DEFAULT_CONFIG; while ((ch = getopt(argc, argv, "c:de:i:l:m:n:p:qs:t:DH")) != -1) { switch (ch) { case 'd': opts.enable_coredump = false; break; case 'c': opts.config_file = optarg; break; case 'i': opts.instance_id = atoi(optarg); break; case 'l': opts.log_facility = optarg; break; case 't': rc = spdk_log_set_trace_flag(optarg); if (rc < 0) { fprintf(stderr, "unknown flag\n"); usage(); exit(EXIT_FAILURE); } #ifndef DEBUG fprintf(stderr, "%s must be rebuilt with CONFIG_DEBUG=y for -t flag.\n", argv[0]); usage(); exit(EXIT_FAILURE); #endif break; case 'm': opts.reactor_mask = optarg; break; case 'n': opts.dpdk_mem_channel = atoi(optarg); break; case 'p': opts.dpdk_master_core = atoi(optarg); break; case 's': opts.dpdk_mem_size = atoi(optarg); break; case 'e': opts.tpoint_group_mask = optarg; break; case 'q': spdk_g_notice_stderr_flag = 0; break; case 'D': case 'H': default: usage(); exit(EXIT_SUCCESS); } } if (spdk_g_notice_stderr_flag == 1 && isatty(STDERR_FILENO) && !strncmp(ttyname(STDERR_FILENO), "/dev/tty", strlen("/dev/tty"))) { printf("Warning: printing stderr to console terminal without -q option specified.\n"); printf("Suggest using -q to disable logging to stderr and monitor syslog, or\n"); printf("redirect stderr to a file.\n"); printf("(Delaying for 10 seconds...)\n"); sleep(10); } opts.shutdown_cb = spdk_nvmf_shutdown_cb; spdk_app_init(&opts); printf("Total cores available: %d\n", rte_lcore_count()); /* Blocks until the application is exiting */ rc = spdk_app_start(spdk_nvmf_startup, NULL, NULL); spdk_app_fini(); return rc; }