Skip to content

Commit

Permalink
hw/nvme: default for namespace EUI-64
Browse files Browse the repository at this point in the history
On machines with version > 6.0 replace a missing EUI-64 by a generated
value.

Signed-off-by: Heinrich Schuchardt <[email protected]>
Reviewed-by: Klaus Jensen <[email protected]>
  • Loading branch information
xypron authored and birkelund committed Jun 29, 2021
1 parent 6870cfb commit 3276dde
Show file tree
Hide file tree
Showing 4 changed files with 14 additions and 0 deletions.
2 changes: 2 additions & 0 deletions docs/system/nvme.rst
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,8 @@ There are a number of parameters available:
``eui64``
Set the EUI-64 of the namespace. This will be reported as a "IEEE Extended
Unique Identifier" descriptor in the Namespace Identification Descriptor List.
Since machine type 6.1 a non-zero default value is used if the parameter
is not provided. For earlier machine types the field defaults to 0.

``bus``
If there are more ``nvme`` devices defined, this parameter may be used to
Expand Down
1 change: 1 addition & 0 deletions hw/core/machine.c
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@
GlobalProperty hw_compat_6_0[] = {
{ "gpex-pcihost", "allow-unmapped-accesses", "false" },
{ "i8042", "extended-state", "false"},
{ "nvme-ns", "eui64-default", "off"},
};
const size_t hw_compat_6_0_len = G_N_ELEMENTS(hw_compat_6_0);

Expand Down
9 changes: 9 additions & 0 deletions hw/nvme/ns.c
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ void nvme_ns_init_format(NvmeNamespace *ns)

static int nvme_ns_init(NvmeNamespace *ns, Error **errp)
{
static uint64_t ns_count;
NvmeIdNs *id_ns = &ns->id_ns;
uint8_t ds;
uint16_t ms;
Expand All @@ -73,6 +74,12 @@ static int nvme_ns_init(NvmeNamespace *ns, Error **errp)
id_ns->nmic |= NVME_NMIC_NS_SHARED;
}

/* Substitute a missing EUI-64 by an autogenerated one */
++ns_count;
if (!ns->params.eui64 && ns->params.eui64_default) {
ns->params.eui64 = ns_count + NVME_EUI64_DEFAULT;
}

/* simple copy */
id_ns->mssrl = cpu_to_le16(ns->params.mssrl);
id_ns->mcl = cpu_to_le32(ns->params.mcl);
Expand Down Expand Up @@ -533,6 +540,8 @@ static Property nvme_ns_props[] = {
params.max_open_zones, 0),
DEFINE_PROP_UINT32("zoned.descr_ext_size", NvmeNamespace,
params.zd_extension_size, 0),
DEFINE_PROP_BOOL("eui64-default", NvmeNamespace, params.eui64_default,
true),
DEFINE_PROP_END_OF_LIST(),
};

Expand Down
2 changes: 2 additions & 0 deletions hw/nvme/nvme.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@

#define NVME_MAX_CONTROLLERS 32
#define NVME_MAX_NAMESPACES 256
#define NVME_EUI64_DEFAULT ((uint64_t)0x5254000000000000)

typedef struct NvmeCtrl NvmeCtrl;
typedef struct NvmeNamespace NvmeNamespace;
Expand Down Expand Up @@ -84,6 +85,7 @@ typedef struct NvmeNamespaceParams {
uint32_t nsid;
QemuUUID uuid;
uint64_t eui64;
bool eui64_default;

uint16_t ms;
uint8_t mset;
Expand Down

0 comments on commit 3276dde

Please sign in to comment.