[
    {
        "BriefDescription": "Number of uclks in domain",
        "EventCode": "0x1",
        "EventName": "UNC_R2_CLOCKTICKS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of uclks in the R2PCIe uclk domain.  This could be slightly different than the count in the Ubox because of enable/freeze delays.  However, because the R2PCIe is close to the Ubox, they generally should not diverge by more than a handful of cycles.",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2PCIe IIO Credit Acquired; DRS",
        "EventCode": "0x33",
        "EventName": "UNC_R2_IIO_CREDITS_ACQUIRED.DRS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of credits that are acquired in the R2PCIe agent for sending transactions into the IIO on either NCB or NCS are in use.  Transactions from the BL ring going into the IIO Agent must first acquire a credit.  These credits are for either the NCB or NCS message classes.  NCB, or non-coherent bypass messages are used to transmit data without coherency (and are common).  NCS is used for reads to PCIe (and should be used sparingly).; Credits to the IIO for the DRS message class.",
        "UMask": "0x8",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2PCIe IIO Credit Acquired; NCB",
        "EventCode": "0x33",
        "EventName": "UNC_R2_IIO_CREDITS_ACQUIRED.NCB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of credits that are acquired in the R2PCIe agent for sending transactions into the IIO on either NCB or NCS are in use.  Transactions from the BL ring going into the IIO Agent must first acquire a credit.  These credits are for either the NCB or NCS message classes.  NCB, or non-coherent bypass messages are used to transmit data without coherency (and are common).  NCS is used for reads to PCIe (and should be used sparingly).; Credits to the IIO for the NCB message class.",
        "UMask": "0x10",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2PCIe IIO Credit Acquired; NCS",
        "EventCode": "0x33",
        "EventName": "UNC_R2_IIO_CREDITS_ACQUIRED.NCS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of credits that are acquired in the R2PCIe agent for sending transactions into the IIO on either NCB or NCS are in use.  Transactions from the BL ring going into the IIO Agent must first acquire a credit.  These credits are for either the NCB or NCS message classes.  NCB, or non-coherent bypass messages are used to transmit data without coherency (and are common).  NCS is used for reads to PCIe (and should be used sparingly).; Credits to the IIO for the NCS message class.",
        "UMask": "0x20",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2PCIe IIO Failed to Acquire a Credit; DRS",
        "EventCode": "0x34",
        "EventName": "UNC_R2_IIO_CREDITS_REJECT.DRS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of times that a request pending in the BL Ingress attempted to acquire either a NCB or NCS credit to transmit into the IIO, but was rejected because no credits were available.  NCB, or non-coherent bypass messages are used to transmit data without coherency (and are common).  NCS is used for reads to PCIe (and should be used sparingly).; Credits to the IIO for the DRS message class.",
        "UMask": "0x8",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2PCIe IIO Credits in Use; DRS",
        "EventCode": "0x32",
        "EventName": "UNC_R2_IIO_CREDITS_USED.DRS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when one or more credits in the R2PCIe agent for sending transactions into the IIO on either NCB or NCS are in use.  Transactions from the BL ring going into the IIO Agent must first acquire a credit.  These credits are for either the NCB or NCS message classes.  NCB, or non-coherent bypass messages are used to transmit data without coherency (and are common).  NCS is used for reads to PCIe (and should be used sparingly).; Credits to the IIO for the DRS message class.",
        "UMask": "0x8",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2PCIe IIO Credits in Use; NCB",
        "EventCode": "0x32",
        "EventName": "UNC_R2_IIO_CREDITS_USED.NCB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when one or more credits in the R2PCIe agent for sending transactions into the IIO on either NCB or NCS are in use.  Transactions from the BL ring going into the IIO Agent must first acquire a credit.  These credits are for either the NCB or NCS message classes.  NCB, or non-coherent bypass messages are used to transmit data without coherency (and are common).  NCS is used for reads to PCIe (and should be used sparingly).; Credits to the IIO for the NCB message class.",
        "UMask": "0x10",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2PCIe IIO Credits in Use; NCS",
        "EventCode": "0x32",
        "EventName": "UNC_R2_IIO_CREDITS_USED.NCS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when one or more credits in the R2PCIe agent for sending transactions into the IIO on either NCB or NCS are in use.  Transactions from the BL ring going into the IIO Agent must first acquire a credit.  These credits are for either the NCB or NCS message classes.  NCB, or non-coherent bypass messages are used to transmit data without coherency (and are common).  NCS is used for reads to PCIe (and should be used sparingly).; Credits to the IIO for the NCS message class.",
        "UMask": "0x20",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AD Ring in Use; Counterclockwise",
        "EventCode": "0x7",
        "EventName": "UNC_R2_RING_AD_USED.CCW",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AD ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.",
        "UMask": "0xcc",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AD Ring in Use; Counterclockwise and Even on VRing 0",
        "EventCode": "0x7",
        "EventName": "UNC_R2_RING_AD_USED.CCW_VR0_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AD ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Even ring polarity on Virtual Ring 0.",
        "UMask": "0x4",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AD Ring in Use; Counterclockwise and Odd on VRing 0",
        "EventCode": "0x7",
        "EventName": "UNC_R2_RING_AD_USED.CCW_VR0_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AD ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Odd ring polarity on Virtual Ring 0.",
        "UMask": "0x8",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AD Ring in Use; Counterclockwise and Even on VRing 1",
        "EventCode": "0x7",
        "EventName": "UNC_R2_RING_AD_USED.CCW_VR1_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AD ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Even ring polarity on Virtual Ring 1.",
        "UMask": "0x40",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AD Ring in Use; Counterclockwise and Odd on VRing 1",
        "EventCode": "0x7",
        "EventName": "UNC_R2_RING_AD_USED.CCW_VR1_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AD ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Odd ring polarity on Virtual Ring 1.",
        "UMask": "0x80",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AD Ring in Use; Clockwise",
        "EventCode": "0x7",
        "EventName": "UNC_R2_RING_AD_USED.CW",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AD ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.",
        "UMask": "0x33",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AD Ring in Use; Clockwise and Even on VRing 0",
        "EventCode": "0x7",
        "EventName": "UNC_R2_RING_AD_USED.CW_VR0_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AD ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Even ring polarity on Virtual Ring 0.",
        "UMask": "0x1",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AD Ring in Use; Clockwise and Odd on VRing 0",
        "EventCode": "0x7",
        "EventName": "UNC_R2_RING_AD_USED.CW_VR0_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AD ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Odd ring polarity on Virtual Ring 0.",
        "UMask": "0x2",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AD Ring in Use; Clockwise and Even on VRing 1",
        "EventCode": "0x7",
        "EventName": "UNC_R2_RING_AD_USED.CW_VR1_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AD ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Even ring polarity on Virtual Ring 1.",
        "UMask": "0x10",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AD Ring in Use; Clockwise and Odd on VRing 1",
        "EventCode": "0x7",
        "EventName": "UNC_R2_RING_AD_USED.CW_VR1_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AD ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Odd ring polarity on Virtual Ring 1.",
        "UMask": "0x20",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AK Ring in Use; Counterclockwise",
        "EventCode": "0x8",
        "EventName": "UNC_R2_RING_AK_USED.CCW",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AK ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.",
        "UMask": "0xcc",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AK Ring in Use; Counterclockwise and Even on VRing 0",
        "EventCode": "0x8",
        "EventName": "UNC_R2_RING_AK_USED.CCW_VR0_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AK ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Even ring polarity on Virtual Ring 0.",
        "UMask": "0x4",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AK Ring in Use; Counterclockwise and Odd on VRing 0",
        "EventCode": "0x8",
        "EventName": "UNC_R2_RING_AK_USED.CCW_VR0_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AK ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Odd ring polarity on Virtual Ring 0.",
        "UMask": "0x8",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AK Ring in Use; Counterclockwise and Even on VRing 1",
        "EventCode": "0x8",
        "EventName": "UNC_R2_RING_AK_USED.CCW_VR1_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AK ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Even ring polarity on Virtual Ring 1.",
        "UMask": "0x40",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AK Ring in Use; Counterclockwise and Odd on VRing 1",
        "EventCode": "0x8",
        "EventName": "UNC_R2_RING_AK_USED.CCW_VR1_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AK ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Odd ring polarity on Virtual Ring 1.",
        "UMask": "0x80",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AK Ring in Use; Clockwise",
        "EventCode": "0x8",
        "EventName": "UNC_R2_RING_AK_USED.CW",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AK ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.",
        "UMask": "0x33",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AK Ring in Use; Clockwise and Even on VRing 0",
        "EventCode": "0x8",
        "EventName": "UNC_R2_RING_AK_USED.CW_VR0_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AK ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Even ring polarity on Virtual Ring 0.",
        "UMask": "0x1",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AK Ring in Use; Clockwise and Odd on VRing 0",
        "EventCode": "0x8",
        "EventName": "UNC_R2_RING_AK_USED.CW_VR0_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AK ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Odd ring polarity on Virtual Ring 0.",
        "UMask": "0x2",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AK Ring in Use; Clockwise and Even on VRing 1",
        "EventCode": "0x8",
        "EventName": "UNC_R2_RING_AK_USED.CW_VR1_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AK ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Even ring polarity on Virtual Ring 1.",
        "UMask": "0x10",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 AK Ring in Use; Clockwise and Odd on VRing 1",
        "EventCode": "0x8",
        "EventName": "UNC_R2_RING_AK_USED.CW_VR1_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the AK ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Odd ring polarity on Virtual Ring 1.",
        "UMask": "0x20",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 BL Ring in Use; Counterclockwise",
        "EventCode": "0x9",
        "EventName": "UNC_R2_RING_BL_USED.CCW",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the BL ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.",
        "UMask": "0xcc",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 BL Ring in Use; Counterclockwise and Even on VRing 0",
        "EventCode": "0x9",
        "EventName": "UNC_R2_RING_BL_USED.CCW_VR0_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the BL ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Even ring polarity on Virtual Ring 0.",
        "UMask": "0x4",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 BL Ring in Use; Counterclockwise and Odd on VRing 0",
        "EventCode": "0x9",
        "EventName": "UNC_R2_RING_BL_USED.CCW_VR0_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the BL ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Odd ring polarity on Virtual Ring 0.",
        "UMask": "0x8",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 BL Ring in Use; Counterclockwise and Even on VRing 1",
        "EventCode": "0x9",
        "EventName": "UNC_R2_RING_BL_USED.CCW_VR1_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the BL ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Even ring polarity on Virtual Ring 1.",
        "UMask": "0x40",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 BL Ring in Use; Counterclockwise and Odd on VRing 1",
        "EventCode": "0x9",
        "EventName": "UNC_R2_RING_BL_USED.CCW_VR1_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the BL ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Counterclockwise and Odd ring polarity on Virtual Ring 1.",
        "UMask": "0x80",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 BL Ring in Use; Clockwise",
        "EventCode": "0x9",
        "EventName": "UNC_R2_RING_BL_USED.CW",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the BL ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.",
        "UMask": "0x33",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 BL Ring in Use; Clockwise and Even on VRing 0",
        "EventCode": "0x9",
        "EventName": "UNC_R2_RING_BL_USED.CW_VR0_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the BL ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Even ring polarity on Virtual Ring 0.",
        "UMask": "0x1",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 BL Ring in Use; Clockwise and Odd on VRing 0",
        "EventCode": "0x9",
        "EventName": "UNC_R2_RING_BL_USED.CW_VR0_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the BL ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Odd ring polarity on Virtual Ring 0.",
        "UMask": "0x2",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 BL Ring in Use; Clockwise and Even on VRing 1",
        "EventCode": "0x9",
        "EventName": "UNC_R2_RING_BL_USED.CW_VR1_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the BL ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Even ring polarity on Virtual Ring 1.",
        "UMask": "0x10",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 BL Ring in Use; Clockwise and Odd on VRing 1",
        "EventCode": "0x9",
        "EventName": "UNC_R2_RING_BL_USED.CW_VR1_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the BL ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sunk, but does not include when packets are being sent from the ring stop.; Filters for the Clockwise and Odd ring polarity on Virtual Ring 1.",
        "UMask": "0x20",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 IV Ring in Use; Any",
        "EventCode": "0xA",
        "EventName": "UNC_R2_RING_IV_USED.ANY",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the IV ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sent, but does not include when packets are being sunk into the ring stop.  The IV ring is unidirectional.  Whether UP or DN is used is dependent on the system programming.  Thereofore, one should generally set both the UP and DN bits for a given polarity (or both) at a given time.; Filters any polarity",
        "UMask": "0xff",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 IV Ring in Use; Counterclockwise",
        "EventCode": "0xa",
        "EventName": "UNC_R2_RING_IV_USED.CCW",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the IV ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sent, but does not include when packets are being sunk into the ring stop.  The IV ring is unidirectional.  Whether UP or DN is used is dependent on the system programming.  Thereofore, one should generally set both the UP and DN bits for a given polarity (or both) at a given time.; Filters for Counterclockwise polarity",
        "UMask": "0xcc",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "R2 IV Ring in Use; Clockwise",
        "EventCode": "0xa",
        "EventName": "UNC_R2_RING_IV_USED.CW",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the IV ring is being used at this ring stop.  This includes when packets are passing by and when packets are being sent, but does not include when packets are being sunk into the ring stop.  The IV ring is unidirectional.  Whether UP or DN is used is dependent on the system programming.  Thereofore, one should generally set both the UP and DN bits for a given polarity (or both) at a given time.; Filters for Clockwise polarity",
        "UMask": "0x33",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "AK Ingress Bounced",
        "EventCode": "0x12",
        "EventName": "UNC_R2_RxR_AK_BOUNCES",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of times when a request destined for the AK ingress bounced.",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "AK Ingress Bounced; Counterclockwise",
        "EventCode": "0x12",
        "EventName": "UNC_R2_RxR_AK_BOUNCES.CCW",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of times when a request destined for the AK ingress bounced.",
        "UMask": "0x2",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "AK Ingress Bounced; Clockwise",
        "EventCode": "0x12",
        "EventName": "UNC_R2_RxR_AK_BOUNCES.CW",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of times when a request destined for the AK ingress bounced.",
        "UMask": "0x1",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Ingress Cycles Not Empty; NCB",
        "EventCode": "0x10",
        "EventName": "UNC_R2_RxR_CYCLES_NE.NCB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the R2PCIe Ingress is not empty.  This tracks one of the three rings that are used by the R2PCIe agent.  This can be used in conjunction with the R2PCIe Ingress Occupancy Accumulator event in order to calculate average queue occupancy.  Multiple ingress buffers can be tracked at a given time using multiple counters.; NCB Ingress Queue",
        "UMask": "0x10",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Ingress Cycles Not Empty; NCS",
        "EventCode": "0x10",
        "EventName": "UNC_R2_RxR_CYCLES_NE.NCS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the R2PCIe Ingress is not empty.  This tracks one of the three rings that are used by the R2PCIe agent.  This can be used in conjunction with the R2PCIe Ingress Occupancy Accumulator event in order to calculate average queue occupancy.  Multiple ingress buffers can be tracked at a given time using multiple counters.; NCS Ingress Queue",
        "UMask": "0x20",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Ingress Allocations; NCB",
        "EventCode": "0x11",
        "EventName": "UNC_R2_RxR_INSERTS.NCB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the R2PCIe Ingress.  This tracks one of the three rings that are used by the R2PCIe agent.  This can be used in conjunction with the R2PCIe Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; NCB Ingress Queue",
        "UMask": "0x10",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Ingress Allocations; NCS",
        "EventCode": "0x11",
        "EventName": "UNC_R2_RxR_INSERTS.NCS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the R2PCIe Ingress.  This tracks one of the three rings that are used by the R2PCIe agent.  This can be used in conjunction with the R2PCIe Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; NCS Ingress Queue",
        "UMask": "0x20",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Ingress Occupancy Accumulator; DRS",
        "EventCode": "0x13",
        "EventName": "UNC_R2_RxR_OCCUPANCY.DRS",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given R2PCIe Ingress queue in each cycles.  This tracks one of the three ring Ingress buffers.  This can be used with the R2PCIe Ingress Not Empty event to calculate average occupancy or the R2PCIe Ingress Allocations event in order to calculate average queuing latency.; DRS Ingress Queue",
        "UMask": "0x8",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress Cycles Full; AD",
        "EventCode": "0x25",
        "EventName": "UNC_R2_TxR_CYCLES_FULL.AD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the R2PCIe Egress buffer is full.; AD Egress Queue",
        "UMask": "0x1",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress Cycles Full; AK",
        "EventCode": "0x25",
        "EventName": "UNC_R2_TxR_CYCLES_FULL.AK",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the R2PCIe Egress buffer is full.; AK Egress Queue",
        "UMask": "0x2",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress Cycles Full; BL",
        "EventCode": "0x25",
        "EventName": "UNC_R2_TxR_CYCLES_FULL.BL",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the R2PCIe Egress buffer is full.; BL Egress Queue",
        "UMask": "0x4",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress Cycles Not Empty; AD",
        "EventCode": "0x23",
        "EventName": "UNC_R2_TxR_CYCLES_NE.AD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the R2PCIe Egress is not empty.  This tracks one of the three rings that are used by the R2PCIe agent.  This can be used in conjunction with the R2PCIe Egress Occupancy Accumulator event in order to calculate average queue occupancy.  Only a single Egress queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.; AD Egress Queue",
        "UMask": "0x1",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress Cycles Not Empty; AK",
        "EventCode": "0x23",
        "EventName": "UNC_R2_TxR_CYCLES_NE.AK",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the R2PCIe Egress is not empty.  This tracks one of the three rings that are used by the R2PCIe agent.  This can be used in conjunction with the R2PCIe Egress Occupancy Accumulator event in order to calculate average queue occupancy.  Only a single Egress queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.; AK Egress Queue",
        "UMask": "0x2",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress Cycles Not Empty; BL",
        "EventCode": "0x23",
        "EventName": "UNC_R2_TxR_CYCLES_NE.BL",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the R2PCIe Egress is not empty.  This tracks one of the three rings that are used by the R2PCIe agent.  This can be used in conjunction with the R2PCIe Egress Occupancy Accumulator event in order to calculate average queue occupancy.  Only a single Egress queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.; BL Egress Queue",
        "UMask": "0x4",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress CCW NACK; AD CCW",
        "EventCode": "0x28",
        "EventName": "UNC_R2_TxR_NACK_CCW.AD",
        "PerPkg": "1",
        "PublicDescription": "AD CounterClockwise Egress Queue",
        "UMask": "0x1",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress CCW NACK; AK CCW",
        "EventCode": "0x28",
        "EventName": "UNC_R2_TxR_NACK_CCW.AK",
        "PerPkg": "1",
        "PublicDescription": "AK CounterClockwise Egress Queue",
        "UMask": "0x2",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress CCW NACK; BL CCW",
        "EventCode": "0x28",
        "EventName": "UNC_R2_TxR_NACK_CCW.BL",
        "PerPkg": "1",
        "PublicDescription": "BL CounterClockwise Egress Queue",
        "UMask": "0x4",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress CW NACK; AD CW",
        "EventCode": "0x26",
        "EventName": "UNC_R2_TxR_NACK_CW.AD",
        "PerPkg": "1",
        "PublicDescription": "AD Clockwise Egress Queue",
        "UMask": "0x1",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress CW NACK; AK CW",
        "EventCode": "0x26",
        "EventName": "UNC_R2_TxR_NACK_CW.AK",
        "PerPkg": "1",
        "PublicDescription": "AK Clockwise Egress Queue",
        "UMask": "0x2",
        "Unit": "R2PCIe"
    },
    {
        "BriefDescription": "Egress CW NACK; BL CW",
        "EventCode": "0x26",
        "EventName": "UNC_R2_TxR_NACK_CW.BL",
        "PerPkg": "1",
        "PublicDescription": "BL Clockwise Egress Queue",
        "UMask": "0x4",
        "Unit": "R2PCIe"
    }
]