summaryrefslogtreecommitdiff
path: root/lib/igt_sysfs.h
diff options
context:
space:
mode:
authorUmesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com>2022-04-19 23:12:50 -0700
committerAshutosh Dixit <ashutosh.dixit@intel.com>2022-04-25 16:07:15 -0700
commit855dc13d376b5e4561f6c022aa52b01aa4d0892f (patch)
treeffdf40ed143ade5606ca2ae4f02126abb982f8e5 /lib/igt_sysfs.h
parent86a1900255fb5c23f52ba425c1f44e5954dfbab3 (diff)
lib/igt_sysfs: Add RPS sysfs helpers
RPS sysfs files exposed by the kernel can either be in per-gt sysfs or in the per-device legacy sysfs. Add helpers to read/write these files in either of the two sets of locations. v2: Added function descriptions (Kamil) Separated patch from "lib/igt_sysfs: Add helpers to iterate over GTs" v3: Improved checks in igt_sysfs_dir_id_to_name() (Ashutosh) Code review comments (Kamil) Cc: Kamil Konieczny <kamil.konieczny@linux.intel.com> Cc: Andi Shyti <andi.shyti@intel.com> Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Cc: Sujaritha Sundaresan <sujaritha.sundaresan@intel.com> Signed-off-by: Umesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com> Signed-off-by: Ashutosh Dixit <ashutosh.dixit@intel.com> Reviewed-by: Ashutosh Dixit <ashutosh.dixit@intel.com> Reviewed-by: Kamil Konieczny <kamil.konieczny@linux.intel.com>
Diffstat (limited to 'lib/igt_sysfs.h')
-rw-r--r--lib/igt_sysfs.h54
1 files changed, 54 insertions, 0 deletions
diff --git a/lib/igt_sysfs.h b/lib/igt_sysfs.h
index 33317a96..8e39b8fa 100644
--- a/lib/igt_sysfs.h
+++ b/lib/igt_sysfs.h
@@ -38,11 +38,65 @@
(dirfd__ = igt_sysfs_gt_open(i915__, gt__)) != -1; \
close(dirfd__), gt__++)
+#define igt_sysfs_rps_write(dir, id, data, len) \
+ igt_sysfs_write(dir, igt_sysfs_dir_id_to_name(dir, id), data, len)
+
+#define igt_sysfs_rps_read(dir, id, data, len) \
+ igt_sysfs_read(dir, igt_sysfs_dir_id_to_name(dir, id), data, len)
+
+#define igt_sysfs_rps_set(dir, id, value) \
+ igt_sysfs_set(dir, igt_sysfs_dir_id_to_name(dir, id), value)
+
+#define igt_sysfs_rps_get(dir, id) \
+ igt_sysfs_get(dir, igt_sysfs_dir_id_to_name(dir, id))
+
+#define igt_sysfs_rps_scanf(dir, id, fmt, ...) \
+ igt_sysfs_scanf(dir, igt_sysfs_dir_id_to_name(dir, id), fmt, ##__VA_ARGS__)
+
+#define igt_sysfs_rps_vprintf(dir, id, fmt, ap) \
+ igt_sysfs_vprintf(dir, igt_sysfs_dir_id_to_name(id), fmt, ap)
+
+#define igt_sysfs_rps_printf(dir, id, fmt, ...) \
+ igt_sysfs_printf(dir, igt_sysfs_dir_id_to_name(dir, id), fmt, ##__VA_ARGS__)
+
+#define igt_sysfs_rps_get_u32(dir, id) \
+ igt_sysfs_get_u32(dir, igt_sysfs_dir_id_to_name(dir, id))
+
+#define igt_sysfs_rps_set_u32(dir, id, value) \
+ igt_sysfs_set_u32(dir, igt_sysfs_dir_id_to_name(dir, id), value)
+
+#define igt_sysfs_rps_get_boolean(dir, id) \
+ igt_sysfs_get_boolean(dir, igt_sysfs_dir_id_to_name(dir, id))
+
+#define igt_sysfs_rps_set_boolean(dir, id, value) \
+ igt_sysfs_set_boolean(dir, igt_sysfs_dir_id_to_name(dir, id), value)
+
+enum i915_attr_id {
+ RPS_ACT_FREQ_MHZ,
+ RPS_CUR_FREQ_MHZ,
+ RPS_MIN_FREQ_MHZ,
+ RPS_MAX_FREQ_MHZ,
+ RPS_RP0_FREQ_MHZ,
+ RPS_RP1_FREQ_MHZ,
+ RPS_RPn_FREQ_MHZ,
+ RPS_IDLE_FREQ_MHZ,
+ RPS_BOOST_FREQ_MHZ,
+ RC6_ENABLE,
+ RC6_RESIDENCY_MS,
+ RC6P_RESIDENCY_MS,
+ RC6PP_RESIDENCY_MS,
+ MEDIA_RC6_RESIDENCY_MS,
+
+ SYSFS_NUM_ATTR,
+};
+
char *igt_sysfs_path(int device, char *path, int pathlen);
int igt_sysfs_open(int device);
char *igt_sysfs_gt_path(int device, int gt, char *path, int pathlen);
int igt_sysfs_gt_open(int device, int gt);
bool igt_sysfs_has_attr(int dir, const char *attr);
+const char *igt_sysfs_dir_id_to_name(int dir, enum i915_attr_id id);
+const char *igt_sysfs_path_id_to_name(const char *path, enum i915_attr_id id);
int igt_sysfs_read(int dir, const char *attr, void *data, int len);
int igt_sysfs_write(int dir, const char *attr, const void *data, int len);