a37f08a882
The oa object manages the oa buffer and must be allocated when the user intends to read performance counter snapshots. This can be achieved by making the oa object part of the stream object which is allocated when a stream is opened by the user. Attributes in the oa object that are gen-specific are moved to the perf object so that they can be initialized on driver load. The split provides a better separation of the objects used in perf implementation of i915 driver so that resources are allocated and initialized only when needed. v2: Fix checkpatch warnings v3: Addressed Lionel's review comment v4: Rebase v5: Fix rebase/merge issue with ratelimit_state_init Signed-off-by: Umesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com> Reviewed-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com> Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Link: https://patchwork.freedesktop.org/patch/msgid/20190806233002.984-1-umesh.nerlige.ramappa@intel.com
89 lines
2.7 KiB
C
89 lines
2.7 KiB
C
// SPDX-License-Identifier: MIT
|
|
/*
|
|
* Copyright © 2018-2019 Intel Corporation
|
|
*
|
|
* Autogenerated file by GPU Top : https://github.com/rib/gputop
|
|
* DO NOT EDIT manually!
|
|
*/
|
|
|
|
#include <linux/sysfs.h>
|
|
|
|
#include "i915_drv.h"
|
|
#include "i915_oa_bxt.h"
|
|
|
|
static const struct i915_oa_reg b_counter_config_test_oa[] = {
|
|
{ _MMIO(0x2740), 0x00000000 },
|
|
{ _MMIO(0x2744), 0x00800000 },
|
|
{ _MMIO(0x2714), 0xf0800000 },
|
|
{ _MMIO(0x2710), 0x00000000 },
|
|
{ _MMIO(0x2724), 0xf0800000 },
|
|
{ _MMIO(0x2720), 0x00000000 },
|
|
{ _MMIO(0x2770), 0x00000004 },
|
|
{ _MMIO(0x2774), 0x00000000 },
|
|
{ _MMIO(0x2778), 0x00000003 },
|
|
{ _MMIO(0x277c), 0x00000000 },
|
|
{ _MMIO(0x2780), 0x00000007 },
|
|
{ _MMIO(0x2784), 0x00000000 },
|
|
{ _MMIO(0x2788), 0x00100002 },
|
|
{ _MMIO(0x278c), 0x0000fff7 },
|
|
{ _MMIO(0x2790), 0x00100002 },
|
|
{ _MMIO(0x2794), 0x0000ffcf },
|
|
{ _MMIO(0x2798), 0x00100082 },
|
|
{ _MMIO(0x279c), 0x0000ffef },
|
|
{ _MMIO(0x27a0), 0x001000c2 },
|
|
{ _MMIO(0x27a4), 0x0000ffe7 },
|
|
{ _MMIO(0x27a8), 0x00100001 },
|
|
{ _MMIO(0x27ac), 0x0000ffe7 },
|
|
};
|
|
|
|
static const struct i915_oa_reg flex_eu_config_test_oa[] = {
|
|
};
|
|
|
|
static const struct i915_oa_reg mux_config_test_oa[] = {
|
|
{ _MMIO(0x9840), 0x00000080 },
|
|
{ _MMIO(0x9888), 0x19800000 },
|
|
{ _MMIO(0x9888), 0x07800063 },
|
|
{ _MMIO(0x9888), 0x11800000 },
|
|
{ _MMIO(0x9888), 0x23810008 },
|
|
{ _MMIO(0x9888), 0x1d950400 },
|
|
{ _MMIO(0x9888), 0x0f922000 },
|
|
{ _MMIO(0x9888), 0x1f908000 },
|
|
{ _MMIO(0x9888), 0x37900000 },
|
|
{ _MMIO(0x9888), 0x55900000 },
|
|
{ _MMIO(0x9888), 0x47900000 },
|
|
{ _MMIO(0x9888), 0x33900000 },
|
|
};
|
|
|
|
static ssize_t
|
|
show_test_oa_id(struct device *kdev, struct device_attribute *attr, char *buf)
|
|
{
|
|
return sprintf(buf, "1\n");
|
|
}
|
|
|
|
void
|
|
i915_perf_load_test_config_bxt(struct drm_i915_private *dev_priv)
|
|
{
|
|
strlcpy(dev_priv->perf.test_config.uuid,
|
|
"5ee72f5c-092f-421e-8b70-225f7c3e9612",
|
|
sizeof(dev_priv->perf.test_config.uuid));
|
|
dev_priv->perf.test_config.id = 1;
|
|
|
|
dev_priv->perf.test_config.mux_regs = mux_config_test_oa;
|
|
dev_priv->perf.test_config.mux_regs_len = ARRAY_SIZE(mux_config_test_oa);
|
|
|
|
dev_priv->perf.test_config.b_counter_regs = b_counter_config_test_oa;
|
|
dev_priv->perf.test_config.b_counter_regs_len = ARRAY_SIZE(b_counter_config_test_oa);
|
|
|
|
dev_priv->perf.test_config.flex_regs = flex_eu_config_test_oa;
|
|
dev_priv->perf.test_config.flex_regs_len = ARRAY_SIZE(flex_eu_config_test_oa);
|
|
|
|
dev_priv->perf.test_config.sysfs_metric.name = "5ee72f5c-092f-421e-8b70-225f7c3e9612";
|
|
dev_priv->perf.test_config.sysfs_metric.attrs = dev_priv->perf.test_config.attrs;
|
|
|
|
dev_priv->perf.test_config.attrs[0] = &dev_priv->perf.test_config.sysfs_metric_id.attr;
|
|
|
|
dev_priv->perf.test_config.sysfs_metric_id.attr.name = "id";
|
|
dev_priv->perf.test_config.sysfs_metric_id.attr.mode = 0444;
|
|
dev_priv->perf.test_config.sysfs_metric_id.show = show_test_oa_id;
|
|
}
|