xref: /netbsd-src/sbin/nvmectl/nvmectl.h (revision e66f4605a1ac8e93e0da0c410a7beb388f0109bf)
1*e66f4605Smlelstv /*	$NetBSD: nvmectl.h,v 1.10 2023/02/02 08:21:32 mlelstv Exp $	*/
2cae3c2f4Snonaka 
3cae3c2f4Snonaka /*-
41f5086ecSnonaka  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
51f5086ecSnonaka  *
6cae3c2f4Snonaka  * Copyright (C) 2012-2013 Intel Corporation
7cae3c2f4Snonaka  * All rights reserved.
8cae3c2f4Snonaka  *
9cae3c2f4Snonaka  * Redistribution and use in source and binary forms, with or without
10cae3c2f4Snonaka  * modification, are permitted provided that the following conditions
11cae3c2f4Snonaka  * are met:
12cae3c2f4Snonaka  * 1. Redistributions of source code must retain the above copyright
13cae3c2f4Snonaka  *    notice, this list of conditions and the following disclaimer.
14cae3c2f4Snonaka  * 2. Redistributions in binary form must reproduce the above copyright
15cae3c2f4Snonaka  *    notice, this list of conditions and the following disclaimer in the
16cae3c2f4Snonaka  *    documentation and/or other materials provided with the distribution.
17cae3c2f4Snonaka  *
18cae3c2f4Snonaka  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
19cae3c2f4Snonaka  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20cae3c2f4Snonaka  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21cae3c2f4Snonaka  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
22cae3c2f4Snonaka  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23cae3c2f4Snonaka  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24cae3c2f4Snonaka  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25cae3c2f4Snonaka  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26cae3c2f4Snonaka  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27cae3c2f4Snonaka  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
28cae3c2f4Snonaka  * SUCH DAMAGE.
29cae3c2f4Snonaka  *
301f5086ecSnonaka  * $FreeBSD: head/sbin/nvmecontrol/nvmecontrol.h 326276 2017-11-27 15:37:16Z pfg $
31cae3c2f4Snonaka  */
32cae3c2f4Snonaka 
33cae3c2f4Snonaka #ifndef __NVMECTL_H__
34cae3c2f4Snonaka #define __NVMECTL_H__
35cae3c2f4Snonaka 
36cae3c2f4Snonaka #include <sys/ioctl.h>
37cae3c2f4Snonaka 
38cae3c2f4Snonaka #include <dev/ic/nvmeio.h>
39cae3c2f4Snonaka #include "nvme.h"
40cae3c2f4Snonaka 
41d003492fSnonaka typedef void (*nvme_fn_t)(int argc, char *argv[]);
42d003492fSnonaka 
43d003492fSnonaka struct nvme_function {
44d003492fSnonaka 	const char	*name;
45d003492fSnonaka 	nvme_fn_t	fn;
46d003492fSnonaka 	const char	*usage;
47d003492fSnonaka };
48d003492fSnonaka 
49cae3c2f4Snonaka #define NVME_CTRLR_PREFIX	"nvme"
50cae3c2f4Snonaka #define NVME_NS_PREFIX		"ns"
51cae3c2f4Snonaka 
52cae3c2f4Snonaka #define DEVLIST_USAGE							       \
53f24079baSjdolecek "devlist\n"
54cae3c2f4Snonaka 
55cae3c2f4Snonaka #define IDENTIFY_USAGE							       \
56d2ae75c2Snonaka "identify [-x [-v]] <controller_id|namespace_id>\n"
57cae3c2f4Snonaka 
581f5086ecSnonaka #ifdef ENABLE_PREFTEST
59cae3c2f4Snonaka #define PERFTEST_USAGE							       \
60f24079baSjdolecek "perftest <-n num_threads> <-o read|write>\n"				       \
61cae3c2f4Snonaka "                        <-s size_in_bytes> <-t time_in_seconds>\n"	       \
62cae3c2f4Snonaka "                        <-i intr|wait> [-f refthread] [-p]\n"		       \
63d2ae75c2Snonaka "                        <namespace_id>\n"
64cae3c2f4Snonaka #endif
65cae3c2f4Snonaka 
661f5086ecSnonaka #ifdef ENABLE_RESET
67cae3c2f4Snonaka #define RESET_USAGE							       \
68f24079baSjdolecek "reset <controller id>\n"
69cae3c2f4Snonaka #endif
70cae3c2f4Snonaka 
71cae3c2f4Snonaka #define LOGPAGE_USAGE							       \
72f24079baSjdolecek "logpage <-p page_id> [-b] [-v vendor] [-x] "				       \
73d2ae75c2Snonaka     "<controller_id|namespace_id>\n"
74cae3c2f4Snonaka 
751f5086ecSnonaka #ifdef ENABLE_FIRMWARE
76cae3c2f4Snonaka #define FIRMWARE_USAGE							       \
77d2ae75c2Snonaka "firmware [-s slot] [-f path_to_firmware] [-a] <controller_id>\n"
78cae3c2f4Snonaka #endif
79cae3c2f4Snonaka 
80cae3c2f4Snonaka #define POWER_USAGE							       \
816eddb6bbSjdolecek "power [-l] [[-s] -p new-state [-w workload-hint]] <controller_id>\n"
82cae3c2f4Snonaka 
83d003492fSnonaka #define WDC_USAGE							       \
84605c860bSnonaka "wdc cap-diag [-o path-templete]\n"
85d003492fSnonaka 
860eed2a94Sjoerg void devlist(int, char *[]) __dead;
870eed2a94Sjoerg void identify(int, char *[]) __dead;
88cae3c2f4Snonaka #ifdef PERFTEST_USAGE
89d003492fSnonaka void perftest(int, char *[]) __dead;
90cae3c2f4Snonaka #endif
91cae3c2f4Snonaka #ifdef RESET_USAGE
92d003492fSnonaka void reset(int, char *[]) __dead;
93cae3c2f4Snonaka #endif
940eed2a94Sjoerg void logpage(int, char *[]) __dead;
95cae3c2f4Snonaka #ifdef FIRMWARE_USAGE
96d003492fSnonaka void firmware(int, char *[]) __dead;
97cae3c2f4Snonaka #endif
980eed2a94Sjoerg void power(int, char *[]) __dead;
99d003492fSnonaka void wdc(int, char *[]) __dead;
100cae3c2f4Snonaka 
101cae3c2f4Snonaka int open_dev(const char *, int *, int, int);
102cae3c2f4Snonaka void parse_ns_str(const char *, char *, int *);
103cae3c2f4Snonaka void read_controller_data(int, struct nvm_identify_controller *);
104cae3c2f4Snonaka void read_namespace_data(int, int, struct nvm_identify_namespace *);
105cae3c2f4Snonaka void print_hex(void *, uint32_t);
106cae3c2f4Snonaka void read_logpage(int, uint8_t, int, void *, uint32_t);
107f24079baSjdolecek __dead void dispatch(int argc, char *argv[], const struct nvme_function *f);
1081f5086ecSnonaka 
1091f5086ecSnonaka /* Utility Routines */
110cae3c2f4Snonaka void nvme_strvis(uint8_t *, int, const uint8_t *, int);
1111f5086ecSnonaka void print_bignum(const char *, uint64_t v[2], const char *);
112*e66f4605Smlelstv void print_bignum1(const char *, uint64_t v[2], const char *, const char *, long);
1131f5086ecSnonaka uint64_t le48dec(const void *);
114cae3c2f4Snonaka 
115cae3c2f4Snonaka #endif	/* __NVMECTL_H__ */
116