[edk2-devel] [PATCH V3 1/2] MdePkg/Include/IndustryStandard: CXL 1.1 Registers

Michael D Kinney michael.d.kinney at intel.com
Fri Jul 24 17:11:40 UTC 2020


Hi Ashraf,

I agree with Liming's feedback.  Please make those updates
and resend the patch series and either Liming or I can
do the commits.

With changes requested:

Reviewed-by: Michael D Kinney <michael.d.kinney at intel.com>

Mike

> -----Original Message-----
> From: Javeed, Ashraf <ashraf.javeed at intel.com>
> Sent: Thursday, July 23, 2020 4:58 AM
> To: Gao, Liming <liming.gao at intel.com>;
> devel at edk2.groups.io
> Cc: Kinney, Michael D <michael.d.kinney at intel.com>
> Subject: RE: [edk2-devel] [PATCH V3 1/2]
> MdePkg/Include/IndustryStandard: CXL 1.1 Registers
> 
> Liming;
> My response inline.
> 
> Thanks for the review.
> Ashraf
> 
> > -----Original Message-----
> > From: Gao, Liming <liming.gao at intel.com>
> > Sent: Thursday, July 23, 2020 3:36 PM
> > To: devel at edk2.groups.io; Javeed, Ashraf
> <ashraf.javeed at intel.com>
> > Cc: Kinney, Michael D <michael.d.kinney at intel.com>
> > Subject: RE: [edk2-devel] [PATCH V3 1/2]
> MdePkg/Include/IndustryStandard:
> > CXL 1.1 Registers
> >
> > Ashraf:
> >
> > -----Original Message-----
> > From: devel at edk2.groups.io <devel at edk2.groups.io> On
> Behalf Of Javeed,
> > Ashraf
> > Sent: 2020年7月22日 23:22
> > To: devel at edk2.groups.io
> > Cc: Kinney, Michael D <michael.d.kinney at intel.com>;
> Gao, Liming
> > <liming.gao at intel.com>
> > Subject: [edk2-devel] [PATCH V3 1/2]
> MdePkg/Include/IndustryStandard: CXL 1.1
> > Registers
> >
> > BZ:
> https://bugzilla.tianocore.org/show_bug.cgi?id=2611
> >
> > Register definitions from chapter 7 of Compute
> Express Link Specification
> > Revision 1.1 are ported into the new Cxl11.h.
> > The CXL Flex Bus registers are based on the PCIe
> Extended Capability DVSEC
> > structure header, led to the inclusion of upgraded
> Pci.h.
> >
> > Signed-off-by: Ashraf Javeed
> <ashraf.javeed at intel.com>
> > Cc: Michael D Kinney <michael.d.kinney at intel.com>
> > Cc: Liming Gao <liming.gao at intel.com>
> > --
> >
> > V2: Indentation and double declaration fix, copyright
> date update
> >
> > V3: Copyright date fix
> > ---
> >  MdePkg/Include/IndustryStandard/Cxl11.h | 569
> >
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++
> >
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++
> >
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++
> >
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++
> >
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++
> >
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++
> >
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++
> >
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++
> > +++++++++++++++++++++++++++++++++++++++++++++++++
> >  MdePkg/Include/IndustryStandard/Pci.h   |   6 ++----
> >  2 files changed, 571 insertions(+), 4 deletions(-)
> >
> > diff --git a/MdePkg/Include/IndustryStandard/Cxl11.h
> > b/MdePkg/Include/IndustryStandard/Cxl11.h
> > new file mode 100644
> > index 0000000000..a261bb3fae
> > --- /dev/null
> > +++ b/MdePkg/Include/IndustryStandard/Cxl11.h
> > @@ -0,0 +1,569 @@
> > +/** @file
> > +  CXL 1.1 Register definitions
> > +
> > +  This file contains the register definitions based
> on the Compute
> > + Express Link
> > +  (CXL) Specification Revision 1.1.
> > +
> > +Copyright (c) 2020, Intel Corporation. All rights
> reserved.<BR>
> > +SPDX-License-Identifier: BSD-2-Clause-Patent
> > +
> > +**/
> > +
> > +#ifndef _CXL11_H_
> > +#define _CXL11_H_
> > +
> > +#include <IndustryStandard/Pci.h>
> > +//
> > +// DVSEC Vendor ID
> > +// Compute Express Link Specification Revision: 1.1
> - Chapter 7.1.1 -
> > +Table 58 // (subject to change as per CXL assigned
> Vendor ID) //
> > +#define INTEL_CXL_DVSEC_VENDOR_ID
> 0x8086
> > +
> > +//
> > +// CXL Flex Bus Device default device and function
> number // Compute
> > +Express Link Specification Revision: 1.1 - Chapter
> 7.1.1 //
> > +#define CXL_DEV_DEV
> 0
> > +#define CXL_DEV_FUNC
> 0
> > +
> > +//
> > +// Ensure proper structure formats
> > +//
> > +#pragma pack(1)
> > +
> > +///
> > +/// The PCIe DVSEC for Flex Bus Device
> > +///@{
> > +typedef union {
> > +  struct {
> > +    UINT16 CacheCapable
> : 1; // bit 0
> > +    UINT16 IoCapable
> : 1; // bit 1
> > +    UINT16 MemCapable
> : 1; // bit 2
> > +    UINT16 MemHwInitMode
> : 1; // bit 3
> > +    UINT16 HdmCount
> : 2; // bit 4..5
> > +    UINT16 Reserved1
> : 8; // bit 6..13
> > +    UINT16 ViralCapable
> : 1; // bit 14
> > +    UINT16 Reserved2
> : 1; // bit 15
> > +  }Bits;
> >
> > This line should have one space between } and Bits.
> Otherwise, ECC will report
> > the issue.
> > Please fix it in this header file.
> >
> > }Bits ==> } Bits
> >
> > Thanks
> > Liming
> I did run the ECC Python script and it did not report
> any issues.
> I shall check again and make the fixed if required.
> 
> > +  UINT16
> Uint16;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_CAPABILITY;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT16 CacheEnable
> : 1; // bit 0
> > +    UINT16 IoEnable
> : 1; // bit 1
> > +    UINT16 MemEnable
> : 1; // bit 2
> > +    UINT16 CacheSfCoverage
> : 5; // bit 3..7
> > +    UINT16 CacheSfGranularity
> : 3; // bit 8..10
> > +    UINT16 CacheCleanEviction
> : 1; // bit 11
> > +    UINT16 Reserved1
> : 2; // bit 12..13
> > +    UINT16 ViralEnable
> : 1; // bit 14
> > +    UINT16 Reserved2
> : 1; // bit 15
> > +  }Bits;
> > +  UINT16
> Uint16;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_CONTROL;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT16 Reserved1
> : 14; // bit 0..13
> > +    UINT16 ViralStatus
> : 1;  // bit 14
> > +    UINT16 Reserved2
> : 1;  // bit 15
> > +  }Bits;
> > +  UINT16
> Uint16;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_STATUS;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT16 Reserved1
> : 1;  // bit 0
> > +    UINT16 Reserved2
> : 1;  // bit 1
> > +    UINT16 Reserved3
> : 1;  // bit 2
> > +    UINT16 Reserved4
> : 13; // bit 3..15
> > +  }Bits;
> > +  UINT16
> Uint16;
> > +} CXL_1_1_DVSEC_FLEX_BUS_DEVICE_CONTROL2;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT16 Reserved1
> : 1;  // bit 0
> > +    UINT16 Reserved2
> : 1;  // bit 1
> > +    UINT16 Reserved3
> : 14; // bit 2..15
> > +  }Bits;
> > +  UINT16
> Uint16;
> > +} CXL_1_1_DVSEC_FLEX_BUS_DEVICE_STATUS2;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT16 ConfigLock
> : 1;  // bit 0
> > +    UINT16 Reserved1
> : 15; // bit 1..15
> > +  }Bits;
> > +  UINT16
> Uint16;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_LOCK;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 MemorySizeHigh
> : 32; // bit 0..31
> > +  }Bits;
> > +  UINT32
> Uint32;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_RANGE1_SIZE_HIGH;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 MemoryInfoValid
> : 1;  // bit 0
> > +    UINT32 MemoryActive
> : 1;  // bit 1
> > +    UINT32 MediaType
> : 3;  // bit 2..4
> > +    UINT32 MemoryClass
> : 3;  // bit 5..7
> > +    UINT32 DesiredInterleave
> : 3;  // bit 8..10
> > +    UINT32 Reserved
> : 17; // bit 11..27
> > +    UINT32 MemorySizeLow
> : 4;  // bit 28..31
> > +  }Bits;
> > +  UINT32
> Uint32;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_RANGE1_SIZE_LOW;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 MemoryBaseHigh
> : 32; // bit 0..31
> > +  }Bits;
> > +  UINT32
> Uint32;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_RANGE1_BASE_HIGH;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 Reserved
> : 28; // bit 0..27
> > +    UINT32 MemoryBaseLow
> : 4;  // bit 28..31
> > +  }Bits;
> > +  UINT32
> Uint32;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_RANGE1_BASE_LOW;
> > +
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 MemorySizeHigh
> : 32; // bit 0..31
> > +  }Bits;
> > +  UINT32
> Uint32;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_RANGE2_SIZE_HIGH;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 MemoryInfoValid
> : 1;  // bit 0
> > +    UINT32 MemoryActive
> : 1;  // bit 1
> > +    UINT32 MediaType
> : 3;  // bit 2..4
> > +    UINT32 MemoryClass
> : 3;  // bit 5..7
> > +    UINT32 DesiredInterleave
> : 3;  // bit 8..10
> > +    UINT32 Reserved
> : 17; // bit 11..27
> > +    UINT32 MemorySizeLow
> : 4;  // bit 28..31
> > +  }Bits;
> > +  UINT32
> Uint32;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_RANGE2_SIZE_LOW;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 MemoryBaseHigh
> : 32; // bit 0..31
> > +  }Bits;
> > +  UINT32
> Uint32;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_RANGE2_BASE_HIGH;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 Reserved
> : 28; // bit 0..27
> > +    UINT32 MemoryBaseLow
> : 4;  // bit 28..31
> > +  }Bits;
> > +  UINT32
> Uint32;
> > +} CXL_DVSEC_FLEX_BUS_DEVICE_RANGE2_BASE_LOW;
> > +
> > +//
> > +// Flex Bus Device DVSEC ID
> > +// Compute Express Link Specification Revision: 1.1
> - Chapter 7.1.1,
> > +Table 58 //
> > +#define FLEX_BUS_DEVICE_DVSEC_ID
> 0
> > +
> > +//
> > +// PCIe DVSEC for Flex Bus Device
> > +// Compute Express Link Specification Revision: 1.1
> - Chapter 7.1.1,
> > +Figure 95 // typedef struct {
> > +  PCI_EXPRESS_EXTENDED_CAPABILITIES_HEADER
> Header;
> > // offset 0
> > +  PCI_EXPRESS_DESIGNATED_VENDOR_SPECIFIC_HEADER_1
> > DesignatedVendorSpecificHeader1;  // offset 4
> > +  PCI_EXPRESS_DESIGNATED_VENDOR_SPECIFIC_HEADER_2
> > DesignatedVendorSpecificHeader2;  // offset 8
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_CAPABILITY
> DeviceCapability;
> > // offset 10
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_CONTROL
> DeviceControl;
> > // offset 12
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_STATUS
> DeviceStatus;
> > // offset 14
> > +  CXL_1_1_DVSEC_FLEX_BUS_DEVICE_CONTROL2
> DeviceControl2;
> > // offset 16
> > +  CXL_1_1_DVSEC_FLEX_BUS_DEVICE_STATUS2
> DeviceStatus2;
> > // offset 18
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_LOCK
> DeviceLock;
> > // offset 20
> > +  UINT16
> Reserved;                         // offset 22
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_RANGE1_SIZE_HIGH
> > DeviceRange1SizeHigh;             // offset 24
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_RANGE1_SIZE_LOW
> > DeviceRange1SizeLow;              // offset 28
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_RANGE1_BASE_HIGH
> > DeviceRange1BaseHigh;             // offset 32
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_RANGE1_BASE_LOW
> > DeviceRange1BaseLow;              // offset 36
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_RANGE2_SIZE_HIGH
> > DeviceRange2SizeHigh;             // offset 40
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_RANGE2_SIZE_LOW
> > DeviceRange2SizeLow;              // offset 44
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_RANGE2_BASE_HIGH
> > DeviceRange2BaseHigh;             // offset 48
> > +  CXL_DVSEC_FLEX_BUS_DEVICE_RANGE2_BASE_LOW
> > DeviceRange2BaseLow;              // offset 52
> > +} CXL_1_1_DVSEC_FLEX_BUS_DEVICE;
> > +///@}
> > +
> > +///
> > +/// PCIe DVSEC for FLex Bus Port
> > +///@{
> > +typedef union {
> > +  struct {
> > +    UINT16 CacheCapable
> : 1;  // bit 0
> > +    UINT16 IoCapable
> : 1;  // bit 1
> > +    UINT16 MemCapable
> : 1;  // bit 2
> > +    UINT16 Reserved
> : 13; // bit 3..15
> > +  }Bits;
> > +  UINT16
> Uint16;
> > +} CXL_1_1_DVSEC_FLEX_BUS_PORT_CAPABILITY;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT16 CacheEnable
> : 1; // bit 0
> > +    UINT16 IoEnable
> : 1; // bit 1
> > +    UINT16 MemEnable
> : 1; // bit 2
> > +    UINT16 CxlSyncBypassEnable
> : 1; // bit 3
> > +    UINT16 DriftBufferEnable
> : 1; // bit 4
> > +    UINT16 Reserved
> : 3; // bit 5..7
> > +    UINT16 Retimer1Present
> : 1; // bit 8
> > +    UINT16 Retimer2Present
> : 1; // bit 9
> > +    UINT16 Reserved2
> : 6; // bit 10..15
> > +  }Bits;
> > +  UINT16
> Uint16;
> > +} CXL_1_1_DVSEC_FLEX_BUS_PORT_CONTROL;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT16 CacheEnable
> : 1; // bit 0
> > +    UINT16 IoEnable
> : 1; // bit 1
> > +    UINT16 MemEnable
> : 1; // bit 2
> > +    UINT16 CxlSyncBypassEnable
> : 1; // bit 3
> > +    UINT16 DriftBufferEnable
> : 1; // bit 4
> > +    UINT16 Reserved
> : 3; // bit 5..7
> > +    UINT16 CxlCorrectableProtocolIdFramingError
> : 1; // bit 8
> > +    UINT16 CxlUncorrectableProtocolIdFramingError
> : 1; // bit 9
> > +    UINT16 CxlUnexpectedProtocolIdDropped
> : 1; // bit 10
> > +    UINT16 Reserved2
> : 5; // bit 11..15
> > +  }Bits;
> > +  UINT16
> Uint16;
> > +} CXL_1_1_DVSEC_FLEX_BUS_PORT_STATUS;
> > +
> > +//
> > +// Flex Bus Port DVSEC ID
> > +// Compute Express Link Specification Revision: 1.1
> - Chapter 7.2.1.3,
> > +Table 62 //
> > +#define FLEX_BUS_PORT_DVSEC_ID
> 7
> > +
> > +//
> > +// PCIe DVSEC for Flex Bus Port
> > +// Compute Express Link Specification Revision: 1.1
> - Chapter 7.2.1.3,
> > +Figure 99 // typedef struct {
> > +  PCI_EXPRESS_EXTENDED_CAPABILITIES_HEADER
> Header;
> > // offset 0
> > +  PCI_EXPRESS_DESIGNATED_VENDOR_SPECIFIC_HEADER_1
> > DesignatedVendorSpecificHeader1;  // offset 4
> > +  PCI_EXPRESS_DESIGNATED_VENDOR_SPECIFIC_HEADER_2
> > DesignatedVendorSpecificHeader2;  // offset 8
> > +  CXL_1_1_DVSEC_FLEX_BUS_PORT_CAPABILITY
> PortCapability;
> > // offset 10
> > +  CXL_1_1_DVSEC_FLEX_BUS_PORT_CONTROL
> PortControl;
> > // offset 12
> > +  CXL_1_1_DVSEC_FLEX_BUS_PORT_STATUS
> PortStatus;
> > // offset 14
> > +} CXL_1_1_DVSEC_FLEX_BUS_PORT;
> > +///@}
> > +
> > +///
> > +/// CXL 1.1 Upstream and Downstream Port Subsystem
> Component registers
> > +///
> > +
> > +/// The CXL.Cache and CXL.Memory Architectural
> register definitions ///
> > +Based on chapter 7.2.2 of Compute Express Link
> Specification Revision:
> > +1.1 ///@{
> > +
> > +#define CXL_CAPABILITY_HEADER_OFFSET
> 0
> > +typedef union {
> > +  struct {
> > +    UINT32 CxlCapabilityId
> : 16; // bit 0..15
> > +    UINT32 CxlCapabilityVersion
> :  4; // bit 16..19
> > +    UINT32 CxlCacheMemVersion
> :  4; // bit 20..23
> > +    UINT32 ArraySize
> :  8; // bit 24..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_CAPABILITY_HEADER;
> > +
> > +#define CXL_RAS_CAPABILITY_HEADER_OFFSET
> 4
> > +typedef union {
> > +  struct {
> > +    UINT32 CxlCapabilityId
> : 16; // bit 0..15
> > +    UINT32 CxlCapabilityVersion
> :  4; // bit 16..19
> > +    UINT32 CxlRasCapabilityPointer
> : 12; // bit 20..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_RAS_CAPABILITY_HEADER;
> > +
> > +#define CXL_SECURITY_CAPABILITY_HEADER_OFFSET
> 8
> > +typedef union {
> > +  struct {
> > +    UINT32 CxlCapabilityId
> : 16; // bit 0..15
> > +    UINT32 CxlCapabilityVersion
> :  4; // bit 16..19
> > +    UINT32 CxlSecurityCapabilityPointer
> : 12; // bit 20..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_SECURITY_CAPABILITY_HEADER;
> > +
> > +#define CXL_LINK_CAPABILITY_HEADER_OFFSET
> 0xC
> > +typedef union {
> > +  struct {
> > +    UINT32 CxlCapabilityId
> : 16; // bit 0..15
> > +    UINT32 CxlCapabilityVersion
> :  4; // bit 16..19
> > +    UINT32 CxlLinkCapabilityPointer
> : 12; // bit 20..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_LINK_CAPABILITY_HEADER;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 CacheDataParity
> :  1; // bit 0..0
> > +    UINT32 CacheAddressParity
> :  1; // bit 1..1
> > +    UINT32 CacheByteEnableParity
> :  1; // bit 2..2
> > +    UINT32 CacheDataEcc
> :  1; // bit 3..3
> > +    UINT32 MemDataParity
> :  1; // bit 4..4
> > +    UINT32 MemAddressParity
> :  1; // bit 5..5
> > +    UINT32 MemByteEnableParity
> :  1; // bit 6..6
> > +    UINT32 MemDataEcc
> :  1; // bit 7..7
> > +    UINT32 ReInitThreshold
> :  1; // bit 8..8
> > +    UINT32 RsvdEncodingViolation
> :  1; // bit 9..9
> > +    UINT32 PoisonReceived
> :  1; // bit 10..10
> > +    UINT32 ReceiverOverflow
> :  1; // bit 11..11
> > +    UINT32 Reserved
> : 20; // bit 12..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_1_1_UNCORRECTABLE_ERROR_STATUS;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 CacheDataParityMask
> :  1; // bit 0..0
> > +    UINT32 CacheAddressParityMask
> :  1; // bit 1..1
> > +    UINT32 CacheByteEnableParityMask
> :  1; // bit 2..2
> > +    UINT32 CacheDataEccMask
> :  1; // bit 3..3
> > +    UINT32 MemDataParityMask
> :  1; // bit 4..4
> > +    UINT32 MemAddressParityMask
> :  1; // bit 5..5
> > +    UINT32 MemByteEnableParityMask
> :  1; // bit 6..6
> > +    UINT32 MemDataEccMask
> :  1; // bit 7..7
> > +    UINT32 ReInitThresholdMask
> :  1; // bit 8..8
> > +    UINT32 RsvdEncodingViolationMask
> :  1; // bit 9..9
> > +    UINT32 PoisonReceivedMask
> :  1; // bit 10..10
> > +    UINT32 ReceiverOverflowMask
> :  1; // bit 11..11
> > +    UINT32 Reserved
> : 20; // bit 12..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_1_1_UNCORRECTABLE_ERROR_MASK;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 CacheDataParitySeverity
> :  1; // bit 0..0
> > +    UINT32 CacheAddressParitySeverity
> :  1; // bit 1..1
> > +    UINT32 CacheByteEnableParitySeverity
> :  1; // bit 2..2
> > +    UINT32 CacheDataEccSeverity
> :  1; // bit 3..3
> > +    UINT32 MemDataParitySeverity
> :  1; // bit 4..4
> > +    UINT32 MemAddressParitySeverity
> :  1; // bit 5..5
> > +    UINT32 MemByteEnableParitySeverity
> :  1; // bit 6..6
> > +    UINT32 MemDataEccSeverity
> :  1; // bit 7..7
> > +    UINT32 ReInitThresholdSeverity
> :  1; // bit 8..8
> > +    UINT32 RsvdEncodingViolationSeverity
> :  1; // bit 9..9
> > +    UINT32 PoisonReceivedSeverity
> :  1; // bit 10..10
> > +    UINT32 ReceiverOverflowSeverity
> :  1; // bit 11..11
> > +    UINT32 Reserved
> : 20; // bit 12..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_1_1_UNCORRECTABLE_ERROR_SEVERITY;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 CacheDataEcc
> :  1; // bit 0..0
> > +    UINT32 MemoryDataEcc
> :  1; // bit 1..1
> > +    UINT32 CrcThreshold
> :  1; // bit 2..2
> > +    UINT32 RetryThreshold
> :  1; // bit 3..3
> > +    UINT32 CachePoisonReceived
> :  1; // bit 4..4
> > +    UINT32 MemoryPoisonReceived
> :  1; // bit 5..5
> > +    UINT32 PhysicalLayerError
> :  1; // bit 6..6
> > +    UINT32 Reserved
> : 25; // bit 7..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_CORRECTABLE_ERROR_STATUS;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 CacheDataEccMask
> :  1; // bit 0..0
> > +    UINT32 MemoryDataEccMask
> :  1; // bit 1..1
> > +    UINT32 CrcThresholdMask
> :  1; // bit 2..2
> > +    UINT32 RetryThresholdMask
> :  1; // bit 3..3
> > +    UINT32 CachePoisonReceivedMask
> :  1; // bit 4..4
> > +    UINT32 MemoryPoisonReceivedMask
> :  1; // bit 5..5
> > +    UINT32 PhysicalLayerErrorMask
> :  1; // bit 6..6
> > +    UINT32 Reserved
> : 25; // bit 7..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_CORRECTABLE_ERROR_MASK;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 FirstErrorPointer
> :  4; // bit 0..3
> > +    UINT32 Reserved1
> :  5; // bit 4..8
> > +    UINT32 MultipleHeaderRecordingCapability
> :  1; // bit 9..9
> > +    UINT32 Reserved2
> :  3; // bit 10..12
> > +    UINT32 PoisonEnabled
> :  1; // bit 13..13
> > +    UINT32 Reserved3
> : 18; // bit 14..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_ERROR_CAPABILITIES_AND_CONTROL;
> > +
> > +typedef struct {
> > +  CXL_1_1_UNCORRECTABLE_ERROR_STATUS
> > UncorrectableErrorStatus;
> > +  CXL_1_1_UNCORRECTABLE_ERROR_MASK
> > UncorrectableErrorMask;
> > +  CXL_1_1_UNCORRECTABLE_ERROR_SEVERITY
> > UncorrectableErrorSeverity;
> > +  CXL_CORRECTABLE_ERROR_STATUS
> > CorrectableErrorStatus;
> > +  CXL_CORRECTABLE_ERROR_MASK
> CorrectableErrorMask;
> > +  CXL_ERROR_CAPABILITIES_AND_CONTROL
> > ErrorCapabilitiesAndControl;
> > +  UINT32
> HeaderLog[16];
> > +} CXL_1_1_RAS_CAPABILITY_STRUCTURE;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 DeviceTrustLevel
> :  2; // bit 0..1
> > +    UINT32 Reserved
> : 30; // bit 2..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_1_1_SECURITY_POLICY;
> > +
> > +typedef struct {
> > +  CXL_1_1_SECURITY_POLICY
> SecurityPolicy;
> > +} CXL_1_1_SECURITY_CAPABILITY_STRUCTURE;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT64 CxlLinkVersionSupported
> :  4; // bit 0..3
> > +    UINT64 CxlLinkVersionReceived
> :  4; // bit 4..7
> > +    UINT64 LlrWrapValueSupported
> :  8; // bit 8..15
> > +    UINT64 LlrWrapValueReceived
> :  8; // bit 16..23
> > +    UINT64 NumRetryReceived
> :  5; // bit 24..28
> > +    UINT64 NumPhyReinitReceived
> :  5; // bit 29..33
> > +    UINT64 WrPtrReceived
> :  8; // bit 34..41
> > +    UINT64 EchoEseqReceived
> :  8; // bit 42..49
> > +    UINT64 NumFreeBufReceived
> :  8; // bit 50..57
> > +    UINT64 Reserved
> :  6; // bit 58..63
> > +  } Bits;
> > +  UINT64
> Uint64;
> > +} CXL_LINK_LAYER_CAPABILITY;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT16 LlReset
> :  1; // bit 0..0
> > +    UINT16 LlInitStall
> :  1; // bit 1..1
> > +    UINT16 LlCrdStall
> :  1; // bit 2..2
> > +    UINT16 InitState
> :  2; // bit 3..4
> > +    UINT16 LlRetryBufferConsumed
> :  8; // bit 5..12
> > +    UINT16 Reserved
> :  3; // bit 13..15
> > +  } Bits;
> > +  UINT16
> Uint16;
> > +} CXL_LINK_LAYER_CONTROL_AND_STATUS;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT64 CacheReqCredits
> : 10; // bit 0..9
> > +    UINT64 CacheRspCredits
> : 10; // bit 10..19
> > +    UINT64 CacheDataCredits
> : 10; // bit 20..29
> > +    UINT64 MemReqRspCredits
> : 10; // bit 30..39
> > +    UINT64 MemDataCredits
> : 10; // bit 40..49
> > +  } Bits;
> > +  UINT64
> Uint64;
> > +} CXL_LINK_LAYER_RX_CREDIT_CONTROL;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT64 CacheReqCredits
> : 10; // bit 0..9
> > +    UINT64 CacheRspCredits
> : 10; // bit 10..19
> > +    UINT64 CacheDataCredits
> : 10; // bit 20..29
> > +    UINT64 MemReqRspCredits
> : 10; // bit 30..39
> > +    UINT64 MemDataCredits
> : 10; // bit 40..49
> > +  } Bits;
> > +  UINT64
> Uint64;
> > +} CXL_LINK_LAYER_RX_CREDIT_RETURN_STATUS;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT64 CacheReqCredits
> : 10; // bit 0..9
> > +    UINT64 CacheRspCredits
> : 10; // bit 10..19
> > +    UINT64 CacheDataCredits
> : 10; // bit 20..29
> > +    UINT64 MemReqRspCredits
> : 10; // bit 30..39
> > +    UINT64 MemDataCredits
> : 10; // bit 40..49
> > +  } Bits;
> > +  UINT64
> Uint64;
> > +} CXL_LINK_LAYER_TX_CREDIT_STATUS;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 AckForceThreshold
> :  8; // bit 0..7
> > +    UINT32 AckFLushRetimer
> : 10; // bit 8..17
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_LINK_LAYER_ACK_TIMER_CONTROL;
> > +
> > +typedef union {
> > +  struct {
> > +    UINT32 MdhDisable
> :  1; // bit 0..0
> > +    UINT32 Reserved
> : 31; // bit 1..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_LINK_LAYER_DEFEATURE;
> > +
> > +typedef struct {
> > +  CXL_LINK_LAYER_CAPABILITY
> LinkLayerCapability;
> > +  CXL_LINK_LAYER_CONTROL_AND_STATUS
> > LinkLayerControlStatus;
> > +  CXL_LINK_LAYER_RX_CREDIT_CONTROL
> > LinkLayerRxCreditControl;
> > +  CXL_LINK_LAYER_RX_CREDIT_RETURN_STATUS
> > LinkLayerRxCreditReturnStatus;
> > +  CXL_LINK_LAYER_TX_CREDIT_STATUS
> > LinkLayerTxCreditStatus;
> > +  CXL_LINK_LAYER_ACK_TIMER_CONTROL
> > LinkLayerAckTimerControl;
> > +  CXL_LINK_LAYER_DEFEATURE
> LinkLayerDefeature;
> > +} CXL_1_1_LINK_CAPABILITY_STRUCTURE;
> > +
> > +#define CXL_IO_ARBITRATION_CONTROL_OFFSET
> 0x180
> > +typedef union {
> > +  struct {
> > +    UINT32 Reserved1
> :  4; // bit 0..3
> > +    UINT32 WeightedRoundRobinArbitrationWeight
> :  4; // bit 4..7
> > +    UINT32 Reserved2
> : 24; // bit 8..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_IO_ARBITRATION_CONTROL;
> > +
> > +#define CXL_CACHE_MEMORY_ARBITRATION_CONTROL_OFFSET
> 0x1C0
> > +typedef union {
> > +  struct {
> > +    UINT32 Reserved1
> :  4; // bit 0..3
> > +    UINT32 WeightedRoundRobinArbitrationWeight
> :  4; // bit 4..7
> > +    UINT32 Reserved2
> : 24; // bit 8..31
> > +  } Bits;
> > +  UINT32
> Uint32;
> > +} CXL_CACHE_MEMORY_ARBITRATION_CONTROL;
> > +///@}
> > +
> > +/// The CXL.RCRB base register definition /// Based
> on chapter 7.3 of
> > +Compute Express Link Specification Revision: 1.1
> ///@{ typedef union {
> > +  struct {
> > +    UINT64 RcrbEnable
> :  1; // bit 0..0
> > +    UINT64 Reserved
> : 12; // bit 1..12
> > +    UINT64 RcrbBaseAddress
> : 51; // bit 13..63
> > +  } Bits;
> > +  UINT64
> Uint64;
> > +} CXL_RCRB_BASE;
> > +///@}
> > +
> > +#pragma pack()
> > +
> > +//
> > +// CXL Downstream / Upstream Port RCRB space
> register offsets //
> > +Compute Express Link Specification Revision: 1.1 -
> Chapter 7.2.1.1 -
> > +Figure 97 //
> > +#define CXL_PORT_RCRB_MEMBAR0_LOW_OFFSET
> 0x010
> > +#define CXL_PORT_RCRB_MEMBAR0_HIGH_OFFSET
> 0x014
> > +#define
> CXL_PORT_RCRB_EXTENDED_CAPABILITY_BASE_OFFSET
> > 0x100
> > +
> > +#endif
> > diff --git a/MdePkg/Include/IndustryStandard/Pci.h
> > b/MdePkg/Include/IndustryStandard/Pci.h
> > index 8ed96b992a..42c00ac762 100644
> > --- a/MdePkg/Include/IndustryStandard/Pci.h
> > +++ b/MdePkg/Include/IndustryStandard/Pci.h
> > @@ -1,7 +1,7 @@
> >  /** @file
> >    Support for the latest PCI standard.
> >
> > -Copyright (c) 2006 - 2018, Intel Corporation. All
> rights reserved.<BR>
> > +Copyright (c) 2006 - 2020, Intel Corporation. All
> rights reserved.<BR>
> >  SPDX-License-Identifier: BSD-2-Clause-Patent
> >
> >  **/
> > @@ -9,9 +9,7 @@ SPDX-License-Identifier: BSD-2-
> Clause-Patent  #ifndef
> > _PCI_H_  #define _PCI_H_
> >
> > -#include <IndustryStandard/Pci30.h>
> > -#include <IndustryStandard/PciExpress21.h> -#include
> > <IndustryStandard/PciExpress30.h>
> > +#include <IndustryStandard/PciExpress50.h>
> >  #include <IndustryStandard/PciCodeId.h>
> >
> >  #endif
> > --
> > 2.21.0.windows.1
> >
> >
> > 


-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.

View/Reply Online (#63254): https://edk2.groups.io/g/devel/message/63254
Mute This Topic: https://groups.io/mt/75726735/1813853
Group Owner: devel+owner at edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub  [edk2-devel-archive at redhat.com]
-=-=-=-=-=-=-=-=-=-=-=-





More information about the edk2-devel-archive mailing list