mirror of https://github.com/xemu-project/xemu.git
mem/cxl-type3: Add sn option to provide serial number for PCI ecap
The Device Serial Number Extended Capability PCI r6.0 sec 7.9.3 provides a standard way to provide a device serial number as an IEEE defined 64-bit extended unique identifier EUI-64. CXL 2.0 section 8.1.12.2 Memory Device PCIe Capabilities and Extended Capabilities requires this to be used to uniquely identify CXL memory devices. Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com> Message-Id: <20220923161835.9805-1-Jonathan.Cameron@huawei.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Reviewed-by: Ben Widawsky <bwidawsk@kernel.org>
This commit is contained in:
parent
0a17270761
commit
9c769e0446
|
@ -14,6 +14,12 @@
|
||||||
#include "sysemu/hostmem.h"
|
#include "sysemu/hostmem.h"
|
||||||
#include "hw/cxl/cxl.h"
|
#include "hw/cxl/cxl.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Null value of all Fs suggested by IEEE RA guidelines for use of
|
||||||
|
* EU, OUI and CID
|
||||||
|
*/
|
||||||
|
#define UI64_NULL ~(0ULL)
|
||||||
|
|
||||||
static void build_dvsecs(CXLType3Dev *ct3d)
|
static void build_dvsecs(CXLType3Dev *ct3d)
|
||||||
{
|
{
|
||||||
CXLComponentState *cxl_cstate = &ct3d->cxl_cstate;
|
CXLComponentState *cxl_cstate = &ct3d->cxl_cstate;
|
||||||
|
@ -149,7 +155,12 @@ static void ct3_realize(PCIDevice *pci_dev, Error **errp)
|
||||||
pci_config_set_class(pci_conf, PCI_CLASS_MEMORY_CXL);
|
pci_config_set_class(pci_conf, PCI_CLASS_MEMORY_CXL);
|
||||||
|
|
||||||
pcie_endpoint_cap_init(pci_dev, 0x80);
|
pcie_endpoint_cap_init(pci_dev, 0x80);
|
||||||
cxl_cstate->dvsec_offset = 0x100;
|
if (ct3d->sn != UI64_NULL) {
|
||||||
|
pcie_dev_ser_num_init(pci_dev, 0x100, ct3d->sn);
|
||||||
|
cxl_cstate->dvsec_offset = 0x100 + 0x0c;
|
||||||
|
} else {
|
||||||
|
cxl_cstate->dvsec_offset = 0x100;
|
||||||
|
}
|
||||||
|
|
||||||
ct3d->cxl_cstate.pdev = pci_dev;
|
ct3d->cxl_cstate.pdev = pci_dev;
|
||||||
build_dvsecs(ct3d);
|
build_dvsecs(ct3d);
|
||||||
|
@ -275,6 +286,7 @@ static Property ct3_props[] = {
|
||||||
HostMemoryBackend *),
|
HostMemoryBackend *),
|
||||||
DEFINE_PROP_LINK("lsa", CXLType3Dev, lsa, TYPE_MEMORY_BACKEND,
|
DEFINE_PROP_LINK("lsa", CXLType3Dev, lsa, TYPE_MEMORY_BACKEND,
|
||||||
HostMemoryBackend *),
|
HostMemoryBackend *),
|
||||||
|
DEFINE_PROP_UINT64("sn", CXLType3Dev, sn, UI64_NULL),
|
||||||
DEFINE_PROP_END_OF_LIST(),
|
DEFINE_PROP_END_OF_LIST(),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -237,6 +237,7 @@ struct CXLType3Dev {
|
||||||
/* Properties */
|
/* Properties */
|
||||||
HostMemoryBackend *hostmem;
|
HostMemoryBackend *hostmem;
|
||||||
HostMemoryBackend *lsa;
|
HostMemoryBackend *lsa;
|
||||||
|
uint64_t sn;
|
||||||
|
|
||||||
/* State */
|
/* State */
|
||||||
AddressSpace hostmem_as;
|
AddressSpace hostmem_as;
|
||||||
|
|
Loading…
Reference in New Issue