[
    {
        "BriefDescription": "Total Write Cache Occupancy; Any Source",
        "EventCode": "0xF",
        "EventName": "UNC_I_CACHE_TOTAL_OCCUPANCY.ANY",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the number of reads and writes that are outstanding in the uncore in each cycle.  This is effectively the sum of the READ_OCCUPANCY and WRITE_OCCUPANCY events.; Tracks all requests from any source port.",
        "UMask": "0x1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Total Write Cache Occupancy; Snoops",
        "EventCode": "0xF",
        "EventName": "UNC_I_CACHE_TOTAL_OCCUPANCY.IV_Q",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the number of reads and writes that are outstanding in the uncore in each cycle.  This is effectively the sum of the READ_OCCUPANCY and WRITE_OCCUPANCY events.",
        "UMask": "0x2",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Total IRP occupancy of inbound read and write requests.",
        "EventCode": "0xF",
        "EventName": "UNC_I_CACHE_TOTAL_OCCUPANCY.MEM",
        "PerPkg": "1",
        "PublicDescription": "Total IRP occupancy of inbound read and write requests.  This is effectively the sum of read occupancy and write occupancy.",
        "UMask": "0x4",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "IRP Clocks",
        "EventCode": "0x1",
        "EventName": "UNC_I_CLOCKTICKS",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Coherent Ops; CLFlush",
        "EventCode": "0x10",
        "EventName": "UNC_I_COHERENT_OPS.CLFLUSH",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of coherency related operations servied by the IRP",
        "UMask": "0x80",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Coherent Ops; CRd",
        "EventCode": "0x10",
        "EventName": "UNC_I_COHERENT_OPS.CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of coherency related operations servied by the IRP",
        "UMask": "0x2",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Coherent Ops; DRd",
        "EventCode": "0x10",
        "EventName": "UNC_I_COHERENT_OPS.DRD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of coherency related operations servied by the IRP",
        "UMask": "0x4",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Coherent Ops; PCIDCAHin5t",
        "EventCode": "0x10",
        "EventName": "UNC_I_COHERENT_OPS.PCIDCAHINT",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of coherency related operations servied by the IRP",
        "UMask": "0x20",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Coherent Ops; PCIRdCur",
        "EventCode": "0x10",
        "EventName": "UNC_I_COHERENT_OPS.PCIRDCUR",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of coherency related operations servied by the IRP",
        "UMask": "0x1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "PCIITOM request issued by the IRP unit to the mesh with the intention of writing a full cacheline.",
        "EventCode": "0x10",
        "EventName": "UNC_I_COHERENT_OPS.PCITOM",
        "PerPkg": "1",
        "PublicDescription": "PCIITOM request issued by the IRP unit to the mesh with the intention of writing a full cacheline to coherent memory, without a RFO.  PCIITOM is a speculative Invalidate to Modified command that requests ownership of the cacheline and does not move data from the mesh to IRP cache.",
        "UMask": "0x10",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "RFO request issued by the IRP unit to the mesh with the intention of writing a partial cacheline.",
        "EventCode": "0x10",
        "EventName": "UNC_I_COHERENT_OPS.RFO",
        "PerPkg": "1",
        "PublicDescription": "RFO request issued by the IRP unit to the mesh with the intention of writing a partial cacheline to coherent memory.  RFO is a Read For Ownership command that requests ownership of the cacheline and moves data from the mesh to IRP cache.",
        "UMask": "0x8",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Coherent Ops; WbMtoI",
        "EventCode": "0x10",
        "EventName": "UNC_I_COHERENT_OPS.WBMTOI",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of coherency related operations servied by the IRP",
        "UMask": "0x40",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "FAF RF full",
        "EventCode": "0x17",
        "EventName": "UNC_I_FAF_FULL",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Inbound read requests received by the IRP and inserted into the FAF queue.",
        "EventCode": "0x18",
        "EventName": "UNC_I_FAF_INSERTS",
        "PerPkg": "1",
        "PublicDescription": "Inbound read requests to coherent memory, received by the IRP and inserted into the Fire and Forget queue (FAF), a queue used for processing inbound reads in the IRP.",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Occupancy of the IRP FAF queue.",
        "EventCode": "0x19",
        "EventName": "UNC_I_FAF_OCCUPANCY",
        "PerPkg": "1",
        "PublicDescription": "Occupancy of the IRP Fire and Forget (FAF) queue, a queue used for processing inbound reads in the IRP.",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "FAF allocation -- sent to ADQ",
        "EventCode": "0x16",
        "EventName": "UNC_I_FAF_TRANSACTIONS",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "All Inserts Inbound (p2p + faf + cset)",
        "EventCode": "0x1E",
        "EventName": "UNC_I_IRP_ALL.INBOUND_INSERTS",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "All Inserts Outbound (BL, AK, Snoops)",
        "EventCode": "0x1E",
        "EventName": "UNC_I_IRP_ALL.OUTBOUND_INSERTS",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 0; Cache Inserts of Atomic Transactions as Secondary",
        "EventCode": "0x1C",
        "EventName": "UNC_I_MISC0.2ND_ATOMIC_INSERT",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 0; Cache Inserts of Read Transactions as Secondary",
        "EventCode": "0x1C",
        "EventName": "UNC_I_MISC0.2ND_RD_INSERT",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 0; Cache Inserts of Write Transactions as Secondary",
        "EventCode": "0x1C",
        "EventName": "UNC_I_MISC0.2ND_WR_INSERT",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 0; Fastpath Rejects",
        "EventCode": "0x1C",
        "EventName": "UNC_I_MISC0.FAST_REJ",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 0; Fastpath Requests",
        "EventCode": "0x1C",
        "EventName": "UNC_I_MISC0.FAST_REQ",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 0; Fastpath Transfers From Primary to Secondary",
        "EventCode": "0x1C",
        "EventName": "UNC_I_MISC0.FAST_XFER",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 0; Prefetch Ack Hints From Primary to Secondary",
        "EventCode": "0x1C",
        "EventName": "UNC_I_MISC0.PF_ACK_HINT",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 0",
        "EventCode": "0x1C",
        "EventName": "UNC_I_MISC0.UNKNOWN",
        "PerPkg": "1",
        "UMask": "0x80",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 1; Lost Forward",
        "EventCode": "0x1D",
        "EventName": "UNC_I_MISC1.LOST_FWD",
        "PerPkg": "1",
        "PublicDescription": "Snoop pulled away ownership before a write was committed",
        "UMask": "0x10",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 1; Received Invalid",
        "EventCode": "0x1D",
        "EventName": "UNC_I_MISC1.SEC_RCVD_INVLD",
        "PerPkg": "1",
        "PublicDescription": "Secondary received a transfer that did not have sufficient MESI state",
        "UMask": "0x20",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 1; Received Valid",
        "EventCode": "0x1D",
        "EventName": "UNC_I_MISC1.SEC_RCVD_VLD",
        "PerPkg": "1",
        "PublicDescription": "Secondary received a transfer that did have sufficient MESI state",
        "UMask": "0x40",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 1; Slow Transfer of E Line",
        "EventCode": "0x1D",
        "EventName": "UNC_I_MISC1.SLOW_E",
        "PerPkg": "1",
        "PublicDescription": "Secondary received a transfer that did have sufficient MESI state",
        "UMask": "0x4",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 1; Slow Transfer of I Line",
        "EventCode": "0x1D",
        "EventName": "UNC_I_MISC1.SLOW_I",
        "PerPkg": "1",
        "PublicDescription": "Snoop took cacheline ownership before write from data was committed.",
        "UMask": "0x1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 1; Slow Transfer of M Line",
        "EventCode": "0x1D",
        "EventName": "UNC_I_MISC1.SLOW_M",
        "PerPkg": "1",
        "PublicDescription": "Snoop took cacheline ownership before write from data was committed.",
        "UMask": "0x8",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Misc Events - Set 1; Slow Transfer of S Line",
        "EventCode": "0x1D",
        "EventName": "UNC_I_MISC1.SLOW_S",
        "PerPkg": "1",
        "PublicDescription": "Secondary received a transfer that did not have sufficient MESI state",
        "UMask": "0x2",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "P2P Requests",
        "EventCode": "0x14",
        "EventName": "UNC_I_P2P_INSERTS",
        "PerPkg": "1",
        "PublicDescription": "P2P requests from the ITC",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "P2P Occupancy",
        "EventCode": "0x15",
        "EventName": "UNC_I_P2P_OCCUPANCY",
        "PerPkg": "1",
        "PublicDescription": "P2P B & S Queue Occupancy",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "P2P Transactions; P2P completions",
        "EventCode": "0x13",
        "EventName": "UNC_I_P2P_TRANSACTIONS.CMPL",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "P2P Transactions; match if local only",
        "EventCode": "0x13",
        "EventName": "UNC_I_P2P_TRANSACTIONS.LOC",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "P2P Transactions; match if local and target matches",
        "EventCode": "0x13",
        "EventName": "UNC_I_P2P_TRANSACTIONS.LOC_AND_TGT_MATCH",
        "PerPkg": "1",
        "UMask": "0x80",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "P2P Transactions; P2P Message",
        "EventCode": "0x13",
        "EventName": "UNC_I_P2P_TRANSACTIONS.MSG",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "P2P Transactions; P2P reads",
        "EventCode": "0x13",
        "EventName": "UNC_I_P2P_TRANSACTIONS.RD",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "P2P Transactions; Match if remote only",
        "EventCode": "0x13",
        "EventName": "UNC_I_P2P_TRANSACTIONS.REM",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "P2P Transactions; match if remote and target matches",
        "EventCode": "0x13",
        "EventName": "UNC_I_P2P_TRANSACTIONS.REM_AND_TGT_MATCH",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "P2P Transactions; P2P Writes",
        "EventCode": "0x13",
        "EventName": "UNC_I_P2P_TRANSACTIONS.WR",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Responses to snoops of any type that hit M, E, S or I line in the IIO",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.ALL_HIT",
        "PerPkg": "1",
        "PublicDescription": "Responses to snoops of any type (code, data, invalidate) that hit M, E, S or I line in the IIO",
        "UMask": "0x7e",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Responses to snoops of any type that hit E or S line in the IIO cache",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.ALL_HIT_ES",
        "PerPkg": "1",
        "PublicDescription": "Responses to snoops of any type (code, data, invalidate) that hit E or S line in the IIO cache",
        "UMask": "0x74",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Responses to snoops of any type that hit I line in the IIO cache",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.ALL_HIT_I",
        "PerPkg": "1",
        "PublicDescription": "Responses to snoops of any type (code, data, invalidate) that hit I line in the IIO cache",
        "UMask": "0x72",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Responses to snoops of any type that hit M line in the IIO cache",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.ALL_HIT_M",
        "PerPkg": "1",
        "PublicDescription": "Responses to snoops of any type (code, data, invalidate) that hit M line in the IIO cache",
        "UMask": "0x78",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Responses to snoops of any type that miss the IIO cache",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.ALL_MISS",
        "PerPkg": "1",
        "PublicDescription": "Responses to snoops of any type (code, data, invalidate) that miss the IIO cache",
        "UMask": "0x71",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Snoop Responses; Hit E or S",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.HIT_ES",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Snoop Responses; Hit I",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.HIT_I",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Snoop Responses; Hit M",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.HIT_M",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Snoop Responses; Miss",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.MISS",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Snoop Responses; SnpCode",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.SNPCODE",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Snoop Responses; SnpData",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.SNPDATA",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Snoop Responses; SnpInv",
        "EventCode": "0x12",
        "EventName": "UNC_I_SNOOP_RESP.SNPINV",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Inbound Transaction Count; Atomic",
        "EventCode": "0x11",
        "EventName": "UNC_I_TRANSACTIONS.ATOMIC",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of Inbound transactions from the IRP to the Uncore.  This can be filtered based on request type in addition to the source queue.  Note the special filtering equation.  We do OR-reduction on the request type.  If the SOURCE bit is set, then we also do AND qualification based on the source portID.; Tracks the number of atomic transactions",
        "UMask": "0x10",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Inbound Transaction Count; Other",
        "EventCode": "0x11",
        "EventName": "UNC_I_TRANSACTIONS.OTHER",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of Inbound transactions from the IRP to the Uncore.  This can be filtered based on request type in addition to the source queue.  Note the special filtering equation.  We do OR-reduction on the request type.  If the SOURCE bit is set, then we also do AND qualification based on the source portID.; Tracks the number of 'other' kinds of transactions.",
        "UMask": "0x20",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Inbound Transaction Count; Read Prefetches",
        "EventCode": "0x11",
        "EventName": "UNC_I_TRANSACTIONS.RD_PREF",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of Inbound transactions from the IRP to the Uncore.  This can be filtered based on request type in addition to the source queue.  Note the special filtering equation.  We do OR-reduction on the request type.  If the SOURCE bit is set, then we also do AND qualification based on the source portID.; Tracks the number of read prefetches.",
        "UMask": "0x4",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Inbound Transaction Count; Reads",
        "EventCode": "0x11",
        "EventName": "UNC_I_TRANSACTIONS.READS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of Inbound transactions from the IRP to the Uncore.  This can be filtered based on request type in addition to the source queue.  Note the special filtering equation.  We do OR-reduction on the request type.  If the SOURCE bit is set, then we also do AND qualification based on the source portID.; Tracks only read requests (not including read prefetches).",
        "UMask": "0x1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Inbound Transaction Count; Writes",
        "EventCode": "0x11",
        "EventName": "UNC_I_TRANSACTIONS.WRITES",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of Inbound transactions from the IRP to the Uncore.  This can be filtered based on request type in addition to the source queue.  Note the special filtering equation.  We do OR-reduction on the request type.  If the SOURCE bit is set, then we also do AND qualification based on the source portID.; Trackes only write requests.  Each write request should have a prefetch, so there is no need to explicitly track these requests.  For writes that are tickled and have to retry, the counter will be incremented for each retry.",
        "UMask": "0x2",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Inbound write (fast path) requests received by the IRP.",
        "EventCode": "0x11",
        "EventName": "UNC_I_TRANSACTIONS.WR_PREF",
        "PerPkg": "1",
        "PublicDescription": "Inbound write (fast path) requests to coherent memory, received by the IRP resulting in write ownership requests issued by IRP to the mesh.",
        "UMask": "0x8",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "AK Egress Allocations",
        "EventCode": "0xB",
        "EventName": "UNC_I_TxC_AK_INSERTS",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "BL DRS Egress Cycles Full",
        "EventCode": "0x5",
        "EventName": "UNC_I_TxC_BL_DRS_CYCLES_FULL",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "BL DRS Egress Inserts",
        "EventCode": "0x2",
        "EventName": "UNC_I_TxC_BL_DRS_INSERTS",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "BL DRS Egress Occupancy",
        "EventCode": "0x8",
        "EventName": "UNC_I_TxC_BL_DRS_OCCUPANCY",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "BL NCB Egress Cycles Full",
        "EventCode": "0x6",
        "EventName": "UNC_I_TxC_BL_NCB_CYCLES_FULL",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "BL NCB Egress Inserts",
        "EventCode": "0x3",
        "EventName": "UNC_I_TxC_BL_NCB_INSERTS",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "BL NCB Egress Occupancy",
        "EventCode": "0x9",
        "EventName": "UNC_I_TxC_BL_NCB_OCCUPANCY",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "BL NCS Egress Cycles Full",
        "EventCode": "0x7",
        "EventName": "UNC_I_TxC_BL_NCS_CYCLES_FULL",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "BL NCS Egress Inserts",
        "EventCode": "0x4",
        "EventName": "UNC_I_TxC_BL_NCS_INSERTS",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "BL NCS Egress Occupancy",
        "EventCode": "0xA",
        "EventName": "UNC_I_TxC_BL_NCS_OCCUPANCY",
        "PerPkg": "1",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "No AD Egress Credit Stalls",
        "EventCode": "0x1A",
        "EventName": "UNC_I_TxR2_AD_STALL_CREDIT_CYCLES",
        "PerPkg": "1",
        "PublicDescription": "Counts the number times when it is not possible to issue a request to the R2PCIe because there are no AD Egress Credits available.",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "No BL Egress Credit Stalls",
        "EventCode": "0x1B",
        "EventName": "UNC_I_TxR2_BL_STALL_CREDIT_CYCLES",
        "PerPkg": "1",
        "PublicDescription": "Counts the number times when it is not possible to issue data to the R2PCIe because there are no BL Egress Credits available.",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Outbound Read Requests",
        "EventCode": "0xD",
        "EventName": "UNC_I_TxS_DATA_INSERTS_NCB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of requests issued to the switch (towards the devices).",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Outbound Read Requests",
        "EventCode": "0xE",
        "EventName": "UNC_I_TxS_DATA_INSERTS_NCS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of requests issued to the switch (towards the devices).",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "Outbound Request Queue Occupancy",
        "EventCode": "0xC",
        "EventName": "UNC_I_TxS_REQUEST_OCCUPANCY",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the number of outstanding outbound requests from the IRP to the switch (towards the devices).  This can be used in conjunction with the allocations event in order to calculate average latency of outbound requests.",
        "Unit": "IRP"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 0",
        "EventCode": "0x80",
        "EventName": "UNC_M2M_AG0_AD_CRD_ACQUIRED.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 1",
        "EventCode": "0x80",
        "EventName": "UNC_M2M_AG0_AD_CRD_ACQUIRED.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 2",
        "EventCode": "0x80",
        "EventName": "UNC_M2M_AG0_AD_CRD_ACQUIRED.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 3",
        "EventCode": "0x80",
        "EventName": "UNC_M2M_AG0_AD_CRD_ACQUIRED.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 4",
        "EventCode": "0x80",
        "EventName": "UNC_M2M_AG0_AD_CRD_ACQUIRED.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 5",
        "EventCode": "0x80",
        "EventName": "UNC_M2M_AG0_AD_CRD_ACQUIRED.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 0",
        "EventCode": "0x82",
        "EventName": "UNC_M2M_AG0_AD_CRD_OCCUPANCY.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 1",
        "EventCode": "0x82",
        "EventName": "UNC_M2M_AG0_AD_CRD_OCCUPANCY.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 2",
        "EventCode": "0x82",
        "EventName": "UNC_M2M_AG0_AD_CRD_OCCUPANCY.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 3",
        "EventCode": "0x82",
        "EventName": "UNC_M2M_AG0_AD_CRD_OCCUPANCY.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 4",
        "EventCode": "0x82",
        "EventName": "UNC_M2M_AG0_AD_CRD_OCCUPANCY.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 5",
        "EventCode": "0x82",
        "EventName": "UNC_M2M_AG0_AD_CRD_OCCUPANCY.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 0",
        "EventCode": "0x88",
        "EventName": "UNC_M2M_AG0_BL_CRD_ACQUIRED.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 1",
        "EventCode": "0x88",
        "EventName": "UNC_M2M_AG0_BL_CRD_ACQUIRED.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 2",
        "EventCode": "0x88",
        "EventName": "UNC_M2M_AG0_BL_CRD_ACQUIRED.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 3",
        "EventCode": "0x88",
        "EventName": "UNC_M2M_AG0_BL_CRD_ACQUIRED.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 4",
        "EventCode": "0x88",
        "EventName": "UNC_M2M_AG0_BL_CRD_ACQUIRED.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 5",
        "EventCode": "0x88",
        "EventName": "UNC_M2M_AG0_BL_CRD_ACQUIRED.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 0",
        "EventCode": "0x8A",
        "EventName": "UNC_M2M_AG0_BL_CRD_OCCUPANCY.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 1",
        "EventCode": "0x8A",
        "EventName": "UNC_M2M_AG0_BL_CRD_OCCUPANCY.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 2",
        "EventCode": "0x8A",
        "EventName": "UNC_M2M_AG0_BL_CRD_OCCUPANCY.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 3",
        "EventCode": "0x8A",
        "EventName": "UNC_M2M_AG0_BL_CRD_OCCUPANCY.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 4",
        "EventCode": "0x8A",
        "EventName": "UNC_M2M_AG0_BL_CRD_OCCUPANCY.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 5",
        "EventCode": "0x8A",
        "EventName": "UNC_M2M_AG0_BL_CRD_OCCUPANCY.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 0",
        "EventCode": "0x84",
        "EventName": "UNC_M2M_AG1_AD_CRD_ACQUIRED.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 1",
        "EventCode": "0x84",
        "EventName": "UNC_M2M_AG1_AD_CRD_ACQUIRED.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 2",
        "EventCode": "0x84",
        "EventName": "UNC_M2M_AG1_AD_CRD_ACQUIRED.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 3",
        "EventCode": "0x84",
        "EventName": "UNC_M2M_AG1_AD_CRD_ACQUIRED.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 4",
        "EventCode": "0x84",
        "EventName": "UNC_M2M_AG1_AD_CRD_ACQUIRED.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 5",
        "EventCode": "0x84",
        "EventName": "UNC_M2M_AG1_AD_CRD_ACQUIRED.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 0",
        "EventCode": "0x86",
        "EventName": "UNC_M2M_AG1_AD_CRD_OCCUPANCY.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 1",
        "EventCode": "0x86",
        "EventName": "UNC_M2M_AG1_AD_CRD_OCCUPANCY.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 2",
        "EventCode": "0x86",
        "EventName": "UNC_M2M_AG1_AD_CRD_OCCUPANCY.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 3",
        "EventCode": "0x86",
        "EventName": "UNC_M2M_AG1_AD_CRD_OCCUPANCY.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 4",
        "EventCode": "0x86",
        "EventName": "UNC_M2M_AG1_AD_CRD_OCCUPANCY.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 5",
        "EventCode": "0x86",
        "EventName": "UNC_M2M_AG1_AD_CRD_OCCUPANCY.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 0",
        "EventCode": "0x8E",
        "EventName": "UNC_M2M_AG1_BL_CRD_OCCUPANCY.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 1",
        "EventCode": "0x8E",
        "EventName": "UNC_M2M_AG1_BL_CRD_OCCUPANCY.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 2",
        "EventCode": "0x8E",
        "EventName": "UNC_M2M_AG1_BL_CRD_OCCUPANCY.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 3",
        "EventCode": "0x8E",
        "EventName": "UNC_M2M_AG1_BL_CRD_OCCUPANCY.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 4",
        "EventCode": "0x8E",
        "EventName": "UNC_M2M_AG1_BL_CRD_OCCUPANCY.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 5",
        "EventCode": "0x8E",
        "EventName": "UNC_M2M_AG1_BL_CRD_OCCUPANCY.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 0",
        "EventCode": "0x8C",
        "EventName": "UNC_M2M_AG1_BL_CREDITS_ACQUIRED.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 1",
        "EventCode": "0x8C",
        "EventName": "UNC_M2M_AG1_BL_CREDITS_ACQUIRED.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 2",
        "EventCode": "0x8C",
        "EventName": "UNC_M2M_AG1_BL_CREDITS_ACQUIRED.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 3",
        "EventCode": "0x8C",
        "EventName": "UNC_M2M_AG1_BL_CREDITS_ACQUIRED.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 4",
        "EventCode": "0x8C",
        "EventName": "UNC_M2M_AG1_BL_CREDITS_ACQUIRED.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 5",
        "EventCode": "0x8C",
        "EventName": "UNC_M2M_AG1_BL_CREDITS_ACQUIRED.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Traffic in which the M2M to iMC Bypass was not taken",
        "EventCode": "0x22",
        "EventName": "UNC_M2M_BYPASS_M2M_Egress.NOT_TAKEN",
        "PerPkg": "1",
        "PublicDescription": "Counts traffic in which the M2M (Mesh to Memory) to iMC (Memory Controller) bypass was not taken",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M to iMC Bypass; Taken",
        "EventCode": "0x22",
        "EventName": "UNC_M2M_BYPASS_M2M_Egress.TAKEN",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M to iMC Bypass; Not Taken",
        "EventCode": "0x21",
        "EventName": "UNC_M2M_BYPASS_M2M_INGRESS.NOT_TAKEN",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M to iMC Bypass; Taken",
        "EventCode": "0x21",
        "EventName": "UNC_M2M_BYPASS_M2M_INGRESS.TAKEN",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles - at UCLK",
        "EventName": "UNC_M2M_CLOCKTICKS",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Clockticks",
        "EventCode": "0xC0",
        "EventName": "UNC_M2M_CMS_CLOCKTICKS",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles when direct to core mode (which bypasses the CHA) was disabled",
        "EventCode": "0x24",
        "EventName": "UNC_M2M_DIRECT2CORE_NOT_TAKEN_DIRSTATE",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles when direct to core mode (which bypasses the CHA) was disabled",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Messages sent direct to core (bypassing the CHA)",
        "EventCode": "0x23",
        "EventName": "UNC_M2M_DIRECT2CORE_TAKEN",
        "PerPkg": "1",
        "PublicDescription": "Counts when messages were sent direct to core (bypassing the CHA)",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Number of reads in which direct to core transaction were overridden",
        "EventCode": "0x25",
        "EventName": "UNC_M2M_DIRECT2CORE_TXN_OVERRIDE",
        "PerPkg": "1",
        "PublicDescription": "Counts reads in which direct to core transactions (which would have bypassed the CHA) were overridden",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Number of reads in which direct to Intel(R) UPI transactions were overridden",
        "EventCode": "0x28",
        "EventName": "UNC_M2M_DIRECT2UPI_NOT_TAKEN_CREDITS",
        "PerPkg": "1",
        "PublicDescription": "Counts reads in which direct to Intel(R) Ultra Path Interconnect (UPI) transactions (which would have bypassed the CHA) were overridden",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles when direct to Intel(R) UPI was disabled",
        "EventCode": "0x27",
        "EventName": "UNC_M2M_DIRECT2UPI_NOT_TAKEN_DIRSTATE",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles when the ability to send messages direct to the Intel(R) Ultra Path Interconnect (bypassing the CHA) was disabled",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Messages sent direct to the Intel(R) UPI",
        "EventCode": "0x26",
        "EventName": "UNC_M2M_DIRECT2UPI_TAKEN",
        "PerPkg": "1",
        "PublicDescription": "Counts when messages were sent direct to the Intel(R) Ultra Path Interconnect (bypassing the CHA)",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Number of reads that a message sent direct2 Intel(R) UPI was overridden",
        "EventCode": "0x29",
        "EventName": "UNC_M2M_DIRECT2UPI_TXN_OVERRIDE",
        "PerPkg": "1",
        "PublicDescription": "Counts when a read message that was sent direct to the Intel(R) Ultra Path Interconnect (bypassing the CHA) was overridden",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Hit; On NonDirty Line in A State",
        "EventCode": "0x2A",
        "EventName": "UNC_M2M_DIRECTORY_HIT.CLEAN_A",
        "PerPkg": "1",
        "UMask": "0x80",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Hit; On NonDirty Line in I State",
        "EventCode": "0x2A",
        "EventName": "UNC_M2M_DIRECTORY_HIT.CLEAN_I",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Hit; On NonDirty Line in L State",
        "EventCode": "0x2A",
        "EventName": "UNC_M2M_DIRECTORY_HIT.CLEAN_P",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Hit; On NonDirty Line in S State",
        "EventCode": "0x2A",
        "EventName": "UNC_M2M_DIRECTORY_HIT.CLEAN_S",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Hit; On Dirty Line in A State",
        "EventCode": "0x2A",
        "EventName": "UNC_M2M_DIRECTORY_HIT.DIRTY_A",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Hit; On Dirty Line in I State",
        "EventCode": "0x2A",
        "EventName": "UNC_M2M_DIRECTORY_HIT.DIRTY_I",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Hit; On Dirty Line in L State",
        "EventCode": "0x2A",
        "EventName": "UNC_M2M_DIRECTORY_HIT.DIRTY_P",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Hit; On Dirty Line in S State",
        "EventCode": "0x2A",
        "EventName": "UNC_M2M_DIRECTORY_HIT.DIRTY_S",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Multi-socket cacheline Directory lookups (any state found)",
        "EventCode": "0x2D",
        "EventName": "UNC_M2M_DIRECTORY_LOOKUP.ANY",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) looks into the multi-socket cacheline Directory state, and found the cacheline marked in Any State (A, I, S or unused)",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Multi-socket cacheline Directory lookups (cacheline found in A state)",
        "EventCode": "0x2D",
        "EventName": "UNC_M2M_DIRECTORY_LOOKUP.STATE_A",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) looks into the multi-socket cacheline Directory state, and found the cacheline marked in the A (SnoopAll) state, indicating the cacheline is stored in another socket in any state, and we must snoop the other sockets to make sure we get the latest data.  The data may be stored in any state in the local socket.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Multi-socket cacheline Directory lookup (cacheline found in I state)",
        "EventCode": "0x2D",
        "EventName": "UNC_M2M_DIRECTORY_LOOKUP.STATE_I",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) looks into the multi-socket cacheline Directory state , and found the cacheline marked in the I (Invalid) state indicating the cacheline is not stored in another socket, and so there is no need to snoop the other sockets for the latest data.  The data may be stored in any state in the local socket.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Multi-socket cacheline Directory lookup (cacheline found in S state)",
        "EventCode": "0x2D",
        "EventName": "UNC_M2M_DIRECTORY_LOOKUP.STATE_S",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) looks into the multi-socket cacheline Directory state , and found the cacheline marked in the S (Shared) state indicating the cacheline is either stored in another socket in the S(hared) state , and so there is no need to snoop the other sockets for the latest data.  The data may be stored in any state in the local socket.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Miss; On NonDirty Line in A State",
        "EventCode": "0x2B",
        "EventName": "UNC_M2M_DIRECTORY_MISS.CLEAN_A",
        "PerPkg": "1",
        "UMask": "0x80",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Miss; On NonDirty Line in I State",
        "EventCode": "0x2B",
        "EventName": "UNC_M2M_DIRECTORY_MISS.CLEAN_I",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Miss; On NonDirty Line in L State",
        "EventCode": "0x2B",
        "EventName": "UNC_M2M_DIRECTORY_MISS.CLEAN_P",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Miss; On NonDirty Line in S State",
        "EventCode": "0x2B",
        "EventName": "UNC_M2M_DIRECTORY_MISS.CLEAN_S",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Miss; On Dirty Line in A State",
        "EventCode": "0x2B",
        "EventName": "UNC_M2M_DIRECTORY_MISS.DIRTY_A",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Miss; On Dirty Line in I State",
        "EventCode": "0x2B",
        "EventName": "UNC_M2M_DIRECTORY_MISS.DIRTY_I",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Miss; On Dirty Line in L State",
        "EventCode": "0x2B",
        "EventName": "UNC_M2M_DIRECTORY_MISS.DIRTY_P",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Directory Miss; On Dirty Line in S State",
        "EventCode": "0x2B",
        "EventName": "UNC_M2M_DIRECTORY_MISS.DIRTY_S",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Multi-socket cacheline Directory update from A to I",
        "EventCode": "0x2E",
        "EventName": "UNC_M2M_DIRECTORY_UPDATE.A2I",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) updates the multi-socket cacheline Directory state from A (SnoopAll) to I (Invalid)",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Multi-socket cacheline Directory update from A to S",
        "EventCode": "0x2E",
        "EventName": "UNC_M2M_DIRECTORY_UPDATE.A2S",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) updates the multi-socket cacheline Directory state from A (SnoopAll) to S (Shared)",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Multi-socket cacheline Directory update from/to Any state",
        "EventCode": "0x2E",
        "EventName": "UNC_M2M_DIRECTORY_UPDATE.ANY",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) updates the multi-socket cacheline Directory to a new state",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Multi-socket cacheline Directory update from I to A",
        "EventCode": "0x2E",
        "EventName": "UNC_M2M_DIRECTORY_UPDATE.I2A",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) updates the multi-socket cacheline Directory state from I (Invalid) to A (SnoopAll)",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Multi-socket cacheline Directory update from I to S",
        "EventCode": "0x2E",
        "EventName": "UNC_M2M_DIRECTORY_UPDATE.I2S",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) updates the multi-socket cacheline Directory state from I (Invalid) to S (Shared)",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Multi-socket cacheline Directory update from S to A",
        "EventCode": "0x2E",
        "EventName": "UNC_M2M_DIRECTORY_UPDATE.S2A",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) updates the multi-socket cacheline Directory state from S (Shared) to A (SnoopAll)",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Multi-socket cacheline Directory update from S to I",
        "EventCode": "0x2E",
        "EventName": "UNC_M2M_DIRECTORY_UPDATE.S2I",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) updates the multi-socket cacheline Directory state from S (Shared) to I (Invalid)",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Egress Blocking due to Ordering requirements; Down",
        "EventCode": "0xAE",
        "EventName": "UNC_M2M_EGRESS_ORDERING.IV_SNOOPGO_DN",
        "PerPkg": "1",
        "PublicDescription": "Counts number of cycles IV was blocked in the TGR Egress due to SNP/GO Ordering requirements",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Egress Blocking due to Ordering requirements; Up",
        "EventCode": "0xAE",
        "EventName": "UNC_M2M_EGRESS_ORDERING.IV_SNOOPGO_UP",
        "PerPkg": "1",
        "PublicDescription": "Counts number of cycles IV was blocked in the TGR Egress due to SNP/GO Ordering requirements",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "FaST wire asserted; Horizontal",
        "EventCode": "0xA5",
        "EventName": "UNC_M2M_FAST_ASSERTED.HORZ",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles either the local or incoming distress signals are asserted.  Incoming distress includes up, dn and across.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "FaST wire asserted; Vertical",
        "EventCode": "0xA5",
        "EventName": "UNC_M2M_FAST_ASSERTED.VERT",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles either the local or incoming distress signals are asserted.  Incoming distress includes up, dn and across.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal AD Ring In Use; Left and Even",
        "EventCode": "0xA7",
        "EventName": "UNC_M2M_HORZ_RING_AD_IN_USE.LEFT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.  We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal AD Ring In Use; Left and Odd",
        "EventCode": "0xA7",
        "EventName": "UNC_M2M_HORZ_RING_AD_IN_USE.LEFT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.  We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal AD Ring In Use; Right and Even",
        "EventCode": "0xA7",
        "EventName": "UNC_M2M_HORZ_RING_AD_IN_USE.RIGHT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.  We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal AD Ring In Use; Right and Odd",
        "EventCode": "0xA7",
        "EventName": "UNC_M2M_HORZ_RING_AD_IN_USE.RIGHT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.  We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal AK Ring In Use; Left and Even",
        "EventCode": "0xA9",
        "EventName": "UNC_M2M_HORZ_RING_AK_IN_USE.LEFT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal AK Ring In Use; Left and Odd",
        "EventCode": "0xA9",
        "EventName": "UNC_M2M_HORZ_RING_AK_IN_USE.LEFT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal AK Ring In Use; Right and Even",
        "EventCode": "0xA9",
        "EventName": "UNC_M2M_HORZ_RING_AK_IN_USE.RIGHT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal AK Ring In Use; Right and Odd",
        "EventCode": "0xA9",
        "EventName": "UNC_M2M_HORZ_RING_AK_IN_USE.RIGHT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal BL Ring in Use; Left and Even",
        "EventCode": "0xAB",
        "EventName": "UNC_M2M_HORZ_RING_BL_IN_USE.LEFT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal BL Ring in Use; Left and Odd",
        "EventCode": "0xAB",
        "EventName": "UNC_M2M_HORZ_RING_BL_IN_USE.LEFT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal BL Ring in Use; Right and Even",
        "EventCode": "0xAB",
        "EventName": "UNC_M2M_HORZ_RING_BL_IN_USE.RIGHT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal BL Ring in Use; Right and Odd",
        "EventCode": "0xAB",
        "EventName": "UNC_M2M_HORZ_RING_BL_IN_USE.RIGHT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal IV Ring in Use; Left",
        "EventCode": "0xAD",
        "EventName": "UNC_M2M_HORZ_RING_IV_IN_USE.LEFT",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal IV 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.  There is only 1 IV ring.  Therefore, if one wants to monitor the Even ring, they should select both UP_EVEN and DN_EVEN.  To monitor the Odd ring, they should select both UP_ODD and DN_ODD.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Horizontal IV Ring in Use; Right",
        "EventCode": "0xAD",
        "EventName": "UNC_M2M_HORZ_RING_IV_IN_USE.RIGHT",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal IV 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.  There is only 1 IV ring.  Therefore, if one wants to monitor the Even ring, they should select both UP_EVEN and DN_EVEN.  To monitor the Odd ring, they should select both UP_ODD and DN_ODD.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Reads to iMC issued",
        "EventCode": "0x37",
        "EventName": "UNC_M2M_IMC_READS.ALL",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) issues reads to the iMC (Memory Controller).",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M Reads Issued to iMC; All, regardless of priority.",
        "EventCode": "0x37",
        "EventName": "UNC_M2M_IMC_READS.FROM_TRANSGRESS",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M Reads Issued to iMC; Critical Priority",
        "EventCode": "0x37",
        "EventName": "UNC_M2M_IMC_READS.ISOCH",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Reads to iMC issued at Normal Priority (Non-Isochronous)",
        "EventCode": "0x37",
        "EventName": "UNC_M2M_IMC_READS.NORMAL",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) issues reads to the iMC (Memory Controller).  It only counts  normal priority non-isochronous reads.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Writes to iMC issued",
        "EventCode": "0x38",
        "EventName": "UNC_M2M_IMC_WRITES.ALL",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) issues writes to the iMC (Memory Controller).",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M Writes Issued to iMC; All, regardless of priority.",
        "EventCode": "0x38",
        "EventName": "UNC_M2M_IMC_WRITES.FROM_TRANSGRESS",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M Writes Issued to iMC; Full Line Non-ISOCH",
        "EventCode": "0x38",
        "EventName": "UNC_M2M_IMC_WRITES.FULL",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M Writes Issued to iMC; ISOCH Full Line",
        "EventCode": "0x38",
        "EventName": "UNC_M2M_IMC_WRITES.FULL_ISOCH",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M Writes Issued to iMC; All, regardless of priority.",
        "EventCode": "0x38",
        "EventName": "UNC_M2M_IMC_WRITES.NI",
        "PerPkg": "1",
        "UMask": "0x80",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Partial Non-Isochronous writes to the iMC",
        "EventCode": "0x38",
        "EventName": "UNC_M2M_IMC_WRITES.PARTIAL",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) issues partial writes to the iMC (Memory Controller).  It only counts normal priority non-isochronous writes.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M Writes Issued to iMC; ISOCH Partial",
        "EventCode": "0x38",
        "EventName": "UNC_M2M_IMC_WRITES.PARTIAL_ISOCH",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Number Packet Header Matches; MC Match",
        "EventCode": "0x4C",
        "EventName": "UNC_M2M_PKT_MATCH.MC",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Number Packet Header Matches; Mesh Match",
        "EventCode": "0x4C",
        "EventName": "UNC_M2M_PKT_MATCH.MESH",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Prefetch CAM Cycles Full",
        "EventCode": "0x53",
        "EventName": "UNC_M2M_PREFCAM_CYCLES_FULL",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Prefetch CAM Cycles Not Empty",
        "EventCode": "0x54",
        "EventName": "UNC_M2M_PREFCAM_CYCLES_NE",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Prefetch requests that got turn into a demand request",
        "EventCode": "0x56",
        "EventName": "UNC_M2M_PREFCAM_DEMAND_PROMOTIONS",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) promotes a outstanding request in the prefetch queue due to a subsequent demand read request that entered the M2M with the same address.  Explanatory Side Note: The Prefetch queue is made of CAM (Content Addressable Memory)",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Inserts into the Memory Controller Prefetch Queue",
        "EventCode": "0x57",
        "EventName": "UNC_M2M_PREFCAM_INSERTS",
        "PerPkg": "1",
        "PublicDescription": "Counts when the M2M (Mesh to Memory) receives a prefetch request and inserts it into its outstanding prefetch queue.  Explanatory Side Note: the prefect queue is made from CAM: Content Addressable Memory",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Prefetch CAM Occupancy",
        "EventCode": "0x55",
        "EventName": "UNC_M2M_PREFCAM_OCCUPANCY",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Messages that bounced on the Horizontal Ring.; AD",
        "EventCode": "0xA1",
        "EventName": "UNC_M2M_RING_BOUNCES_HORZ.AD",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Horizontal ring that were bounced, by ring type.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Messages that bounced on the Horizontal Ring.; AK",
        "EventCode": "0xA1",
        "EventName": "UNC_M2M_RING_BOUNCES_HORZ.AK",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Horizontal ring that were bounced, by ring type.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Messages that bounced on the Horizontal Ring.; BL",
        "EventCode": "0xA1",
        "EventName": "UNC_M2M_RING_BOUNCES_HORZ.BL",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Horizontal ring that were bounced, by ring type.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Messages that bounced on the Horizontal Ring.; IV",
        "EventCode": "0xA1",
        "EventName": "UNC_M2M_RING_BOUNCES_HORZ.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Horizontal ring that were bounced, by ring type.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Messages that bounced on the Vertical Ring.; AD",
        "EventCode": "0xA0",
        "EventName": "UNC_M2M_RING_BOUNCES_VERT.AD",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Vertical ring that were bounced, by ring type.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Messages that bounced on the Vertical Ring.; Acknowledgements to core",
        "EventCode": "0xA0",
        "EventName": "UNC_M2M_RING_BOUNCES_VERT.AK",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Vertical ring that were bounced, by ring type.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Messages that bounced on the Vertical Ring.; Data Responses to core",
        "EventCode": "0xA0",
        "EventName": "UNC_M2M_RING_BOUNCES_VERT.BL",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Vertical ring that were bounced, by ring type.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Messages that bounced on the Vertical Ring.; Snoops of processor's cache.",
        "EventCode": "0xA0",
        "EventName": "UNC_M2M_RING_BOUNCES_VERT.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Vertical ring that were bounced, by ring type.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Sink Starvation on Horizontal Ring; AD",
        "EventCode": "0xA3",
        "EventName": "UNC_M2M_RING_SINK_STARVED_HORZ.AD",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Sink Starvation on Horizontal Ring; AK",
        "EventCode": "0xA3",
        "EventName": "UNC_M2M_RING_SINK_STARVED_HORZ.AK",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Sink Starvation on Horizontal Ring; Acknowledgements to Agent 1",
        "EventCode": "0xA3",
        "EventName": "UNC_M2M_RING_SINK_STARVED_HORZ.AK_AG1",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Sink Starvation on Horizontal Ring; BL",
        "EventCode": "0xA3",
        "EventName": "UNC_M2M_RING_SINK_STARVED_HORZ.BL",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Sink Starvation on Horizontal Ring; IV",
        "EventCode": "0xA3",
        "EventName": "UNC_M2M_RING_SINK_STARVED_HORZ.IV",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Sink Starvation on Vertical Ring; AD",
        "EventCode": "0xA2",
        "EventName": "UNC_M2M_RING_SINK_STARVED_VERT.AD",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Sink Starvation on Vertical Ring; Acknowledgements to core",
        "EventCode": "0xA2",
        "EventName": "UNC_M2M_RING_SINK_STARVED_VERT.AK",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Sink Starvation on Vertical Ring; Data Responses to core",
        "EventCode": "0xA2",
        "EventName": "UNC_M2M_RING_SINK_STARVED_VERT.BL",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Sink Starvation on Vertical Ring; Snoops of processor's cache.",
        "EventCode": "0xA2",
        "EventName": "UNC_M2M_RING_SINK_STARVED_VERT.IV",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Source Throttle",
        "EventCode": "0xA4",
        "EventName": "UNC_M2M_RING_SRC_THRTL",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_M2M_RPQ_CYCLES_SPEC_CREDITS.CHN0",
        "Deprecated": "1",
        "EventCode": "0x44",
        "EventName": "UNC_M2M_RPQ_CYCLES_NO_SPEC_CREDITS.CHN0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_M2M_RPQ_CYCLES_SPEC_CREDITS.CHN1",
        "Deprecated": "1",
        "EventCode": "0x44",
        "EventName": "UNC_M2M_RPQ_CYCLES_NO_SPEC_CREDITS.CHN1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_M2M_RPQ_CYCLES_SPEC_CREDITS.CHN2",
        "Deprecated": "1",
        "EventCode": "0x44",
        "EventName": "UNC_M2M_RPQ_CYCLES_NO_SPEC_CREDITS.CHN2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M to iMC RPQ Cycles w/Credits - Regular; Channel 0",
        "EventCode": "0x43",
        "EventName": "UNC_M2M_RPQ_CYCLES_REG_CREDITS.CHN0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M to iMC RPQ Cycles w/Credits - Regular; Channel 1",
        "EventCode": "0x43",
        "EventName": "UNC_M2M_RPQ_CYCLES_REG_CREDITS.CHN1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M to iMC RPQ Cycles w/Credits - Regular; Channel 2",
        "EventCode": "0x43",
        "EventName": "UNC_M2M_RPQ_CYCLES_REG_CREDITS.CHN2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M to iMC RPQ Cycles w/Credits - Special; Channel 0",
        "EventCode": "0x44",
        "EventName": "UNC_M2M_RPQ_CYCLES_SPEC_CREDITS.CHN0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M to iMC RPQ Cycles w/Credits - Special; Channel 1",
        "EventCode": "0x44",
        "EventName": "UNC_M2M_RPQ_CYCLES_SPEC_CREDITS.CHN1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M to iMC RPQ Cycles w/Credits - Special; Channel 2",
        "EventCode": "0x44",
        "EventName": "UNC_M2M_RPQ_CYCLES_SPEC_CREDITS.CHN2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AD Ingress (from CMS) Full",
        "EventCode": "0x4",
        "EventName": "UNC_M2M_RxC_AD_CYCLES_FULL",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AD Ingress (from CMS) Not Empty",
        "EventCode": "0x3",
        "EventName": "UNC_M2M_RxC_AD_CYCLES_NE",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AD Ingress (from CMS) Queue Inserts",
        "EventCode": "0x1",
        "EventName": "UNC_M2M_RxC_AD_INSERTS",
        "PerPkg": "1",
        "PublicDescription": "Counts when the a new entry is Received(RxC) and then added to the AD (Address Ring) Ingress Queue from the CMS (Common Mesh Stop).  This is generally used for reads, and",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AD Ingress (from CMS) Occupancy",
        "EventCode": "0x2",
        "EventName": "UNC_M2M_RxC_AD_OCCUPANCY",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Ingress (from CMS) Full",
        "EventCode": "0x8",
        "EventName": "UNC_M2M_RxC_BL_CYCLES_FULL",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Ingress (from CMS) Not Empty",
        "EventCode": "0x7",
        "EventName": "UNC_M2M_RxC_BL_CYCLES_NE",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Ingress (from CMS) Allocations",
        "EventCode": "0x5",
        "EventName": "UNC_M2M_RxC_BL_INSERTS",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Ingress (from CMS) Occupancy",
        "EventCode": "0x6",
        "EventName": "UNC_M2M_RxC_BL_OCCUPANCY",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; AD - Bounce",
        "EventCode": "0xB4",
        "EventName": "UNC_M2M_RxR_BUSY_STARVED.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, because a message from the other queue has higher priority",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; AD - Credit",
        "EventCode": "0xB4",
        "EventName": "UNC_M2M_RxR_BUSY_STARVED.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, because a message from the other queue has higher priority",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; BL - Bounce",
        "EventCode": "0xB4",
        "EventName": "UNC_M2M_RxR_BUSY_STARVED.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, because a message from the other queue has higher priority",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; BL - Credit",
        "EventCode": "0xB4",
        "EventName": "UNC_M2M_RxR_BUSY_STARVED.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, because a message from the other queue has higher priority",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; AD - Bounce",
        "EventCode": "0xB2",
        "EventName": "UNC_M2M_RxR_BYPASS.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; AD - Credit",
        "EventCode": "0xB2",
        "EventName": "UNC_M2M_RxR_BYPASS.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; AK - Bounce",
        "EventCode": "0xB2",
        "EventName": "UNC_M2M_RxR_BYPASS.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; BL - Bounce",
        "EventCode": "0xB2",
        "EventName": "UNC_M2M_RxR_BYPASS.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; BL - Credit",
        "EventCode": "0xB2",
        "EventName": "UNC_M2M_RxR_BYPASS.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; IV - Bounce",
        "EventCode": "0xB2",
        "EventName": "UNC_M2M_RxR_BYPASS.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; AD - Bounce",
        "EventCode": "0xB3",
        "EventName": "UNC_M2M_RxR_CRD_STARVED.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; AD - Credit",
        "EventCode": "0xB3",
        "EventName": "UNC_M2M_RxR_CRD_STARVED.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; AK - Bounce",
        "EventCode": "0xB3",
        "EventName": "UNC_M2M_RxR_CRD_STARVED.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; BL - Bounce",
        "EventCode": "0xB3",
        "EventName": "UNC_M2M_RxR_CRD_STARVED.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; BL - Credit",
        "EventCode": "0xB3",
        "EventName": "UNC_M2M_RxR_CRD_STARVED.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; IFV - Credit",
        "EventCode": "0xB3",
        "EventName": "UNC_M2M_RxR_CRD_STARVED.IFV",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x80",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; IV - Bounce",
        "EventCode": "0xB3",
        "EventName": "UNC_M2M_RxR_CRD_STARVED.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; AD - Bounce",
        "EventCode": "0xB1",
        "EventName": "UNC_M2M_RxR_INSERTS.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; AD - Credit",
        "EventCode": "0xB1",
        "EventName": "UNC_M2M_RxR_INSERTS.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; AK - Bounce",
        "EventCode": "0xB1",
        "EventName": "UNC_M2M_RxR_INSERTS.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; BL - Bounce",
        "EventCode": "0xB1",
        "EventName": "UNC_M2M_RxR_INSERTS.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; BL - Credit",
        "EventCode": "0xB1",
        "EventName": "UNC_M2M_RxR_INSERTS.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; IV - Bounce",
        "EventCode": "0xB1",
        "EventName": "UNC_M2M_RxR_INSERTS.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; AD - Bounce",
        "EventCode": "0xB0",
        "EventName": "UNC_M2M_RxR_OCCUPANCY.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; AD - Credit",
        "EventCode": "0xB0",
        "EventName": "UNC_M2M_RxR_OCCUPANCY.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; AK - Bounce",
        "EventCode": "0xB0",
        "EventName": "UNC_M2M_RxR_OCCUPANCY.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; BL - Bounce",
        "EventCode": "0xB0",
        "EventName": "UNC_M2M_RxR_OCCUPANCY.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; BL - Credit",
        "EventCode": "0xB0",
        "EventName": "UNC_M2M_RxR_OCCUPANCY.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; IV - Bounce",
        "EventCode": "0xB0",
        "EventName": "UNC_M2M_RxR_OCCUPANCY.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 0",
        "EventCode": "0xD0",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 1",
        "EventCode": "0xD0",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 2",
        "EventCode": "0xD0",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 3",
        "EventCode": "0xD0",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 4",
        "EventCode": "0xD0",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 5",
        "EventCode": "0xD0",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 0",
        "EventCode": "0xD2",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 1",
        "EventCode": "0xD2",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 2",
        "EventCode": "0xD2",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 3",
        "EventCode": "0xD2",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 4",
        "EventCode": "0xD2",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 5",
        "EventCode": "0xD2",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 0",
        "EventCode": "0xD4",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 1",
        "EventCode": "0xD4",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 2",
        "EventCode": "0xD4",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 3",
        "EventCode": "0xD4",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 4",
        "EventCode": "0xD4",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 5",
        "EventCode": "0xD4",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 0",
        "EventCode": "0xD6",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 1",
        "EventCode": "0xD6",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 2",
        "EventCode": "0xD6",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 3",
        "EventCode": "0xD6",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 4",
        "EventCode": "0xD6",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 5",
        "EventCode": "0xD6",
        "EventName": "UNC_M2M_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Number AD Ingress Credits",
        "EventCode": "0x41",
        "EventName": "UNC_M2M_TGR_AD_CREDITS",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Number BL Ingress Credits",
        "EventCode": "0x42",
        "EventName": "UNC_M2M_TGR_BL_CREDITS",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Cycles Full; Channel 0",
        "EventCode": "0x45",
        "EventName": "UNC_M2M_TRACKER_CYCLES_FULL.CH0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Cycles Full; Channel 1",
        "EventCode": "0x45",
        "EventName": "UNC_M2M_TRACKER_CYCLES_FULL.CH1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Cycles Full; Channel 2",
        "EventCode": "0x45",
        "EventName": "UNC_M2M_TRACKER_CYCLES_FULL.CH2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Cycles Not Empty; Channel 0",
        "EventCode": "0x46",
        "EventName": "UNC_M2M_TRACKER_CYCLES_NE.CH0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Cycles Not Empty; Channel 1",
        "EventCode": "0x46",
        "EventName": "UNC_M2M_TRACKER_CYCLES_NE.CH1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Cycles Not Empty; Channel 2",
        "EventCode": "0x46",
        "EventName": "UNC_M2M_TRACKER_CYCLES_NE.CH2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Inserts; Channel 0",
        "EventCode": "0x49",
        "EventName": "UNC_M2M_TRACKER_INSERTS.CH0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Inserts; Channel 1",
        "EventCode": "0x49",
        "EventName": "UNC_M2M_TRACKER_INSERTS.CH1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Inserts; Channel 2",
        "EventCode": "0x49",
        "EventName": "UNC_M2M_TRACKER_INSERTS.CH2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Occupancy; Channel 0",
        "EventCode": "0x47",
        "EventName": "UNC_M2M_TRACKER_OCCUPANCY.CH0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Occupancy; Channel 1",
        "EventCode": "0x47",
        "EventName": "UNC_M2M_TRACKER_OCCUPANCY.CH1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Tracker Occupancy; Channel 2",
        "EventCode": "0x47",
        "EventName": "UNC_M2M_TRACKER_OCCUPANCY.CH2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Data Pending Occupancy",
        "EventCode": "0x48",
        "EventName": "UNC_M2M_TRACKER_PENDING_OCCUPANCY",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AD Egress (to CMS) Credit Acquired",
        "EventCode": "0xD",
        "EventName": "UNC_M2M_TxC_AD_CREDITS_ACQUIRED",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AD Egress (to CMS) Credits Occupancy",
        "EventCode": "0xE",
        "EventName": "UNC_M2M_TxC_AD_CREDIT_OCCUPANCY",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AD Egress (to CMS) Full",
        "EventCode": "0xC",
        "EventName": "UNC_M2M_TxC_AD_CYCLES_FULL",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AD Egress (to CMS) Not Empty",
        "EventCode": "0xB",
        "EventName": "UNC_M2M_TxC_AD_CYCLES_NE",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AD Egress (to CMS) Allocations",
        "EventCode": "0x9",
        "EventName": "UNC_M2M_TxC_AD_INSERTS",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles with No AD Egress (to CMS) Credits",
        "EventCode": "0xF",
        "EventName": "UNC_M2M_TxC_AD_NO_CREDIT_CYCLES",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles Stalled with No AD Egress (to CMS) Credits",
        "EventCode": "0x10",
        "EventName": "UNC_M2M_TxC_AD_NO_CREDIT_STALLED",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AD Egress (to CMS) Occupancy",
        "EventCode": "0xA",
        "EventName": "UNC_M2M_TxC_AD_OCCUPANCY",
        "PerPkg": "1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Outbound Ring Transactions on AK; CRD Transactions to Cbo",
        "EventCode": "0x39",
        "EventName": "UNC_M2M_TxC_AK.CRD_CBO",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Outbound Ring Transactions on AK; NDR Transactions",
        "EventCode": "0x39",
        "EventName": "UNC_M2M_TxC_AK.NDR",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Credit Acquired; Common Mesh Stop - Near Side",
        "EventCode": "0x1D",
        "EventName": "UNC_M2M_TxC_AK_CREDITS_ACQUIRED.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Credit Acquired; Common Mesh Stop - Far Side",
        "EventCode": "0x1D",
        "EventName": "UNC_M2M_TxC_AK_CREDITS_ACQUIRED.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Credits Occupancy; Common Mesh Stop - Near Side",
        "EventCode": "0x1E",
        "EventName": "UNC_M2M_TxC_AK_CREDIT_OCCUPANCY.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Credits Occupancy; Common Mesh Stop - Far Side",
        "EventCode": "0x1E",
        "EventName": "UNC_M2M_TxC_AK_CREDIT_OCCUPANCY.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Full; All",
        "EventCode": "0x14",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_FULL.ALL",
        "PerPkg": "1",
        "UMask": "0x3",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Full; Common Mesh Stop - Near Side",
        "EventCode": "0x14",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_FULL.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Full; Common Mesh Stop - Far Side",
        "EventCode": "0x14",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_FULL.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Full; Read Credit Request",
        "EventCode": "0x14",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_FULL.RDCRD0",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Full; Read Credit Request",
        "EventCode": "0x14",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_FULL.RDCRD1",
        "PerPkg": "1",
        "UMask": "0x88",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Full; Write Compare Request",
        "EventCode": "0x14",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_FULL.WRCMP0",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Full; Write Compare Request",
        "EventCode": "0x14",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_FULL.WRCMP1",
        "PerPkg": "1",
        "UMask": "0xa0",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Full; Write Credit Request",
        "EventCode": "0x14",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_FULL.WRCRD0",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Full; Write Credit Request",
        "EventCode": "0x14",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_FULL.WRCRD1",
        "PerPkg": "1",
        "UMask": "0x90",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Not Empty; All",
        "EventCode": "0x13",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_NE.ALL",
        "PerPkg": "1",
        "UMask": "0x3",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Not Empty; Common Mesh Stop - Near Side",
        "EventCode": "0x13",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_NE.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Not Empty; Common Mesh Stop - Far Side",
        "EventCode": "0x13",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_NE.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Not Empty; Read Credit Request",
        "EventCode": "0x13",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_NE.RDCRD",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Not Empty; Write Compare Request",
        "EventCode": "0x13",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_NE.WRCMP",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Not Empty; Write Credit Request",
        "EventCode": "0x13",
        "EventName": "UNC_M2M_TxC_AK_CYCLES_NE.WRCRD",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Allocations; All",
        "EventCode": "0x11",
        "EventName": "UNC_M2M_TxC_AK_INSERTS.ALL",
        "PerPkg": "1",
        "UMask": "0x3",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Allocations; Common Mesh Stop - Near Side",
        "EventCode": "0x11",
        "EventName": "UNC_M2M_TxC_AK_INSERTS.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Allocations; Common Mesh Stop - Far Side",
        "EventCode": "0x11",
        "EventName": "UNC_M2M_TxC_AK_INSERTS.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Allocations; Prefetch Read Cam Hit",
        "EventCode": "0x11",
        "EventName": "UNC_M2M_TxC_AK_INSERTS.PREF_RD_CAM_HIT",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Allocations; Read Credit Request",
        "EventCode": "0x11",
        "EventName": "UNC_M2M_TxC_AK_INSERTS.RDCRD",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Allocations; Write Compare Request",
        "EventCode": "0x11",
        "EventName": "UNC_M2M_TxC_AK_INSERTS.WRCMP",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Allocations; Write Credit Request",
        "EventCode": "0x11",
        "EventName": "UNC_M2M_TxC_AK_INSERTS.WRCRD",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles with No AK Egress (to CMS) Credits; Common Mesh Stop - Near Side",
        "EventCode": "0x1F",
        "EventName": "UNC_M2M_TxC_AK_NO_CREDIT_CYCLES.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles with No AK Egress (to CMS) Credits; Common Mesh Stop - Far Side",
        "EventCode": "0x1F",
        "EventName": "UNC_M2M_TxC_AK_NO_CREDIT_CYCLES.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles Stalled with No AK Egress (to CMS) Credits; Common Mesh Stop - Near Side",
        "EventCode": "0x20",
        "EventName": "UNC_M2M_TxC_AK_NO_CREDIT_STALLED.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles Stalled with No AK Egress (to CMS) Credits; Common Mesh Stop - Far Side",
        "EventCode": "0x20",
        "EventName": "UNC_M2M_TxC_AK_NO_CREDIT_STALLED.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Occupancy; All",
        "EventCode": "0x12",
        "EventName": "UNC_M2M_TxC_AK_OCCUPANCY.ALL",
        "PerPkg": "1",
        "UMask": "0x3",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Occupancy; Common Mesh Stop - Near Side",
        "EventCode": "0x12",
        "EventName": "UNC_M2M_TxC_AK_OCCUPANCY.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Occupancy; Common Mesh Stop - Far Side",
        "EventCode": "0x12",
        "EventName": "UNC_M2M_TxC_AK_OCCUPANCY.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Occupancy; Read Credit Request",
        "EventCode": "0x12",
        "EventName": "UNC_M2M_TxC_AK_OCCUPANCY.RDCRD",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Occupancy; Write Compare Request",
        "EventCode": "0x12",
        "EventName": "UNC_M2M_TxC_AK_OCCUPANCY.WRCMP",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Occupancy; Write Credit Request",
        "EventCode": "0x12",
        "EventName": "UNC_M2M_TxC_AK_OCCUPANCY.WRCRD",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Sideband",
        "EventCode": "0x6B",
        "EventName": "UNC_M2M_TxC_AK_SIDEBAND.RD",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "AK Egress (to CMS) Sideband",
        "EventCode": "0x6B",
        "EventName": "UNC_M2M_TxC_AK_SIDEBAND.WR",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Outbound DRS Ring Transactions to Cache; Data to Cache",
        "EventCode": "0x40",
        "EventName": "UNC_M2M_TxC_BL.DRS_CACHE",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Outbound DRS Ring Transactions to Cache; Data to Core",
        "EventCode": "0x40",
        "EventName": "UNC_M2M_TxC_BL.DRS_CORE",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Outbound DRS Ring Transactions to Cache; Data to QPI",
        "EventCode": "0x40",
        "EventName": "UNC_M2M_TxC_BL.DRS_UPI",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Credit Acquired; Common Mesh Stop - Near Side",
        "EventCode": "0x19",
        "EventName": "UNC_M2M_TxC_BL_CREDITS_ACQUIRED.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Credit Acquired; Common Mesh Stop - Far Side",
        "EventCode": "0x19",
        "EventName": "UNC_M2M_TxC_BL_CREDITS_ACQUIRED.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Credits Occupancy; Common Mesh Stop - Near Side",
        "EventCode": "0x1A",
        "EventName": "UNC_M2M_TxC_BL_CREDIT_OCCUPANCY.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Credits Occupancy; Common Mesh Stop - Far Side",
        "EventCode": "0x1A",
        "EventName": "UNC_M2M_TxC_BL_CREDIT_OCCUPANCY.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Full; All",
        "EventCode": "0x18",
        "EventName": "UNC_M2M_TxC_BL_CYCLES_FULL.ALL",
        "PerPkg": "1",
        "UMask": "0x3",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Full; Common Mesh Stop - Near Side",
        "EventCode": "0x18",
        "EventName": "UNC_M2M_TxC_BL_CYCLES_FULL.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Full; Common Mesh Stop - Far Side",
        "EventCode": "0x18",
        "EventName": "UNC_M2M_TxC_BL_CYCLES_FULL.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Not Empty; All",
        "EventCode": "0x17",
        "EventName": "UNC_M2M_TxC_BL_CYCLES_NE.ALL",
        "PerPkg": "1",
        "UMask": "0x3",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Not Empty; Common Mesh Stop - Near Side",
        "EventCode": "0x17",
        "EventName": "UNC_M2M_TxC_BL_CYCLES_NE.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Not Empty; Common Mesh Stop - Far Side",
        "EventCode": "0x17",
        "EventName": "UNC_M2M_TxC_BL_CYCLES_NE.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Allocations; All",
        "EventCode": "0x15",
        "EventName": "UNC_M2M_TxC_BL_INSERTS.ALL",
        "PerPkg": "1",
        "UMask": "0x3",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Allocations; Common Mesh Stop - Near Side",
        "EventCode": "0x15",
        "EventName": "UNC_M2M_TxC_BL_INSERTS.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Allocations; Common Mesh Stop - Far Side",
        "EventCode": "0x15",
        "EventName": "UNC_M2M_TxC_BL_INSERTS.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles with No BL Egress (to CMS) Credits; Common Mesh Stop - Near Side",
        "EventCode": "0x1B",
        "EventName": "UNC_M2M_TxC_BL_NO_CREDIT_CYCLES.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles with No BL Egress (to CMS) Credits; Common Mesh Stop - Far Side",
        "EventCode": "0x1B",
        "EventName": "UNC_M2M_TxC_BL_NO_CREDIT_CYCLES.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles Stalled with No BL Egress (to CMS) Credits; Common Mesh Stop - Near Side",
        "EventCode": "0x1C",
        "EventName": "UNC_M2M_TxC_BL_NO_CREDIT_STALLED.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles Stalled with No BL Egress (to CMS) Credits; Common Mesh Stop - Far Side",
        "EventCode": "0x1C",
        "EventName": "UNC_M2M_TxC_BL_NO_CREDIT_STALLED.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Occupancy; All",
        "EventCode": "0x16",
        "EventName": "UNC_M2M_TxC_BL_OCCUPANCY.ALL",
        "PerPkg": "1",
        "UMask": "0x3",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Occupancy; Common Mesh Stop - Near Side",
        "EventCode": "0x16",
        "EventName": "UNC_M2M_TxC_BL_OCCUPANCY.CMS0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "BL Egress (to CMS) Occupancy; Common Mesh Stop - Far Side",
        "EventCode": "0x16",
        "EventName": "UNC_M2M_TxC_BL_OCCUPANCY.CMS1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal ADS Used; AD - Bounce",
        "EventCode": "0x9D",
        "EventName": "UNC_M2M_TxR_HORZ_ADS_USED.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Horizontal Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal ADS Used; AD - Credit",
        "EventCode": "0x9D",
        "EventName": "UNC_M2M_TxR_HORZ_ADS_USED.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Horizontal Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal ADS Used; AK - Bounce",
        "EventCode": "0x9D",
        "EventName": "UNC_M2M_TxR_HORZ_ADS_USED.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Horizontal Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal ADS Used; BL - Bounce",
        "EventCode": "0x9D",
        "EventName": "UNC_M2M_TxR_HORZ_ADS_USED.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Horizontal Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal ADS Used; BL - Credit",
        "EventCode": "0x9D",
        "EventName": "UNC_M2M_TxR_HORZ_ADS_USED.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Horizontal Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; AD - Bounce",
        "EventCode": "0x9F",
        "EventName": "UNC_M2M_TxR_HORZ_BYPASS.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; AD - Credit",
        "EventCode": "0x9F",
        "EventName": "UNC_M2M_TxR_HORZ_BYPASS.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; AK - Bounce",
        "EventCode": "0x9F",
        "EventName": "UNC_M2M_TxR_HORZ_BYPASS.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; BL - Bounce",
        "EventCode": "0x9F",
        "EventName": "UNC_M2M_TxR_HORZ_BYPASS.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; BL - Credit",
        "EventCode": "0x9F",
        "EventName": "UNC_M2M_TxR_HORZ_BYPASS.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; IV - Bounce",
        "EventCode": "0x9F",
        "EventName": "UNC_M2M_TxR_HORZ_BYPASS.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; AD - Bounce",
        "EventCode": "0x96",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_FULL.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; AD - Credit",
        "EventCode": "0x96",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_FULL.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; AK - Bounce",
        "EventCode": "0x96",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_FULL.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; BL - Bounce",
        "EventCode": "0x96",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_FULL.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; BL - Credit",
        "EventCode": "0x96",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_FULL.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; IV - Bounce",
        "EventCode": "0x96",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_FULL.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; AD - Bounce",
        "EventCode": "0x97",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_NE.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; AD - Credit",
        "EventCode": "0x97",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_NE.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; AK - Bounce",
        "EventCode": "0x97",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_NE.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; BL - Bounce",
        "EventCode": "0x97",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_NE.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; BL - Credit",
        "EventCode": "0x97",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_NE.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; IV - Bounce",
        "EventCode": "0x97",
        "EventName": "UNC_M2M_TxR_HORZ_CYCLES_NE.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; AD - Bounce",
        "EventCode": "0x95",
        "EventName": "UNC_M2M_TxR_HORZ_INSERTS.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; AD - Credit",
        "EventCode": "0x95",
        "EventName": "UNC_M2M_TxR_HORZ_INSERTS.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; AK - Bounce",
        "EventCode": "0x95",
        "EventName": "UNC_M2M_TxR_HORZ_INSERTS.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; BL - Bounce",
        "EventCode": "0x95",
        "EventName": "UNC_M2M_TxR_HORZ_INSERTS.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; BL - Credit",
        "EventCode": "0x95",
        "EventName": "UNC_M2M_TxR_HORZ_INSERTS.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; IV - Bounce",
        "EventCode": "0x95",
        "EventName": "UNC_M2M_TxR_HORZ_INSERTS.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; AD - Bounce",
        "EventCode": "0x99",
        "EventName": "UNC_M2M_TxR_HORZ_NACK.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; AD - Credit",
        "EventCode": "0x99",
        "EventName": "UNC_M2M_TxR_HORZ_NACK.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; AK - Bounce",
        "EventCode": "0x99",
        "EventName": "UNC_M2M_TxR_HORZ_NACK.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; BL - Bounce",
        "EventCode": "0x99",
        "EventName": "UNC_M2M_TxR_HORZ_NACK.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; BL - Credit",
        "EventCode": "0x99",
        "EventName": "UNC_M2M_TxR_HORZ_NACK.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; IV - Bounce",
        "EventCode": "0x99",
        "EventName": "UNC_M2M_TxR_HORZ_NACK.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; AD - Bounce",
        "EventCode": "0x94",
        "EventName": "UNC_M2M_TxR_HORZ_OCCUPANCY.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; AD - Credit",
        "EventCode": "0x94",
        "EventName": "UNC_M2M_TxR_HORZ_OCCUPANCY.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; AK - Bounce",
        "EventCode": "0x94",
        "EventName": "UNC_M2M_TxR_HORZ_OCCUPANCY.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; BL - Bounce",
        "EventCode": "0x94",
        "EventName": "UNC_M2M_TxR_HORZ_OCCUPANCY.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; BL - Credit",
        "EventCode": "0x94",
        "EventName": "UNC_M2M_TxR_HORZ_OCCUPANCY.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; IV - Bounce",
        "EventCode": "0x94",
        "EventName": "UNC_M2M_TxR_HORZ_OCCUPANCY.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Injection Starvation; AD - Bounce",
        "EventCode": "0x9B",
        "EventName": "UNC_M2M_TxR_HORZ_STARVED.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Transgress buffer cannot send a transaction onto the Horizontal ring for a long period of time.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Injection Starvation; AK - Bounce",
        "EventCode": "0x9B",
        "EventName": "UNC_M2M_TxR_HORZ_STARVED.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Transgress buffer cannot send a transaction onto the Horizontal ring for a long period of time.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Injection Starvation; BL - Bounce",
        "EventCode": "0x9B",
        "EventName": "UNC_M2M_TxR_HORZ_STARVED.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Transgress buffer cannot send a transaction onto the Horizontal ring for a long period of time.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Injection Starvation; IV - Bounce",
        "EventCode": "0x9B",
        "EventName": "UNC_M2M_TxR_HORZ_STARVED.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Transgress buffer cannot send a transaction onto the Horizontal ring for a long period of time.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AD - Agent 0",
        "EventCode": "0x9C",
        "EventName": "UNC_M2M_TxR_VERT_ADS_USED.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AD - Agent 1",
        "EventCode": "0x9C",
        "EventName": "UNC_M2M_TxR_VERT_ADS_USED.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AK - Agent 0",
        "EventCode": "0x9C",
        "EventName": "UNC_M2M_TxR_VERT_ADS_USED.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AK - Agent 1",
        "EventCode": "0x9C",
        "EventName": "UNC_M2M_TxR_VERT_ADS_USED.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; BL - Agent 0",
        "EventCode": "0x9C",
        "EventName": "UNC_M2M_TxR_VERT_ADS_USED.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; BL - Agent 1",
        "EventCode": "0x9C",
        "EventName": "UNC_M2M_TxR_VERT_ADS_USED.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AD - Agent 0",
        "EventCode": "0x9E",
        "EventName": "UNC_M2M_TxR_VERT_BYPASS.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AD - Agent 1",
        "EventCode": "0x9E",
        "EventName": "UNC_M2M_TxR_VERT_BYPASS.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AK - Agent 0",
        "EventCode": "0x9E",
        "EventName": "UNC_M2M_TxR_VERT_BYPASS.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AK - Agent 1",
        "EventCode": "0x9E",
        "EventName": "UNC_M2M_TxR_VERT_BYPASS.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; BL - Agent 0",
        "EventCode": "0x9E",
        "EventName": "UNC_M2M_TxR_VERT_BYPASS.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; BL - Agent 1",
        "EventCode": "0x9E",
        "EventName": "UNC_M2M_TxR_VERT_BYPASS.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; IV",
        "EventCode": "0x9E",
        "EventName": "UNC_M2M_TxR_VERT_BYPASS.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; AD - Agent 0",
        "EventCode": "0x92",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_FULL.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AD ring.  Some example include outbound requests, snoop requests, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; AD - Agent 1",
        "EventCode": "0x92",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_FULL.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AD ring.  This is commonly used for outbound requests.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; AK - Agent 0",
        "EventCode": "0x92",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_FULL.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AK ring.  This is commonly used for credit returns and GO responses.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; AK - Agent 1",
        "EventCode": "0x92",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_FULL.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AK ring.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; BL - Agent 0",
        "EventCode": "0x92",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_FULL.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the BL ring.  This is commonly used to send data from the cache to various destinations.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; BL - Agent 1",
        "EventCode": "0x92",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_FULL.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the BL ring.  This is commonly used for transferring writeback data to the cache.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; IV",
        "EventCode": "0x92",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_FULL.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the IV ring.  This is commonly used for snoops to the cores.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; AD - Agent 0",
        "EventCode": "0x93",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_NE.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AD ring.  Some example include outbound requests, snoop requests, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; AD - Agent 1",
        "EventCode": "0x93",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_NE.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AD ring.  This is commonly used for outbound requests.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; AK - Agent 0",
        "EventCode": "0x93",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_NE.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AK ring.  This is commonly used for credit returns and GO responses.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; AK - Agent 1",
        "EventCode": "0x93",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_NE.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AK ring.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; BL - Agent 0",
        "EventCode": "0x93",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_NE.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the BL ring.  This is commonly used to send data from the cache to various destinations.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; BL - Agent 1",
        "EventCode": "0x93",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_NE.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the BL ring.  This is commonly used for transferring writeback data to the cache.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; IV",
        "EventCode": "0x93",
        "EventName": "UNC_M2M_TxR_VERT_CYCLES_NE.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the IV ring.  This is commonly used for snoops to the cores.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; AD - Agent 0",
        "EventCode": "0x91",
        "EventName": "UNC_M2M_TxR_VERT_INSERTS.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AD ring.  Some example include outbound requests, snoop requests, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; AD - Agent 1",
        "EventCode": "0x91",
        "EventName": "UNC_M2M_TxR_VERT_INSERTS.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AD ring.  This is commonly used for outbound requests.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; AK - Agent 0",
        "EventCode": "0x91",
        "EventName": "UNC_M2M_TxR_VERT_INSERTS.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AK ring.  This is commonly used for credit returns and GO responses.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; AK - Agent 1",
        "EventCode": "0x91",
        "EventName": "UNC_M2M_TxR_VERT_INSERTS.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AK ring.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; BL - Agent 0",
        "EventCode": "0x91",
        "EventName": "UNC_M2M_TxR_VERT_INSERTS.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the BL ring.  This is commonly used to send data from the cache to various destinations.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; BL - Agent 1",
        "EventCode": "0x91",
        "EventName": "UNC_M2M_TxR_VERT_INSERTS.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the BL ring.  This is commonly used for transferring writeback data to the cache.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; IV",
        "EventCode": "0x91",
        "EventName": "UNC_M2M_TxR_VERT_INSERTS.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the IV ring.  This is commonly used for snoops to the cores.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; AD - Agent 0",
        "EventCode": "0x98",
        "EventName": "UNC_M2M_TxR_VERT_NACK.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; AD - Agent 1",
        "EventCode": "0x98",
        "EventName": "UNC_M2M_TxR_VERT_NACK.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; AK - Agent 0",
        "EventCode": "0x98",
        "EventName": "UNC_M2M_TxR_VERT_NACK.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; AK - Agent 1",
        "EventCode": "0x98",
        "EventName": "UNC_M2M_TxR_VERT_NACK.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; BL - Agent 0",
        "EventCode": "0x98",
        "EventName": "UNC_M2M_TxR_VERT_NACK.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; BL - Agent 1",
        "EventCode": "0x98",
        "EventName": "UNC_M2M_TxR_VERT_NACK.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; IV",
        "EventCode": "0x98",
        "EventName": "UNC_M2M_TxR_VERT_NACK.IV",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; AD - Agent 0",
        "EventCode": "0x90",
        "EventName": "UNC_M2M_TxR_VERT_OCCUPANCY.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AD ring.  Some example include outbound requests, snoop requests, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; AD - Agent 1",
        "EventCode": "0x90",
        "EventName": "UNC_M2M_TxR_VERT_OCCUPANCY.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AD ring.  This is commonly used for outbound requests.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; AK - Agent 0",
        "EventCode": "0x90",
        "EventName": "UNC_M2M_TxR_VERT_OCCUPANCY.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AK ring.  This is commonly used for credit returns and GO responses.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; AK - Agent 1",
        "EventCode": "0x90",
        "EventName": "UNC_M2M_TxR_VERT_OCCUPANCY.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AK ring.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; BL - Agent 0",
        "EventCode": "0x90",
        "EventName": "UNC_M2M_TxR_VERT_OCCUPANCY.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the BL ring.  This is commonly used to send data from the cache to various destinations.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; BL - Agent 1",
        "EventCode": "0x90",
        "EventName": "UNC_M2M_TxR_VERT_OCCUPANCY.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the BL ring.  This is commonly used for transferring writeback data to the cache.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; IV",
        "EventCode": "0x90",
        "EventName": "UNC_M2M_TxR_VERT_OCCUPANCY.IV",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the IV ring.  This is commonly used for snoops to the cores.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; AD - Agent 0",
        "EventCode": "0x9A",
        "EventName": "UNC_M2M_TxR_VERT_STARVED.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; AD - Agent 1",
        "EventCode": "0x9A",
        "EventName": "UNC_M2M_TxR_VERT_STARVED.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x10",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; AK - Agent 0",
        "EventCode": "0x9A",
        "EventName": "UNC_M2M_TxR_VERT_STARVED.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; AK - Agent 1",
        "EventCode": "0x9A",
        "EventName": "UNC_M2M_TxR_VERT_STARVED.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x20",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; BL - Agent 0",
        "EventCode": "0x9A",
        "EventName": "UNC_M2M_TxR_VERT_STARVED.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; BL - Agent 1",
        "EventCode": "0x9A",
        "EventName": "UNC_M2M_TxR_VERT_STARVED.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x40",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; IV",
        "EventCode": "0x9A",
        "EventName": "UNC_M2M_TxR_VERT_STARVED.IV",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical AD Ring In Use; Down and Even",
        "EventCode": "0xA6",
        "EventName": "UNC_M2M_VERT_RING_AD_IN_USE.DN_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.  We really have two rings  -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical AD Ring In Use; Down and Odd",
        "EventCode": "0xA6",
        "EventName": "UNC_M2M_VERT_RING_AD_IN_USE.DN_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.  We really have two rings  -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical AD Ring In Use; Up and Even",
        "EventCode": "0xA6",
        "EventName": "UNC_M2M_VERT_RING_AD_IN_USE.UP_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.  We really have two rings  -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical AD Ring In Use; Up and Odd",
        "EventCode": "0xA6",
        "EventName": "UNC_M2M_VERT_RING_AD_IN_USE.UP_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.  We really have two rings  -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical AK Ring In Use; Down and Even",
        "EventCode": "0xA8",
        "EventName": "UNC_M2M_VERT_RING_AK_IN_USE.DN_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings in -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical AK Ring In Use; Down and Odd",
        "EventCode": "0xA8",
        "EventName": "UNC_M2M_VERT_RING_AK_IN_USE.DN_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings in -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical AK Ring In Use; Up and Even",
        "EventCode": "0xA8",
        "EventName": "UNC_M2M_VERT_RING_AK_IN_USE.UP_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings in -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical AK Ring In Use; Up and Odd",
        "EventCode": "0xA8",
        "EventName": "UNC_M2M_VERT_RING_AK_IN_USE.UP_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings in -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical BL Ring in Use; Down and Even",
        "EventCode": "0xAA",
        "EventName": "UNC_M2M_VERT_RING_BL_IN_USE.DN_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical BL Ring in Use; Down and Odd",
        "EventCode": "0xAA",
        "EventName": "UNC_M2M_VERT_RING_BL_IN_USE.DN_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical BL Ring in Use; Up and Even",
        "EventCode": "0xAA",
        "EventName": "UNC_M2M_VERT_RING_BL_IN_USE.UP_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical BL Ring in Use; Up and Odd",
        "EventCode": "0xAA",
        "EventName": "UNC_M2M_VERT_RING_BL_IN_USE.UP_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical IV Ring in Use; Down",
        "EventCode": "0xAC",
        "EventName": "UNC_M2M_VERT_RING_IV_IN_USE.DN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical IV 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.  There is only 1 IV ring.  Therefore, if one wants to monitor the Even ring, they should select both UP_EVEN and DN_EVEN.  To monitor the Odd ring, they should select both UP_ODD and DN_ODD.",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Vertical IV Ring in Use; Up",
        "EventCode": "0xAC",
        "EventName": "UNC_M2M_VERT_RING_IV_IN_USE.UP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical IV 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.  There is only 1 IV ring.  Therefore, if one wants to monitor the Even ring, they should select both UP_EVEN and DN_EVEN.  To monitor the Odd ring, they should select both UP_ODD and DN_ODD.",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_M2M_WPQ_CYCLES_REG_CREDITS.CHN0",
        "Deprecated": "1",
        "EventCode": "0x4D",
        "EventName": "UNC_M2M_WPQ_CYCLES_NO_REG_CREDITS.CHN0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_M2M_WPQ_CYCLES_REG_CREDITS.CHN1",
        "Deprecated": "1",
        "EventCode": "0x4D",
        "EventName": "UNC_M2M_WPQ_CYCLES_NO_REG_CREDITS.CHN1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_M2M_WPQ_CYCLES_REG_CREDITS.CHN2",
        "Deprecated": "1",
        "EventCode": "0x4D",
        "EventName": "UNC_M2M_WPQ_CYCLES_NO_REG_CREDITS.CHN2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M->iMC WPQ Cycles w/Credits - Regular; Channel 0",
        "EventCode": "0x4D",
        "EventName": "UNC_M2M_WPQ_CYCLES_REG_CREDITS.CHN0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M->iMC WPQ Cycles w/Credits - Regular; Channel 1",
        "EventCode": "0x4D",
        "EventName": "UNC_M2M_WPQ_CYCLES_REG_CREDITS.CHN1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M->iMC WPQ Cycles w/Credits - Regular; Channel 2",
        "EventCode": "0x4D",
        "EventName": "UNC_M2M_WPQ_CYCLES_REG_CREDITS.CHN2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M->iMC WPQ Cycles w/Credits - Special; Channel 0",
        "EventCode": "0x4E",
        "EventName": "UNC_M2M_WPQ_CYCLES_SPEC_CREDITS.CHN0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M->iMC WPQ Cycles w/Credits - Special; Channel 1",
        "EventCode": "0x4E",
        "EventName": "UNC_M2M_WPQ_CYCLES_SPEC_CREDITS.CHN1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "M2M->iMC WPQ Cycles w/Credits - Special; Channel 2",
        "EventCode": "0x4E",
        "EventName": "UNC_M2M_WPQ_CYCLES_SPEC_CREDITS.CHN2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Cycles Full; Channel 0",
        "EventCode": "0x4A",
        "EventName": "UNC_M2M_WRITE_TRACKER_CYCLES_FULL.CH0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Cycles Full; Channel 1",
        "EventCode": "0x4A",
        "EventName": "UNC_M2M_WRITE_TRACKER_CYCLES_FULL.CH1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Cycles Full; Channel 2",
        "EventCode": "0x4A",
        "EventName": "UNC_M2M_WRITE_TRACKER_CYCLES_FULL.CH2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Cycles Not Empty; Channel 0",
        "EventCode": "0x4B",
        "EventName": "UNC_M2M_WRITE_TRACKER_CYCLES_NE.CH0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Cycles Not Empty; Channel 1",
        "EventCode": "0x4B",
        "EventName": "UNC_M2M_WRITE_TRACKER_CYCLES_NE.CH1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Cycles Not Empty; Channel 2",
        "EventCode": "0x4B",
        "EventName": "UNC_M2M_WRITE_TRACKER_CYCLES_NE.CH2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Inserts; Channel 0",
        "EventCode": "0x61",
        "EventName": "UNC_M2M_WRITE_TRACKER_INSERTS.CH0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Inserts; Channel 1",
        "EventCode": "0x61",
        "EventName": "UNC_M2M_WRITE_TRACKER_INSERTS.CH1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Inserts; Channel 2",
        "EventCode": "0x61",
        "EventName": "UNC_M2M_WRITE_TRACKER_INSERTS.CH2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Occupancy; Channel 0",
        "EventCode": "0x60",
        "EventName": "UNC_M2M_WRITE_TRACKER_OCCUPANCY.CH0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Occupancy; Channel 1",
        "EventCode": "0x60",
        "EventName": "UNC_M2M_WRITE_TRACKER_OCCUPANCY.CH1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Write Tracker Occupancy; Channel 2",
        "EventCode": "0x60",
        "EventName": "UNC_M2M_WRITE_TRACKER_OCCUPANCY.CH2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 0",
        "EventCode": "0x80",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_ACQUIRED.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 1",
        "EventCode": "0x80",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_ACQUIRED.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 2",
        "EventCode": "0x80",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_ACQUIRED.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 3",
        "EventCode": "0x80",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_ACQUIRED.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 4",
        "EventCode": "0x80",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_ACQUIRED.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Acquired; For Transgress 5",
        "EventCode": "0x80",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_ACQUIRED.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 0",
        "EventCode": "0x82",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_OCCUPANCY.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 1",
        "EventCode": "0x82",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_OCCUPANCY.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 2",
        "EventCode": "0x82",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_OCCUPANCY.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 3",
        "EventCode": "0x82",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_OCCUPANCY.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 4",
        "EventCode": "0x82",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_OCCUPANCY.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 AD Credits Occupancy; For Transgress 5",
        "EventCode": "0x82",
        "EventName": "UNC_M3UPI_AG0_AD_CRD_OCCUPANCY.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 AD credits in use in a given cycle, per transgress",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 0",
        "EventCode": "0x88",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_ACQUIRED.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 1",
        "EventCode": "0x88",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_ACQUIRED.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 2",
        "EventCode": "0x88",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_ACQUIRED.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 3",
        "EventCode": "0x88",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_ACQUIRED.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 4",
        "EventCode": "0x88",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_ACQUIRED.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Acquired; For Transgress 5",
        "EventCode": "0x88",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_ACQUIRED.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 0",
        "EventCode": "0x8A",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_OCCUPANCY.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 1",
        "EventCode": "0x8A",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_OCCUPANCY.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 2",
        "EventCode": "0x8A",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_OCCUPANCY.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 3",
        "EventCode": "0x8A",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_OCCUPANCY.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 4",
        "EventCode": "0x8A",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_OCCUPANCY.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent0 BL Credits Occupancy; For Transgress 5",
        "EventCode": "0x8A",
        "EventName": "UNC_M3UPI_AG0_BL_CRD_OCCUPANCY.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 0 BL credits in use in a given cycle, per transgress",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 0",
        "EventCode": "0x84",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_ACQUIRED.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 1",
        "EventCode": "0x84",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_ACQUIRED.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 2",
        "EventCode": "0x84",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_ACQUIRED.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 3",
        "EventCode": "0x84",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_ACQUIRED.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 4",
        "EventCode": "0x84",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_ACQUIRED.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Acquired; For Transgress 5",
        "EventCode": "0x84",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_ACQUIRED.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits acquired in a given cycle, per transgress.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 0",
        "EventCode": "0x86",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_OCCUPANCY.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 1",
        "EventCode": "0x86",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_OCCUPANCY.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 2",
        "EventCode": "0x86",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_OCCUPANCY.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 3",
        "EventCode": "0x86",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_OCCUPANCY.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 4",
        "EventCode": "0x86",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_OCCUPANCY.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 AD Credits Occupancy; For Transgress 5",
        "EventCode": "0x86",
        "EventName": "UNC_M3UPI_AG1_AD_CRD_OCCUPANCY.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 AD credits in use in a given cycle, per transgress",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 0",
        "EventCode": "0x8E",
        "EventName": "UNC_M3UPI_AG1_BL_CRD_OCCUPANCY.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 1",
        "EventCode": "0x8E",
        "EventName": "UNC_M3UPI_AG1_BL_CRD_OCCUPANCY.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 2",
        "EventCode": "0x8E",
        "EventName": "UNC_M3UPI_AG1_BL_CRD_OCCUPANCY.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 3",
        "EventCode": "0x8E",
        "EventName": "UNC_M3UPI_AG1_BL_CRD_OCCUPANCY.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 4",
        "EventCode": "0x8E",
        "EventName": "UNC_M3UPI_AG1_BL_CRD_OCCUPANCY.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Occupancy; For Transgress 5",
        "EventCode": "0x8E",
        "EventName": "UNC_M3UPI_AG1_BL_CRD_OCCUPANCY.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits in use in a given cycle, per transgress",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 0",
        "EventCode": "0x8C",
        "EventName": "UNC_M3UPI_AG1_BL_CREDITS_ACQUIRED.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 1",
        "EventCode": "0x8C",
        "EventName": "UNC_M3UPI_AG1_BL_CREDITS_ACQUIRED.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 2",
        "EventCode": "0x8C",
        "EventName": "UNC_M3UPI_AG1_BL_CREDITS_ACQUIRED.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 3",
        "EventCode": "0x8C",
        "EventName": "UNC_M3UPI_AG1_BL_CREDITS_ACQUIRED.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 4",
        "EventCode": "0x8C",
        "EventName": "UNC_M3UPI_AG1_BL_CREDITS_ACQUIRED.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Agent1 BL Credits Acquired; For Transgress 5",
        "EventCode": "0x8C",
        "EventName": "UNC_M3UPI_AG1_BL_CREDITS_ACQUIRED.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of CMS Agent 1 BL credits acquired in a given cycle, per transgress.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CBox AD Credits Empty; Requests",
        "EventCode": "0x22",
        "EventName": "UNC_M3UPI_CHA_AD_CREDITS_EMPTY.REQ",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to Cbox on the AD Ring (covers higher CBoxes)",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CBox AD Credits Empty; Snoops",
        "EventCode": "0x22",
        "EventName": "UNC_M3UPI_CHA_AD_CREDITS_EMPTY.SNP",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to Cbox on the AD Ring (covers higher CBoxes)",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CBox AD Credits Empty; VNA Messages",
        "EventCode": "0x22",
        "EventName": "UNC_M3UPI_CHA_AD_CREDITS_EMPTY.VNA",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to Cbox on the AD Ring (covers higher CBoxes)",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CBox AD Credits Empty; Writebacks",
        "EventCode": "0x22",
        "EventName": "UNC_M3UPI_CHA_AD_CREDITS_EMPTY.WB",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to Cbox on the AD Ring (covers higher CBoxes)",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Number of uclks in domain",
        "EventCode": "0x1",
        "EventName": "UNC_M3UPI_CLOCKTICKS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of uclks in the M3 uclk domain.  This could be slightly different than the count in the Ubox because of enable/freeze delays.  However, because the M3 is close to the Ubox, they generally should not diverge by more than a handful of cycles.",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Clockticks",
        "EventCode": "0xC0",
        "EventName": "UNC_M3UPI_CMS_CLOCKTICKS",
        "PerPkg": "1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "D2C Sent",
        "EventCode": "0x2B",
        "EventName": "UNC_M3UPI_D2C_SENT",
        "PerPkg": "1",
        "PublicDescription": "Count cases BL sends direct to core",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "D2U Sent",
        "EventCode": "0x2A",
        "EventName": "UNC_M3UPI_D2U_SENT",
        "PerPkg": "1",
        "PublicDescription": "Cases where SMI3 sends D2U command",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Egress Blocking due to Ordering requirements; Down",
        "EventCode": "0xAE",
        "EventName": "UNC_M3UPI_EGRESS_ORDERING.IV_SNOOPGO_DN",
        "PerPkg": "1",
        "PublicDescription": "Counts number of cycles IV was blocked in the TGR Egress due to SNP/GO Ordering requirements",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Egress Blocking due to Ordering requirements; Up",
        "EventCode": "0xAE",
        "EventName": "UNC_M3UPI_EGRESS_ORDERING.IV_SNOOPGO_UP",
        "PerPkg": "1",
        "PublicDescription": "Counts number of cycles IV was blocked in the TGR Egress due to SNP/GO Ordering requirements",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "FaST wire asserted; Horizontal",
        "EventCode": "0xA5",
        "EventName": "UNC_M3UPI_FAST_ASSERTED.HORZ",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles either the local or incoming distress signals are asserted.  Incoming distress includes up, dn and across.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "FaST wire asserted; Vertical",
        "EventCode": "0xA5",
        "EventName": "UNC_M3UPI_FAST_ASSERTED.VERT",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles either the local or incoming distress signals are asserted.  Incoming distress includes up, dn and across.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal AD Ring In Use; Left and Even",
        "EventCode": "0xA7",
        "EventName": "UNC_M3UPI_HORZ_RING_AD_IN_USE.LEFT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.  We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal AD Ring In Use; Left and Odd",
        "EventCode": "0xA7",
        "EventName": "UNC_M3UPI_HORZ_RING_AD_IN_USE.LEFT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.  We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal AD Ring In Use; Right and Even",
        "EventCode": "0xA7",
        "EventName": "UNC_M3UPI_HORZ_RING_AD_IN_USE.RIGHT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.  We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal AD Ring In Use; Right and Odd",
        "EventCode": "0xA7",
        "EventName": "UNC_M3UPI_HORZ_RING_AD_IN_USE.RIGHT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.  We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal AK Ring In Use; Left and Even",
        "EventCode": "0xA9",
        "EventName": "UNC_M3UPI_HORZ_RING_AK_IN_USE.LEFT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal AK Ring In Use; Left and Odd",
        "EventCode": "0xA9",
        "EventName": "UNC_M3UPI_HORZ_RING_AK_IN_USE.LEFT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal AK Ring In Use; Right and Even",
        "EventCode": "0xA9",
        "EventName": "UNC_M3UPI_HORZ_RING_AK_IN_USE.RIGHT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal AK Ring In Use; Right and Odd",
        "EventCode": "0xA9",
        "EventName": "UNC_M3UPI_HORZ_RING_AK_IN_USE.RIGHT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal BL Ring in Use; Left and Even",
        "EventCode": "0xAB",
        "EventName": "UNC_M3UPI_HORZ_RING_BL_IN_USE.LEFT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal BL Ring in Use; Left and Odd",
        "EventCode": "0xAB",
        "EventName": "UNC_M3UPI_HORZ_RING_BL_IN_USE.LEFT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal BL Ring in Use; Right and Even",
        "EventCode": "0xAB",
        "EventName": "UNC_M3UPI_HORZ_RING_BL_IN_USE.RIGHT_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal BL Ring in Use; Right and Odd",
        "EventCode": "0xAB",
        "EventName": "UNC_M3UPI_HORZ_RING_BL_IN_USE.RIGHT_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal IV Ring in Use; Left",
        "EventCode": "0xAD",
        "EventName": "UNC_M3UPI_HORZ_RING_IV_IN_USE.LEFT",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal IV 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.  There is only 1 IV ring.  Therefore, if one wants to monitor the Even ring, they should select both UP_EVEN and DN_EVEN.  To monitor the Odd ring, they should select both UP_ODD and DN_ODD.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Horizontal IV Ring in Use; Right",
        "EventCode": "0xAD",
        "EventName": "UNC_M3UPI_HORZ_RING_IV_IN_USE.RIGHT",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Horizontal IV 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.  There is only 1 IV ring.  Therefore, if one wants to monitor the Even ring, they should select both UP_EVEN and DN_EVEN.  To monitor the Odd ring, they should select both UP_ODD and DN_ODD.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "M2 BL Credits Empty; IIO0 and IIO1 share the same ring destination. (1 VN0 credit only)",
        "EventCode": "0x23",
        "EventName": "UNC_M3UPI_M2_BL_CREDITS_EMPTY.IIO0_IIO1_NCB",
        "PerPkg": "1",
        "PublicDescription": "No vn0 and vna credits available to send to M2",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "M2 BL Credits Empty; IIO2",
        "EventCode": "0x23",
        "EventName": "UNC_M3UPI_M2_BL_CREDITS_EMPTY.IIO2_NCB",
        "PerPkg": "1",
        "PublicDescription": "No vn0 and vna credits available to send to M2",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "M2 BL Credits Empty; IIO3",
        "EventCode": "0x23",
        "EventName": "UNC_M3UPI_M2_BL_CREDITS_EMPTY.IIO3_NCB",
        "PerPkg": "1",
        "PublicDescription": "No vn0 and vna credits available to send to M2",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "M2 BL Credits Empty; IIO4",
        "EventCode": "0x23",
        "EventName": "UNC_M3UPI_M2_BL_CREDITS_EMPTY.IIO4_NCB",
        "PerPkg": "1",
        "PublicDescription": "No vn0 and vna credits available to send to M2",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "M2 BL Credits Empty; IIO5",
        "EventCode": "0x23",
        "EventName": "UNC_M3UPI_M2_BL_CREDITS_EMPTY.IIO5_NCB",
        "PerPkg": "1",
        "PublicDescription": "No vn0 and vna credits available to send to M2",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "M2 BL Credits Empty; All IIO targets for NCS are in single mask. ORs them together",
        "EventCode": "0x23",
        "EventName": "UNC_M3UPI_M2_BL_CREDITS_EMPTY.NCS",
        "PerPkg": "1",
        "PublicDescription": "No vn0 and vna credits available to send to M2",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "M2 BL Credits Empty; Selected M2p BL NCS credits",
        "EventCode": "0x23",
        "EventName": "UNC_M3UPI_M2_BL_CREDITS_EMPTY.NCS_SEL",
        "PerPkg": "1",
        "PublicDescription": "No vn0 and vna credits available to send to M2",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Multi Slot Flit Received; AD - Slot 0",
        "EventCode": "0x3E",
        "EventName": "UNC_M3UPI_MULTI_SLOT_RCVD.AD_SLOT0",
        "PerPkg": "1",
        "PublicDescription": "Multi slot flit received - S0, S1 and/or S2 populated (can use AK S0/S1 masks for AK allocations)",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Multi Slot Flit Received; AD - Slot 1",
        "EventCode": "0x3E",
        "EventName": "UNC_M3UPI_MULTI_SLOT_RCVD.AD_SLOT1",
        "PerPkg": "1",
        "PublicDescription": "Multi slot flit received - S0, S1 and/or S2 populated (can use AK S0/S1 masks for AK allocations)",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Multi Slot Flit Received; AD - Slot 2",
        "EventCode": "0x3E",
        "EventName": "UNC_M3UPI_MULTI_SLOT_RCVD.AD_SLOT2",
        "PerPkg": "1",
        "PublicDescription": "Multi slot flit received - S0, S1 and/or S2 populated (can use AK S0/S1 masks for AK allocations)",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Multi Slot Flit Received; AK - Slot 0",
        "EventCode": "0x3E",
        "EventName": "UNC_M3UPI_MULTI_SLOT_RCVD.AK_SLOT0",
        "PerPkg": "1",
        "PublicDescription": "Multi slot flit received - S0, S1 and/or S2 populated (can use AK S0/S1 masks for AK allocations)",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Multi Slot Flit Received; AK - Slot 2",
        "EventCode": "0x3E",
        "EventName": "UNC_M3UPI_MULTI_SLOT_RCVD.AK_SLOT2",
        "PerPkg": "1",
        "PublicDescription": "Multi slot flit received - S0, S1 and/or S2 populated (can use AK S0/S1 masks for AK allocations)",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Multi Slot Flit Received; BL - Slot 0",
        "EventCode": "0x3E",
        "EventName": "UNC_M3UPI_MULTI_SLOT_RCVD.BL_SLOT0",
        "PerPkg": "1",
        "PublicDescription": "Multi slot flit received - S0, S1 and/or S2 populated (can use AK S0/S1 masks for AK allocations)",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Messages that bounced on the Horizontal Ring.; AD",
        "EventCode": "0xA1",
        "EventName": "UNC_M3UPI_RING_BOUNCES_HORZ.AD",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Horizontal ring that were bounced, by ring type.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Messages that bounced on the Horizontal Ring.; AK",
        "EventCode": "0xA1",
        "EventName": "UNC_M3UPI_RING_BOUNCES_HORZ.AK",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Horizontal ring that were bounced, by ring type.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Messages that bounced on the Horizontal Ring.; BL",
        "EventCode": "0xA1",
        "EventName": "UNC_M3UPI_RING_BOUNCES_HORZ.BL",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Horizontal ring that were bounced, by ring type.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Messages that bounced on the Horizontal Ring.; IV",
        "EventCode": "0xA1",
        "EventName": "UNC_M3UPI_RING_BOUNCES_HORZ.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Horizontal ring that were bounced, by ring type.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Messages that bounced on the Vertical Ring.; AD",
        "EventCode": "0xA0",
        "EventName": "UNC_M3UPI_RING_BOUNCES_VERT.AD",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Vertical ring that were bounced, by ring type.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Messages that bounced on the Vertical Ring.; Acknowledgements to core",
        "EventCode": "0xA0",
        "EventName": "UNC_M3UPI_RING_BOUNCES_VERT.AK",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Vertical ring that were bounced, by ring type.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Messages that bounced on the Vertical Ring.; Data Responses to core",
        "EventCode": "0xA0",
        "EventName": "UNC_M3UPI_RING_BOUNCES_VERT.BL",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Vertical ring that were bounced, by ring type.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Messages that bounced on the Vertical Ring.; Snoops of processor's cache.",
        "EventCode": "0xA0",
        "EventName": "UNC_M3UPI_RING_BOUNCES_VERT.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles incoming messages from the Vertical ring that were bounced, by ring type.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sink Starvation on Horizontal Ring; AD",
        "EventCode": "0xA3",
        "EventName": "UNC_M3UPI_RING_SINK_STARVED_HORZ.AD",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sink Starvation on Horizontal Ring; AK",
        "EventCode": "0xA3",
        "EventName": "UNC_M3UPI_RING_SINK_STARVED_HORZ.AK",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sink Starvation on Horizontal Ring; Acknowledgements to Agent 1",
        "EventCode": "0xA3",
        "EventName": "UNC_M3UPI_RING_SINK_STARVED_HORZ.AK_AG1",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sink Starvation on Horizontal Ring; BL",
        "EventCode": "0xA3",
        "EventName": "UNC_M3UPI_RING_SINK_STARVED_HORZ.BL",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sink Starvation on Horizontal Ring; IV",
        "EventCode": "0xA3",
        "EventName": "UNC_M3UPI_RING_SINK_STARVED_HORZ.IV",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sink Starvation on Vertical Ring; AD",
        "EventCode": "0xA2",
        "EventName": "UNC_M3UPI_RING_SINK_STARVED_VERT.AD",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sink Starvation on Vertical Ring; Acknowledgements to core",
        "EventCode": "0xA2",
        "EventName": "UNC_M3UPI_RING_SINK_STARVED_VERT.AK",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sink Starvation on Vertical Ring; Data Responses to core",
        "EventCode": "0xA2",
        "EventName": "UNC_M3UPI_RING_SINK_STARVED_VERT.BL",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sink Starvation on Vertical Ring; Snoops of processor's cache.",
        "EventCode": "0xA2",
        "EventName": "UNC_M3UPI_RING_SINK_STARVED_VERT.IV",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Source Throttle",
        "EventCode": "0xA4",
        "EventName": "UNC_M3UPI_RING_SRC_THRTL",
        "PerPkg": "1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN0; REQ on AD",
        "EventCode": "0x4B",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN0.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "VN0 message requested but lost arbitration; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN0; RSP on AD",
        "EventCode": "0x4B",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN0.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN0 message requested but lost arbitration; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN0; SNP on AD",
        "EventCode": "0x4B",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN0.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "VN0 message requested but lost arbitration; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN0; NCB on BL",
        "EventCode": "0x4B",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN0.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "VN0 message requested but lost arbitration; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN0; NCS on BL",
        "EventCode": "0x4B",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN0.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "VN0 message requested but lost arbitration; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN0; RSP on BL",
        "EventCode": "0x4B",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN0.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN0 message requested but lost arbitration; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN0; WB on BL",
        "EventCode": "0x4B",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN0.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "VN0 message requested but lost arbitration; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN1; REQ on AD",
        "EventCode": "0x4C",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN1.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "VN1 message requested but lost arbitration; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN1; RSP on AD",
        "EventCode": "0x4C",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN1.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN1 message requested but lost arbitration; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN1; SNP on AD",
        "EventCode": "0x4C",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN1.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "VN1 message requested but lost arbitration; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN1; NCB on BL",
        "EventCode": "0x4C",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN1.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "VN1 message requested but lost arbitration; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN1; NCS on BL",
        "EventCode": "0x4C",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN1.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "VN1 message requested but lost arbitration; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN1; RSP on BL",
        "EventCode": "0x4C",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN1.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN1 message requested but lost arbitration; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Lost Arb for VN1; WB on BL",
        "EventCode": "0x4C",
        "EventName": "UNC_M3UPI_RxC_ARB_LOST_VN1.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "VN1 message requested but lost arbitration; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Arb Miscellaneous; AD, BL Parallel Win",
        "EventCode": "0x4D",
        "EventName": "UNC_M3UPI_RxC_ARB_MISC.ADBL_PARALLEL_WIN",
        "PerPkg": "1",
        "PublicDescription": "AD and BL messages won arbitration concurrently / in parallel",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Arb Miscellaneous; No Progress on Pending AD VN0",
        "EventCode": "0x4D",
        "EventName": "UNC_M3UPI_RxC_ARB_MISC.NO_PROG_AD_VN0",
        "PerPkg": "1",
        "PublicDescription": "Arbitration stage made no progress on pending ad vn0 messages because slotting stage cannot accept new message",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Arb Miscellaneous; No Progress on Pending AD VN1",
        "EventCode": "0x4D",
        "EventName": "UNC_M3UPI_RxC_ARB_MISC.NO_PROG_AD_VN1",
        "PerPkg": "1",
        "PublicDescription": "Arbitration stage made no progress on pending ad vn1 messages because slotting stage cannot accept new message",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Arb Miscellaneous; No Progress on Pending BL VN0",
        "EventCode": "0x4D",
        "EventName": "UNC_M3UPI_RxC_ARB_MISC.NO_PROG_BL_VN0",
        "PerPkg": "1",
        "PublicDescription": "Arbitration stage made no progress on pending bl vn0 messages because slotting stage cannot accept new message",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Arb Miscellaneous; No Progress on Pending BL VN1",
        "EventCode": "0x4D",
        "EventName": "UNC_M3UPI_RxC_ARB_MISC.NO_PROG_BL_VN1",
        "PerPkg": "1",
        "PublicDescription": "Arbitration stage made no progress on pending bl vn1 messages because slotting stage cannot accept new message",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Arb Miscellaneous; Parallel Bias to VN0",
        "EventCode": "0x4D",
        "EventName": "UNC_M3UPI_RxC_ARB_MISC.PAR_BIAS_VN0",
        "PerPkg": "1",
        "PublicDescription": "VN0/VN1 arbiter gave second, consecutive win to vn0, delaying vn1 win, because vn0 offered parallel ad/bl",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Arb Miscellaneous; Parallel Bias to VN1",
        "EventCode": "0x4D",
        "EventName": "UNC_M3UPI_RxC_ARB_MISC.PAR_BIAS_VN1",
        "PerPkg": "1",
        "PublicDescription": "VN0/VN1 arbiter gave second, consecutive win to vn1, delaying vn0 win, because vn1 offered parallel ad/bl",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN0; REQ on AD",
        "EventCode": "0x49",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN0.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "VN0 message was not able to request arbitration while some other message won arbitration; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN0; RSP on AD",
        "EventCode": "0x49",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN0.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN0 message was not able to request arbitration while some other message won arbitration; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN0; SNP on AD",
        "EventCode": "0x49",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN0.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "VN0 message was not able to request arbitration while some other message won arbitration; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN0; NCB on BL",
        "EventCode": "0x49",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN0.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "VN0 message was not able to request arbitration while some other message won arbitration; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN0; NCS on BL",
        "EventCode": "0x49",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN0.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "VN0 message was not able to request arbitration while some other message won arbitration; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN0; RSP on BL",
        "EventCode": "0x49",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN0.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN0 message was not able to request arbitration while some other message won arbitration; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN0; WB on BL",
        "EventCode": "0x49",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN0.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "VN0 message was not able to request arbitration while some other message won arbitration; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN1; REQ on AD",
        "EventCode": "0x4A",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN1.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "VN1 message was not able to request arbitration while some other message won arbitration; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN1; RSP on AD",
        "EventCode": "0x4A",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN1.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN1 message was not able to request arbitration while some other message won arbitration; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN1; SNP on AD",
        "EventCode": "0x4A",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN1.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "VN1 message was not able to request arbitration while some other message won arbitration; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN1; NCB on BL",
        "EventCode": "0x4A",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN1.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "VN1 message was not able to request arbitration while some other message won arbitration; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN1; NCS on BL",
        "EventCode": "0x4A",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN1.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "VN1 message was not able to request arbitration while some other message won arbitration; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN1; RSP on BL",
        "EventCode": "0x4A",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN1.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN1 message was not able to request arbitration while some other message won arbitration; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Can't Arb for VN1; WB on BL",
        "EventCode": "0x4A",
        "EventName": "UNC_M3UPI_RxC_ARB_NOAD_REQ_VN1.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "VN1 message was not able to request arbitration while some other message won arbitration; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN0; REQ on AD",
        "EventCode": "0x47",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN0.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "VN0 message is blocked from requesting arbitration due to lack of remote UPI credits; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN0; RSP on AD",
        "EventCode": "0x47",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN0.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN0 message is blocked from requesting arbitration due to lack of remote UPI credits; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN0; SNP on AD",
        "EventCode": "0x47",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN0.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "VN0 message is blocked from requesting arbitration due to lack of remote UPI credits; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN0; NCB on BL",
        "EventCode": "0x47",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN0.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "VN0 message is blocked from requesting arbitration due to lack of remote UPI credits; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN0; NCS on BL",
        "EventCode": "0x47",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN0.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "VN0 message is blocked from requesting arbitration due to lack of remote UPI credits; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN0; RSP on BL",
        "EventCode": "0x47",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN0.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN0 message is blocked from requesting arbitration due to lack of remote UPI credits; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN0; WB on BL",
        "EventCode": "0x47",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN0.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "VN0 message is blocked from requesting arbitration due to lack of remote UPI credits; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN1; REQ on AD",
        "EventCode": "0x48",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN1.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "VN1 message is blocked from requesting arbitration due to lack of remote UPI credits; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN1; RSP on AD",
        "EventCode": "0x48",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN1.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN1 message is blocked from requesting arbitration due to lack of remote UPI credits; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN1; SNP on AD",
        "EventCode": "0x48",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN1.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "VN1 message is blocked from requesting arbitration due to lack of remote UPI credits; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN1; NCB on BL",
        "EventCode": "0x48",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN1.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "VN1 message is blocked from requesting arbitration due to lack of remote UPI credits; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN1; NCS on BL",
        "EventCode": "0x48",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN1.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "VN1 message is blocked from requesting arbitration due to lack of remote UPI credits; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN1; RSP on BL",
        "EventCode": "0x48",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN1.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "VN1 message is blocked from requesting arbitration due to lack of remote UPI credits; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "No Credits to Arb for VN1; WB on BL",
        "EventCode": "0x48",
        "EventName": "UNC_M3UPI_RxC_ARB_NOCRED_VN1.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "VN1 message is blocked from requesting arbitration due to lack of remote UPI credits; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Ingress Queue Bypasses; AD to Slot 0 on BL Arb",
        "EventCode": "0x40",
        "EventName": "UNC_M3UPI_RxC_BYPASSED.AD_S0_BL_ARB",
        "PerPkg": "1",
        "PublicDescription": "Number of times message is bypassed around the Ingress Queue; AD is taking bypass to slot 0 of independent flit while bl message is in arbitration",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Ingress Queue Bypasses; AD to Slot 0 on Idle",
        "EventCode": "0x40",
        "EventName": "UNC_M3UPI_RxC_BYPASSED.AD_S0_IDLE",
        "PerPkg": "1",
        "PublicDescription": "Number of times message is bypassed around the Ingress Queue; AD is taking bypass to slot 0 of independent flit while pipeline is idle",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Ingress Queue Bypasses; AD + BL to Slot 1",
        "EventCode": "0x40",
        "EventName": "UNC_M3UPI_RxC_BYPASSED.AD_S1_BL_SLOT",
        "PerPkg": "1",
        "PublicDescription": "Number of times message is bypassed around the Ingress Queue; AD is taking bypass to flit slot 1 while merging with bl message in same flit",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Ingress Queue Bypasses; AD + BL to Slot 2",
        "EventCode": "0x40",
        "EventName": "UNC_M3UPI_RxC_BYPASSED.AD_S2_BL_SLOT",
        "PerPkg": "1",
        "PublicDescription": "Number of times message is bypassed around the Ingress Queue; AD is taking bypass to flit slot 2 while merging with bl message in same flit",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message lost contest for flit; REQ on AD",
        "EventCode": "0x50",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN0.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN0 packets lost the contest for Flit Slot 0.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message lost contest for flit; RSP on AD",
        "EventCode": "0x50",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN0.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN0 packets lost the contest for Flit Slot 0.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message lost contest for flit; SNP on AD",
        "EventCode": "0x50",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN0.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN0 packets lost the contest for Flit Slot 0.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message lost contest for flit; NCB on BL",
        "EventCode": "0x50",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN0.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN0 packets lost the contest for Flit Slot 0.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message lost contest for flit; NCS on BL",
        "EventCode": "0x50",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN0.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN0 packets lost the contest for Flit Slot 0.; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message lost contest for flit; RSP on BL",
        "EventCode": "0x50",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN0.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN0 packets lost the contest for Flit Slot 0.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message lost contest for flit; WB on BL",
        "EventCode": "0x50",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN0.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN0 packets lost the contest for Flit Slot 0.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message lost contest for flit; REQ on AD",
        "EventCode": "0x51",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN1.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN1 packets lost the contest for Flit Slot 0.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message lost contest for flit; RSP on AD",
        "EventCode": "0x51",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN1.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN1 packets lost the contest for Flit Slot 0.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message lost contest for flit; SNP on AD",
        "EventCode": "0x51",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN1.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN1 packets lost the contest for Flit Slot 0.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message lost contest for flit; NCB on BL",
        "EventCode": "0x51",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN1.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN1 packets lost the contest for Flit Slot 0.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message lost contest for flit; NCS on BL",
        "EventCode": "0x51",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN1.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN1 packets lost the contest for Flit Slot 0.; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message lost contest for flit; RSP on BL",
        "EventCode": "0x51",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN1.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN1 packets lost the contest for Flit Slot 0.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message lost contest for flit; WB on BL",
        "EventCode": "0x51",
        "EventName": "UNC_M3UPI_RxC_COLLISION_VN1.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress VN1 packets lost the contest for Flit Slot 0.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Miscellaneous Credit Events; Any In BGF FIFO",
        "EventCode": "0x60",
        "EventName": "UNC_M3UPI_RxC_CRD_MISC.ANY_BGF_FIFO",
        "PerPkg": "1",
        "PublicDescription": "Indication that at least one packet (flit) is in the bgf (fifo only)",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Miscellaneous Credit Events; Any in BGF Path",
        "EventCode": "0x60",
        "EventName": "UNC_M3UPI_RxC_CRD_MISC.ANY_BGF_PATH",
        "PerPkg": "1",
        "PublicDescription": "Indication that at least one packet (flit) is in the bgf path (i.e. pipe to fifo)",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Miscellaneous Credit Events; No D2K For Arb",
        "EventCode": "0x60",
        "EventName": "UNC_M3UPI_RxC_CRD_MISC.NO_D2K_FOR_ARB",
        "PerPkg": "1",
        "PublicDescription": "VN0 or VN1 BL RSP message was blocked from arbitration request due to lack of D2K CMP credits",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Credit Occupancy; D2K Credits",
        "EventCode": "0x61",
        "EventName": "UNC_M3UPI_RxC_CRD_OCC.D2K_CRD",
        "PerPkg": "1",
        "PublicDescription": "D2K completion fifo credit occupancy (credits in use), accumulated across all cycles",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Credit Occupancy; Packets in BGF FIFO",
        "EventCode": "0x61",
        "EventName": "UNC_M3UPI_RxC_CRD_OCC.FLITS_IN_FIFO",
        "PerPkg": "1",
        "PublicDescription": "Occupancy of m3upi ingress -> upi link layer bgf; packets (flits) in fifo",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Credit Occupancy; Packets in BGF Path",
        "EventCode": "0x61",
        "EventName": "UNC_M3UPI_RxC_CRD_OCC.FLITS_IN_PATH",
        "PerPkg": "1",
        "PublicDescription": "Occupancy of m3upi ingress -> upi link layer bgf; packets (flits) in path (i.e. pipe to fifo or fifo)",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Credit Occupancy",
        "EventCode": "0x61",
        "EventName": "UNC_M3UPI_RxC_CRD_OCC.P1P_FIFO",
        "PerPkg": "1",
        "PublicDescription": "count of bl messages in pump-1-pending state, in completion fifo only",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Credit Occupancy",
        "EventCode": "0x61",
        "EventName": "UNC_M3UPI_RxC_CRD_OCC.P1P_TOTAL",
        "PerPkg": "1",
        "PublicDescription": "count of bl messages in pump-1-pending state, in marker table and in fifo",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Credit Occupancy; Transmit Credits",
        "EventCode": "0x61",
        "EventName": "UNC_M3UPI_RxC_CRD_OCC.TxQ_CRD",
        "PerPkg": "1",
        "PublicDescription": "Link layer transmit queue credit occupancy (credits in use), accumulated across all cycles",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Credit Occupancy; VNA In Use",
        "EventCode": "0x61",
        "EventName": "UNC_M3UPI_RxC_CRD_OCC.VNA_IN_USE",
        "PerPkg": "1",
        "PublicDescription": "Remote UPI VNA credit occupancy (number of credits in use), accumulated across all cycles",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Cycles Not Empty; REQ on AD",
        "EventCode": "0x43",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN0.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the UPI Ingress is not empty.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue occupancy.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Cycles Not Empty; RSP on AD",
        "EventCode": "0x43",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN0.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the UPI Ingress is not empty.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue occupancy.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Cycles Not Empty; SNP on AD",
        "EventCode": "0x43",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN0.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the UPI Ingress is not empty.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue occupancy.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Cycles Not Empty; NCB on BL",
        "EventCode": "0x43",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN0.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the UPI Ingress is not empty.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue occupancy.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Cycles Not Empty; NCS on BL",
        "EventCode": "0x43",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN0.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the UPI Ingress is not empty.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue occupancy.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Cycles Not Empty; RSP on BL",
        "EventCode": "0x43",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN0.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the UPI Ingress is not empty.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue occupancy.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Cycles Not Empty; WB on BL",
        "EventCode": "0x43",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN0.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles when the UPI Ingress is not empty.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue occupancy.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Cycles Not Empty; REQ on AD",
        "EventCode": "0x44",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN1.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Cycles Not Empty; RSP on AD",
        "EventCode": "0x44",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN1.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Cycles Not Empty; SNP on AD",
        "EventCode": "0x44",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN1.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Cycles Not Empty; NCB on BL",
        "EventCode": "0x44",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN1.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Cycles Not Empty; NCS on BL",
        "EventCode": "0x44",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN1.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Cycles Not Empty; RSP on BL",
        "EventCode": "0x44",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN1.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Cycles Not Empty; WB on BL",
        "EventCode": "0x44",
        "EventName": "UNC_M3UPI_RxC_CYCLES_NE_VN1.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Data Flit Not Sent; All",
        "EventCode": "0x57",
        "EventName": "UNC_M3UPI_RxC_FLITS_DATA_NOT_SENT.ALL",
        "PerPkg": "1",
        "PublicDescription": "Data flit is ready for transmission but could not be sent",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Data Flit Not Sent; No BGF Credits",
        "EventCode": "0x57",
        "EventName": "UNC_M3UPI_RxC_FLITS_DATA_NOT_SENT.NO_BGF",
        "PerPkg": "1",
        "PublicDescription": "Data flit is ready for transmission but could not be sent",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Data Flit Not Sent; No TxQ Credits",
        "EventCode": "0x57",
        "EventName": "UNC_M3UPI_RxC_FLITS_DATA_NOT_SENT.NO_TXQ",
        "PerPkg": "1",
        "PublicDescription": "Data flit is ready for transmission but could not be sent",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Generating BL Data Flit Sequence; Wait on Pump 0",
        "EventCode": "0x59",
        "EventName": "UNC_M3UPI_RxC_FLITS_GEN_BL.P0_WAIT",
        "PerPkg": "1",
        "PublicDescription": "generating bl data flit sequence; waiting for data pump 0",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Generating BL Data Flit Sequence",
        "EventCode": "0x59",
        "EventName": "UNC_M3UPI_RxC_FLITS_GEN_BL.P1P_AT_LIMIT",
        "PerPkg": "1",
        "PublicDescription": "pump-1-pending logic is at capacity (pending table plus completion fifo at limit)",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Generating BL Data Flit Sequence",
        "EventCode": "0x59",
        "EventName": "UNC_M3UPI_RxC_FLITS_GEN_BL.P1P_BUSY",
        "PerPkg": "1",
        "PublicDescription": "pump-1-pending logic is tracking at least one message",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Generating BL Data Flit Sequence",
        "EventCode": "0x59",
        "EventName": "UNC_M3UPI_RxC_FLITS_GEN_BL.P1P_FIFO_FULL",
        "PerPkg": "1",
        "PublicDescription": "pump-1-pending completion fifo is full",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Generating BL Data Flit Sequence",
        "EventCode": "0x59",
        "EventName": "UNC_M3UPI_RxC_FLITS_GEN_BL.P1P_HOLD_P0",
        "PerPkg": "1",
        "PublicDescription": "pump-1-pending logic is at or near capacity, such that pump-0-only bl messages are getting stalled in slotting stage",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Generating BL Data Flit Sequence",
        "EventCode": "0x59",
        "EventName": "UNC_M3UPI_RxC_FLITS_GEN_BL.P1P_TO_LIMBO",
        "PerPkg": "1",
        "PublicDescription": "a bl message finished but is in limbo and moved to pump-1-pending logic",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Generating BL Data Flit Sequence; Wait on Pump 1",
        "EventCode": "0x59",
        "EventName": "UNC_M3UPI_RxC_FLITS_GEN_BL.P1_WAIT",
        "PerPkg": "1",
        "PublicDescription": "generating bl data flit sequence; waiting for data pump 1",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UNC_M3UPI_RxC_FLITS_MISC",
        "EventCode": "0x5A",
        "EventName": "UNC_M3UPI_RxC_FLITS_MISC",
        "PerPkg": "1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sent Header Flit; One Message",
        "EventCode": "0x56",
        "EventName": "UNC_M3UPI_RxC_FLITS_SENT.1_MSG",
        "PerPkg": "1",
        "PublicDescription": "One message in flit; VNA or non-VNA flit",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sent Header Flit; One Message in non-VNA",
        "EventCode": "0x56",
        "EventName": "UNC_M3UPI_RxC_FLITS_SENT.1_MSG_VNX",
        "PerPkg": "1",
        "PublicDescription": "One message in flit; non-VNA flit",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sent Header Flit; Two Messages",
        "EventCode": "0x56",
        "EventName": "UNC_M3UPI_RxC_FLITS_SENT.2_MSGS",
        "PerPkg": "1",
        "PublicDescription": "Two messages in flit; VNA flit",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sent Header Flit; Three Messages",
        "EventCode": "0x56",
        "EventName": "UNC_M3UPI_RxC_FLITS_SENT.3_MSGS",
        "PerPkg": "1",
        "PublicDescription": "Three messages in flit; VNA flit",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sent Header Flit",
        "EventCode": "0x56",
        "EventName": "UNC_M3UPI_RxC_FLITS_SENT.SLOTS_1",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sent Header Flit",
        "EventCode": "0x56",
        "EventName": "UNC_M3UPI_RxC_FLITS_SENT.SLOTS_2",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Sent Header Flit",
        "EventCode": "0x56",
        "EventName": "UNC_M3UPI_RxC_FLITS_SENT.SLOTS_3",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Slotting BL Message Into Header Flit; All",
        "EventCode": "0x58",
        "EventName": "UNC_M3UPI_RxC_FLITS_SLOT_BL.ALL",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Slotting BL Message Into Header Flit; Needs Data Flit",
        "EventCode": "0x58",
        "EventName": "UNC_M3UPI_RxC_FLITS_SLOT_BL.NEED_DATA",
        "PerPkg": "1",
        "PublicDescription": "BL message requires data flit sequence",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Slotting BL Message Into Header Flit; Wait on Pump 0",
        "EventCode": "0x58",
        "EventName": "UNC_M3UPI_RxC_FLITS_SLOT_BL.P0_WAIT",
        "PerPkg": "1",
        "PublicDescription": "Waiting for header pump 0",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Slotting BL Message Into Header Flit; Don't Need Pump 1",
        "EventCode": "0x58",
        "EventName": "UNC_M3UPI_RxC_FLITS_SLOT_BL.P1_NOT_REQ",
        "PerPkg": "1",
        "PublicDescription": "Header pump 1 is not required for flit",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Slotting BL Message Into Header Flit; Don't Need Pump 1 - Bubble",
        "EventCode": "0x58",
        "EventName": "UNC_M3UPI_RxC_FLITS_SLOT_BL.P1_NOT_REQ_BUT_BUBBLE",
        "PerPkg": "1",
        "PublicDescription": "Header pump 1 is not required for flit but flit transmission delayed",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Slotting BL Message Into Header Flit; Don't Need Pump 1 - Not Avail",
        "EventCode": "0x58",
        "EventName": "UNC_M3UPI_RxC_FLITS_SLOT_BL.P1_NOT_REQ_NOT_AVAIL",
        "PerPkg": "1",
        "PublicDescription": "Header pump 1 is not required for flit and not available",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Slotting BL Message Into Header Flit; Wait on Pump 1",
        "EventCode": "0x58",
        "EventName": "UNC_M3UPI_RxC_FLITS_SLOT_BL.P1_WAIT",
        "PerPkg": "1",
        "PublicDescription": "Waiting for header pump 1",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Flit Gen - Header 1; Accumulate",
        "EventCode": "0x53",
        "EventName": "UNC_M3UPI_RxC_FLIT_GEN_HDR1.ACCUM",
        "PerPkg": "1",
        "PublicDescription": "Events related to Header Flit Generation - Set 1; Header flit slotting control state machine is in any accumulate state; multi-message flit may be assembled over multiple cycles",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Flit Gen - Header 1; Accumulate Ready",
        "EventCode": "0x53",
        "EventName": "UNC_M3UPI_RxC_FLIT_GEN_HDR1.ACCUM_READ",
        "PerPkg": "1",
        "PublicDescription": "Events related to Header Flit Generation - Set 1; header flit slotting control state machine is in accum_ready state; flit is ready to send but transmission is blocked; more messages may be slotted into flit",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Flit Gen - Header 1; Accumulate Wasted",
        "EventCode": "0x53",
        "EventName": "UNC_M3UPI_RxC_FLIT_GEN_HDR1.ACCUM_WASTED",
        "PerPkg": "1",
        "PublicDescription": "Events related to Header Flit Generation - Set 1; Flit is being assembled over multiple cycles, but no additional message is being slotted into flit in current cycle; accumulate cycle is wasted",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Flit Gen - Header 1; Run-Ahead - Blocked",
        "EventCode": "0x53",
        "EventName": "UNC_M3UPI_RxC_FLIT_GEN_HDR1.AHEAD_BLOCKED",
        "PerPkg": "1",
        "PublicDescription": "Events related to Header Flit Generation - Set 1; Header flit slotting entered run-ahead state; new header flit is started while transmission of prior, fully assembled flit is blocked",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Flit Gen - Header 1; Run-Ahead - Message",
        "EventCode": "0x53",
        "EventName": "UNC_M3UPI_RxC_FLIT_GEN_HDR1.AHEAD_MSG",
        "PerPkg": "1",
        "PublicDescription": "Events related to Header Flit Generation - Set 1; Header flit slotting is in run-ahead to start new flit, and message is actually slotted into new flit",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Flit Gen - Header 1; Parallel Ok",
        "EventCode": "0x53",
        "EventName": "UNC_M3UPI_RxC_FLIT_GEN_HDR1.PAR",
        "PerPkg": "1",
        "PublicDescription": "Events related to Header Flit Generation - Set 1; New header flit construction may proceed in parallel with data flit sequence",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Flit Gen - Header 1; Parallel Flit Finished",
        "EventCode": "0x53",
        "EventName": "UNC_M3UPI_RxC_FLIT_GEN_HDR1.PAR_FLIT",
        "PerPkg": "1",
        "PublicDescription": "Events related to Header Flit Generation - Set 1; Header flit finished assembly in parallel with data flit sequence",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Flit Gen - Header 1; Parallel Message",
        "EventCode": "0x53",
        "EventName": "UNC_M3UPI_RxC_FLIT_GEN_HDR1.PAR_MSG",
        "PerPkg": "1",
        "PublicDescription": "Events related to Header Flit Generation - Set 1; Message is slotted into header flit in parallel with data flit sequence",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Flit Gen - Header 2; Rate-matching Stall",
        "EventCode": "0x54",
        "EventName": "UNC_M3UPI_RxC_FLIT_GEN_HDR2.RMSTALL",
        "PerPkg": "1",
        "PublicDescription": "Events related to Header Flit Generation - Set 2; Rate-matching stall injected",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Flit Gen - Header 2; Rate-matching Stall - No Message",
        "EventCode": "0x54",
        "EventName": "UNC_M3UPI_RxC_FLIT_GEN_HDR2.RMSTALL_NOMSG",
        "PerPkg": "1",
        "PublicDescription": "Events related to Header Flit Generation - Set 2; Rate matching stall injected, but no additional message slotted during stall cycle",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Header Not Sent; All",
        "EventCode": "0x55",
        "EventName": "UNC_M3UPI_RxC_FLIT_NOT_SENT.ALL",
        "PerPkg": "1",
        "PublicDescription": "header flit is ready for transmission but could not be sent",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Header Not Sent; No BGF Credits",
        "EventCode": "0x55",
        "EventName": "UNC_M3UPI_RxC_FLIT_NOT_SENT.NO_BGF_CRD",
        "PerPkg": "1",
        "PublicDescription": "header flit is ready for transmission but could not be sent; No BGF credits available",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Header Not Sent; No BGF Credits + No Extra Message Slotted",
        "EventCode": "0x55",
        "EventName": "UNC_M3UPI_RxC_FLIT_NOT_SENT.NO_BGF_NO_MSG",
        "PerPkg": "1",
        "PublicDescription": "header flit is ready for transmission but could not be sent; No BGF credits available; no additional message slotted into flit",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Header Not Sent; No TxQ Credits",
        "EventCode": "0x55",
        "EventName": "UNC_M3UPI_RxC_FLIT_NOT_SENT.NO_TXQ_CRD",
        "PerPkg": "1",
        "PublicDescription": "header flit is ready for transmission but could not be sent; No TxQ credits available",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Header Not Sent; No TxQ Credits + No Extra Message Slotted",
        "EventCode": "0x55",
        "EventName": "UNC_M3UPI_RxC_FLIT_NOT_SENT.NO_TXQ_NO_MSG",
        "PerPkg": "1",
        "PublicDescription": "header flit is ready for transmission but could not be sent; No TxQ credits available; no additional message slotted into flit",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Header Not Sent; Sent - One Slot Taken",
        "EventCode": "0x55",
        "EventName": "UNC_M3UPI_RxC_FLIT_NOT_SENT.ONE_TAKEN",
        "PerPkg": "1",
        "PublicDescription": "header flit is ready for transmission but could not be sent; sending header flit with only one slot taken (two slots free)",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Header Not Sent; Sent - Three Slots Taken",
        "EventCode": "0x55",
        "EventName": "UNC_M3UPI_RxC_FLIT_NOT_SENT.THREE_TAKEN",
        "PerPkg": "1",
        "PublicDescription": "header flit is ready for transmission but could not be sent; sending header flit with three slots taken (no slots free)",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Header Not Sent; Sent - Two Slots Taken",
        "EventCode": "0x55",
        "EventName": "UNC_M3UPI_RxC_FLIT_NOT_SENT.TWO_TAKEN",
        "PerPkg": "1",
        "PublicDescription": "header flit is ready for transmission but could not be sent; sending header flit with only two slots taken (one slots free)",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Message Held; Can't Slot AD",
        "EventCode": "0x52",
        "EventName": "UNC_M3UPI_RxC_HELD.CANT_SLOT_AD",
        "PerPkg": "1",
        "PublicDescription": "some AD message could not be slotted (logical OR of all AD events under INGR_SLOT_CANT_MC_VN{0,1})",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Message Held; Can't Slot BL",
        "EventCode": "0x52",
        "EventName": "UNC_M3UPI_RxC_HELD.CANT_SLOT_BL",
        "PerPkg": "1",
        "PublicDescription": "some BL message could not be slotted (logical OR of all BL events under INGR_SLOT_CANT_MC_VN{0,1})",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Message Held; Parallel AD Lost",
        "EventCode": "0x52",
        "EventName": "UNC_M3UPI_RxC_HELD.PARALLEL_AD_LOST",
        "PerPkg": "1",
        "PublicDescription": "some AD message lost contest for slot 0 (logical OR of all AD events under INGR_SLOT_LOST_MC_VN{0,1})",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Message Held; Parallel Attempt",
        "EventCode": "0x52",
        "EventName": "UNC_M3UPI_RxC_HELD.PARALLEL_ATTEMPT",
        "PerPkg": "1",
        "PublicDescription": "ad and bl messages attempted to slot into the same flit in parallel",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Message Held; Parallel BL Lost",
        "EventCode": "0x52",
        "EventName": "UNC_M3UPI_RxC_HELD.PARALLEL_BL_LOST",
        "PerPkg": "1",
        "PublicDescription": "some BL message lost contest for slot 0 (logical OR of all BL events under INGR_SLOT_LOST_MC_VN{0,1})",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Message Held; Parallel Success",
        "EventCode": "0x52",
        "EventName": "UNC_M3UPI_RxC_HELD.PARALLEL_SUCCESS",
        "PerPkg": "1",
        "PublicDescription": "ad and bl messages were actually slotted into the same flit in parallel",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Message Held; VN0",
        "EventCode": "0x52",
        "EventName": "UNC_M3UPI_RxC_HELD.VN0",
        "PerPkg": "1",
        "PublicDescription": "vn0 message(s) that couldn't be slotted into last vn0 flit are held in slotting stage while processing vn1 flit",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Message Held; VN1",
        "EventCode": "0x52",
        "EventName": "UNC_M3UPI_RxC_HELD.VN1",
        "PerPkg": "1",
        "PublicDescription": "vn1 message(s) that couldn't be slotted into last vn1 flit are held in slotting stage while processing vn0 flit",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Inserts; REQ on AD",
        "EventCode": "0x41",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN0.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Inserts; RSP on AD",
        "EventCode": "0x41",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN0.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Inserts; SNP on AD",
        "EventCode": "0x41",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN0.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Inserts; NCB on BL",
        "EventCode": "0x41",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN0.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Inserts; NCS on BL",
        "EventCode": "0x41",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN0.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Inserts; RSP on BL",
        "EventCode": "0x41",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN0.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Inserts; WB on BL",
        "EventCode": "0x41",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN0.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Inserts; REQ on AD",
        "EventCode": "0x42",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN1.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Inserts; RSP on AD",
        "EventCode": "0x42",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN1.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Inserts; SNP on AD",
        "EventCode": "0x42",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN1.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Inserts; NCB on BL",
        "EventCode": "0x42",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN1.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Inserts; NCS on BL",
        "EventCode": "0x42",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN1.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Inserts; RSP on BL",
        "EventCode": "0x42",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN1.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Inserts; WB on BL",
        "EventCode": "0x42",
        "EventName": "UNC_M3UPI_RxC_INSERTS_VN1.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the UPI VN1  Ingress.  This tracks one of the three rings that are used by the UPI agent.  This can be used in conjunction with the UPI VN1  Ingress Occupancy Accumulator event in order to calculate average queue latency.  Multiple ingress buffers can be tracked at a given time using multiple counters.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Occupancy; REQ on AD",
        "EventCode": "0x45",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN0.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Occupancy; RSP on AD",
        "EventCode": "0x45",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN0.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Occupancy; SNP on AD",
        "EventCode": "0x45",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN0.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Occupancy; NCB on BL",
        "EventCode": "0x45",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN0.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Occupancy; NCS on BL",
        "EventCode": "0x45",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN0.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Occupancy; RSP on BL",
        "EventCode": "0x45",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN0.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Ingress (from CMS) Queue - Occupancy; WB on BL",
        "EventCode": "0x45",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN0.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Occupancy; REQ on AD",
        "EventCode": "0x46",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN1.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Occupancy; RSP on AD",
        "EventCode": "0x46",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN1.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Occupancy; SNP on AD",
        "EventCode": "0x46",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN1.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Occupancy; NCB on BL",
        "EventCode": "0x46",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN1.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Occupancy; NCS on BL",
        "EventCode": "0x46",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN1.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Occupancy; RSP on BL",
        "EventCode": "0x46",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN1.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Ingress (from CMS) Queue - Occupancy; WB on BL",
        "EventCode": "0x46",
        "EventName": "UNC_M3UPI_RxC_OCCUPANCY_VN1.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the occupancy of a given UPI VN1  Ingress queue in each cycle.  This tracks one of the three ring Ingress buffers.  This can be used with the UPI VN1  Ingress Not Empty event to calculate average occupancy or the UPI VN1  Ingress Allocations event in order to calculate average queuing latency.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message can't slot into flit; REQ on AD",
        "EventCode": "0x4E",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN0.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message can't slot into flit; RSP on AD",
        "EventCode": "0x4E",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN0.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message can't slot into flit; SNP on AD",
        "EventCode": "0x4E",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN0.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message can't slot into flit; NCB on BL",
        "EventCode": "0x4E",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN0.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message can't slot into flit; NCS on BL",
        "EventCode": "0x4E",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN0.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message can't slot into flit; RSP on BL",
        "EventCode": "0x4E",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN0.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 message can't slot into flit; WB on BL",
        "EventCode": "0x4E",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN0.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message can't slot into flit; REQ on AD",
        "EventCode": "0x4F",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN1.AD_REQ",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message can't slot into flit; RSP on AD",
        "EventCode": "0x4F",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN1.AD_RSP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message can't slot into flit; SNP on AD",
        "EventCode": "0x4F",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN1.AD_SNP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message can't slot into flit; NCB on BL",
        "EventCode": "0x4F",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN1.BL_NCB",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message can't slot into flit; NCS on BL",
        "EventCode": "0x4F",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN1.BL_NCS",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Non-Coherent Standard (NCS) messages on BL.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message can't slot into flit; RSP on BL",
        "EventCode": "0x4F",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN1.BL_RSP",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 message can't slot into flit; WB on BL",
        "EventCode": "0x4F",
        "EventName": "UNC_M3UPI_RxC_PACKING_MISS_VN1.BL_WB",
        "PerPkg": "1",
        "PublicDescription": "Count cases where Ingress has packets to send but did not have time to pack into flit before sending to Agent so slot was left NULL which could have been used.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "SMI3 Prefetch Messages; Lost Arbitration",
        "EventCode": "0x62",
        "EventName": "UNC_M3UPI_RxC_SMI3_PFTCH.ARB_LOST",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "SMI3 Prefetch Messages; Arrived",
        "EventCode": "0x62",
        "EventName": "UNC_M3UPI_RxC_SMI3_PFTCH.ARRIVED",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "SMI3 Prefetch Messages; Dropped - Old",
        "EventCode": "0x62",
        "EventName": "UNC_M3UPI_RxC_SMI3_PFTCH.DROP_OLD",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "SMI3 Prefetch Messages; Dropped - Wrap",
        "EventCode": "0x62",
        "EventName": "UNC_M3UPI_RxC_SMI3_PFTCH.DROP_WRAP",
        "PerPkg": "1",
        "PublicDescription": "Dropped because it was overwritten by new message while prefetch queue was full",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "SMI3 Prefetch Messages; Slotted",
        "EventCode": "0x62",
        "EventName": "UNC_M3UPI_RxC_SMI3_PFTCH.SLOTTED",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Remote VNA Credits; Any In Use",
        "EventCode": "0x5B",
        "EventName": "UNC_M3UPI_RxC_VNA_CRD.ANY_IN_USE",
        "PerPkg": "1",
        "PublicDescription": "At least one remote vna credit is in use",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Remote VNA Credits; Corrected",
        "EventCode": "0x5B",
        "EventName": "UNC_M3UPI_RxC_VNA_CRD.CORRECTED",
        "PerPkg": "1",
        "PublicDescription": "Number of remote vna credits corrected (local return) per cycle",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Remote VNA Credits; Level < 1",
        "EventCode": "0x5B",
        "EventName": "UNC_M3UPI_RxC_VNA_CRD.LT1",
        "PerPkg": "1",
        "PublicDescription": "Remote vna credit level is less than 1 (i.e. no vna credits available)",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Remote VNA Credits; Level < 4",
        "EventCode": "0x5B",
        "EventName": "UNC_M3UPI_RxC_VNA_CRD.LT4",
        "PerPkg": "1",
        "PublicDescription": "Remote vna credit level is less than 4; bl (or ad requiring 4 vna) cannot arb on vna",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Remote VNA Credits; Level < 5",
        "EventCode": "0x5B",
        "EventName": "UNC_M3UPI_RxC_VNA_CRD.LT5",
        "PerPkg": "1",
        "PublicDescription": "Remote vna credit level is less than 5; parallel ad/bl arb on vna not possible",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Remote VNA Credits; Used",
        "EventCode": "0x5B",
        "EventName": "UNC_M3UPI_RxC_VNA_CRD.USED",
        "PerPkg": "1",
        "PublicDescription": "Number of remote vna credits consumed per cycle",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; AD - Bounce",
        "EventCode": "0xB4",
        "EventName": "UNC_M3UPI_RxR_BUSY_STARVED.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, because a message from the other queue has higher priority",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; AD - Credit",
        "EventCode": "0xB4",
        "EventName": "UNC_M3UPI_RxR_BUSY_STARVED.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, because a message from the other queue has higher priority",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; BL - Bounce",
        "EventCode": "0xB4",
        "EventName": "UNC_M3UPI_RxR_BUSY_STARVED.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, because a message from the other queue has higher priority",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; BL - Credit",
        "EventCode": "0xB4",
        "EventName": "UNC_M3UPI_RxR_BUSY_STARVED.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, because a message from the other queue has higher priority",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; AD - Bounce",
        "EventCode": "0xB2",
        "EventName": "UNC_M3UPI_RxR_BYPASS.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; AD - Credit",
        "EventCode": "0xB2",
        "EventName": "UNC_M3UPI_RxR_BYPASS.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; AK - Bounce",
        "EventCode": "0xB2",
        "EventName": "UNC_M3UPI_RxR_BYPASS.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; BL - Bounce",
        "EventCode": "0xB2",
        "EventName": "UNC_M3UPI_RxR_BYPASS.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; BL - Credit",
        "EventCode": "0xB2",
        "EventName": "UNC_M3UPI_RxR_BYPASS.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Bypass; IV - Bounce",
        "EventCode": "0xB2",
        "EventName": "UNC_M3UPI_RxR_BYPASS.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the CMS Ingress",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; AD - Bounce",
        "EventCode": "0xB3",
        "EventName": "UNC_M3UPI_RxR_CRD_STARVED.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; AD - Credit",
        "EventCode": "0xB3",
        "EventName": "UNC_M3UPI_RxR_CRD_STARVED.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; AK - Bounce",
        "EventCode": "0xB3",
        "EventName": "UNC_M3UPI_RxR_CRD_STARVED.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; BL - Bounce",
        "EventCode": "0xB3",
        "EventName": "UNC_M3UPI_RxR_CRD_STARVED.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; BL - Credit",
        "EventCode": "0xB3",
        "EventName": "UNC_M3UPI_RxR_CRD_STARVED.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; IFV - Credit",
        "EventCode": "0xB3",
        "EventName": "UNC_M3UPI_RxR_CRD_STARVED.IFV",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Injection Starvation; IV - Bounce",
        "EventCode": "0xB3",
        "EventName": "UNC_M3UPI_RxR_CRD_STARVED.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles under injection starvation mode.  This starvation is triggered when the CMS Ingress cannot send a transaction onto the mesh for a long period of time.  In this case, the Ingress is unable to forward to the Egress due to a lack of credit.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; AD - Bounce",
        "EventCode": "0xB1",
        "EventName": "UNC_M3UPI_RxR_INSERTS.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; AD - Credit",
        "EventCode": "0xB1",
        "EventName": "UNC_M3UPI_RxR_INSERTS.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; AK - Bounce",
        "EventCode": "0xB1",
        "EventName": "UNC_M3UPI_RxR_INSERTS.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; BL - Bounce",
        "EventCode": "0xB1",
        "EventName": "UNC_M3UPI_RxR_INSERTS.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; BL - Credit",
        "EventCode": "0xB1",
        "EventName": "UNC_M3UPI_RxR_INSERTS.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Allocations; IV - Bounce",
        "EventCode": "0xB1",
        "EventName": "UNC_M3UPI_RxR_INSERTS.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the CMS Ingress  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; AD - Bounce",
        "EventCode": "0xB0",
        "EventName": "UNC_M3UPI_RxR_OCCUPANCY.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; AD - Credit",
        "EventCode": "0xB0",
        "EventName": "UNC_M3UPI_RxR_OCCUPANCY.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; AK - Bounce",
        "EventCode": "0xB0",
        "EventName": "UNC_M3UPI_RxR_OCCUPANCY.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; BL - Bounce",
        "EventCode": "0xB0",
        "EventName": "UNC_M3UPI_RxR_OCCUPANCY.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; BL - Credit",
        "EventCode": "0xB0",
        "EventName": "UNC_M3UPI_RxR_OCCUPANCY.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Transgress Ingress Occupancy; IV - Bounce",
        "EventCode": "0xB0",
        "EventName": "UNC_M3UPI_RxR_OCCUPANCY.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Ingress buffers in the CMS  The Ingress is used to queue up requests received from the mesh",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 0",
        "EventCode": "0xD0",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 1",
        "EventCode": "0xD0",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 2",
        "EventCode": "0xD0",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 3",
        "EventCode": "0xD0",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 4",
        "EventCode": "0xD0",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent0 Transgress Credits; For Transgress 5",
        "EventCode": "0xD0",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG0.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 0",
        "EventCode": "0xD2",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 1",
        "EventCode": "0xD2",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 2",
        "EventCode": "0xD2",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 3",
        "EventCode": "0xD2",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 4",
        "EventCode": "0xD2",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No AD Agent1 Transgress Credits; For Transgress 5",
        "EventCode": "0xD2",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_AD_AG1.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 0",
        "EventCode": "0xD4",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 1",
        "EventCode": "0xD4",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 2",
        "EventCode": "0xD4",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 3",
        "EventCode": "0xD4",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 4",
        "EventCode": "0xD4",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent0 Transgress Credits; For Transgress 5",
        "EventCode": "0xD4",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG0.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 0 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 0",
        "EventCode": "0xD6",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 1",
        "EventCode": "0xD6",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 2",
        "EventCode": "0xD6",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR2",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 3",
        "EventCode": "0xD6",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR3",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 4",
        "EventCode": "0xD6",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR4",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Stall on No BL Agent1 Transgress Credits; For Transgress 5",
        "EventCode": "0xD6",
        "EventName": "UNC_M3UPI_STALL_NO_TxR_HORZ_CRD_BL_AG1.TGR5",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Agent 1 Egress Buffer is stalled waiting for a TGR credit to become available, per transgress.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for AD; VN0 REQ Messages",
        "EventCode": "0x30",
        "EventName": "UNC_M3UPI_TxC_AD_ARB_FAIL.VN0_REQ",
        "PerPkg": "1",
        "PublicDescription": "AD arb but no win; arb request asserted but not won",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for AD; VN0 RSP Messages",
        "EventCode": "0x30",
        "EventName": "UNC_M3UPI_TxC_AD_ARB_FAIL.VN0_RSP",
        "PerPkg": "1",
        "PublicDescription": "AD arb but no win; arb request asserted but not won",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for AD; VN0 SNP Messages",
        "EventCode": "0x30",
        "EventName": "UNC_M3UPI_TxC_AD_ARB_FAIL.VN0_SNP",
        "PerPkg": "1",
        "PublicDescription": "AD arb but no win; arb request asserted but not won",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for AD; VN0 WB Messages",
        "EventCode": "0x30",
        "EventName": "UNC_M3UPI_TxC_AD_ARB_FAIL.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "AD arb but no win; arb request asserted but not won",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for AD; VN1 REQ Messages",
        "EventCode": "0x30",
        "EventName": "UNC_M3UPI_TxC_AD_ARB_FAIL.VN1_REQ",
        "PerPkg": "1",
        "PublicDescription": "AD arb but no win; arb request asserted but not won",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for AD; VN1 RSP Messages",
        "EventCode": "0x30",
        "EventName": "UNC_M3UPI_TxC_AD_ARB_FAIL.VN1_RSP",
        "PerPkg": "1",
        "PublicDescription": "AD arb but no win; arb request asserted but not won",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for AD; VN1 SNP Messages",
        "EventCode": "0x30",
        "EventName": "UNC_M3UPI_TxC_AD_ARB_FAIL.VN1_SNP",
        "PerPkg": "1",
        "PublicDescription": "AD arb but no win; arb request asserted but not won",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for AD; VN1 WB Messages",
        "EventCode": "0x30",
        "EventName": "UNC_M3UPI_TxC_AD_ARB_FAIL.VN1_WB",
        "PerPkg": "1",
        "PublicDescription": "AD arb but no win; arb request asserted but not won",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD FlowQ Bypass",
        "EventCode": "0x2C",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_BYPASS.AD_SLOT0",
        "PerPkg": "1",
        "PublicDescription": "Counts cases when the AD flowQ is bypassed (S0, S1 and S2 indicate which slot was bypassed with S0 having the highest priority and S2 the least)",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD FlowQ Bypass",
        "EventCode": "0x2C",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_BYPASS.AD_SLOT1",
        "PerPkg": "1",
        "PublicDescription": "Counts cases when the AD flowQ is bypassed (S0, S1 and S2 indicate which slot was bypassed with S0 having the highest priority and S2 the least)",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD FlowQ Bypass",
        "EventCode": "0x2C",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_BYPASS.AD_SLOT2",
        "PerPkg": "1",
        "PublicDescription": "Counts cases when the AD flowQ is bypassed (S0, S1 and S2 indicate which slot was bypassed with S0 having the highest priority and S2 the least)",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD FlowQ Bypass",
        "EventCode": "0x2C",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_BYPASS.BL_EARLY_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts cases when the AD flowQ is bypassed (S0, S1 and S2 indicate which slot was bypassed with S0 having the highest priority and S2 the least)",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Not Empty; VN0 REQ Messages",
        "EventCode": "0x27",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_CYCLES_NE.VN0_REQ",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Egress queue is Not Empty",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Not Empty; VN0 RSP Messages",
        "EventCode": "0x27",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_CYCLES_NE.VN0_RSP",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Egress queue is Not Empty",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Not Empty; VN0 SNP Messages",
        "EventCode": "0x27",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_CYCLES_NE.VN0_SNP",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Egress queue is Not Empty",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Not Empty; VN0 WB Messages",
        "EventCode": "0x27",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_CYCLES_NE.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Egress queue is Not Empty",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Not Empty; VN1 REQ Messages",
        "EventCode": "0x27",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_CYCLES_NE.VN1_REQ",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Egress queue is Not Empty",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Not Empty; VN1 RSP Messages",
        "EventCode": "0x27",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_CYCLES_NE.VN1_RSP",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Egress queue is Not Empty",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Not Empty; VN1 SNP Messages",
        "EventCode": "0x27",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_CYCLES_NE.VN1_SNP",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Egress queue is Not Empty",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Not Empty; VN1 WB Messages",
        "EventCode": "0x27",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_CYCLES_NE.VN1_WB",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the AD Egress queue is Not Empty",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Inserts; VN0 REQ Messages",
        "EventCode": "0x2D",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_INSERTS.VN0_REQ",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Inserts; VN0 RSP Messages",
        "EventCode": "0x2D",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_INSERTS.VN0_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Inserts; VN0 SNP Messages",
        "EventCode": "0x2D",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_INSERTS.VN0_SNP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Inserts; VN0 WB Messages",
        "EventCode": "0x2D",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_INSERTS.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Inserts; VN1 REQ Messages",
        "EventCode": "0x2D",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_INSERTS.VN1_REQ",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Inserts; VN1 RSP Messages",
        "EventCode": "0x2D",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_INSERTS.VN1_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Inserts; VN1 SNP Messages",
        "EventCode": "0x2D",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_INSERTS.VN1_SNP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Occupancy; VN0 REQ Messages",
        "EventCode": "0x1C",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_OCCUPANCY.VN0_REQ",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Occupancy; VN0 RSP Messages",
        "EventCode": "0x1C",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_OCCUPANCY.VN0_RSP",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Occupancy; VN0 SNP Messages",
        "EventCode": "0x1C",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_OCCUPANCY.VN0_SNP",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Occupancy; VN0 WB Messages",
        "EventCode": "0x1C",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_OCCUPANCY.VN0_WB",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Occupancy; VN1 REQ Messages",
        "EventCode": "0x1C",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_OCCUPANCY.VN1_REQ",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Occupancy; VN1 RSP Messages",
        "EventCode": "0x1C",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_OCCUPANCY.VN1_RSP",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AD Flow Q Occupancy; VN1 SNP Messages",
        "EventCode": "0x1C",
        "EventName": "UNC_M3UPI_TxC_AD_FLQ_OCCUPANCY.VN1_SNP",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Number of Snoop Targets; CHA on VN0",
        "EventCode": "0x3C",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP1_VN1.VN0_CHA",
        "PerPkg": "1",
        "PublicDescription": "Number of snpfanout targets and non-idle cycles can be used to calculate average snpfanout latency; Number of VN0 Snpf to CHA",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Number of Snoop Targets; Non Idle cycles on VN0",
        "EventCode": "0x3C",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP1_VN1.VN0_NON_IDLE",
        "PerPkg": "1",
        "PublicDescription": "Number of snpfanout targets and non-idle cycles can be used to calculate average snpfanout latency; Number of non-idle cycles in issuing Vn0 Snpf",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Number of Snoop Targets; Peer UPI0 on VN0",
        "EventCode": "0x3C",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP1_VN1.VN0_PEER_UPI0",
        "PerPkg": "1",
        "PublicDescription": "Number of snpfanout targets and non-idle cycles can be used to calculate average snpfanout latency; Number of VN0 Snpf to peer UPI0",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Number of Snoop Targets; Peer UPI1 on VN0",
        "EventCode": "0x3C",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP1_VN1.VN0_PEER_UPI1",
        "PerPkg": "1",
        "PublicDescription": "Number of snpfanout targets and non-idle cycles can be used to calculate average snpfanout latency; Number of VN0 Snpf to peer UPI1",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Number of Snoop Targets; CHA on VN1",
        "EventCode": "0x3C",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP1_VN1.VN1_CHA",
        "PerPkg": "1",
        "PublicDescription": "Number of snpfanout targets and non-idle cycles can be used to calculate average snpfanout latency; Number of VN1 Snpf to CHA",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Number of Snoop Targets; Non Idle cycles on VN1",
        "EventCode": "0x3C",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP1_VN1.VN1_NON_IDLE",
        "PerPkg": "1",
        "PublicDescription": "Number of snpfanout targets and non-idle cycles can be used to calculate average snpfanout latency; Number of non-idle cycles in issuing Vn1 Snpf",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Number of Snoop Targets; Peer UPI0 on VN1",
        "EventCode": "0x3C",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP1_VN1.VN1_PEER_UPI0",
        "PerPkg": "1",
        "PublicDescription": "Number of snpfanout targets and non-idle cycles can be used to calculate average snpfanout latency; Number of VN1 Snpf to peer UPI0",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Number of Snoop Targets; Peer UPI1 on VN1",
        "EventCode": "0x3C",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP1_VN1.VN1_PEER_UPI1",
        "PerPkg": "1",
        "PublicDescription": "Number of snpfanout targets and non-idle cycles can be used to calculate average snpfanout latency; Number of VN1 Snpf to peer UPI1",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Snoop Arbitration; FlowQ Won",
        "EventCode": "0x3D",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP2_VN1.VN0_SNPFP_NONSNP",
        "PerPkg": "1",
        "PublicDescription": "Outcome of SnpF pending arbitration; FlowQ txn issued when SnpF pending on Vn0",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Snoop Arbitration; FlowQ SnpF Won",
        "EventCode": "0x3D",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP2_VN1.VN0_SNPFP_VN2SNP",
        "PerPkg": "1",
        "PublicDescription": "Outcome of SnpF pending arbitration; FlowQ Vn0 SnpF issued when SnpF pending on Vn1",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Snoop Arbitration; FlowQ Won",
        "EventCode": "0x3D",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP2_VN1.VN1_SNPFP_NONSNP",
        "PerPkg": "1",
        "PublicDescription": "Outcome of SnpF pending arbitration; FlowQ txn issued when SnpF pending on Vn1",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Snoop Arbitration; FlowQ SnpF Won",
        "EventCode": "0x3D",
        "EventName": "UNC_M3UPI_TxC_AD_SNPF_GRP2_VN1.VN1_SNPFP_VN0SNP",
        "PerPkg": "1",
        "PublicDescription": "Outcome of SnpF pending arbitration; FlowQ Vn1 SnpF issued when SnpF pending on Vn0",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  -  Credit Available; VN0 REQ Messages",
        "EventCode": "0x34",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_CRD_AVAIL.VN0_REQ",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request with prior cycle credit check complete and credit avail",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  -  Credit Available; VN0 SNP Messages",
        "EventCode": "0x34",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_CRD_AVAIL.VN0_SNP",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request with prior cycle credit check complete and credit avail",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  -  Credit Available; VN0 WB Messages",
        "EventCode": "0x34",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_CRD_AVAIL.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request with prior cycle credit check complete and credit avail",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  -  Credit Available; VN1 REQ Messages",
        "EventCode": "0x34",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_CRD_AVAIL.VN1_REQ",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request with prior cycle credit check complete and credit avail",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  -  Credit Available; VN1 SNP Messages",
        "EventCode": "0x34",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_CRD_AVAIL.VN1_SNP",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request with prior cycle credit check complete and credit avail",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  -  Credit Available; VN1 WB Messages",
        "EventCode": "0x34",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_CRD_AVAIL.VN1_WB",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request with prior cycle credit check complete and credit avail",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - New Message; VN0 REQ Messages",
        "EventCode": "0x33",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NEW_MSG.VN0_REQ",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - New Message; VN0 SNP Messages",
        "EventCode": "0x33",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NEW_MSG.VN0_SNP",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - New Message; VN0 WB Messages",
        "EventCode": "0x33",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NEW_MSG.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - New Message; VN1 REQ Messages",
        "EventCode": "0x33",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NEW_MSG.VN1_REQ",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - New Message; VN1 SNP Messages",
        "EventCode": "0x33",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NEW_MSG.VN1_SNP",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - New Message; VN1 WB Messages",
        "EventCode": "0x33",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NEW_MSG.VN1_WB",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - No Credit; VN0 REQ Messages",
        "EventCode": "0x32",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NO_OTHER_PEND.VN0_REQ",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - No Credit; VN0 RSP Messages",
        "EventCode": "0x32",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NO_OTHER_PEND.VN0_RSP",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - No Credit; VN0 SNP Messages",
        "EventCode": "0x32",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NO_OTHER_PEND.VN0_SNP",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - No Credit; VN0 WB Messages",
        "EventCode": "0x32",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NO_OTHER_PEND.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - No Credit; VN1 REQ Messages",
        "EventCode": "0x32",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NO_OTHER_PEND.VN1_REQ",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - No Credit; VN1 RSP Messages",
        "EventCode": "0x32",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NO_OTHER_PEND.VN1_RSP",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - No Credit; VN1 SNP Messages",
        "EventCode": "0x32",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NO_OTHER_PEND.VN1_SNP",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD  - No Credit; VN1 WB Messages",
        "EventCode": "0x32",
        "EventName": "UNC_M3UPI_TxC_AD_SPEC_ARB_NO_OTHER_PEND.VN1_WB",
        "PerPkg": "1",
        "PublicDescription": "AD speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AK Flow Q Inserts",
        "EventCode": "0x2F",
        "EventName": "UNC_M3UPI_TxC_AK_FLQ_INSERTS",
        "PerPkg": "1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "AK Flow Q Occupancy",
        "EventCode": "0x1E",
        "EventName": "UNC_M3UPI_TxC_AK_FLQ_OCCUPANCY",
        "PerPkg": "1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for BL; VN0 NCB Messages",
        "EventCode": "0x35",
        "EventName": "UNC_M3UPI_TxC_BL_ARB_FAIL.VN0_NCB",
        "PerPkg": "1",
        "PublicDescription": "BL arb but no win; arb request asserted but not won",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for BL; VN0 NCS Messages",
        "EventCode": "0x35",
        "EventName": "UNC_M3UPI_TxC_BL_ARB_FAIL.VN0_NCS",
        "PerPkg": "1",
        "PublicDescription": "BL arb but no win; arb request asserted but not won",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for BL; VN0 RSP Messages",
        "EventCode": "0x35",
        "EventName": "UNC_M3UPI_TxC_BL_ARB_FAIL.VN0_RSP",
        "PerPkg": "1",
        "PublicDescription": "BL arb but no win; arb request asserted but not won",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for BL; VN0 WB Messages",
        "EventCode": "0x35",
        "EventName": "UNC_M3UPI_TxC_BL_ARB_FAIL.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "BL arb but no win; arb request asserted but not won",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for BL; VN1 NCS Messages",
        "EventCode": "0x35",
        "EventName": "UNC_M3UPI_TxC_BL_ARB_FAIL.VN1_NCB",
        "PerPkg": "1",
        "PublicDescription": "BL arb but no win; arb request asserted but not won",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for BL; VN1 NCB Messages",
        "EventCode": "0x35",
        "EventName": "UNC_M3UPI_TxC_BL_ARB_FAIL.VN1_NCS",
        "PerPkg": "1",
        "PublicDescription": "BL arb but no win; arb request asserted but not won",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for BL; VN1 RSP Messages",
        "EventCode": "0x35",
        "EventName": "UNC_M3UPI_TxC_BL_ARB_FAIL.VN1_RSP",
        "PerPkg": "1",
        "PublicDescription": "BL arb but no win; arb request asserted but not won",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Failed ARB for BL; VN1 WB Messages",
        "EventCode": "0x35",
        "EventName": "UNC_M3UPI_TxC_BL_ARB_FAIL.VN1_WB",
        "PerPkg": "1",
        "PublicDescription": "BL arb but no win; arb request asserted but not won",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Not Empty; VN0 REQ Messages",
        "EventCode": "0x28",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_CYCLES_NE.VN0_REQ",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Egress queue is Not Empty",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Not Empty; VN0 RSP Messages",
        "EventCode": "0x28",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_CYCLES_NE.VN0_RSP",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Egress queue is Not Empty",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Not Empty; VN0 SNP Messages",
        "EventCode": "0x28",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_CYCLES_NE.VN0_SNP",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Egress queue is Not Empty",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Not Empty; VN0 WB Messages",
        "EventCode": "0x28",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_CYCLES_NE.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Egress queue is Not Empty",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Not Empty; VN1 REQ Messages",
        "EventCode": "0x28",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_CYCLES_NE.VN1_REQ",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Egress queue is Not Empty",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Not Empty; VN1 RSP Messages",
        "EventCode": "0x28",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_CYCLES_NE.VN1_RSP",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Egress queue is Not Empty",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Not Empty; VN1 SNP Messages",
        "EventCode": "0x28",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_CYCLES_NE.VN1_SNP",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Egress queue is Not Empty",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Not Empty; VN1 WB Messages",
        "EventCode": "0x28",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_CYCLES_NE.VN1_WB",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the BL Egress queue is Not Empty",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Inserts; VN0 RSP Messages",
        "EventCode": "0x2E",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_INSERTS.VN0_NCB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Inserts; VN0 WB Messages",
        "EventCode": "0x2E",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_INSERTS.VN0_NCS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Inserts; VN0 NCS Messages",
        "EventCode": "0x2E",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_INSERTS.VN0_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Inserts; VN0 NCB Messages",
        "EventCode": "0x2E",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_INSERTS.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Inserts; VN1 RSP Messages",
        "EventCode": "0x2E",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_INSERTS.VN1_NCB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Inserts; VN1 WB Messages",
        "EventCode": "0x2E",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_INSERTS.VN1_NCS",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Inserts; VN1_NCB Messages",
        "EventCode": "0x2E",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_INSERTS.VN1_RSP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Inserts; VN1_NCS Messages",
        "EventCode": "0x2E",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_INSERTS.VN1_WB",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of allocations into the QPI FlowQ. This can be used in conjunction with the QPI FlowQ Occupancy Accumulator event in order to calculate average queue latency.  Only a single FlowQ queue can be tracked at any given time.  It is not possible to filter based on direction or polarity.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Occupancy; VN0 NCB Messages",
        "EventCode": "0x1D",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_OCCUPANCY.VN0_NCB",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Occupancy; VN0 NCS Messages",
        "EventCode": "0x1D",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_OCCUPANCY.VN0_NCS",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Occupancy; VN0 RSP Messages",
        "EventCode": "0x1D",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_OCCUPANCY.VN0_RSP",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Occupancy; VN0 WB Messages",
        "EventCode": "0x1D",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_OCCUPANCY.VN0_WB",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Occupancy; VN1_NCS Messages",
        "EventCode": "0x1D",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_OCCUPANCY.VN1_NCB",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Occupancy; VN1_NCB Messages",
        "EventCode": "0x1D",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_OCCUPANCY.VN1_NCS",
        "PerPkg": "1",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Occupancy; VN1 RSP Messages",
        "EventCode": "0x1D",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_OCCUPANCY.VN1_RSP",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "BL Flow Q Occupancy; VN1 WB Messages",
        "EventCode": "0x1D",
        "EventName": "UNC_M3UPI_TxC_BL_FLQ_OCCUPANCY.VN1_WB",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for BL  - New Message; VN0 WB Messages",
        "EventCode": "0x38",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NEW_MSG.VN0_NCB",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for BL  - New Message; VN0 NCS Messages",
        "EventCode": "0x38",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NEW_MSG.VN0_NCS",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for BL  - New Message; VN0 WB Messages",
        "EventCode": "0x38",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NEW_MSG.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for BL  - New Message; VN1 WB Messages",
        "EventCode": "0x38",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NEW_MSG.VN1_NCB",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for BL  - New Message; VN1 NCB Messages",
        "EventCode": "0x38",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NEW_MSG.VN1_NCS",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for BL  - New Message; VN1 RSP Messages",
        "EventCode": "0x38",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NEW_MSG.VN1_WB",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request due to new message arriving on a specific channel (MC/VN)",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD Failed - No Credit; VN0 NCB Messages",
        "EventCode": "0x37",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NO_OTHER_PEND.VN0_NCB",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD Failed - No Credit; VN0 NCS Messages",
        "EventCode": "0x37",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NO_OTHER_PEND.VN0_NCS",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD Failed - No Credit; VN0 RSP Messages",
        "EventCode": "0x37",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NO_OTHER_PEND.VN0_RSP",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD Failed - No Credit; VN0 WB Messages",
        "EventCode": "0x37",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NO_OTHER_PEND.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD Failed - No Credit; VN1 NCS Messages",
        "EventCode": "0x37",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NO_OTHER_PEND.VN1_NCB",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD Failed - No Credit; VN1 NCB Messages",
        "EventCode": "0x37",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NO_OTHER_PEND.VN1_NCS",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x80",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD Failed - No Credit; VN1 RSP Messages",
        "EventCode": "0x37",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NO_OTHER_PEND.VN1_RSP",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Speculative ARB for AD Failed - No Credit; VN1 WB Messages",
        "EventCode": "0x37",
        "EventName": "UNC_M3UPI_TxC_BL_SPEC_ARB_NO_OTHER_PEND.VN1_WB",
        "PerPkg": "1",
        "PublicDescription": "BL speculative arb request asserted due to no other channel being active (have a valid entry but don't have credits to send)",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal ADS Used; AD - Bounce",
        "EventCode": "0x9D",
        "EventName": "UNC_M3UPI_TxR_HORZ_ADS_USED.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Horizontal Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal ADS Used; AD - Credit",
        "EventCode": "0x9D",
        "EventName": "UNC_M3UPI_TxR_HORZ_ADS_USED.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Horizontal Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal ADS Used; AK - Bounce",
        "EventCode": "0x9D",
        "EventName": "UNC_M3UPI_TxR_HORZ_ADS_USED.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Horizontal Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal ADS Used; BL - Bounce",
        "EventCode": "0x9D",
        "EventName": "UNC_M3UPI_TxR_HORZ_ADS_USED.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Horizontal Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal ADS Used; BL - Credit",
        "EventCode": "0x9D",
        "EventName": "UNC_M3UPI_TxR_HORZ_ADS_USED.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Horizontal Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; AD - Bounce",
        "EventCode": "0x9F",
        "EventName": "UNC_M3UPI_TxR_HORZ_BYPASS.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; AD - Credit",
        "EventCode": "0x9F",
        "EventName": "UNC_M3UPI_TxR_HORZ_BYPASS.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; AK - Bounce",
        "EventCode": "0x9F",
        "EventName": "UNC_M3UPI_TxR_HORZ_BYPASS.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; BL - Bounce",
        "EventCode": "0x9F",
        "EventName": "UNC_M3UPI_TxR_HORZ_BYPASS.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; BL - Credit",
        "EventCode": "0x9F",
        "EventName": "UNC_M3UPI_TxR_HORZ_BYPASS.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Bypass Used; IV - Bounce",
        "EventCode": "0x9F",
        "EventName": "UNC_M3UPI_TxR_HORZ_BYPASS.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Horizontal Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; AD - Bounce",
        "EventCode": "0x96",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_FULL.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; AD - Credit",
        "EventCode": "0x96",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_FULL.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; AK - Bounce",
        "EventCode": "0x96",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_FULL.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; BL - Bounce",
        "EventCode": "0x96",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_FULL.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; BL - Credit",
        "EventCode": "0x96",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_FULL.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Full; IV - Bounce",
        "EventCode": "0x96",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_FULL.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Full.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; AD - Bounce",
        "EventCode": "0x97",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_NE.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; AD - Credit",
        "EventCode": "0x97",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_NE.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; AK - Bounce",
        "EventCode": "0x97",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_NE.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; BL - Bounce",
        "EventCode": "0x97",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_NE.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; BL - Credit",
        "EventCode": "0x97",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_NE.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Horizontal Egress Queue is Not Empty; IV - Bounce",
        "EventCode": "0x97",
        "EventName": "UNC_M3UPI_TxR_HORZ_CYCLES_NE.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Cycles the Transgress buffers in the Common Mesh Stop are Not-Empty.  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; AD - Bounce",
        "EventCode": "0x95",
        "EventName": "UNC_M3UPI_TxR_HORZ_INSERTS.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; AD - Credit",
        "EventCode": "0x95",
        "EventName": "UNC_M3UPI_TxR_HORZ_INSERTS.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; AK - Bounce",
        "EventCode": "0x95",
        "EventName": "UNC_M3UPI_TxR_HORZ_INSERTS.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; BL - Bounce",
        "EventCode": "0x95",
        "EventName": "UNC_M3UPI_TxR_HORZ_INSERTS.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; BL - Credit",
        "EventCode": "0x95",
        "EventName": "UNC_M3UPI_TxR_HORZ_INSERTS.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Inserts; IV - Bounce",
        "EventCode": "0x95",
        "EventName": "UNC_M3UPI_TxR_HORZ_INSERTS.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; AD - Bounce",
        "EventCode": "0x99",
        "EventName": "UNC_M3UPI_TxR_HORZ_NACK.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; AD - Credit",
        "EventCode": "0x99",
        "EventName": "UNC_M3UPI_TxR_HORZ_NACK.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; AK - Bounce",
        "EventCode": "0x99",
        "EventName": "UNC_M3UPI_TxR_HORZ_NACK.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; BL - Bounce",
        "EventCode": "0x99",
        "EventName": "UNC_M3UPI_TxR_HORZ_NACK.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; BL - Credit",
        "EventCode": "0x99",
        "EventName": "UNC_M3UPI_TxR_HORZ_NACK.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress NACKs; IV - Bounce",
        "EventCode": "0x99",
        "EventName": "UNC_M3UPI_TxR_HORZ_NACK.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Horizontal Ring",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; AD - Bounce",
        "EventCode": "0x94",
        "EventName": "UNC_M3UPI_TxR_HORZ_OCCUPANCY.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; AD - Credit",
        "EventCode": "0x94",
        "EventName": "UNC_M3UPI_TxR_HORZ_OCCUPANCY.AD_CRD",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; AK - Bounce",
        "EventCode": "0x94",
        "EventName": "UNC_M3UPI_TxR_HORZ_OCCUPANCY.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; BL - Bounce",
        "EventCode": "0x94",
        "EventName": "UNC_M3UPI_TxR_HORZ_OCCUPANCY.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; BL - Credit",
        "EventCode": "0x94",
        "EventName": "UNC_M3UPI_TxR_HORZ_OCCUPANCY.BL_CRD",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Occupancy; IV - Bounce",
        "EventCode": "0x94",
        "EventName": "UNC_M3UPI_TxR_HORZ_OCCUPANCY.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Transgress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Horizontal Ring on the Mesh.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Injection Starvation; AD - Bounce",
        "EventCode": "0x9B",
        "EventName": "UNC_M3UPI_TxR_HORZ_STARVED.AD_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Transgress buffer cannot send a transaction onto the Horizontal ring for a long period of time.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Injection Starvation; AK - Bounce",
        "EventCode": "0x9B",
        "EventName": "UNC_M3UPI_TxR_HORZ_STARVED.AK_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Transgress buffer cannot send a transaction onto the Horizontal ring for a long period of time.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Injection Starvation; BL - Bounce",
        "EventCode": "0x9B",
        "EventName": "UNC_M3UPI_TxR_HORZ_STARVED.BL_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Transgress buffer cannot send a transaction onto the Horizontal ring for a long period of time.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Horizontal Egress Injection Starvation; IV - Bounce",
        "EventCode": "0x9B",
        "EventName": "UNC_M3UPI_TxR_HORZ_STARVED.IV_BNC",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Transgress buffer cannot send a transaction onto the Horizontal ring for a long period of time.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AD - Agent 0",
        "EventCode": "0x9C",
        "EventName": "UNC_M3UPI_TxR_VERT_ADS_USED.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AD - Agent 1",
        "EventCode": "0x9C",
        "EventName": "UNC_M3UPI_TxR_VERT_ADS_USED.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AK - Agent 0",
        "EventCode": "0x9C",
        "EventName": "UNC_M3UPI_TxR_VERT_ADS_USED.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AK - Agent 1",
        "EventCode": "0x9C",
        "EventName": "UNC_M3UPI_TxR_VERT_ADS_USED.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; BL - Agent 0",
        "EventCode": "0x9C",
        "EventName": "UNC_M3UPI_TxR_VERT_ADS_USED.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; BL - Agent 1",
        "EventCode": "0x9C",
        "EventName": "UNC_M3UPI_TxR_VERT_ADS_USED.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets using the Vertical Anti-Deadlock Slot, broken down by ring type and CMS Agent.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AD - Agent 0",
        "EventCode": "0x9E",
        "EventName": "UNC_M3UPI_TxR_VERT_BYPASS.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AD - Agent 1",
        "EventCode": "0x9E",
        "EventName": "UNC_M3UPI_TxR_VERT_BYPASS.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AK - Agent 0",
        "EventCode": "0x9E",
        "EventName": "UNC_M3UPI_TxR_VERT_BYPASS.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; AK - Agent 1",
        "EventCode": "0x9E",
        "EventName": "UNC_M3UPI_TxR_VERT_BYPASS.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; BL - Agent 0",
        "EventCode": "0x9E",
        "EventName": "UNC_M3UPI_TxR_VERT_BYPASS.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; BL - Agent 1",
        "EventCode": "0x9E",
        "EventName": "UNC_M3UPI_TxR_VERT_BYPASS.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical ADS Used; IV",
        "EventCode": "0x9E",
        "EventName": "UNC_M3UPI_TxR_VERT_BYPASS.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of packets bypassing the Vertical Egress, broken down by ring type and CMS Agent.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; AD - Agent 0",
        "EventCode": "0x92",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_FULL.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AD ring.  Some example include outbound requests, snoop requests, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; AD - Agent 1",
        "EventCode": "0x92",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_FULL.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AD ring.  This is commonly used for outbound requests.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; AK - Agent 0",
        "EventCode": "0x92",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_FULL.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AK ring.  This is commonly used for credit returns and GO responses.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; AK - Agent 1",
        "EventCode": "0x92",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_FULL.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AK ring.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; BL - Agent 0",
        "EventCode": "0x92",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_FULL.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the BL ring.  This is commonly used to send data from the cache to various destinations.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; BL - Agent 1",
        "EventCode": "0x92",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_FULL.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the BL ring.  This is commonly used for transferring writeback data to the cache.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Full; IV",
        "EventCode": "0x92",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_FULL.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Full.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the IV ring.  This is commonly used for snoops to the cores.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; AD - Agent 0",
        "EventCode": "0x93",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_NE.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AD ring.  Some example include outbound requests, snoop requests, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; AD - Agent 1",
        "EventCode": "0x93",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_NE.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AD ring.  This is commonly used for outbound requests.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; AK - Agent 0",
        "EventCode": "0x93",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_NE.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AK ring.  This is commonly used for credit returns and GO responses.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; AK - Agent 1",
        "EventCode": "0x93",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_NE.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AK ring.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; BL - Agent 0",
        "EventCode": "0x93",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_NE.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the BL ring.  This is commonly used to send data from the cache to various destinations.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; BL - Agent 1",
        "EventCode": "0x93",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_NE.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the BL ring.  This is commonly used for transferring writeback data to the cache.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Cycles CMS Vertical Egress Queue Is Not Empty; IV",
        "EventCode": "0x93",
        "EventName": "UNC_M3UPI_TxR_VERT_CYCLES_NE.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of cycles the Common Mesh Stop Egress was Not Empty.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the IV ring.  This is commonly used for snoops to the cores.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; AD - Agent 0",
        "EventCode": "0x91",
        "EventName": "UNC_M3UPI_TxR_VERT_INSERTS.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AD ring.  Some example include outbound requests, snoop requests, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; AD - Agent 1",
        "EventCode": "0x91",
        "EventName": "UNC_M3UPI_TxR_VERT_INSERTS.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AD ring.  This is commonly used for outbound requests.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; AK - Agent 0",
        "EventCode": "0x91",
        "EventName": "UNC_M3UPI_TxR_VERT_INSERTS.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AK ring.  This is commonly used for credit returns and GO responses.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; AK - Agent 1",
        "EventCode": "0x91",
        "EventName": "UNC_M3UPI_TxR_VERT_INSERTS.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AK ring.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; BL - Agent 0",
        "EventCode": "0x91",
        "EventName": "UNC_M3UPI_TxR_VERT_INSERTS.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the BL ring.  This is commonly used to send data from the cache to various destinations.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; BL - Agent 1",
        "EventCode": "0x91",
        "EventName": "UNC_M3UPI_TxR_VERT_INSERTS.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the BL ring.  This is commonly used for transferring writeback data to the cache.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Allocations; IV",
        "EventCode": "0x91",
        "EventName": "UNC_M3UPI_TxR_VERT_INSERTS.IV",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the Common Mesh Stop Egress.  The Egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the IV ring.  This is commonly used for snoops to the cores.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; AD - Agent 0",
        "EventCode": "0x98",
        "EventName": "UNC_M3UPI_TxR_VERT_NACK.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; AD - Agent 1",
        "EventCode": "0x98",
        "EventName": "UNC_M3UPI_TxR_VERT_NACK.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; AK - Agent 0",
        "EventCode": "0x98",
        "EventName": "UNC_M3UPI_TxR_VERT_NACK.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; AK - Agent 1",
        "EventCode": "0x98",
        "EventName": "UNC_M3UPI_TxR_VERT_NACK.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; BL - Agent 0",
        "EventCode": "0x98",
        "EventName": "UNC_M3UPI_TxR_VERT_NACK.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; BL - Agent 1",
        "EventCode": "0x98",
        "EventName": "UNC_M3UPI_TxR_VERT_NACK.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress NACKs; IV",
        "EventCode": "0x98",
        "EventName": "UNC_M3UPI_TxR_VERT_NACK.IV",
        "PerPkg": "1",
        "PublicDescription": "Counts number of Egress packets NACK'ed on to the Vertical Ring",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; AD - Agent 0",
        "EventCode": "0x90",
        "EventName": "UNC_M3UPI_TxR_VERT_OCCUPANCY.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AD ring.  Some example include outbound requests, snoop requests, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; AD - Agent 1",
        "EventCode": "0x90",
        "EventName": "UNC_M3UPI_TxR_VERT_OCCUPANCY.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AD ring.  This is commonly used for outbound requests.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; AK - Agent 0",
        "EventCode": "0x90",
        "EventName": "UNC_M3UPI_TxR_VERT_OCCUPANCY.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the AK ring.  This is commonly used for credit returns and GO responses.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; AK - Agent 1",
        "EventCode": "0x90",
        "EventName": "UNC_M3UPI_TxR_VERT_OCCUPANCY.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the AK ring.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; BL - Agent 0",
        "EventCode": "0x90",
        "EventName": "UNC_M3UPI_TxR_VERT_OCCUPANCY.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the BL ring.  This is commonly used to send data from the cache to various destinations.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; BL - Agent 1",
        "EventCode": "0x90",
        "EventName": "UNC_M3UPI_TxR_VERT_OCCUPANCY.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 1 destined for the BL ring.  This is commonly used for transferring writeback data to the cache.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vert Egress Occupancy; IV",
        "EventCode": "0x90",
        "EventName": "UNC_M3UPI_TxR_VERT_OCCUPANCY.IV",
        "PerPkg": "1",
        "PublicDescription": "Occupancy event for the Egress buffers in the Common Mesh Stop  The egress is used to queue up requests destined for the Vertical Ring on the Mesh.; Ring transactions from Agent 0 destined for the IV ring.  This is commonly used for snoops to the cores.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; AD - Agent 0",
        "EventCode": "0x9A",
        "EventName": "UNC_M3UPI_TxR_VERT_STARVED.AD_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; AD - Agent 1",
        "EventCode": "0x9A",
        "EventName": "UNC_M3UPI_TxR_VERT_STARVED.AD_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; AK - Agent 0",
        "EventCode": "0x9A",
        "EventName": "UNC_M3UPI_TxR_VERT_STARVED.AK_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; AK - Agent 1",
        "EventCode": "0x9A",
        "EventName": "UNC_M3UPI_TxR_VERT_STARVED.AK_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; BL - Agent 0",
        "EventCode": "0x9A",
        "EventName": "UNC_M3UPI_TxR_VERT_STARVED.BL_AG0",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; BL - Agent 1",
        "EventCode": "0x9A",
        "EventName": "UNC_M3UPI_TxR_VERT_STARVED.BL_AG1",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "CMS Vertical Egress Injection Starvation; IV",
        "EventCode": "0x9A",
        "EventName": "UNC_M3UPI_TxR_VERT_STARVED.IV",
        "PerPkg": "1",
        "PublicDescription": "Counts injection starvation.  This starvation is triggered when the CMS Egress cannot send a transaction onto the Vertical ring for a long period of time.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 AD Credits Empty; VN0 REQ Messages",
        "EventCode": "0x20",
        "EventName": "UNC_M3UPI_UPI_PEER_AD_CREDITS_EMPTY.VN0_REQ",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPIs on the AD Ring",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 AD Credits Empty; VN0 RSP Messages",
        "EventCode": "0x20",
        "EventName": "UNC_M3UPI_UPI_PEER_AD_CREDITS_EMPTY.VN0_RSP",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPIs on the AD Ring",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 AD Credits Empty; VN0 SNP Messages",
        "EventCode": "0x20",
        "EventName": "UNC_M3UPI_UPI_PEER_AD_CREDITS_EMPTY.VN0_SNP",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPIs on the AD Ring",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 AD Credits Empty; VN1 REQ Messages",
        "EventCode": "0x20",
        "EventName": "UNC_M3UPI_UPI_PEER_AD_CREDITS_EMPTY.VN1_REQ",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPIs on the AD Ring",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 AD Credits Empty; VN1 RSP Messages",
        "EventCode": "0x20",
        "EventName": "UNC_M3UPI_UPI_PEER_AD_CREDITS_EMPTY.VN1_RSP",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPIs on the AD Ring",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 AD Credits Empty; VN1 SNP Messages",
        "EventCode": "0x20",
        "EventName": "UNC_M3UPI_UPI_PEER_AD_CREDITS_EMPTY.VN1_SNP",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPIs on the AD Ring",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 AD Credits Empty; VNA",
        "EventCode": "0x20",
        "EventName": "UNC_M3UPI_UPI_PEER_AD_CREDITS_EMPTY.VNA",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPIs on the AD Ring",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 BL Credits Empty; VN0 RSP Messages",
        "EventCode": "0x21",
        "EventName": "UNC_M3UPI_UPI_PEER_BL_CREDITS_EMPTY.VN0_NCS_NCB",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPI on the BL Ring (diff between non-SMI and SMI mode)",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 BL Credits Empty; VN0 REQ Messages",
        "EventCode": "0x21",
        "EventName": "UNC_M3UPI_UPI_PEER_BL_CREDITS_EMPTY.VN0_RSP",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPI on the BL Ring (diff between non-SMI and SMI mode)",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 BL Credits Empty; VN0 SNP Messages",
        "EventCode": "0x21",
        "EventName": "UNC_M3UPI_UPI_PEER_BL_CREDITS_EMPTY.VN0_WB",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPI on the BL Ring (diff between non-SMI and SMI mode)",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 BL Credits Empty; VN1 RSP Messages",
        "EventCode": "0x21",
        "EventName": "UNC_M3UPI_UPI_PEER_BL_CREDITS_EMPTY.VN1_NCS_NCB",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPI on the BL Ring (diff between non-SMI and SMI mode)",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 BL Credits Empty; VN1 REQ Messages",
        "EventCode": "0x21",
        "EventName": "UNC_M3UPI_UPI_PEER_BL_CREDITS_EMPTY.VN1_RSP",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPI on the BL Ring (diff between non-SMI and SMI mode)",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 BL Credits Empty; VN1 SNP Messages",
        "EventCode": "0x21",
        "EventName": "UNC_M3UPI_UPI_PEER_BL_CREDITS_EMPTY.VN1_WB",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPI on the BL Ring (diff between non-SMI and SMI mode)",
        "UMask": "0x40",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "UPI0 BL Credits Empty; VNA",
        "EventCode": "0x21",
        "EventName": "UNC_M3UPI_UPI_PEER_BL_CREDITS_EMPTY.VNA",
        "PerPkg": "1",
        "PublicDescription": "No credits available to send to UPI on the BL Ring (diff between non-SMI and SMI mode)",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Prefetches generated by the flow control queue of the M3UPI unit.",
        "EventCode": "0x29",
        "EventName": "UNC_M3UPI_UPI_PREFETCH_SPAWN",
        "PerPkg": "1",
        "PublicDescription": "Count cases where flow control queue that sits between the Intel(R) Ultra Path Interconnect (UPI) and the mesh spawns a prefetch to the iMC (Memory Controller)",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical AD Ring In Use; Down and Even",
        "EventCode": "0xA6",
        "EventName": "UNC_M3UPI_VERT_RING_AD_IN_USE.DN_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.  We really have two rings  -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical AD Ring In Use; Down and Odd",
        "EventCode": "0xA6",
        "EventName": "UNC_M3UPI_VERT_RING_AD_IN_USE.DN_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.  We really have two rings  -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical AD Ring In Use; Up and Even",
        "EventCode": "0xA6",
        "EventName": "UNC_M3UPI_VERT_RING_AD_IN_USE.UP_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.  We really have two rings  -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical AD Ring In Use; Up and Odd",
        "EventCode": "0xA6",
        "EventName": "UNC_M3UPI_VERT_RING_AD_IN_USE.UP_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.  We really have two rings  -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical AK Ring In Use; Down and Even",
        "EventCode": "0xA8",
        "EventName": "UNC_M3UPI_VERT_RING_AK_IN_USE.DN_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings in -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical AK Ring In Use; Down and Odd",
        "EventCode": "0xA8",
        "EventName": "UNC_M3UPI_VERT_RING_AK_IN_USE.DN_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings in -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical AK Ring In Use; Up and Even",
        "EventCode": "0xA8",
        "EventName": "UNC_M3UPI_VERT_RING_AK_IN_USE.UP_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings in -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical AK Ring In Use; Up and Odd",
        "EventCode": "0xA8",
        "EventName": "UNC_M3UPI_VERT_RING_AK_IN_USE.UP_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings in -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical BL Ring in Use; Down and Even",
        "EventCode": "0xAA",
        "EventName": "UNC_M3UPI_VERT_RING_BL_IN_USE.DN_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical BL Ring in Use; Down and Odd",
        "EventCode": "0xAA",
        "EventName": "UNC_M3UPI_VERT_RING_BL_IN_USE.DN_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical BL Ring in Use; Up and Even",
        "EventCode": "0xAA",
        "EventName": "UNC_M3UPI_VERT_RING_BL_IN_USE.UP_EVEN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical BL Ring in Use; Up and Odd",
        "EventCode": "0xAA",
        "EventName": "UNC_M3UPI_VERT_RING_BL_IN_USE.UP_ODD",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical 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.We really have two rings -- a clockwise ring and a counter-clockwise ring.  On the left side of the ring, the UP direction is on the clockwise ring and DN is on the counter-clockwise ring.  On the right side of the ring, this is reversed.  The first half of the CBos are on the left side of the ring, and the 2nd half are on the right side of the ring.  In other words (for example), in a 4c part, Cbo 0 UP AD is NOT the same ring as CBo 2 UP AD because they are on opposite sides of the ring.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical IV Ring in Use; Down",
        "EventCode": "0xAC",
        "EventName": "UNC_M3UPI_VERT_RING_IV_IN_USE.DN",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical IV 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.  There is only 1 IV ring.  Therefore, if one wants to monitor the Even ring, they should select both UP_EVEN and DN_EVEN.  To monitor the Odd ring, they should select both UP_ODD and DN_ODD.",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "Vertical IV Ring in Use; Up",
        "EventCode": "0xAC",
        "EventName": "UNC_M3UPI_VERT_RING_IV_IN_USE.UP",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of cycles that the Vertical IV 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.  There is only 1 IV ring.  Therefore, if one wants to monitor the Even ring, they should select both UP_EVEN and DN_EVEN.  To monitor the Odd ring, they should select both UP_ODD and DN_ODD.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Credit Used; WB on BL",
        "EventCode": "0x5C",
        "EventName": "UNC_M3UPI_VN0_CREDITS_USED.NCB",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN0 credit was used on the DRS message channel.  In order for a request to be transferred across UPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN0.  VNA is a shared pool used to achieve high performance.  The VN0 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN0 if they fail.  This counts the number of times a VN0 credit was used.  Note that a single VN0 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN0 will only count a single credit even though it may use multiple buffers.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Credit Used; NCB on BL",
        "EventCode": "0x5C",
        "EventName": "UNC_M3UPI_VN0_CREDITS_USED.NCS",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN0 credit was used on the DRS message channel.  In order for a request to be transferred across UPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN0.  VNA is a shared pool used to achieve high performance.  The VN0 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN0 if they fail.  This counts the number of times a VN0 credit was used.  Note that a single VN0 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN0 will only count a single credit even though it may use multiple buffers.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Credit Used; REQ on AD",
        "EventCode": "0x5C",
        "EventName": "UNC_M3UPI_VN0_CREDITS_USED.REQ",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN0 credit was used on the DRS message channel.  In order for a request to be transferred across UPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN0.  VNA is a shared pool used to achieve high performance.  The VN0 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN0 if they fail.  This counts the number of times a VN0 credit was used.  Note that a single VN0 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN0 will only count a single credit even though it may use multiple buffers.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Credit Used; RSP on AD",
        "EventCode": "0x5C",
        "EventName": "UNC_M3UPI_VN0_CREDITS_USED.RSP",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN0 credit was used on the DRS message channel.  In order for a request to be transferred across UPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN0.  VNA is a shared pool used to achieve high performance.  The VN0 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN0 if they fail.  This counts the number of times a VN0 credit was used.  Note that a single VN0 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN0 will only count a single credit even though it may use multiple buffers.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Credit Used; SNP on AD",
        "EventCode": "0x5C",
        "EventName": "UNC_M3UPI_VN0_CREDITS_USED.SNP",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN0 credit was used on the DRS message channel.  In order for a request to be transferred across UPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN0.  VNA is a shared pool used to achieve high performance.  The VN0 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN0 if they fail.  This counts the number of times a VN0 credit was used.  Note that a single VN0 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN0 will only count a single credit even though it may use multiple buffers.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 Credit Used; RSP on BL",
        "EventCode": "0x5C",
        "EventName": "UNC_M3UPI_VN0_CREDITS_USED.WB",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN0 credit was used on the DRS message channel.  In order for a request to be transferred across UPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN0.  VNA is a shared pool used to achieve high performance.  The VN0 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN0 if they fail.  This counts the number of times a VN0 credit was used.  Note that a single VN0 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN0 will only count a single credit even though it may use multiple buffers.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 No Credits; WB on BL",
        "EventCode": "0x5E",
        "EventName": "UNC_M3UPI_VN0_NO_CREDITS.NCB",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN0 Credits; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 No Credits; NCB on BL",
        "EventCode": "0x5E",
        "EventName": "UNC_M3UPI_VN0_NO_CREDITS.NCS",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN0 Credits; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 No Credits; REQ on AD",
        "EventCode": "0x5E",
        "EventName": "UNC_M3UPI_VN0_NO_CREDITS.REQ",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN0 Credits; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 No Credits; RSP on AD",
        "EventCode": "0x5E",
        "EventName": "UNC_M3UPI_VN0_NO_CREDITS.RSP",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN0 Credits; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 No Credits; SNP on AD",
        "EventCode": "0x5E",
        "EventName": "UNC_M3UPI_VN0_NO_CREDITS.SNP",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN0 Credits; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN0 No Credits; RSP on BL",
        "EventCode": "0x5E",
        "EventName": "UNC_M3UPI_VN0_NO_CREDITS.WB",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN0 Credits; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Credit Used; WB on BL",
        "EventCode": "0x5D",
        "EventName": "UNC_M3UPI_VN1_CREDITS_USED.NCB",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN1 credit was used on the WB message channel.  In order for a request to be transferred across QPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN1.  VNA is a shared pool used to achieve high performance.  The VN1 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN1 if they fail.  This counts the number of times a VN1 credit was used.  Note that a single VN1 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN1 will only count a single credit even though it may use multiple buffers.; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Credit Used; NCB on BL",
        "EventCode": "0x5D",
        "EventName": "UNC_M3UPI_VN1_CREDITS_USED.NCS",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN1 credit was used on the WB message channel.  In order for a request to be transferred across QPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN1.  VNA is a shared pool used to achieve high performance.  The VN1 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN1 if they fail.  This counts the number of times a VN1 credit was used.  Note that a single VN1 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN1 will only count a single credit even though it may use multiple buffers.; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Credit Used; REQ on AD",
        "EventCode": "0x5D",
        "EventName": "UNC_M3UPI_VN1_CREDITS_USED.REQ",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN1 credit was used on the WB message channel.  In order for a request to be transferred across QPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN1.  VNA is a shared pool used to achieve high performance.  The VN1 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN1 if they fail.  This counts the number of times a VN1 credit was used.  Note that a single VN1 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN1 will only count a single credit even though it may use multiple buffers.; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Credit Used; RSP on AD",
        "EventCode": "0x5D",
        "EventName": "UNC_M3UPI_VN1_CREDITS_USED.RSP",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN1 credit was used on the WB message channel.  In order for a request to be transferred across QPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN1.  VNA is a shared pool used to achieve high performance.  The VN1 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN1 if they fail.  This counts the number of times a VN1 credit was used.  Note that a single VN1 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN1 will only count a single credit even though it may use multiple buffers.; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Credit Used; SNP on AD",
        "EventCode": "0x5D",
        "EventName": "UNC_M3UPI_VN1_CREDITS_USED.SNP",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN1 credit was used on the WB message channel.  In order for a request to be transferred across QPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN1.  VNA is a shared pool used to achieve high performance.  The VN1 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN1 if they fail.  This counts the number of times a VN1 credit was used.  Note that a single VN1 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN1 will only count a single credit even though it may use multiple buffers.; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 Credit Used; RSP on BL",
        "EventCode": "0x5D",
        "EventName": "UNC_M3UPI_VN1_CREDITS_USED.WB",
        "PerPkg": "1",
        "PublicDescription": "Number of times a VN1 credit was used on the WB message channel.  In order for a request to be transferred across QPI, it must be guaranteed to have a flit buffer on the remote socket to sink into.  There are two credit pools, VNA and VN1.  VNA is a shared pool used to achieve high performance.  The VN1 pool has reserved entries for each message class and is used to prevent deadlock.  Requests first attempt to acquire a VNA credit, and then fall back to VN1 if they fail.  This counts the number of times a VN1 credit was used.  Note that a single VN1 credit holds access to potentially multiple flit buffers.  For example, a transfer that uses VNA could use 9 flit buffers and in that case uses 9 credits.  A transfer on VN1 will only count a single credit even though it may use multiple buffers.; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 No Credits; WB on BL",
        "EventCode": "0x5F",
        "EventName": "UNC_M3UPI_VN1_NO_CREDITS.NCB",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN1 Credits; Data Response (WB) messages on BL.  WB is generally used to transmit data with coherency.  For example, remote reads and writes, or cache to cache transfers will transmit their data using WB.",
        "UMask": "0x10",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 No Credits; NCB on BL",
        "EventCode": "0x5F",
        "EventName": "UNC_M3UPI_VN1_NO_CREDITS.NCS",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN1 Credits; Non-Coherent Broadcast (NCB) messages on BL.  NCB is generally used to transmit data without coherency.  For example, non-coherent read data returns.",
        "UMask": "0x20",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 No Credits; REQ on AD",
        "EventCode": "0x5F",
        "EventName": "UNC_M3UPI_VN1_NO_CREDITS.REQ",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN1 Credits; Home (REQ) messages on AD.  REQ is generally used to send requests, request responses, and snoop responses.",
        "UMask": "0x1",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 No Credits; RSP on AD",
        "EventCode": "0x5F",
        "EventName": "UNC_M3UPI_VN1_NO_CREDITS.RSP",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN1 Credits; Response (RSP) messages on AD.  RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x4",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 No Credits; SNP on AD",
        "EventCode": "0x5F",
        "EventName": "UNC_M3UPI_VN1_NO_CREDITS.SNP",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN1 Credits; Snoops (SNP) messages on AD.  SNP is used for outgoing snoops.",
        "UMask": "0x2",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "VN1 No Credits; RSP on BL",
        "EventCode": "0x5F",
        "EventName": "UNC_M3UPI_VN1_NO_CREDITS.WB",
        "PerPkg": "1",
        "PublicDescription": "Number of Cycles there were no VN1 Credits; Response (RSP) messages on BL. RSP packets are used to transmit a variety of protocol flits including grants and completions (CMP).",
        "UMask": "0x8",
        "Unit": "M3UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_M2M_TxC_BL.DRS_UPI",
        "Deprecated": "1",
        "EventCode": "0x40",
        "EventName": "UNC_NoUnit_TxC_BL.DRS_UPI",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "M2M"
    },
    {
        "BriefDescription": "Clocks of the Intel(R) Ultra Path Interconnect (UPI)",
        "EventCode": "0x1",
        "EventName": "UNC_UPI_CLOCKTICKS",
        "PerPkg": "1",
        "PublicDescription": "Counts clockticks of the fixed frequency clock controlling the Intel(R) Ultra Path Interconnect (UPI).  This clock runs at1/8th the 'GT/s' speed of the UPI link.  For example, a  9.6GT/s  link will have a fixed Frequency of 1.2 Ghz.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Data Response packets that go direct to core",
        "EventCode": "0x12",
        "EventName": "UNC_UPI_DIRECT_ATTEMPTS.D2C",
        "PerPkg": "1",
        "PublicDescription": "Counts Data Response (DRS) packets that attempted to go direct to core bypassing the CHA.",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_DIRECT_ATTEMPTS.D2U",
        "Deprecated": "1",
        "EventCode": "0x12",
        "EventName": "UNC_UPI_DIRECT_ATTEMPTS.D2K",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Data Response packets that go direct to Intel(R) UPI",
        "EventCode": "0x12",
        "EventName": "UNC_UPI_DIRECT_ATTEMPTS.D2U",
        "PerPkg": "1",
        "PublicDescription": "Counts Data Response (DRS) packets that attempted to go direct to Intel(R) Ultra Path Interconnect (UPI) bypassing the CHA .",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_FLOWQ_NO_VNA_CRD.AD_VNA_EQ0",
        "EventCode": "0x18",
        "EventName": "UNC_UPI_FLOWQ_NO_VNA_CRD.AD_VNA_EQ0",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_FLOWQ_NO_VNA_CRD.AD_VNA_EQ1",
        "EventCode": "0x18",
        "EventName": "UNC_UPI_FLOWQ_NO_VNA_CRD.AD_VNA_EQ1",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_FLOWQ_NO_VNA_CRD.AD_VNA_EQ2",
        "EventCode": "0x18",
        "EventName": "UNC_UPI_FLOWQ_NO_VNA_CRD.AD_VNA_EQ2",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_FLOWQ_NO_VNA_CRD.AK_VNA_EQ0",
        "EventCode": "0x18",
        "EventName": "UNC_UPI_FLOWQ_NO_VNA_CRD.AK_VNA_EQ0",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_FLOWQ_NO_VNA_CRD.AK_VNA_EQ1",
        "EventCode": "0x18",
        "EventName": "UNC_UPI_FLOWQ_NO_VNA_CRD.AK_VNA_EQ1",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_FLOWQ_NO_VNA_CRD.AK_VNA_EQ2",
        "EventCode": "0x18",
        "EventName": "UNC_UPI_FLOWQ_NO_VNA_CRD.AK_VNA_EQ2",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_FLOWQ_NO_VNA_CRD.AK_VNA_EQ3",
        "EventCode": "0x18",
        "EventName": "UNC_UPI_FLOWQ_NO_VNA_CRD.AK_VNA_EQ3",
        "PerPkg": "1",
        "UMask": "0x80",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_FLOWQ_NO_VNA_CRD.BL_VNA_EQ0",
        "EventCode": "0x18",
        "EventName": "UNC_UPI_FLOWQ_NO_VNA_CRD.BL_VNA_EQ0",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Cycles Intel(R) UPI is in L1 power mode (shutdown)",
        "EventCode": "0x21",
        "EventName": "UNC_UPI_L1_POWER_CYCLES",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles when the Intel(R) Ultra Path Interconnect (UPI) is in L1 power mode.  L1 is a mode that totally shuts down the UPI link.  Link power states are per link and per direction, so for example the Tx direction could be in one state while Rx was in another, this event only coutns when both links are shutdown.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_BYP_BLOCKED.BGF_CRD",
        "EventCode": "0x14",
        "EventName": "UNC_UPI_M3_BYP_BLOCKED.BGF_CRD",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_BYP_BLOCKED.FLOWQ_AD_VNA_LE2",
        "EventCode": "0x14",
        "EventName": "UNC_UPI_M3_BYP_BLOCKED.FLOWQ_AD_VNA_LE2",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_BYP_BLOCKED.FLOWQ_AK_VNA_LE3",
        "EventCode": "0x14",
        "EventName": "UNC_UPI_M3_BYP_BLOCKED.FLOWQ_AK_VNA_LE3",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_BYP_BLOCKED.FLOWQ_BL_VNA_EQ0",
        "EventCode": "0x14",
        "EventName": "UNC_UPI_M3_BYP_BLOCKED.FLOWQ_BL_VNA_EQ0",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_BYP_BLOCKED.GV_BLOCK",
        "EventCode": "0x14",
        "EventName": "UNC_UPI_M3_BYP_BLOCKED.GV_BLOCK",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_CRD_RETURN_BLOCKED",
        "EventCode": "0x16",
        "EventName": "UNC_UPI_M3_CRD_RETURN_BLOCKED",
        "PerPkg": "1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_RXQ_BLOCKED.BGF_CRD",
        "EventCode": "0x15",
        "EventName": "UNC_UPI_M3_RXQ_BLOCKED.BGF_CRD",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_RXQ_BLOCKED.FLOWQ_AD_VNA_BTW_2_THRESH",
        "EventCode": "0x15",
        "EventName": "UNC_UPI_M3_RXQ_BLOCKED.FLOWQ_AD_VNA_BTW_2_THRESH",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_RXQ_BLOCKED.FLOWQ_AD_VNA_LE2",
        "EventCode": "0x15",
        "EventName": "UNC_UPI_M3_RXQ_BLOCKED.FLOWQ_AD_VNA_LE2",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_RXQ_BLOCKED.FLOWQ_AK_VNA_LE3",
        "EventCode": "0x15",
        "EventName": "UNC_UPI_M3_RXQ_BLOCKED.FLOWQ_AK_VNA_LE3",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_RXQ_BLOCKED.FLOWQ_BL_VNA_BTW_0_THRESH",
        "EventCode": "0x15",
        "EventName": "UNC_UPI_M3_RXQ_BLOCKED.FLOWQ_BL_VNA_BTW_0_THRESH",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_RXQ_BLOCKED.FLOWQ_BL_VNA_EQ0",
        "EventCode": "0x15",
        "EventName": "UNC_UPI_M3_RXQ_BLOCKED.FLOWQ_BL_VNA_EQ0",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_M3_RXQ_BLOCKED.GV_BLOCK",
        "EventCode": "0x15",
        "EventName": "UNC_UPI_M3_RXQ_BLOCKED.GV_BLOCK",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Cycles where phy is not in L0, L0c, L0p, L1",
        "EventCode": "0x20",
        "EventName": "UNC_UPI_PHY_INIT_CYCLES",
        "PerPkg": "1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "L1 Req Nack",
        "EventCode": "0x23",
        "EventName": "UNC_UPI_POWER_L1_NACK",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of times a link sends/receives a LinkReqNAck.  When the UPI links would like to change power state, the Tx side initiates a request to the Rx side requesting to change states.  This requests can either be accepted or denied.  If the Rx side replies with an Ack, the power mode will change.  If it replies with NAck, no change will take place.  This can be filtered based on Rx and Tx.  An Rx LinkReqNAck refers to receiving an NAck (meaning this agent's Tx originally requested the power change).  A Tx LinkReqNAck refers to sending this command (meaning the peer agent's Tx originally requested the power change and this agent accepted it).",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "L1 Req (same as L1 Ack).",
        "EventCode": "0x22",
        "EventName": "UNC_UPI_POWER_L1_REQ",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of times a link sends/receives a LinkReqAck.  When the UPI links would like to change power state, the Tx side initiates a request to the Rx side requesting to change states.  This requests can either be accepted or denied.  If the Rx side replies with an Ack, the power mode will change.  If it replies with NAck, no change will take place.  This can be filtered based on Rx and Tx.  An Rx LinkReqAck refers to receiving an Ack (meaning this agent's Tx originally requested the power change).  A Tx LinkReqAck refers to sending this command (meaning the peer agent's Tx originally requested the power change and this agent accepted it).",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_REQ_SLOT2_FROM_M3.ACK",
        "EventCode": "0x46",
        "EventName": "UNC_UPI_REQ_SLOT2_FROM_M3.ACK",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_REQ_SLOT2_FROM_M3.VN0",
        "EventCode": "0x46",
        "EventName": "UNC_UPI_REQ_SLOT2_FROM_M3.VN0",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_REQ_SLOT2_FROM_M3.VN1",
        "EventCode": "0x46",
        "EventName": "UNC_UPI_REQ_SLOT2_FROM_M3.VN1",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_REQ_SLOT2_FROM_M3.VNA",
        "EventCode": "0x46",
        "EventName": "UNC_UPI_REQ_SLOT2_FROM_M3.VNA",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Cycles the Rx of the Intel(R) UPI is in L0p power mode",
        "EventCode": "0x25",
        "EventName": "UNC_UPI_RxL0P_POWER_CYCLES",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles when the receive side (Rx) of the Intel(R) Ultra Path Interconnect(UPI) is in L0p power mode. L0p is a mode where we disable 60% of the UPI lanes, decreasing our bandwidth in order to save power.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Cycles in L0. Receive side.",
        "EventCode": "0x24",
        "EventName": "UNC_UPI_RxL0_POWER_CYCLES",
        "PerPkg": "1",
        "PublicDescription": "Number of UPI qfclk cycles spent in L0 power mode in the Link Layer.  L0 is the default mode which provides the highest performance with the most power.  Use edge detect to count the number of instances that the link entered L0.  Link power states are per link and per direction, so for example the Tx direction could be in one state while Rx was in another.  The phy layer  sometimes leaves L0 for training, which will not be captured by this event.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Non-Coherent Bypass",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.NCB",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - NCB",
        "UMask": "0xe",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Non-Coherent Bypass",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.NCB_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - NCB",
        "UMask": "0x10e",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Non-Coherent Standard",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.NCS",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - NCS",
        "UMask": "0xf",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Non-Coherent Standard",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.NCS_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - NCS",
        "UMask": "0x10f",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Request",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.REQ",
        "PerPkg": "1",
        "PublicDescription": "REQ Message Class",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Request Opcode",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.REQ_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match REQ Opcodes - Specified in Umask[7:4]",
        "UMask": "0x108",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Response - Conflict",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.RSPCNFLT",
        "PerPkg": "1",
        "UMask": "0x1aa",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Response - Invalid",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.RSPI",
        "PerPkg": "1",
        "UMask": "0x12a",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Response - Data",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.RSP_DATA",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class -WB",
        "UMask": "0xc",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Response - Data",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.RSP_DATA_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class -WB",
        "UMask": "0x10c",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Response - No Data",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.RSP_NODATA",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - RSP",
        "UMask": "0xa",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Response - No Data",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.RSP_NODATA_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - RSP",
        "UMask": "0x10a",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Snoop",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.SNP",
        "PerPkg": "1",
        "PublicDescription": "SNP Message Class",
        "UMask": "0x9",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Snoop Opcode",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.SNP_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match SNP Opcodes - Specified in Umask[7:4]",
        "UMask": "0x109",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Writeback",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.WB",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class -WB",
        "UMask": "0xd",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Receive path of a UPI Port; Writeback",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_BASIC_HDR_MATCH.WB_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class -WB",
        "UMask": "0x10d",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "FLITs received which bypassed the Slot0 Receive Buffer",
        "EventCode": "0x31",
        "EventName": "UNC_UPI_RxL_BYPASSED.SLOT0",
        "PerPkg": "1",
        "PublicDescription": "Counts incoming FLITs (FLow control unITs) which bypassed the slot0 RxQ buffer (Receive Queue) and passed directly to the Egress.  This is a latency optimization, and should generally be the common case.  If this value is less than the number of FLITs transferred, it implies that there was queueing getting onto the ring, and thus the transactions saw higher latency.",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "FLITs received which bypassed the Slot0 Receive Buffer",
        "EventCode": "0x31",
        "EventName": "UNC_UPI_RxL_BYPASSED.SLOT1",
        "PerPkg": "1",
        "PublicDescription": "Counts incoming FLITs (FLow control unITs) which bypassed the slot1 RxQ buffer  (Receive Queue) and passed directly across the BGF and into the Egress.  This is a latency optimization, and should generally be the common case.  If this value is less than the number of FLITs transferred, it implies that there was queueing getting onto the ring, and thus the transactions saw higher latency.",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "FLITs received which bypassed the Slot0 Receive Buffer",
        "EventCode": "0x31",
        "EventName": "UNC_UPI_RxL_BYPASSED.SLOT2",
        "PerPkg": "1",
        "PublicDescription": "Counts incoming FLITs (FLow control unITs) which bypassed the slot2 RxQ buffer (Receive Queue)  and passed directly to the Egress.  This is a latency optimization, and should generally be the common case.  If this value is less than the number of FLITs transferred, it implies that there was queueing getting onto the ring, and thus the transactions saw higher latency.",
        "UMask": "0x4",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "CRC Errors Detected",
        "EventCode": "0xB",
        "EventName": "UNC_UPI_RxL_CRC_ERRORS",
        "PerPkg": "1",
        "PublicDescription": "Number of CRC errors detected in the UPI Agent.  Each UPI flit incorporates 8 bits of CRC for error detection.  This counts the number of flits where the CRC was able to detect an error.  After an error has been detected, the UPI agent will send a request to the transmitting socket to resend the flit (as well as any flits that came after it).",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "LLR Requests Sent",
        "EventCode": "0x8",
        "EventName": "UNC_UPI_RxL_CRC_LLR_REQ_TRANSMIT",
        "PerPkg": "1",
        "PublicDescription": "Number of LLR Requests were transmitted.  This should generally be <= the number of CRC errors detected.  If multiple errors are detected before the Rx side receives a LLC_REQ_ACK from the Tx side, there is no need to send more LLR_REQ_NACKs.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "VN0 Credit Consumed",
        "EventCode": "0x39",
        "EventName": "UNC_UPI_RxL_CREDITS_CONSUMED_VN0",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of times that an RxQ VN0 credit was consumed (i.e. message uses a VN0 credit for the Rx Buffer).  This includes packets that went through the RxQ and those that were bypasssed.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "VN1 Credit Consumed",
        "EventCode": "0x3A",
        "EventName": "UNC_UPI_RxL_CREDITS_CONSUMED_VN1",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of times that an RxQ VN1 credit was consumed (i.e. message uses a VN1 credit for the Rx Buffer).  This includes packets that went through the RxQ and those that were bypasssed.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "VNA Credit Consumed",
        "EventCode": "0x38",
        "EventName": "UNC_UPI_RxL_CREDITS_CONSUMED_VNA",
        "PerPkg": "1",
        "PublicDescription": "Counts the number of times that an RxQ VNA credit was consumed (i.e. message uses a VNA credit for the Rx Buffer).  This includes packets that went through the RxQ and those that were bypasssed.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid data FLITs received from any slot",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.ALL_DATA",
        "PerPkg": "1",
        "PublicDescription": "Counts valid data FLITs  (80 bit FLow control unITs: 64bits of data) received from any of the 3 Intel(R) Ultra Path Interconnect (UPI) Receive Queue slots on this UPI unit.",
        "UMask": "0xf",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Null FLITs received from any slot",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.ALL_NULL",
        "PerPkg": "1",
        "PublicDescription": "Counts null FLITs (80 bit FLow control unITs) received from any of the 3 Intel(R) Ultra Path Interconnect (UPI) Receive Queue slots on this UPI unit.",
        "UMask": "0x27",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Received; Data",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.DATA",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Count Data Flits (which consume all slots), but how much to count is based on Slot0-2 mask, so count can be 0-3 depending on which slots are enabled for counting..",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Received; Idle",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.IDLE",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).",
        "UMask": "0x47",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Received; LLCRD Not Empty",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.LLCRD",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Enables counting of LLCRD (with non-zero payload). This only applies to slot 2 since LLCRD is only allowed in slot 2",
        "UMask": "0x10",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Received; LLCTRL",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.LLCTRL",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Equivalent to an idle packet.  Enables counting of slot 0 LLCTRL messages.",
        "UMask": "0x40",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Protocol header and credit FLITs received from any slot",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.NON_DATA",
        "PerPkg": "1",
        "PublicDescription": "Counts protocol header and credit FLITs  (80 bit FLow control unITs) received from any of the 3 UPI slots on this UPI unit.",
        "UMask": "0x97",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_RxL_FLITS.ALL_NULL",
        "Deprecated": "1",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.NULL",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Received; Protocol Header",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.PROTHDR",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Enables count of protocol headers in slot 0,1,2 (depending on slot uMask bits)",
        "UMask": "0x80",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_RxL_FLITS.PROTHDR",
        "Deprecated": "1",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.PROT_HDR",
        "PerPkg": "1",
        "UMask": "0x80",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Received; Slot 0",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.SLOT0",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Count Slot 0 - Other mask bits determine types of headers to count.",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Received; Slot 1",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.SLOT1",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Count Slot 1 - Other mask bits determine types of headers to count.",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Received; Slot 2",
        "EventCode": "0x3",
        "EventName": "UNC_UPI_RxL_FLITS.SLOT2",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Count Slot 2 - Other mask bits determine types of headers to count.",
        "UMask": "0x4",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_RxL_BASIC_HDR_MATCH.NCB",
        "Deprecated": "1",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_HDR_MATCH.NCB",
        "PerPkg": "1",
        "UMask": "0xc",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_RxL_BASIC_HDR_MATCH.NCS",
        "Deprecated": "1",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_HDR_MATCH.NCS",
        "PerPkg": "1",
        "UMask": "0xd",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_RxL_BASIC_HDR_MATCH.REQ",
        "Deprecated": "1",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_HDR_MATCH.REQ",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_RxL_BASIC_HDR_MATCH.RSP_DATA",
        "Deprecated": "1",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_HDR_MATCH.RSP",
        "PerPkg": "1",
        "UMask": "0xa",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_RxL_BASIC_HDR_MATCH.SNP",
        "Deprecated": "1",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_HDR_MATCH.SNP",
        "PerPkg": "1",
        "UMask": "0x9",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_RxL_BASIC_HDR_MATCH.WB",
        "Deprecated": "1",
        "EventCode": "0x5",
        "EventName": "UNC_UPI_RxL_HDR_MATCH.WB",
        "PerPkg": "1",
        "UMask": "0xb",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "RxQ Flit Buffer Allocations; Slot 0",
        "EventCode": "0x30",
        "EventName": "UNC_UPI_RxL_INSERTS.SLOT0",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the UPI Rx Flit Buffer.  Generally, when data is transmitted across UPI, it will bypass the RxQ and pass directly to the ring interface.  If things back up getting transmitted onto the ring, however, it may need to allocate into this buffer, thus increasing the latency.  This event can be used in conjunction with the Flit Buffer Occupancy event in order to calculate the average flit buffer lifetime.",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "RxQ Flit Buffer Allocations; Slot 1",
        "EventCode": "0x30",
        "EventName": "UNC_UPI_RxL_INSERTS.SLOT1",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the UPI Rx Flit Buffer.  Generally, when data is transmitted across UPI, it will bypass the RxQ and pass directly to the ring interface.  If things back up getting transmitted onto the ring, however, it may need to allocate into this buffer, thus increasing the latency.  This event can be used in conjunction with the Flit Buffer Occupancy event in order to calculate the average flit buffer lifetime.",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "RxQ Flit Buffer Allocations; Slot 2",
        "EventCode": "0x30",
        "EventName": "UNC_UPI_RxL_INSERTS.SLOT2",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the UPI Rx Flit Buffer.  Generally, when data is transmitted across UPI, it will bypass the RxQ and pass directly to the ring interface.  If things back up getting transmitted onto the ring, however, it may need to allocate into this buffer, thus increasing the latency.  This event can be used in conjunction with the Flit Buffer Occupancy event in order to calculate the average flit buffer lifetime.",
        "UMask": "0x4",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "RxQ Occupancy - All Packets; Slot 0",
        "EventCode": "0x32",
        "EventName": "UNC_UPI_RxL_OCCUPANCY.SLOT0",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the number of elements in the UPI RxQ in each cycle.  Generally, when data is transmitted across UPI, it will bypass the RxQ and pass directly to the ring interface.  If things back up getting transmitted onto the ring, however, it may need to allocate into this buffer, thus increasing the latency.  This event can be used in conjunction with the Flit Buffer Not Empty event to calculate average occupancy, or with the Flit Buffer Allocations event to track average lifetime.",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "RxQ Occupancy - All Packets; Slot 1",
        "EventCode": "0x32",
        "EventName": "UNC_UPI_RxL_OCCUPANCY.SLOT1",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the number of elements in the UPI RxQ in each cycle.  Generally, when data is transmitted across UPI, it will bypass the RxQ and pass directly to the ring interface.  If things back up getting transmitted onto the ring, however, it may need to allocate into this buffer, thus increasing the latency.  This event can be used in conjunction with the Flit Buffer Not Empty event to calculate average occupancy, or with the Flit Buffer Allocations event to track average lifetime.",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "RxQ Occupancy - All Packets; Slot 2",
        "EventCode": "0x32",
        "EventName": "UNC_UPI_RxL_OCCUPANCY.SLOT2",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the number of elements in the UPI RxQ in each cycle.  Generally, when data is transmitted across UPI, it will bypass the RxQ and pass directly to the ring interface.  If things back up getting transmitted onto the ring, however, it may need to allocate into this buffer, thus increasing the latency.  This event can be used in conjunction with the Flit Buffer Not Empty event to calculate average occupancy, or with the Flit Buffer Allocations event to track average lifetime.",
        "UMask": "0x4",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_RxL_SLOT_BYPASS.S0_RXQ1",
        "EventCode": "0x33",
        "EventName": "UNC_UPI_RxL_SLOT_BYPASS.S0_RXQ1",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_RxL_SLOT_BYPASS.S0_RXQ2",
        "EventCode": "0x33",
        "EventName": "UNC_UPI_RxL_SLOT_BYPASS.S0_RXQ2",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_RxL_SLOT_BYPASS.S1_RXQ0",
        "EventCode": "0x33",
        "EventName": "UNC_UPI_RxL_SLOT_BYPASS.S1_RXQ0",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_RxL_SLOT_BYPASS.S1_RXQ2",
        "EventCode": "0x33",
        "EventName": "UNC_UPI_RxL_SLOT_BYPASS.S1_RXQ2",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_RxL_SLOT_BYPASS.S2_RXQ0",
        "EventCode": "0x33",
        "EventName": "UNC_UPI_RxL_SLOT_BYPASS.S2_RXQ0",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_RxL_SLOT_BYPASS.S2_RXQ1",
        "EventCode": "0x33",
        "EventName": "UNC_UPI_RxL_SLOT_BYPASS.S2_RXQ1",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_TxL0P_CLK_ACTIVE.CFG_CTL",
        "EventCode": "0x2A",
        "EventName": "UNC_UPI_TxL0P_CLK_ACTIVE.CFG_CTL",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_TxL0P_CLK_ACTIVE.DFX",
        "EventCode": "0x2A",
        "EventName": "UNC_UPI_TxL0P_CLK_ACTIVE.DFX",
        "PerPkg": "1",
        "UMask": "0x40",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_TxL0P_CLK_ACTIVE.RETRY",
        "EventCode": "0x2A",
        "EventName": "UNC_UPI_TxL0P_CLK_ACTIVE.RETRY",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_TxL0P_CLK_ACTIVE.RXQ",
        "EventCode": "0x2A",
        "EventName": "UNC_UPI_TxL0P_CLK_ACTIVE.RXQ",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_TxL0P_CLK_ACTIVE.RXQ_BYPASS",
        "EventCode": "0x2A",
        "EventName": "UNC_UPI_TxL0P_CLK_ACTIVE.RXQ_BYPASS",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_TxL0P_CLK_ACTIVE.RXQ_CRED",
        "EventCode": "0x2A",
        "EventName": "UNC_UPI_TxL0P_CLK_ACTIVE.RXQ_CRED",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_TxL0P_CLK_ACTIVE.SPARE",
        "EventCode": "0x2A",
        "EventName": "UNC_UPI_TxL0P_CLK_ACTIVE.SPARE",
        "PerPkg": "1",
        "UMask": "0x80",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_TxL0P_CLK_ACTIVE.TXQ",
        "EventCode": "0x2A",
        "EventName": "UNC_UPI_TxL0P_CLK_ACTIVE.TXQ",
        "PerPkg": "1",
        "UMask": "0x10",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Cycles in which the Tx of the Intel(R) Ultra Path Interconnect (UPI) is in L0p power mode",
        "EventCode": "0x27",
        "EventName": "UNC_UPI_TxL0P_POWER_CYCLES",
        "PerPkg": "1",
        "PublicDescription": "Counts cycles when the transmit side (Tx) of the Intel(R) Ultra Path Interconnect(UPI) is in L0p power mode. L0p is a mode where we disable 60% of the UPI lanes, decreasing our bandwidth in order to save power.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_TxL0P_POWER_CYCLES_LL_ENTER",
        "EventCode": "0x28",
        "EventName": "UNC_UPI_TxL0P_POWER_CYCLES_LL_ENTER",
        "PerPkg": "1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_TxL0P_POWER_CYCLES_M3_EXIT",
        "EventCode": "0x29",
        "EventName": "UNC_UPI_TxL0P_POWER_CYCLES_M3_EXIT",
        "PerPkg": "1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Cycles in L0. Transmit side.",
        "EventCode": "0x26",
        "EventName": "UNC_UPI_TxL0_POWER_CYCLES",
        "PerPkg": "1",
        "PublicDescription": "Number of UPI qfclk cycles spent in L0 power mode in the Link Layer.  L0 is the default mode which provides the highest performance with the most power.  Use edge detect to count the number of instances that the link entered L0.  Link power states are per link and per direction, so for example the Tx direction could be in one state while Rx was in another.  The phy layer  sometimes leaves L0 for training, which will not be captured by this event.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Non-Coherent Bypass",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.NCB",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - NCB",
        "UMask": "0xe",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Non-Coherent Bypass",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.NCB_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - NCB",
        "UMask": "0x10e",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Non-Coherent Standard",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.NCS",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - NCS",
        "UMask": "0xf",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Non-Coherent Standard",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.NCS_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - NCS",
        "UMask": "0x10f",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Request",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.REQ",
        "PerPkg": "1",
        "PublicDescription": "REQ Message Class",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Request Opcode",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.REQ_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match REQ Opcodes - Specified in Umask[7:4]",
        "UMask": "0x108",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Response - Conflict",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.RSPCNFLT",
        "PerPkg": "1",
        "UMask": "0x1aa",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Response - Invalid",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.RSPI",
        "PerPkg": "1",
        "UMask": "0x12a",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Response - Data",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.RSP_DATA",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class -WB",
        "UMask": "0xc",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Response - Data",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.RSP_DATA_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class -WB",
        "UMask": "0x10c",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Response - No Data",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.RSP_NODATA",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - RSP",
        "UMask": "0xa",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Response - No Data",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.RSP_NODATA_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class - RSP",
        "UMask": "0x10a",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Snoop",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.SNP",
        "PerPkg": "1",
        "PublicDescription": "SNP Message Class",
        "UMask": "0x9",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Snoop Opcode",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.SNP_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match SNP Opcodes - Specified in Umask[7:4]",
        "UMask": "0x109",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Writeback",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.WB",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class -WB",
        "UMask": "0xd",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Matches on Transmit path of a UPI Port; Writeback",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_BASIC_HDR_MATCH.WB_OPC",
        "PerPkg": "1",
        "PublicDescription": "Match Message Class -WB",
        "UMask": "0x10d",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "FLITs that bypassed the TxL Buffer",
        "EventCode": "0x41",
        "EventName": "UNC_UPI_TxL_BYPASSED",
        "PerPkg": "1",
        "PublicDescription": "Counts incoming FLITs (FLow control unITs) which bypassed the TxL(transmit) FLIT buffer and pass directly out the UPI Link. Generally, when data is transmitted across the Intel(R) Ultra Path Interconnect (UPI), it will bypass the TxQ and pass directly to the link.  However, the TxQ will be used in L0p (Low Power) mode and (Link Layer Retry) LLR  mode, increasing latency to transfer out to the link.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid data FLITs transmitted via any slot",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.ALL_DATA",
        "PerPkg": "1",
        "PublicDescription": "Counts valid data FLITs (80 bit FLow control unITs: 64bits of data) transmitted (TxL) via any of the 3 Intel(R) Ultra Path Interconnect (UPI) slots on this UPI unit.",
        "UMask": "0xf",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Null FLITs transmitted from any slot",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.ALL_NULL",
        "PerPkg": "1",
        "PublicDescription": "Counts null FLITs (80 bit FLow control unITs) transmitted via any of the 3 Intel(R) Ulra Path Interconnect (UPI) slots on this UPI unit.",
        "UMask": "0x27",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Sent; Data",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.DATA",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Count Data Flits (which consume all slots), but how much to count is based on Slot0-2 mask, so count can be 0-3 depending on which slots are enabled for counting..",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Idle FLITs transmitted",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.IDLE",
        "PerPkg": "1",
        "PublicDescription": "Counts when the Intel Ultra Path Interconnect(UPI) transmits an idle FLIT(80 bit FLow control unITs).  Every UPI cycle must be sending either data FLITs, protocol/credit FLITs or idle FLITs.",
        "UMask": "0x47",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Sent; LLCRD Not Empty",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.LLCRD",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Enables counting of LLCRD (with non-zero payload). This only applies to slot 2 since LLCRD is only allowed in slot 2",
        "UMask": "0x10",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Sent; LLCTRL",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.LLCTRL",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Equivalent to an idle packet.  Enables counting of slot 0 LLCTRL messages.",
        "UMask": "0x40",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Protocol header and credit FLITs transmitted across any slot",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.NON_DATA",
        "PerPkg": "1",
        "PublicDescription": "Counts protocol header and credit FLITs (80 bit FLow control unITs) transmitted across any of the 3 UPI (Ultra Path Interconnect) slots on this UPI unit.",
        "UMask": "0x97",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_TxL_FLITS.ALL_NULL",
        "Deprecated": "1",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.NULL",
        "PerPkg": "1",
        "UMask": "0x20",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Sent; Protocol Header",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.PROTHDR",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Enables count of protocol headers in slot 0,1,2 (depending on slot uMask bits)",
        "UMask": "0x80",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_TxL_FLITS.PROTHDR",
        "Deprecated": "1",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.PROT_HDR",
        "PerPkg": "1",
        "UMask": "0x80",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Sent; Slot 0",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.SLOT0",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Count Slot 0 - Other mask bits determine types of headers to count.",
        "UMask": "0x1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Sent; Slot 1",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.SLOT1",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Count Slot 1 - Other mask bits determine types of headers to count.",
        "UMask": "0x2",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Valid Flits Sent; Slot 2",
        "EventCode": "0x2",
        "EventName": "UNC_UPI_TxL_FLITS.SLOT2",
        "PerPkg": "1",
        "PublicDescription": "Shows legal flit time (hides impact of L0p and L0c).; Count Slot 2 - Other mask bits determine types of headers to count.",
        "UMask": "0x4",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated.",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.DATA_HDR",
        "PerPkg": "1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated.",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.DUAL_SLOT_HDR",
        "PerPkg": "1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated.",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.LOC",
        "PerPkg": "1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_TxL_BASIC_HDR_MATCH.NCB",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.NCB",
        "PerPkg": "1",
        "UMask": "0xe",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_TxL_BASIC_HDR_MATCH.NCS",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.NCS",
        "PerPkg": "1",
        "UMask": "0xf",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated.",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.NON_DATA_HDR",
        "PerPkg": "1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated.",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.REM",
        "PerPkg": "1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_TxL_BASIC_HDR_MATCH.REQ",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.REQ",
        "PerPkg": "1",
        "UMask": "0x8",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_TxL_BASIC_HDR_MATCH.RSP_DATA",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.RSP_DATA",
        "PerPkg": "1",
        "UMask": "0xc",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_TxL_BASIC_HDR_MATCH.RSP_NODATA",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.RSP_NODATA",
        "PerPkg": "1",
        "UMask": "0xa",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated.",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.SGL_SLOT_HDR",
        "PerPkg": "1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_TxL_BASIC_HDR_MATCH.SNP",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.SNP",
        "PerPkg": "1",
        "UMask": "0x9",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "This event is deprecated. Refer to new event UNC_UPI_TxL_BASIC_HDR_MATCH.WB",
        "Deprecated": "1",
        "EventCode": "0x4",
        "EventName": "UNC_UPI_TxL_HDR_MATCH.WB",
        "PerPkg": "1",
        "UMask": "0xc",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Tx Flit Buffer Allocations",
        "EventCode": "0x40",
        "EventName": "UNC_UPI_TxL_INSERTS",
        "PerPkg": "1",
        "PublicDescription": "Number of allocations into the UPI Tx Flit Buffer.  Generally, when data is transmitted across UPI, it will bypass the TxQ and pass directly to the link.  However, the TxQ will be used with L0p and when LLR occurs, increasing latency to transfer out to the link.  This event can be used in conjunction with the Flit Buffer Occupancy event in order to calculate the average flit buffer lifetime.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Tx Flit Buffer Occupancy",
        "EventCode": "0x42",
        "EventName": "UNC_UPI_TxL_OCCUPANCY",
        "PerPkg": "1",
        "PublicDescription": "Accumulates the number of flits in the TxQ.  Generally, when data is transmitted across UPI, it will bypass the TxQ and pass directly to the link.  However, the TxQ will be used with L0p and when LLR occurs, increasing latency to transfer out to the link. This can be used with the cycles not empty event to track average occupancy, or the allocations event to track average lifetime in the TxQ.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "UNC_UPI_VNA_CREDIT_RETURN_BLOCKED_VN01",
        "EventCode": "0x45",
        "EventName": "UNC_UPI_VNA_CREDIT_RETURN_BLOCKED_VN01",
        "PerPkg": "1",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "VNA Credits Pending Return - Occupancy",
        "EventCode": "0x44",
        "EventName": "UNC_UPI_VNA_CREDIT_RETURN_OCCUPANCY",
        "PerPkg": "1",
        "PublicDescription": "Number of VNA credits in the Rx side that are waitng to be returned back across the link.",
        "Unit": "UPI"
    },
    {
        "BriefDescription": "Clockticks in the UBOX using a dedicated 48-bit Fixed Counter",
        "EventCode": "0xff",
        "EventName": "UNC_U_CLOCKTICKS",
        "PerPkg": "1",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "Message Received",
        "EventCode": "0x42",
        "EventName": "UNC_U_EVENT_MSG.DOORBELL_RCVD",
        "PerPkg": "1",
        "PublicDescription": "Virtual Logical Wire (legacy) message were received from Uncore.",
        "UMask": "0x8",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "Message Received",
        "EventCode": "0x42",
        "EventName": "UNC_U_EVENT_MSG.INT_PRIO",
        "PerPkg": "1",
        "PublicDescription": "Virtual Logical Wire (legacy) message were received from Uncore.",
        "UMask": "0x10",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "Message Received; IPI",
        "EventCode": "0x42",
        "EventName": "UNC_U_EVENT_MSG.IPI_RCVD",
        "PerPkg": "1",
        "PublicDescription": "Virtual Logical Wire (legacy) message were received from Uncore.; Inter Processor Interrupts",
        "UMask": "0x4",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "Message Received; MSI",
        "EventCode": "0x42",
        "EventName": "UNC_U_EVENT_MSG.MSI_RCVD",
        "PerPkg": "1",
        "PublicDescription": "Virtual Logical Wire (legacy) message were received from Uncore.; Message Signaled Interrupts - interrupts sent by devices (including PCIe via IOxAPIC) (Socket Mode only)",
        "UMask": "0x2",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "Message Received; VLW",
        "EventCode": "0x42",
        "EventName": "UNC_U_EVENT_MSG.VLW_RCVD",
        "PerPkg": "1",
        "PublicDescription": "Virtual Logical Wire (legacy) message were received from Uncore.",
        "UMask": "0x1",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "IDI Lock/SplitLock Cycles",
        "EventCode": "0x44",
        "EventName": "UNC_U_LOCK_CYCLES",
        "PerPkg": "1",
        "PublicDescription": "Number of times an IDI Lock/SplitLock sequence was started",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "Cycles PHOLD Assert to Ack; Assert to ACK",
        "EventCode": "0x45",
        "EventName": "UNC_U_PHOLD_CYCLES.ASSERT_TO_ACK",
        "PerPkg": "1",
        "PublicDescription": "PHOLD cycles.",
        "UMask": "0x1",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "UNC_U_RACU_DRNG.PFTCH_BUF_EMPTY",
        "EventCode": "0x4C",
        "EventName": "UNC_U_RACU_DRNG.PFTCH_BUF_EMPTY",
        "PerPkg": "1",
        "UMask": "0x4",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "UNC_U_RACU_DRNG.RDRAND",
        "EventCode": "0x4C",
        "EventName": "UNC_U_RACU_DRNG.RDRAND",
        "PerPkg": "1",
        "UMask": "0x1",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "UNC_U_RACU_DRNG.RDSEED",
        "EventCode": "0x4C",
        "EventName": "UNC_U_RACU_DRNG.RDSEED",
        "PerPkg": "1",
        "UMask": "0x2",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "RACU Request",
        "EventCode": "0x46",
        "EventName": "UNC_U_RACU_REQUESTS",
        "PerPkg": "1",
        "PublicDescription": "Number outstanding register requests within message channel tracker",
        "Unit": "UBOX"
    },
    {
        "BriefDescription": "UPI interconnect send bandwidth for payload. Derived from unc_upi_txl_flits.all_data",
        "EventCode": "0x2",
        "EventName": "UPI_DATA_BANDWIDTH_TX",
        "PerPkg": "1",
        "PublicDescription": "Counts valid data FLITs (80 bit FLow control unITs: 64bits of data) transmitted (TxL) via any of the 3 Intel(R) Ultra Path Interconnect (UPI) slots on this UPI unit.",
        "ScaleUnit": "7.11E-06Bytes",
        "UMask": "0xf",
        "Unit": "UPI"
    }
]