hw/cxl/device: Add a memory device (8.2.8.5)
authorBen Widawsky <ben.widawsky@intel.com>
Fri, 29 Apr 2022 14:40:42 +0000 (15:40 +0100)
committerMichael S. Tsirkin <mst@redhat.com>
Fri, 13 May 2022 10:13:36 +0000 (06:13 -0400)
commite1706ea83da0120be6708b66394ec3a9f3ec48ca
tree42ac4a2a145073d799d7264e95cde85b578a4565
parentd86d30192b7bc5a10fa6c82c073f55aea25f9291
hw/cxl/device: Add a memory device (8.2.8.5)

A CXL memory device (AKA Type 3) is a CXL component that contains some
combination of volatile and persistent memory. It also implements the
previously defined mailbox interface as well as the memory device
firmware interface.

Although the memory device is configured like a normal PCIe device, the
memory traffic is on an entirely separate bus conceptually (using the
same physical wires as PCIe, but different protocol).

Once the CXL topology is fully configure and address decoders committed,
the guest physical address for the memory device is part of a larger
window which is owned by the platform.  The creation of these windows
is later in this series.

The following example will create a 256M device in a 512M window:
-object "memory-backend-file,id=cxl-mem1,share,mem-path=cxl-type3,size=512M"
-device "cxl-type3,bus=rp0,memdev=cxl-mem1,id=cxl-pmem0"

Note: Dropped PCDIMM info interfaces for now.  They can be added if
appropriate at a later date.

Signed-off-by: Ben Widawsky <ben.widawsky@intel.com>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
Message-Id: <20220429144110.25167-18-Jonathan.Cameron@huawei.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
hw/cxl/cxl-component-utils.c
hw/cxl/cxl-mailbox-utils.c
hw/mem/Kconfig
hw/mem/cxl_type3.c [new file with mode: 0644]
hw/mem/meson.build
include/hw/cxl/cxl_device.h
include/hw/cxl/cxl_pci.h
include/hw/pci/pci_ids.h