Home | History | Annotate | Line # | Download | only in oa
      1 /*	$NetBSD: i915_oa_bdw.c,v 1.2 2021/12/18 23:45:31 riastradh Exp $	*/
      2 
      3 // SPDX-License-Identifier: MIT
      4 /*
      5  * Copyright  2018-2019 Intel Corporation
      6  *
      7  * Autogenerated file by GPU Top : https://github.com/rib/gputop
      8  * DO NOT EDIT manually!
      9  */
     10 
     11 #include <sys/cdefs.h>
     12 __KERNEL_RCSID(0, "$NetBSD: i915_oa_bdw.c,v 1.2 2021/12/18 23:45:31 riastradh Exp $");
     13 
     14 #include <linux/sysfs.h>
     15 
     16 #include "i915_drv.h"
     17 #include "i915_oa_bdw.h"
     18 
     19 static const struct i915_oa_reg b_counter_config_test_oa[] = {
     20 	{ _MMIO(0x2740), 0x00000000 },
     21 	{ _MMIO(0x2744), 0x00800000 },
     22 	{ _MMIO(0x2714), 0xf0800000 },
     23 	{ _MMIO(0x2710), 0x00000000 },
     24 	{ _MMIO(0x2724), 0xf0800000 },
     25 	{ _MMIO(0x2720), 0x00000000 },
     26 	{ _MMIO(0x2770), 0x00000004 },
     27 	{ _MMIO(0x2774), 0x00000000 },
     28 	{ _MMIO(0x2778), 0x00000003 },
     29 	{ _MMIO(0x277c), 0x00000000 },
     30 	{ _MMIO(0x2780), 0x00000007 },
     31 	{ _MMIO(0x2784), 0x00000000 },
     32 	{ _MMIO(0x2788), 0x00100002 },
     33 	{ _MMIO(0x278c), 0x0000fff7 },
     34 	{ _MMIO(0x2790), 0x00100002 },
     35 	{ _MMIO(0x2794), 0x0000ffcf },
     36 	{ _MMIO(0x2798), 0x00100082 },
     37 	{ _MMIO(0x279c), 0x0000ffef },
     38 	{ _MMIO(0x27a0), 0x001000c2 },
     39 	{ _MMIO(0x27a4), 0x0000ffe7 },
     40 	{ _MMIO(0x27a8), 0x00100001 },
     41 	{ _MMIO(0x27ac), 0x0000ffe7 },
     42 };
     43 
     44 static const struct i915_oa_reg flex_eu_config_test_oa[] = {
     45 };
     46 
     47 static const struct i915_oa_reg mux_config_test_oa[] = {
     48 	{ _MMIO(0x9840), 0x000000a0 },
     49 	{ _MMIO(0x9888), 0x198b0000 },
     50 	{ _MMIO(0x9888), 0x078b0066 },
     51 	{ _MMIO(0x9888), 0x118b0000 },
     52 	{ _MMIO(0x9888), 0x258b0000 },
     53 	{ _MMIO(0x9888), 0x21850008 },
     54 	{ _MMIO(0x9888), 0x0d834000 },
     55 	{ _MMIO(0x9888), 0x07844000 },
     56 	{ _MMIO(0x9888), 0x17804000 },
     57 	{ _MMIO(0x9888), 0x21800000 },
     58 	{ _MMIO(0x9888), 0x4f800000 },
     59 	{ _MMIO(0x9888), 0x41800000 },
     60 	{ _MMIO(0x9888), 0x31800000 },
     61 	{ _MMIO(0x9840), 0x00000080 },
     62 };
     63 
     64 static ssize_t
     65 show_test_oa_id(struct device *kdev, struct device_attribute *attr, char *buf)
     66 {
     67 	return sprintf(buf, "1\n");
     68 }
     69 
     70 void
     71 i915_perf_load_test_config_bdw(struct drm_i915_private *dev_priv)
     72 {
     73 	strlcpy(dev_priv->perf.test_config.uuid,
     74 		"d6de6f55-e526-4f79-a6a6-d7315c09044e",
     75 		sizeof(dev_priv->perf.test_config.uuid));
     76 	dev_priv->perf.test_config.id = 1;
     77 
     78 	dev_priv->perf.test_config.mux_regs = mux_config_test_oa;
     79 	dev_priv->perf.test_config.mux_regs_len = ARRAY_SIZE(mux_config_test_oa);
     80 
     81 	dev_priv->perf.test_config.b_counter_regs = b_counter_config_test_oa;
     82 	dev_priv->perf.test_config.b_counter_regs_len = ARRAY_SIZE(b_counter_config_test_oa);
     83 
     84 	dev_priv->perf.test_config.flex_regs = flex_eu_config_test_oa;
     85 	dev_priv->perf.test_config.flex_regs_len = ARRAY_SIZE(flex_eu_config_test_oa);
     86 
     87 	dev_priv->perf.test_config.sysfs_metric.name = "d6de6f55-e526-4f79-a6a6-d7315c09044e";
     88 	dev_priv->perf.test_config.sysfs_metric.attrs = dev_priv->perf.test_config.attrs;
     89 
     90 	dev_priv->perf.test_config.attrs[0] = &dev_priv->perf.test_config.sysfs_metric_id.attr;
     91 
     92 	dev_priv->perf.test_config.sysfs_metric_id.attr.name = "id";
     93 	dev_priv->perf.test_config.sysfs_metric_id.attr.mode = 0444;
     94 	dev_priv->perf.test_config.sysfs_metric_id.show = show_test_oa_id;
     95 }
     96