1libnvme(9)                        API Manual                        libnvme(9)
2
3
4

NAME

6       struct nvme_id_ns - Identify Namespace data structure
7

SYNOPSIS

9       struct nvme_id_ns {
10           __le64 nsze;
11           __le64 ncap;
12           __le64 nuse;
13           __u8 nsfeat;
14           __u8 nlbaf;
15           __u8 flbas;
16           __u8 mc;
17           __u8 dpc;
18           __u8 dps;
19           __u8 nmic;
20           __u8 rescap;
21           __u8 fpi;
22           __u8 dlfeat;
23           __le16 nawun;
24           __le16 nawupf;
25           __le16 nacwu;
26           __le16 nabsn;
27           __le16 nabo;
28           __le16 nabspf;
29           __le16 noiob;
30           __u8 nvmcap[16];
31           __le16 npwg;
32           __le16 npwa;
33           __le16 npdg;
34           __le16 npda;
35           __le16 nows;
36           __le16 mssrl;
37           __le32 mcl;
38           __u8 msrc;
39           __u8 rsvd81;
40           __u8 nulbaf;
41           __u8 rsvd83[9];
42           __le32 anagrpid;
43           __u8 rsvd96[3];
44           __u8 nsattr;
45           __le16 nvmsetid;
46           __le16 endgid;
47           __u8 nguid[16];
48           __u8 eui64[8];
49           struct nvme_lbaf        lbaf[64];
50           __le64 lbstm;
51           __u8 vs[3704];
52        };
53
54

Members

