930 lines
29 KiB
Diff
930 lines
29 KiB
Diff
|
From 9325ac1c6648be97da5b6e2504b70a3f31a66690 Mon Sep 17 00:00:00 2001
|
||
|
From: Shravan Kumar Ramani <shravankr@nvidia.com>
|
||
|
Date: Wed, 11 Jan 2023 04:49:23 -0500
|
||
|
Subject: [PATCH backport 5.10 4/6] UBUNTU: SAUCE: mlxbf-pmc: Support for
|
||
|
BlueField-3 performance counters
|
||
|
|
||
|
BugLink: https://bugs.launchpad.net/bugs/2002501
|
||
|
|
||
|
Add new mechanism for programming and reading the counters in
|
||
|
BlueField-3, along with the updated event list supported in each block.
|
||
|
Read llt_enable and mss_enable info from the ACPI table entry to
|
||
|
identify the enabled blocks.
|
||
|
|
||
|
Signed-off-by: Shravan Kumar Ramani <shravankr@nvidia.com>
|
||
|
Acked-by: Bartlomiej Zolnierkiewicz <bartlomiej.zolnierkiewicz@canonical.com>
|
||
|
Acked-by: Tim Gardner <tim.gardner@canonical.com>
|
||
|
Signed-off-by: Bartlomiej Zolnierkiewicz <bartlomiej.zolnierkiewicz@canonical.com>
|
||
|
---
|
||
|
drivers/platform/mellanox/mlxbf-pmc.c | 252 +++++++++++++--
|
||
|
drivers/platform/mellanox/mlxbf-pmc.h | 445 +++++++++++++++++++++++++-
|
||
|
2 files changed, 658 insertions(+), 39 deletions(-)
|
||
|
|
||
|
diff --git a/drivers/platform/mellanox/mlxbf-pmc.c b/drivers/platform/mellanox/mlxbf-pmc.c
|
||
|
index 106acea8c..285b7433e 100644
|
||
|
--- a/drivers/platform/mellanox/mlxbf-pmc.c
|
||
|
+++ b/drivers/platform/mellanox/mlxbf-pmc.c
|
||
|
@@ -243,17 +243,32 @@ struct mlxbf_pmc_events *mlxbf_pmc_event_list(char *blk)
|
||
|
break;
|
||
|
}
|
||
|
else if (strstr(blk, "mss"))
|
||
|
- events = mlxbf_mss_events;
|
||
|
+ switch (pmc->event_set) {
|
||
|
+ case MLNX_EVENT_SET_BF1:
|
||
|
+ case MLNX_EVENT_SET_BF2:
|
||
|
+ events = mlxbf_mss_events;
|
||
|
+ break;
|
||
|
+ case MLNX_EVENT_SET_BF3:
|
||
|
+ events = mlxbf3_mss_events;
|
||
|
+ break;
|
||
|
+ default:
|
||
|
+ events = NULL;
|
||
|
+ break;
|
||
|
+ }
|
||
|
else if (strstr(blk, "ecc"))
|
||
|
events = mlxbf_ecc_events;
|
||
|
else if (strstr(blk, "pcie"))
|
||
|
events = mlxbf_pcie_events;
|
||
|
else if (strstr(blk, "l3cache"))
|
||
|
events = mlxbf_l3cache_events;
|
||
|
- else if (strstr(blk, "gic"))
|
||
|
+ else if (strstr(blk, "gic"))
|
||
|
events = mlxbf_smgen_events;
|
||
|
- else if (strstr(blk, "smmu"))
|
||
|
+ else if (strstr(blk, "smmu"))
|
||
|
events = mlxbf_smgen_events;
|
||
|
+ else if (strstr(blk, "llt_miss"))
|
||
|
+ events = mlxbf3_llt_miss_events;
|
||
|
+ else if (strstr(blk, "llt"))
|
||
|
+ events = mlxbf3_llt_events;
|
||
|
else
|
||
|
events = NULL;
|
||
|
|
||
|
@@ -378,6 +393,46 @@ int mlxbf_program_l3_counter(int blk_num, uint32_t cnt_num, uint32_t evt)
|
||
|
return mlxbf_pmc_writel(*wordaddr, pmcaddr);
|
||
|
}
|
||
|
|
||
|
+/* Method to handle crspace counter programming */
|
||
|
+int mlxbf_program_crspace_counter(int blk_num, uint32_t cnt_num, uint32_t evt)
|
||
|
+{
|
||
|
+ int reg_num, ret;
|
||
|
+ uint32_t word;
|
||
|
+ void *addr;
|
||
|
+
|
||
|
+ reg_num = (cnt_num / 2);
|
||
|
+ addr = pmc->block[blk_num].mmio_base + (reg_num * 4);
|
||
|
+
|
||
|
+ ret = mlxbf_pmc_readl(&word, addr);
|
||
|
+ if (ret)
|
||
|
+ return ret;
|
||
|
+
|
||
|
+ switch(cnt_num % 2) {
|
||
|
+ case 0:
|
||
|
+ word &= ~MLXBF_CRSPACE_PERFSEL0;
|
||
|
+ word |= FIELD_PREP(MLXBF_CRSPACE_PERFSEL0, evt);
|
||
|
+ break;
|
||
|
+ case 1:
|
||
|
+ word &= ~MLXBF_CRSPACE_PERFSEL1;
|
||
|
+ word |= FIELD_PREP(MLXBF_CRSPACE_PERFSEL1, evt);
|
||
|
+ break;
|
||
|
+ default:
|
||
|
+ return -EINVAL;
|
||
|
+ }
|
||
|
+
|
||
|
+ return mlxbf_pmc_writel(word, addr);
|
||
|
+}
|
||
|
+
|
||
|
+int mlxbf_clear_crspace_counter(int blk_num, uint32_t cnt_num)
|
||
|
+{
|
||
|
+ void *addr;
|
||
|
+
|
||
|
+ addr = pmc->block[blk_num].mmio_base + MLXBF_CRSPACE_PERFMON_VAL0 +
|
||
|
+ (cnt_num * 4);
|
||
|
+
|
||
|
+ return mlxbf_pmc_writel(0x0, addr);
|
||
|
+}
|
||
|
+
|
||
|
/* Method to program a counter to monitor an event */
|
||
|
int mlxbf_program_counter(int blk_num, uint32_t cnt_num, uint32_t evt,
|
||
|
bool is_l3)
|
||
|
@@ -390,6 +445,9 @@ int mlxbf_program_counter(int blk_num, uint32_t cnt_num, uint32_t evt,
|
||
|
if (is_l3)
|
||
|
return mlxbf_program_l3_counter(blk_num, cnt_num, evt);
|
||
|
|
||
|
+ if (pmc->block[blk_num].type == MLXBF_PERFTYPE_CRSPACE)
|
||
|
+ return mlxbf_program_crspace_counter(blk_num, cnt_num, evt);
|
||
|
+
|
||
|
/* Configure the counter */
|
||
|
perfctl = 0;
|
||
|
perfctl |= FIELD_PREP(MLXBF_GEN_PERFCTL__EN0, 1);
|
||
|
@@ -467,6 +525,22 @@ int mlxbf_read_l3_counter(int blk_num, uint32_t cnt_num, uint64_t *result)
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
+/* Method to handle crspace counter reads */
|
||
|
+int mlxbf_read_crspace_counter(int blk_num, uint32_t cnt_num, uint64_t *result)
|
||
|
+{
|
||
|
+ uint32_t value;
|
||
|
+ int status = 0;
|
||
|
+
|
||
|
+ status = mlxbf_pmc_readl(&value, pmc->block[blk_num].mmio_base +
|
||
|
+ MLXBF_CRSPACE_PERFMON_VAL0 + (cnt_num * 4));
|
||
|
+ if (status)
|
||
|
+ return status;
|
||
|
+
|
||
|
+ *result = value;
|
||
|
+
|
||
|
+ return 0;
|
||
|
+}
|
||
|
+
|
||
|
/* Method to read the counter value */
|
||
|
int mlxbf_read_counter(int blk_num, uint32_t cnt_num, bool is_l3,
|
||
|
uint64_t *result)
|
||
|
@@ -481,6 +555,9 @@ int mlxbf_read_counter(int blk_num, uint32_t cnt_num, bool is_l3,
|
||
|
if (is_l3)
|
||
|
return mlxbf_read_l3_counter(blk_num, cnt_num, result);
|
||
|
|
||
|
+ if (pmc->block[blk_num].type == MLXBF_PERFTYPE_CRSPACE)
|
||
|
+ return mlxbf_read_crspace_counter(blk_num, cnt_num, result);
|
||
|
+
|
||
|
perfcfg_offset = cnt_num * 8;
|
||
|
perfval_offset = perfcfg_offset + pmc->block[blk_num].counters * 8;
|
||
|
|
||
|
@@ -557,6 +634,34 @@ int mlxbf_read_l3_event(int blk_num, uint32_t cnt_num, uint64_t *result)
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
+int mlxbf_read_crspace_event(int blk_num, uint32_t cnt_num, uint64_t *result)
|
||
|
+{
|
||
|
+ uint32_t word, evt;
|
||
|
+ int reg_num, ret;
|
||
|
+ void *addr;
|
||
|
+
|
||
|
+ reg_num = (cnt_num / 2);
|
||
|
+ addr = pmc->block[blk_num].mmio_base + (reg_num * 4);
|
||
|
+
|
||
|
+ ret = mlxbf_pmc_readl(&word, addr);
|
||
|
+ if (ret)
|
||
|
+ return ret;
|
||
|
+
|
||
|
+ switch(cnt_num % 2) {
|
||
|
+ case 0:
|
||
|
+ evt = FIELD_GET(MLXBF_CRSPACE_PERFSEL0, word);
|
||
|
+ break;
|
||
|
+ case 1:
|
||
|
+ evt = FIELD_GET(MLXBF_CRSPACE_PERFSEL1, word);
|
||
|
+ break;
|
||
|
+ default:
|
||
|
+ return -EINVAL;
|
||
|
+ }
|
||
|
+ *result = evt;
|
||
|
+
|
||
|
+ return 0;
|
||
|
+}
|
||
|
+
|
||
|
/* Method to find the event currently being monitored by a counter */
|
||
|
int mlxbf_read_event(int blk_num, uint32_t cnt_num, bool is_l3,
|
||
|
uint64_t *result)
|
||
|
@@ -570,6 +675,10 @@ int mlxbf_read_event(int blk_num, uint32_t cnt_num, bool is_l3,
|
||
|
if (is_l3)
|
||
|
return mlxbf_read_l3_event(blk_num, cnt_num, result);
|
||
|
|
||
|
+ if (pmc->block[blk_num].type == MLXBF_PERFTYPE_CRSPACE)
|
||
|
+ return mlxbf_read_crspace_event(blk_num, cnt_num, result);
|
||
|
+
|
||
|
+
|
||
|
perfcfg_offset = cnt_num * 8;
|
||
|
perfval_offset = perfcfg_offset + pmc->block[blk_num].counters * 8;
|
||
|
|
||
|
@@ -645,7 +754,8 @@ static ssize_t mlxbf_counter_read(struct kobject *ko,
|
||
|
if (strstr(ko->name, "l3cache"))
|
||
|
is_l3 = true;
|
||
|
|
||
|
- if (pmc->block[blk_num].type == MLXBF_PERFTYPE_COUNTER) {
|
||
|
+ if ((pmc->block[blk_num].type == MLXBF_PERFTYPE_COUNTER) ||
|
||
|
+ (pmc->block[blk_num].type == MLXBF_PERFTYPE_CRSPACE)) {
|
||
|
err = sscanf(attr->attr.name, "counter%d", &cnt_num);
|
||
|
if (err < 0)
|
||
|
return -EINVAL;
|
||
|
@@ -706,6 +816,11 @@ static ssize_t mlxbf_counter_clear(struct kobject *ko,
|
||
|
err = mlxbf_write_reg(blk_num, offset, data);
|
||
|
if (err < 0)
|
||
|
return -EINVAL;
|
||
|
+ } else if (pmc->block[blk_num].type == MLXBF_PERFTYPE_CRSPACE) {
|
||
|
+ err = sscanf(attr->attr.name, "counter%d", &cnt_num);
|
||
|
+ if (err < 0)
|
||
|
+ return -EINVAL;
|
||
|
+ err = mlxbf_clear_crspace_counter(blk_num, cnt_num);
|
||
|
} else
|
||
|
return -EINVAL;
|
||
|
|
||
|
@@ -738,7 +853,8 @@ static ssize_t mlxbf_event_find(struct kobject *ko,
|
||
|
|
||
|
evt_name = mlxbf_pmc_get_event_name((char *)ko->name, evt_num);
|
||
|
|
||
|
- return snprintf(buf, PAGE_SIZE, "0x%llx: %s\n", evt_num, evt_name);
|
||
|
+ return snprintf(buf, PAGE_SIZE,
|
||
|
+ "0x%llx: %s\n", evt_num, evt_name);
|
||
|
}
|
||
|
|
||
|
/* Store function for "event" sysfs files */
|
||
|
@@ -806,32 +922,41 @@ static ssize_t mlxbf_print_event_list(struct kobject *ko,
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
-/* Show function for "enable" sysfs files - only for l3cache */
|
||
|
+/* Show function for "enable" sysfs files - only for l3cache and crspace */
|
||
|
static ssize_t mlxbf_show_counter_state(struct kobject *ko,
|
||
|
struct kobj_attribute *attr, char *buf)
|
||
|
{
|
||
|
- uint32_t perfcnt_cfg;
|
||
|
- int blk_num, value;
|
||
|
+ uint32_t perfcnt_cfg, word;
|
||
|
+ int blk_num, value, err;
|
||
|
|
||
|
blk_num = mlxbf_pmc_get_block_num(ko->name);
|
||
|
if (blk_num < 0)
|
||
|
return -EINVAL;
|
||
|
|
||
|
- if (mlxbf_pmc_readl(&perfcnt_cfg,
|
||
|
- pmc->block[blk_num].mmio_base + MLXBF_L3C_PERF_CNT_CFG))
|
||
|
- return -EINVAL;
|
||
|
+ if (pmc->block[blk_num].type == MLXBF_PERFTYPE_CRSPACE) {
|
||
|
+ err = mlxbf_pmc_readl(&word, pmc->block[blk_num].mmio_base +
|
||
|
+ MLXBF_CRSPACE_PERFMON_CTL);
|
||
|
+ if (err)
|
||
|
+ return -EINVAL;
|
||
|
+ value = FIELD_GET(MLXBF_CRSPACE_PERFMON_EN, word);
|
||
|
+ } else {
|
||
|
+ if (mlxbf_pmc_readl(&perfcnt_cfg, pmc->block[blk_num].mmio_base
|
||
|
+ + MLXBF_L3C_PERF_CNT_CFG))
|
||
|
+ return -EINVAL;
|
||
|
|
||
|
- value = FIELD_GET(MLXBF_L3C_PERF_CNT_CFG__EN, perfcnt_cfg);
|
||
|
+ value = FIELD_GET(MLXBF_L3C_PERF_CNT_CFG__EN, perfcnt_cfg);
|
||
|
+ }
|
||
|
|
||
|
return snprintf(buf, PAGE_SIZE, "%d\n", value);
|
||
|
}
|
||
|
|
||
|
-/* Store function for "enable" sysfs files - only for l3cache */
|
||
|
+/* Store function for "enable" sysfs files - only for l3cache and crspace */
|
||
|
static ssize_t mlxbf_enable_counters(struct kobject *ko,
|
||
|
struct kobj_attribute *attr,
|
||
|
const char *buf, size_t count)
|
||
|
{
|
||
|
int err, en, blk_num;
|
||
|
+ uint32_t word;
|
||
|
|
||
|
blk_num = mlxbf_pmc_get_block_num(ko->name);
|
||
|
if (blk_num < 0)
|
||
|
@@ -840,20 +965,32 @@ static ssize_t mlxbf_enable_counters(struct kobject *ko,
|
||
|
err = sscanf(buf, "%x\n", &en);
|
||
|
if (err < 0)
|
||
|
return err;
|
||
|
-
|
||
|
- if (en == 0) {
|
||
|
- err = mlxbf_config_l3_counters(blk_num, false, false);
|
||
|
- if (err)
|
||
|
- return err;
|
||
|
- } else if (en == 1) {
|
||
|
- err = mlxbf_config_l3_counters(blk_num, false, true);
|
||
|
- if (err)
|
||
|
- return err;
|
||
|
- err = mlxbf_config_l3_counters(blk_num, true, false);
|
||
|
+ if (pmc->block[blk_num].type == MLXBF_PERFTYPE_CRSPACE) {
|
||
|
+ err = mlxbf_pmc_readl(&word, pmc->block[blk_num].mmio_base +
|
||
|
+ MLXBF_CRSPACE_PERFMON_CTL);
|
||
|
if (err)
|
||
|
- return err;
|
||
|
- } else
|
||
|
- return -EINVAL;
|
||
|
+ return -EINVAL;
|
||
|
+ word &= ~MLXBF_CRSPACE_PERFMON_EN;
|
||
|
+ word |= FIELD_PREP(MLXBF_CRSPACE_PERFMON_EN, en);
|
||
|
+ if (en)
|
||
|
+ word |= FIELD_PREP(MLXBF_CRSPACE_PERFMON_CLR, 1);
|
||
|
+ mlxbf_pmc_writel(word, pmc->block[blk_num].mmio_base +
|
||
|
+ MLXBF_CRSPACE_PERFMON_CTL);
|
||
|
+ } else {
|
||
|
+ if (en == 0) {
|
||
|
+ err = mlxbf_config_l3_counters(blk_num, false, false);
|
||
|
+ if (err)
|
||
|
+ return err;
|
||
|
+ } else if (en == 1) {
|
||
|
+ err = mlxbf_config_l3_counters(blk_num, false, true);
|
||
|
+ if (err)
|
||
|
+ return err;
|
||
|
+ err = mlxbf_config_l3_counters(blk_num, true, false);
|
||
|
+ if (err)
|
||
|
+ return err;
|
||
|
+ } else
|
||
|
+ return -EINVAL;
|
||
|
+ }
|
||
|
|
||
|
return count;
|
||
|
}
|
||
|
@@ -871,7 +1008,8 @@ int mlxbf_pmc_create_sysfs(struct device *dev, struct kobject *ko, int blk_num)
|
||
|
return -EFAULT;
|
||
|
}
|
||
|
|
||
|
- if (pmc->block[blk_num].type == MLXBF_PERFTYPE_COUNTER) {
|
||
|
+ if ((pmc->block[blk_num].type == MLXBF_PERFTYPE_COUNTER) ||
|
||
|
+ (pmc->block[blk_num].type == MLXBF_PERFTYPE_CRSPACE)) {
|
||
|
pmc->block[blk_num].attr_event_list.attr.mode = 0444;
|
||
|
pmc->block[blk_num].attr_event_list.show =
|
||
|
mlxbf_print_event_list;
|
||
|
@@ -888,7 +1026,8 @@ int mlxbf_pmc_create_sysfs(struct device *dev, struct kobject *ko, int blk_num)
|
||
|
return err;
|
||
|
}
|
||
|
|
||
|
- if (strstr(pmc->block_name[blk_num], "l3cache")) {
|
||
|
+ if ((strstr(pmc->block_name[blk_num], "l3cache")) ||
|
||
|
+ (pmc->block[blk_num].type == MLXBF_PERFTYPE_CRSPACE)) {
|
||
|
pmc->block[blk_num].attr_enable.attr.mode =
|
||
|
0644;
|
||
|
pmc->block[blk_num].attr_enable.show =
|
||
|
@@ -1092,6 +1231,8 @@ static int mlxbf_pmc_probe(struct platform_device *pdev)
|
||
|
pmc->event_set = MLNX_EVENT_SET_BF1;
|
||
|
else if (strcmp(hid, "MLNXBFD1") == 0)
|
||
|
pmc->event_set = MLNX_EVENT_SET_BF2;
|
||
|
+ else if (strcmp(hid, "MLNXBFD2") == 0)
|
||
|
+ pmc->event_set = MLNX_EVENT_SET_BF3;
|
||
|
else {
|
||
|
dev_err(dev, "Invalid device ID %s\n", hid);
|
||
|
err = -ENODEV;
|
||
|
@@ -1115,13 +1256,23 @@ static int mlxbf_pmc_probe(struct platform_device *pdev)
|
||
|
}
|
||
|
|
||
|
if (device_property_read_u32(dev, "tile_num", &pmc->tile_count)) {
|
||
|
- dev_err(dev, "Number of tiles undefined\n");
|
||
|
- err = -EINVAL;
|
||
|
- goto error;
|
||
|
+ if (device_property_read_u8(dev, "llt_enable",
|
||
|
+ &pmc->llt_enable)) {
|
||
|
+ dev_err(dev, "Number of tiles/LLTs undefined\n");
|
||
|
+ err = -EINVAL;
|
||
|
+ goto error;
|
||
|
+ }
|
||
|
+ if (device_property_read_u8(dev, "mss_enable",
|
||
|
+ &pmc->mss_enable)) {
|
||
|
+ dev_err(dev, "Number of tiles/MSSs undefined\n");
|
||
|
+ err = -EINVAL;
|
||
|
+ goto error;
|
||
|
+ }
|
||
|
}
|
||
|
|
||
|
/* Map the Performance Counters from the varios blocks */
|
||
|
for (i = 0; i < pmc->total_blocks; ++i) {
|
||
|
+ /* Check if block number is within tile_count */
|
||
|
if (strstr(pmc->block_name[i], "tile")) {
|
||
|
int tile_num;
|
||
|
|
||
|
@@ -1133,6 +1284,44 @@ static int mlxbf_pmc_probe(struct platform_device *pdev)
|
||
|
if (tile_num >= pmc->tile_count)
|
||
|
continue;
|
||
|
}
|
||
|
+
|
||
|
+ /* Create sysfs directories only for enabled MSS blocks */
|
||
|
+ if (strstr(pmc->block_name[i], "mss") &&
|
||
|
+ pmc->event_set == MLNX_EVENT_SET_BF3) {
|
||
|
+ int mss_num;
|
||
|
+
|
||
|
+ ret = sscanf(pmc->block_name[i], "mss%d", &mss_num);
|
||
|
+ if (ret < 0) {
|
||
|
+ err = -EINVAL;
|
||
|
+ goto error;
|
||
|
+ }
|
||
|
+ if (!((pmc->mss_enable >> mss_num) & 0x1))
|
||
|
+ continue;
|
||
|
+ }
|
||
|
+
|
||
|
+ /* Create sysfs directories only for enabled LLTs */
|
||
|
+ if (strstr(pmc->block_name[i], "llt_miss")) {
|
||
|
+ int llt_num;
|
||
|
+
|
||
|
+ ret = sscanf(pmc->block_name[i], "llt_miss%d", &llt_num);
|
||
|
+ if (ret < 0) {
|
||
|
+ err = -EINVAL;
|
||
|
+ goto error;
|
||
|
+ }
|
||
|
+ if (!((pmc->llt_enable >> llt_num) & 0x1))
|
||
|
+ continue;
|
||
|
+ } else if (strstr(pmc->block_name[i], "llt")) {
|
||
|
+ int llt_num;
|
||
|
+
|
||
|
+ ret = sscanf(pmc->block_name[i], "llt%d", &llt_num);
|
||
|
+ if (ret < 0) {
|
||
|
+ err = -EINVAL;
|
||
|
+ goto error;
|
||
|
+ }
|
||
|
+ if (!((pmc->llt_enable >> llt_num) & 0x1))
|
||
|
+ continue;
|
||
|
+ }
|
||
|
+
|
||
|
err = device_property_read_u64_array(dev, pmc->block_name[i],
|
||
|
info, 4);
|
||
|
if (err) {
|
||
|
@@ -1215,6 +1404,7 @@ static int mlxbf_pmc_remove(struct platform_device *pdev)
|
||
|
static const struct acpi_device_id pmc_acpi_ids[] = {
|
||
|
{"MLNXBFD0", 0},
|
||
|
{"MLNXBFD1", 0},
|
||
|
+ {"MLNXBFD2", 0},
|
||
|
{},
|
||
|
};
|
||
|
|
||
|
diff --git a/drivers/platform/mellanox/mlxbf-pmc.h b/drivers/platform/mellanox/mlxbf-pmc.h
|
||
|
index a6f7aade4..fe2516616 100644
|
||
|
--- a/drivers/platform/mellanox/mlxbf-pmc.h
|
||
|
+++ b/drivers/platform/mellanox/mlxbf-pmc.h
|
||
|
@@ -16,6 +16,7 @@
|
||
|
|
||
|
#define MLNX_EVENT_SET_BF1 0
|
||
|
#define MLNX_EVENT_SET_BF2 1
|
||
|
+#define MLNX_EVENT_SET_BF3 2
|
||
|
|
||
|
#define MLNX_PMC_SVC_REQ_MAJOR 0
|
||
|
#define MLNX_PMC_SVC_MIN_MINOR 3
|
||
|
@@ -55,6 +56,8 @@ struct mlxbf_pmc_block_info {
|
||
|
* @pdev: The kernel structure representing the device
|
||
|
* @total_blocks: Total number of blocks
|
||
|
* @tile_count: Number of tiles in the system
|
||
|
+ * @llt_enable: Info on enabled LLTs
|
||
|
+ * @mss_enable: Info on enabled MSSs
|
||
|
* @hwmon_dev: Hwmon device for bfperf
|
||
|
* @ko: Kobject for bfperf
|
||
|
* @block_name: Block name
|
||
|
@@ -67,6 +70,8 @@ struct mlxbf_pmc_context {
|
||
|
struct platform_device *pdev;
|
||
|
uint32_t total_blocks;
|
||
|
uint32_t tile_count;
|
||
|
+ uint8_t llt_enable;
|
||
|
+ uint8_t mss_enable;
|
||
|
struct device *hwmon_dev;
|
||
|
struct kobject *ko;
|
||
|
const char *block_name[MLXBF_PMC_MAX_BLOCKS];
|
||
|
@@ -76,16 +81,17 @@ struct mlxbf_pmc_context {
|
||
|
unsigned int event_set;
|
||
|
};
|
||
|
|
||
|
-#define MLXBF_PERFTYPE_COUNTER 1
|
||
|
#define MLXBF_PERFTYPE_REGISTER 0
|
||
|
+#define MLXBF_PERFTYPE_COUNTER 1
|
||
|
+#define MLXBF_PERFTYPE_CRSPACE 2
|
||
|
|
||
|
-#define MLXBF_PERFCTL 0
|
||
|
-#define MLXBF_PERFEVT 1
|
||
|
-#define MLXBF_PERFVALEXT 2
|
||
|
-#define MLXBF_PERFACC0 4
|
||
|
-#define MLXBF_PERFACC1 5
|
||
|
-#define MLXBF_PERFMVAL0 6
|
||
|
-#define MLXBF_PERFMVAL1 7
|
||
|
+#define MLXBF_PERFCTL 0
|
||
|
+#define MLXBF_PERFEVT 1
|
||
|
+#define MLXBF_PERFVALEXT 2
|
||
|
+#define MLXBF_PERFACC0 4
|
||
|
+#define MLXBF_PERFACC1 5
|
||
|
+#define MLXBF_PERFMVAL0 6
|
||
|
+#define MLXBF_PERFMVAL1 7
|
||
|
|
||
|
#define MLXBF_GEN_PERFMON_CONFIG__WR_R_B BIT(0)
|
||
|
#define MLXBF_GEN_PERFMON_CONFIG__STROBE BIT(1)
|
||
|
@@ -143,6 +149,14 @@ struct mlxbf_pmc_context {
|
||
|
#define MLXBF_L3C_PERF_CNT_LOW__VAL GENMASK(31, 0)
|
||
|
#define MLXBF_L3C_PERF_CNT_HIGH__VAL GENMASK(24, 0)
|
||
|
|
||
|
+#define MLXBF_CRSPACE_PERFMON_REG0 0x0
|
||
|
+#define MLXBF_CRSPACE_PERFSEL0 GENMASK(23, 16)
|
||
|
+#define MLXBF_CRSPACE_PERFSEL1 GENMASK(7, 0)
|
||
|
+#define MLXBF_CRSPACE_PERFMON_CTL 0x40
|
||
|
+#define MLXBF_CRSPACE_PERFMON_EN BIT(30)
|
||
|
+#define MLXBF_CRSPACE_PERFMON_CLR BIT(28)
|
||
|
+#define MLXBF_CRSPACE_PERFMON_VAL0 0x4c
|
||
|
+
|
||
|
struct mlxbf_pmc_events {
|
||
|
uint32_t evt_num;
|
||
|
char *evt_name;
|
||
|
@@ -431,4 +445,419 @@ struct mlxbf_pmc_events mlxbf_l3cache_events[] = {
|
||
|
{-1, NULL}
|
||
|
};
|
||
|
|
||
|
+struct mlxbf_pmc_events mlxbf3_llt_events[] = {
|
||
|
+{0, "HNF0_CYCLES"},
|
||
|
+{1, "HNF0_REQS_RECEIVED"},
|
||
|
+{2, "HNF0_REQS_PROCESSED"},
|
||
|
+{3, "HNF0_DIR_HIT"},
|
||
|
+{4, "HNF0_DIR_MISS"},
|
||
|
+{5, "HNF0_DIR_RD_ALLOC"},
|
||
|
+{6, "HNF0_DIR_WR_ALLOC"},
|
||
|
+{7, "HNF0_DIR_VICTIM"},
|
||
|
+{8, "HNF0_CL_HAZARD"},
|
||
|
+{9, "HNF0_ALL_HAZARD"},
|
||
|
+{10, "HNF0_PIPE_STALLS"},
|
||
|
+{11, "HNF0_MEM_READS"},
|
||
|
+{12, "HNF0_MEM_WRITES"},
|
||
|
+{13, "HNF0_MEM_ACCESS"},
|
||
|
+{14, "HNF0_DCL_READ"},
|
||
|
+{15, "HNF0_DCL_INVAL"},
|
||
|
+{16, "HNF0_CHI_RXDAT"},
|
||
|
+{17, "HNF0_CHI_RXRSP"},
|
||
|
+{18, "HNF0_CHI_TXDAT"},
|
||
|
+{19, "HNF0_CHI_TXRSP"},
|
||
|
+{20, "HNF0_CHI_TXSNP"},
|
||
|
+{21, "HNF0_DCT_SNP"},
|
||
|
+{22, "HNF0_SNP_FWD_DATA"},
|
||
|
+{23, "HNF0_SNP_FWD_RSP"},
|
||
|
+{24, "HNF0_SNP_RSP"},
|
||
|
+{25, "HNF0_EXCL_FULL"},
|
||
|
+{26, "HNF0_EXCL_WRITE_F"},
|
||
|
+{27, "HNF0_EXCL_WRITE_S"},
|
||
|
+{28, "HNF0_EXCL_WRITE"},
|
||
|
+{29, "HNF0_EXCL_READ"},
|
||
|
+{30, "HNF0_REQ_BUF_EMPTY"},
|
||
|
+{31, "HNF0_ALL_MAFS_BUSY"},
|
||
|
+{32, "HNF0_TXDAT_NO_LCRD"},
|
||
|
+{33, "HNF0_TXSNP_NO_LCRD"},
|
||
|
+{34, "HNF0_TXRSP_NO_LCRD"},
|
||
|
+{35, "HNF0_TXREQ_NO_LCRD"},
|
||
|
+{36, "HNF0_WRITE"},
|
||
|
+{37, "HNF0_READ"},
|
||
|
+{38, "HNF0_ACCESS"},
|
||
|
+{39, "HNF0_MAF_N_BUSY"},
|
||
|
+{40, "HNF0_MAF_N_REQS"},
|
||
|
+{41, "HNF0_SEL_OPCODE"},
|
||
|
+{42, "HNF1_CYCLES"},
|
||
|
+{43, "HNF1_REQS_RECEIVED"},
|
||
|
+{44, "HNF1_REQS_PROCESSED"},
|
||
|
+{45, "HNF1_DIR_HIT"},
|
||
|
+{46, "HNF1_DIR_MISS"},
|
||
|
+{47, "HNF1_DIR_RD_ALLOC"},
|
||
|
+{48, "HNF1_DIR_WR_ALLOC"},
|
||
|
+{49, "HNF1_DIR_VICTIM"},
|
||
|
+{50, "HNF1_CL_HAZARD"},
|
||
|
+{51, "HNF1_ALL_HAZARD"},
|
||
|
+{52, "HNF1_PIPE_STALLS"},
|
||
|
+{53, "HNF1_MEM_READS"},
|
||
|
+{54, "HNF1_MEM_WRITES"},
|
||
|
+{55, "HNF1_MEM_ACCESS"},
|
||
|
+{56, "HNF1_DCL_READ"},
|
||
|
+{57, "HNF1_DCL_INVAL"},
|
||
|
+{58, "HNF1_CHI_RXDAT"},
|
||
|
+{59, "HNF1_CHI_RXRSP"},
|
||
|
+{60, "HNF1_CHI_TXDAT"},
|
||
|
+{61, "HNF1_CHI_TXRSP"},
|
||
|
+{62, "HNF1_CHI_TXSNP"},
|
||
|
+{63, "HNF1_DCT_SNP"},
|
||
|
+{64, "HNF1_SNP_FWD_DATA"},
|
||
|
+{65, "HNF1_SNP_FWD_RSP"},
|
||
|
+{66, "HNF1_SNP_RSP"},
|
||
|
+{67, "HNF1_EXCL_FULL"},
|
||
|
+{68, "HNF1_EXCL_WRITE_F"},
|
||
|
+{69, "HNF1_EXCL_WRITE_S"},
|
||
|
+{70, "HNF1_EXCL_WRITE"},
|
||
|
+{71, "HNF1_EXCL_READ"},
|
||
|
+{72, "HNF1_REQ_BUF_EMPTY"},
|
||
|
+{73, "HNF1_ALL_MAFS_BUSY"},
|
||
|
+{74, "HNF1_TXDAT_NO_LCRD"},
|
||
|
+{75, "HNF1_TXSNP_NO_LCRD"},
|
||
|
+{76, "HNF1_TXRSP_NO_LCRD"},
|
||
|
+{77, "HNF1_TXREQ_NO_LCRD"},
|
||
|
+{78, "HNF1_WRITE"},
|
||
|
+{79, "HNF1_READ"},
|
||
|
+{80, "HNF1_ACCESS"},
|
||
|
+{81, "HNF1_MAF_N_BUSY"},
|
||
|
+{82, "HNF1_MAF_N_REQS"},
|
||
|
+{83, "HNF1_SEL_OPCODE"},
|
||
|
+{84, "GDC_BANK0_RD_REQ"},
|
||
|
+{85, "GDC_BANK0_WR_REQ"},
|
||
|
+{86, "GDC_BANK0_ALLOCATE"},
|
||
|
+{87, "GDC_BANK0_HIT"},
|
||
|
+{88, "GDC_BANK0_MISS"},
|
||
|
+{89, "GDC_BANK0_INVALIDATE"},
|
||
|
+{90, "GDC_BANK0_EVICT"},
|
||
|
+{91, "GDC_BANK0_RD_RESP"},
|
||
|
+{92, "GDC_BANK0_WR_ACK"},
|
||
|
+{93, "GDC_BANK0_SNOOP"},
|
||
|
+{94, "GDC_BANK0_SNOOP_NORMAL"},
|
||
|
+{95, "GDC_BANK0_SNOOP_FWD"},
|
||
|
+{96, "GDC_BANK0_SNOOP_STASH"},
|
||
|
+{97, "GDC_BANK0_SNOOP_STASH_INDPND_RD"},
|
||
|
+{98, "GDC_BANK0_FOLLOWER"},
|
||
|
+{99, "GDC_BANK0_FW"},
|
||
|
+{100, "GDC_BANK0_HIT_DCL_BOTH"},
|
||
|
+{101, "GDC_BANK0_HIT_DCL_PARTIAL"},
|
||
|
+{102, "GDC_BANK0_EVICT_DCL"},
|
||
|
+{103, "GDC_BANK0_G_RSE_PIPE_CACHE_DATA0"},
|
||
|
+{103, "GDC_BANK0_G_RSE_PIPE_CACHE_DATA1"},
|
||
|
+{105, "GDC_BANK0_ARB_STRB"},
|
||
|
+{106, "GDC_BANK0_ARB_WAIT"},
|
||
|
+{107, "GDC_BANK0_GGA_STRB"},
|
||
|
+{108, "GDC_BANK0_GGA_WAIT"},
|
||
|
+{109, "GDC_BANK0_FW_STRB"},
|
||
|
+{110, "GDC_BANK0_FW_WAIT"},
|
||
|
+{111, "GDC_BANK0_SNP_STRB"},
|
||
|
+{112, "GDC_BANK0_SNP_WAIT"},
|
||
|
+{113, "GDC_BANK0_MISS_INARB_STRB"},
|
||
|
+{114, "GDC_BANK0_MISS_INARB_WAIT"},
|
||
|
+{115, "GDC_BANK0_G_FIFO_FF_GGA_RSP_RD0"},
|
||
|
+{116, "GDC_BANK0_G_FIFO_FF_GGA_RSP_RD1"},
|
||
|
+{117, "GDC_BANK0_G_FIFO_FF_GGA_RSP_RD2"},
|
||
|
+{118, "GDC_BANK0_G_FIFO_FF_GGA_RSP_RD3"},
|
||
|
+{119, "GDC_BANK0_G_FIFO_FF_GGA_RSP_WR0"},
|
||
|
+{120, "GDC_BANK0_G_FIFO_FF_GGA_RSP_WR1"},
|
||
|
+{121, "GDC_BANK0_G_FIFO_FF_GGA_RSP_WR2"},
|
||
|
+{122, "GDC_BANK0_G_FIFO_FF_GGA_RSP_WR3"},
|
||
|
+{123, "GDC_BANK1_RD_REQ"},
|
||
|
+{124, "GDC_BANK1_WR_REQ"},
|
||
|
+{125, "GDC_BANK1_ALLOCATE"},
|
||
|
+{126, "GDC_BANK1_HIT"},
|
||
|
+{127, "GDC_BANK1_MISS"},
|
||
|
+{128, "GDC_BANK1_INVALIDATE"},
|
||
|
+{129, "GDC_BANK1_EVICT"},
|
||
|
+{130, "GDC_BANK1_RD_RESP"},
|
||
|
+{131, "GDC_BANK1_WR_ACK"},
|
||
|
+{132, "GDC_BANK1_SNOOP"},
|
||
|
+{133, "GDC_BANK1_SNOOP_NORMAL"},
|
||
|
+{134, "GDC_BANK1_SNOOP_FWD"},
|
||
|
+{135, "GDC_BANK1_SNOOP_STASH"},
|
||
|
+{136, "GDC_BANK1_SNOOP_STASH_INDPND_RD"},
|
||
|
+{137, "GDC_BANK1_FOLLOWER"},
|
||
|
+{138, "GDC_BANK1_FW"},
|
||
|
+{139, "GDC_BANK1_HIT_DCL_BOTH"},
|
||
|
+{140, "GDC_BANK1_HIT_DCL_PARTIAL"},
|
||
|
+{141, "GDC_BANK1_EVICT_DCL"},
|
||
|
+{142, "GDC_BANK1_G_RSE_PIPE_CACHE_DATA0"},
|
||
|
+{143, "GDC_BANK1_G_RSE_PIPE_CACHE_DATA1"},
|
||
|
+{144, "GDC_BANK1_ARB_STRB"},
|
||
|
+{145, "GDC_BANK1_ARB_WAIT"},
|
||
|
+{146, "GDC_BANK1_GGA_STRB"},
|
||
|
+{147, "GDC_BANK1_GGA_WAIT"},
|
||
|
+{148, "GDC_BANK1_FW_STRB"},
|
||
|
+{149, "GDC_BANK1_FW_WAIT"},
|
||
|
+{150, "GDC_BANK1_SNP_STRB"},
|
||
|
+{151, "GDC_BANK1_SNP_WAIT"},
|
||
|
+{152, "GDC_BANK1_MISS_INARB_STRB"},
|
||
|
+{153, "GDC_BANK1_MISS_INARB_WAIT"},
|
||
|
+{154, "GDC_BANK1_G_FIFO_FF_GGA_RSP_RD0"},
|
||
|
+{155, "GDC_BANK1_G_FIFO_FF_GGA_RSP_RD1"},
|
||
|
+{156, "GDC_BANK1_G_FIFO_FF_GGA_RSP_RD2"},
|
||
|
+{157, "GDC_BANK1_G_FIFO_FF_GGA_RSP_RD3"},
|
||
|
+{158, "GDC_BANK1_G_FIFO_FF_GGA_RSP_WR0"},
|
||
|
+{159, "GDC_BANK1_G_FIFO_FF_GGA_RSP_WR1"},
|
||
|
+{160, "GDC_BANK1_G_FIFO_FF_GGA_RSP_WR2"},
|
||
|
+{161, "GDC_BANK1_G_FIFO_FF_GGA_RSP_WR3"},
|
||
|
+{162, "HISTOGRAM_HISTOGRAM_BIN0"},
|
||
|
+{163, "HISTOGRAM_HISTOGRAM_BIN1"},
|
||
|
+{164, "HISTOGRAM_HISTOGRAM_BIN2"},
|
||
|
+{165, "HISTOGRAM_HISTOGRAM_BIN3"},
|
||
|
+{166, "HISTOGRAM_HISTOGRAM_BIN4"},
|
||
|
+{167, "HISTOGRAM_HISTOGRAM_BIN5"},
|
||
|
+{168, "HISTOGRAM_HISTOGRAM_BIN6"},
|
||
|
+{169, "HISTOGRAM_HISTOGRAM_BIN7"},
|
||
|
+{170, "HISTOGRAM_HISTOGRAM_BIN8"},
|
||
|
+{171, "HISTOGRAM_HISTOGRAM_BIN9"},
|
||
|
+{-1, NULL}
|
||
|
+};
|
||
|
+
|
||
|
+struct mlxbf_pmc_events mlxbf3_llt_miss_events[] = {
|
||
|
+{0, "GDC_MISS_MACHINE_RD_REQ"},
|
||
|
+{1, "GDC_MISS_MACHINE_WR_REQ"},
|
||
|
+{2, "GDC_MISS_MACHINE_SNP_REQ"},
|
||
|
+{3, "GDC_MISS_MACHINE_EVICT_REQ"},
|
||
|
+{4, "GDC_MISS_MACHINE_FW_REQ"},
|
||
|
+{5, "GDC_MISS_MACHINE_RD_RESP"},
|
||
|
+{6, "GDC_MISS_MACHINE_WR_RESP"},
|
||
|
+{7, "GDC_MISS_MACHINE_SNP_STASH_DATAPULL_DROP"},
|
||
|
+{8, "GDC_MISS_MACHINE_SNP_STASH_DATAPULL_DROP_TXDAT"},
|
||
|
+{9, "GDC_MISS_MACHINE_CHI_TXREQ"},
|
||
|
+{10, "GDC_MISS_MACHINE_CHI_RXRSP"},
|
||
|
+{11, "GDC_MISS_MACHINE_CHI_TXDAT"},
|
||
|
+{12, "GDC_MISS_MACHINE_CHI_RXDAT"},
|
||
|
+{13, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC0_0"},
|
||
|
+{14, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC0_1 "},
|
||
|
+{15, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC0_2"},
|
||
|
+{16, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC0_3 "},
|
||
|
+{17, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC1_0 "},
|
||
|
+{18, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC1_1 "},
|
||
|
+{19, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC1_2 "},
|
||
|
+{20, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC1_3 "},
|
||
|
+{21, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC_DONE0_0"},
|
||
|
+{22, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC_DONE0_1"},
|
||
|
+{23, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC_DONE0_2"},
|
||
|
+{24, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC_DONE0_3"},
|
||
|
+{25, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC_DONE1_0 "},
|
||
|
+{26, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC_DONE1_1"},
|
||
|
+{27, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC_DONE1_2"},
|
||
|
+{28, "GDC_MISS_MACHINE_G_FIFO_FF_EXEC_DONE1_3"},
|
||
|
+{29, "GDC_MISS_MACHINE_GDC_LINK_LIST_FF_0"},
|
||
|
+{30, "GDC_MISS_MACHINE_GDC_LINK_LIST_FF_1"},
|
||
|
+{31, "GDC_MISS_MACHINE_GDC_LINK_LIST_FF_2"},
|
||
|
+{32, "GDC_MISS_MACHINE_GDC_LINK_LIST_FF_3"},
|
||
|
+{33, "GDC_MISS_MACHINE_GDC_LINK_LIST_FF_4"},
|
||
|
+{34, "GDC_MISS_MACHINE_GDC_LINK_LIST_FF_5"},
|
||
|
+{35, "GDC_MISS_MACHINE_GDC_LINK_LIST_FF_6"},
|
||
|
+{36, "GDC_MISS_MACHINE_G_RSE_PIPE_TXREQ_0"},
|
||
|
+{37, "GDC_MISS_MACHINE_G_RSE_PIPE_TXREQ_1"},
|
||
|
+{38, "GDC_MISS_MACHINE_G_CREDIT_TXREQ_0"},
|
||
|
+{39, "GDC_MISS_MACHINE_G_CREDIT_TXREQ_1"},
|
||
|
+{40, "GDC_MISS_MACHINE_G_RSE_PIPE_TXDAT_0"},
|
||
|
+{41, "GDC_MISS_MACHINE_G_RSE_PIPE_TXDAT_1"},
|
||
|
+{42, "GDC_MISS_MACHINE_G_CREDIT_TXDAT_0"},
|
||
|
+{43, "GDC_MISS_MACHINE_G_CREDIT_TXDAT_1"},
|
||
|
+{44, "GDC_MISS_MACHINE_G_FIFO_FF_COMPACK_0"},
|
||
|
+{45, "GDC_MISS_MACHINE_G_FIFO_FF_COMPACK_1"},
|
||
|
+{46, "GDC_MISS_MACHINE_G_FIFO_FF_COMPACK_2"},
|
||
|
+{47, "GDC_MISS_MACHINE_G_FIFO_FF_COMPACK_3"},
|
||
|
+{48, "GDC_MISS_MACHINE_G_RSE_PIPE_TXRSP_0"},
|
||
|
+{49, "GDC_MISS_MACHINE_G_RSE_PIPE_TXRSP_1"},
|
||
|
+{50, "GDC_MISS_MACHINE_G_CREDIT_TXRSP_0"},
|
||
|
+{51, "GDC_MISS_MACHINE_G_CREDIT_TXRSP_1"},
|
||
|
+{52, "GDC_MISS_MACHINE_G_RSE_PIPE_INARB_0"},
|
||
|
+{53, "GDC_MISS_MACHINE_G_RSE_PIPE_INARB_1"},
|
||
|
+{54, "GDC_MISS_MACHINE_G_FIFO_FF_SNOOP_IN_0"},
|
||
|
+{55, "GDC_MISS_MACHINE_G_FIFO_FF_SNOOP_IN_1"},
|
||
|
+{56, "GDC_MISS_MACHINE_G_FIFO_FF_SNOOP_IN_2"},
|
||
|
+{57, "GDC_MISS_MACHINE_G_FIFO_FF_SNOOP_IN_3"},
|
||
|
+{58, "GDC_MISS_MACHINE_G_FIFO_FF_TXRSP_SNOOP_DATAPULL_0"},
|
||
|
+{59, "GDC_MISS_MACHINE_G_FIFO_FF_TXRSP_SNOOP_DATAPULL_1"},
|
||
|
+{60, "GDC_MISS_MACHINE_G_FIFO_FF_TXRSP_SNOOP_DATAPULL_2"},
|
||
|
+{61, "GDC_MISS_MACHINE_G_FIFO_FF_TXRSP_SNOOP_DATAPULL_3"},
|
||
|
+{62, "GDC_MISS_MACHINE_G_FIFO_FF_TXDAT_SNOOP_DATAPULL_4"},
|
||
|
+{63, "GDC_MISS_MACHINE_G_FIFO_FF_TXDAT_SNOOP_DATAPULL_5"},
|
||
|
+{64, "GDC_MISS_MACHINE_G_FIFO_FF_TXDAT_SNOOP_DATAPULL_6"},
|
||
|
+{65, "GDC_MISS_MACHINE_G_FIFO_FF_TXDAT_SNOOP_DATAPULL_7"},
|
||
|
+{66, "HISTOGRAM_HISTOGRAM_BIN0"},
|
||
|
+{67, "HISTOGRAM_HISTOGRAM_BIN1"},
|
||
|
+{68, "HISTOGRAM_HISTOGRAM_BIN2"},
|
||
|
+{69, "HISTOGRAM_HISTOGRAM_BIN3"},
|
||
|
+{70, "HISTOGRAM_HISTOGRAM_BIN4"},
|
||
|
+{71, "HISTOGRAM_HISTOGRAM_BIN5"},
|
||
|
+{72, "HISTOGRAM_HISTOGRAM_BIN6"},
|
||
|
+{73, "HISTOGRAM_HISTOGRAM_BIN7"},
|
||
|
+{74, "HISTOGRAM_HISTOGRAM_BIN8"},
|
||
|
+{75, "HISTOGRAM_HISTOGRAM_BIN9"},
|
||
|
+{-1, NULL}
|
||
|
+};
|
||
|
+
|
||
|
+struct mlxbf_pmc_events mlxbf3_mss_events[] = {
|
||
|
+{0, "SKYLIB_CDN_TX_FLITS"},
|
||
|
+{1, "SKYLIB_DDN_TX_FLITS"},
|
||
|
+{2, "SKYLIB_NDN_TX_FLITS"},
|
||
|
+{3, "SKYLIB_SDN_TX_FLITS"},
|
||
|
+{4, "SKYLIB_UDN_TX_FLITS"},
|
||
|
+{5, "SKYLIB_CDN_RX_FLITS"},
|
||
|
+{6, "SKYLIB_DDN_RX_FLITS"},
|
||
|
+{7, "SKYLIB_NDN_RX_FLITS"},
|
||
|
+{8, "SKYLIB_SDN_RX_FLITS"},
|
||
|
+{9, "SKYLIB_UDN_RX_FLITS"},
|
||
|
+{10, "SKYLIB_CDN_TX_STALL"},
|
||
|
+{11, "SKYLIB_DDN_TX_STALL"},
|
||
|
+{12, "SKYLIB_NDN_TX_STALL"},
|
||
|
+{13, "SKYLIB_SDN_TX_STALL"},
|
||
|
+{14, "SKYLIB_UDN_TX_STALL"},
|
||
|
+{15, "SKYLIB_CDN_RX_STALL"},
|
||
|
+{16, "SKYLIB_DDN_RX_STALL"},
|
||
|
+{17, "SKYLIB_NDN_RX_STALL"},
|
||
|
+{18, "SKYLIB_SDN_RX_STALL"},
|
||
|
+{19, "SKYLIB_UDN_RX_STALL"},
|
||
|
+{20, "SKYLIB_CHI_REQ0_TX_FLITS"},
|
||
|
+{21, "SKYLIB_CHI_DATA0_TX_FLITS"},
|
||
|
+{22, "SKYLIB_CHI_RESP0_TX_FLITS"},
|
||
|
+{23, "SKYLIB_CHI_SNP0_TX_FLITS"},
|
||
|
+{24, "SKYLIB_CHI_REQ1_TX_FLITS"},
|
||
|
+{25, "SKYLIB_CHI_DATA1_TX_FLITS"},
|
||
|
+{26, "SKYLIB_CHI_RESP1_TX_FLITS"},
|
||
|
+{27, "SKYLIB_CHI_SNP1_TX_FLITS"},
|
||
|
+{28, "SKYLIB_CHI_REQ2_TX_FLITS"},
|
||
|
+{29, "SKYLIB_CHI_DATA2_TX_FLITS"},
|
||
|
+{30, "SKYLIB_CHI_RESP2_TX_FLITS"},
|
||
|
+{31, "SKYLIB_CHI_SNP2_TX_FLITS"},
|
||
|
+{32, "SKYLIB_CHI_REQ3_TX_FLITS"},
|
||
|
+{33, "SKYLIB_CHI_DATA3_TX_FLITS"},
|
||
|
+{34, "SKYLIB_CHI_RESP3_TX_FLITS"},
|
||
|
+{35, "SKYLIB_CHI_SNP3_TX_FLITS"},
|
||
|
+{36, "SKYLIB_TLP_REQ_TX_FLITS"},
|
||
|
+{37, "SKYLIB_TLP_RESP_TX_FLITS"},
|
||
|
+{38, "SKYLIB_TLP_META_TX_FLITS"},
|
||
|
+{39, "SKYLIB_AXIS_DATA_TX_FLITS"},
|
||
|
+{40, "SKYLIB_AXIS_CRED_TX_FLITS"},
|
||
|
+{41, "SKYLIB_APB_TX_FLITS"},
|
||
|
+{42, "SKYLIB_VW_TX_FLITS"},
|
||
|
+{43, "SKYLIB_GGA_MSN_W_TX_FLITS"},
|
||
|
+{44, "SKYLIB_GGA_MSN_N_TX_FLITS"},
|
||
|
+{45, "SKYLIB_CR_REQ_TX_FLITS"},
|
||
|
+{46, "SKYLIB_CR_RESP_TX_FLITS"},
|
||
|
+{47, "SKYLIB_MSN_PRNF_TX_FLITS"},
|
||
|
+{48, "SKYLIB_DBG_DATA_TX_FLITS"},
|
||
|
+{49, "SKYLIB_DBG_CRED_TX_FLITS"},
|
||
|
+{50, "SKYLIB_CHI_REQ0_RX_FLITS"},
|
||
|
+{51, "SKYLIB_CHI_DATA0_RX_FLITS"},
|
||
|
+{52, "SKYLIB_CHI_RESP0_RX_FLITS"},
|
||
|
+{53, "SKYLIB_CHI_SNP0_RX_FLITS"},
|
||
|
+{54, "SKYLIB_CHI_REQ1_RX_FLITS"},
|
||
|
+{55, "SKYLIB_CHI_DATA1_RX_FLITS"},
|
||
|
+{56, "SKYLIB_CHI_RESP1_RX_FLITS"},
|
||
|
+{57, "SKYLIB_CHI_SNP1_RX_FLITS"},
|
||
|
+{58, "SKYLIB_CHI_REQ2_RX_FLITS"},
|
||
|
+{59, "SKYLIB_CHI_DATA2_RX_FLITS"},
|
||
|
+{60, "SKYLIB_CHI_RESP2_RX_FLITS"},
|
||
|
+{61, "SKYLIB_CHI_SNP2_RX_FLITS"},
|
||
|
+{62, "SKYLIB_CHI_REQ3_RX_FLITS"},
|
||
|
+{63, "SKYLIB_CHI_DATA3_RX_FLITS"},
|
||
|
+{64, "SKYLIB_CHI_RESP3_RX_FLITS"},
|
||
|
+{65, "SKYLIB_CHI_SNP3_RX_FLITS"},
|
||
|
+{66, "SKYLIB_TLP_REQ_RX_FLITS"},
|
||
|
+{67, "SKYLIB_TLP_RESP_RX_FLITS"},
|
||
|
+{68, "SKYLIB_TLP_META_RX_FLITS"},
|
||
|
+{69, "SKYLIB_AXIS_DATA_RX_FLITS"},
|
||
|
+{70, "SKYLIB_AXIS_CRED_RX_FLITS"},
|
||
|
+{71, "SKYLIB_APB_RX_FLITS"},
|
||
|
+{72, "SKYLIB_VW_RX_FLITS"},
|
||
|
+{73, "SKYLIB_GGA_MSN_W_RX_FLITS"},
|
||
|
+{74, "SKYLIB_GGA_MSN_N_RX_FLITS"},
|
||
|
+{75, "SKYLIB_CR_REQ_RX_FLITS"},
|
||
|
+{76, "SKYLIB_CR_RESP_RX_FLITS"},
|
||
|
+{77, "SKYLIB_MSN_PRNF_RX_FLITS"},
|
||
|
+{78, "SKYLIB_DBG_DATA_RX_FLITS"},
|
||
|
+{79, "SKYLIB_DBG_CRED_RX_FLITS"},
|
||
|
+{80, "SKYLIB_CHI_REQ0_TX_STALL"},
|
||
|
+{81, "SKYLIB_CHI_DATA0_TX_STALL"},
|
||
|
+{82, "SKYLIB_CHI_RESP0_TX_STALL"},
|
||
|
+{83, "SKYLIB_CHI_SNP0_TX_STALL"},
|
||
|
+{84, "SKYLIB_CHI_REQ1_TX_STALL"},
|
||
|
+{85, "SKYLIB_CHI_DATA1_TX_STALL"},
|
||
|
+{86, "SKYLIB_CHI_RESP1_TX_STALL"},
|
||
|
+{87, "SKYLIB_CHI_SNP1_TX_STALL"},
|
||
|
+{88, "SKYLIB_CHI_REQ2_TX_STALL"},
|
||
|
+{89, "SKYLIB_CHI_DATA2_TX_STALL"},
|
||
|
+{90, "SKYLIB_CHI_RESP2_TX_STALL"},
|
||
|
+{91, "SKYLIB_CHI_SNP2_TX_STALL"},
|
||
|
+{92, "SKYLIB_CHI_REQ3_TX_STALL"},
|
||
|
+{93, "SKYLIB_CHI_DATA3_TX_STALL"},
|
||
|
+{94, "SKYLIB_CHI_RESP3_TX_STALL"},
|
||
|
+{95, "SKYLIB_CHI_SNP3_TX_STALL"},
|
||
|
+{96, "SKYLIB_TLP_REQ_TX_STALL"},
|
||
|
+{97, "SKYLIB_TLP_RESP_TX_STALL"},
|
||
|
+{98, "SKYLIB_TLP_META_TX_STALL"},
|
||
|
+{99, "SKYLIB_AXIS_DATA_TX_STALL"},
|
||
|
+{100, "SKYLIB_AXIS_CRED_TX_STALL"},
|
||
|
+{101, "SKYLIB_APB_TX_STALL"},
|
||
|
+{102, "SKYLIB_VW_TX_STALL"},
|
||
|
+{103, "SKYLIB_GGA_MSN_W_TX_STALL"},
|
||
|
+{104, "SKYLIB_GGA_MSN_N_TX_STALL"},
|
||
|
+{105, "SKYLIB_CR_REQ_TX_STALL"},
|
||
|
+{106, "SKYLIB_CR_RESP_TX_STALL"},
|
||
|
+{107, "SKYLIB_MSN_PRNF_TX_STALL"},
|
||
|
+{108, "SKYLIB_DBG_DATA_TX_STALL"},
|
||
|
+{109, "SKYLIB_DBG_CRED_TX_STALL"},
|
||
|
+{110, "SKYLIB_CHI_REQ0_RX_STALL"},
|
||
|
+{111, "SKYLIB_CHI_DATA0_RX_STALL"},
|
||
|
+{112, "SKYLIB_CHI_RESP0_RX_STALL"},
|
||
|
+{113, "SKYLIB_CHI_SNP0_RX_STALL"},
|
||
|
+{114, "SKYLIB_CHI_REQ1_RX_STALL"},
|
||
|
+{115, "SKYLIB_CHI_DATA1_RX_STALL"},
|
||
|
+{116, "SKYLIB_CHI_RESP1_RX_STALL"},
|
||
|
+{117, "SKYLIB_CHI_SNP1_RX_STALL"},
|
||
|
+{118, "SKYLIB_CHI_REQ2_RX_STALL"},
|
||
|
+{119, "SKYLIB_CHI_DATA2_RX_STALL"},
|
||
|
+{120, "SKYLIB_CHI_RESP2_RX_STALL"},
|
||
|
+{121, "SKYLIB_CHI_SNP2_RX_STALL"},
|
||
|
+{122, "SKYLIB_CHI_REQ3_RX_STALL"},
|
||
|
+{123, "SKYLIB_CHI_DATA3_RX_STALL"},
|
||
|
+{124, "SKYLIB_CHI_RESP3_RX_STALL"},
|
||
|
+{125, "SKYLIB_CHI_SNP3_RX_STALL"},
|
||
|
+{126, "SKYLIB_TLP_REQ_RX_STALL"},
|
||
|
+{127, "SKYLIB_TLP_RESP_RX_STALL"},
|
||
|
+{128, "SKYLIB_TLP_META_RX_STALL"},
|
||
|
+{129, "SKYLIB_AXIS_DATA_RX_STALL"},
|
||
|
+{130, "SKYLIB_AXIS_CRED_RX_STALL"},
|
||
|
+{131, "SKYLIB_APB_RX_STALL"},
|
||
|
+{132, "SKYLIB_VW_RX_STALL"},
|
||
|
+{133, "SKYLIB_GGA_MSN_W_RX_STALL"},
|
||
|
+{134, "SKYLIB_GGA_MSN_N_RX_STALL"},
|
||
|
+{135, "SKYLIB_CR_REQ_RX_STALL"},
|
||
|
+{136, "SKYLIB_CR_RESP_RX_STALL"},
|
||
|
+{137, "SKYLIB_MSN_PRNF_RX_STALL"},
|
||
|
+{138, "SKYLIB_DBG_DATA_RX_STALL"},
|
||
|
+{139, "SKYLIB_DBG_CRED_RX_STALL"},
|
||
|
+{140, "SKYLIB_CDN_LOOPBACK_FLITS"},
|
||
|
+{141, "SKYLIB_DDN_LOOPBACK_FLITS"},
|
||
|
+{142, "SKYLIB_NDN_LOOPBACK_FLITS"},
|
||
|
+{143, "SKYLIB_SDN_LOOPBACK_FLITS"},
|
||
|
+{144, "SKYLIB_UDN_LOOPBACK_FLITS"},
|
||
|
+{145, "HISTOGRAM_HISTOGRAM_BIN0"},
|
||
|
+{146, "HISTOGRAM_HISTOGRAM_BIN1"},
|
||
|
+{147, "HISTOGRAM_HISTOGRAM_BIN2"},
|
||
|
+{148, "HISTOGRAM_HISTOGRAM_BIN3"},
|
||
|
+{149, "HISTOGRAM_HISTOGRAM_BIN4"},
|
||
|
+{150, "HISTOGRAM_HISTOGRAM_BIN5"},
|
||
|
+{151, "HISTOGRAM_HISTOGRAM_BIN6"},
|
||
|
+{152, "HISTOGRAM_HISTOGRAM_BIN7"},
|
||
|
+{153, "HISTOGRAM_HISTOGRAM_BIN8"},
|
||
|
+{154, "HISTOGRAM_HISTOGRAM_BIN9"},
|
||
|
+{-1, NULL}
|
||
|
+};
|
||
|
+
|
||
|
#endif /* __MLXBF_PMC_H__ */
|
||
|
--
|
||
|
2.20.1
|
||
|
|