56       nsze        Namespace Size indicates the total size of the namespace in
57                   logical blocks. The number of logical blocks  is  based  on
58                   the formatted LBA size.
59
60       ncap        Namespace  Capacity indicates the maximum number of logical
61                   blocks that may be allocated in the namespace at any  point
62                   in  time. The number of logical blocks is based on the for‐
63                   matted LBA size.
64
65       nuse        Namespace Utilization indicates the current number of logi‐
66                   cal  blocks  allocated  in  the  namespace.  This  field is
67                   smaller than or equal to the Namespace Capacity. The number
68                   of logical blocks is based on the formatted LBA size.
69
70       nsfeat      Namespace Features, see enum nvme_id_nsfeat.
71
72       nlbaf       Number  of  LBA Formats defines the number of supported LBA
73                   data size and metadata size combinations supported  by  the
74                   namespace   and   the  highest  possible  index  to  struct
75                   nvme_id_ns.lbaf.
76
77       flbas       Formatted LBA Size, see enum nvme_id_ns_flbas.
78
79       mc          Metadata Capabilities, see enum nvme_id_ns_mc.
80
81       dpc         End-to-end   Data   Protection   Capabilities,   see   enum
82                   nvme_id_ns_dpc.
83
84       dps         End-to-end   Data   Protection   Type  Settings,  see  enum
85                   nvme_id_ns_dps.
86
87       nmic        Namespace Multi-path I/O and  Namespace  Sharing  Capabili‐
88                   ties, see enum nvme_id_ns_nmic.
89
90       rescap      Reservation Capabilities, see enum nvme_id_ns_rescap.
91
92       fpi         Format Progress Indicator, see enum nvme_nd_ns_fpi.
93
94       dlfeat      Deallocate     Logical    Block    Features,    see    enum
95                   nvme_id_ns_dlfeat.
96
97       nawun       Namespace Atomic Write Unit Normal indicates the  namespace
98                   specific size of the write operation guaranteed to be writ‐
99                   ten atomically to the NVM during normal operation.
100
101       nawupf      Namespace Atomic Write Unit Power Fail indicates the  name‐
102                   space specific size of the write operation guaranteed to be
103                   written atomically to the NVM during a power fail or  error
104                   condition.
105
106       nacwu       Namespace  Atomic  Compare & Write Unit indicates the name‐
107                   space specific size of the write operation guaranteed to be
108                   written atomically to the NVM for a Compare and Write fused
109                   command.
110
111       nabsn       Namespace Atomic Boundary Size Normal indicates the  atomic
112                   boundary  size for this namespace for the NAWUN value. This
113                   field is specified in logical blocks.
114
115       nabo        Namespace Atomic Boundary Offset indicates the LBA on  this
116                   namespace where the first atomic boundary starts.
117
118       nabspf      Namespace  Atomic  Boundary  Size  Power Fail indicates the
119                   atomic boundary size for this  namespace  specific  to  the
120                   Namespace Atomic Write Unit Power Fail value. This field is
121                   specified in logical blocks.
122
123       noiob       Namespace Optimal I/O Boundary indicates  the  optimal  I/O
124                   boundary  for  this  namespace.  This field is specified in
125                   logical blocks.  The host should construct Read  and  Write
126                   commands  that do not cross the I/O boundary to achieve op‐
127                   timal performance.
128
129       nvmcap      NVM Capacity indicates the total size of the NVM  allocated
130                   to this namespace. The value is in bytes.
131
132       npwg        Namespace  Preferred Write Granularity indicates the small‐
133                   est recommended write granularity  in  logical  blocks  for
134                   this namespace. This is a 0's based value.
135
136       npwa        Namespace  Preferred  Write  Alignment indicates the recom‐
137                   mended write alignment in logical  blocks  for  this  name‐
138                   space. This is a 0's based value.
139
140       npdg        Namespace  Preferred  Deallocate  Granularity indicates the
141                   recommended granularity in logical blocks for  the  Dataset
142                   Management command with the Attribute - Deallocate bit.
143
144       npda        Namespace Preferred Deallocate Alignment indicates the rec‐
145                   ommended alignment in logical blocks for the  Dataset  Man‐
146                   agement command with the Attribute - Deallocate bit
147
148       nows        Namespace  Optimal Write Size indicates the size in logical
149                   blocks for optimal write performance  for  this  namespace.
150                   This is a 0's based value.
151
152       mssrl       Maximum  Single  Source  Range Length indicates the maximum
153                   number of logical blocks that  may  be  specified  in  each
154                   valid Source Range field of a Copy command.
155
156       mcl         Maximum Copy Length indicates the maximum number of logical
157                   blocks that may be specified in a Copy command.
158
159       msrc        Maximum Source Range Count indicates the maximum number  of
160                   Source  Range  entries  that  may be used to specify source
161                   data in a Copy command. This is a 0’s based value.
162
163       rsvd81      Reserved
164
165       nulbaf      Number of Unique Capability LBA Formats defines the  number
166                   of  supported user data size and metadata size combinations
167                   supported by the namespace that may not share the same  ca‐
168                   pabilities.  LBA  formats  shall  be allocated in order and
169                   packed sequentially.
170
171       rsvd83      Reserved
172
173       anagrpid    ANA Group Identifier indicates the ANA Group Identifier  of
174                   the ANA group of which the namespace is a member.
175
176       rsvd96      Reserved
177
178       nsattr      Namespace Attributes, see enum nvme_id_ns_attr.
179
180       nvmsetid    NVM  Set  Identifier  indicates the NVM Set with which this
181                   namespace is associated.
182
183       endgid      Endurance Group Identifier indicates  the  Endurance  Group
184                   with which this namespace is associated.
185
186       nguid       Namespace  Globally  Unique  Identifier  contains a 128-bit
187                   value that is globally unique and assigned to the namespace
188                   when  the  namespace  is  created. This field remains fixed
189                   throughout the life  of  the  namespace  and  is  preserved
190                   across namespace and controller operations
191
192       eui64       IEEE  Extended Unique Identifier contains a 64-bit IEEE Ex‐
193                   tended Unique Identifier (EUI-64) that is  globally  unique
194                   and  assigned  to  the namespace when the namespace is cre‐
195                   ated. This field remains fixed throughout the life  of  the
196                   namespace  and is preserved across namespace and controller
197                   operations
198
199       lbaf        LBA Format, see struct nvme_lbaf.
200
201       lbstm       Logical Block Storage Tag Mask for end-to-end protection
202
203       vs          Vendor Specific
204
205
206
207April 2023                     struct nvme_id_ns                    libnvme(9)
Impressum