1 // SPDX-License-Identifier: MIT 2 /* 3 * Copyright © 2022 Intel Corporation 4 */ 5 6 #include <drm/drm_device.h> 7 #include <linux/sysfs.h> 8 #include <linux/printk.h> 9 10 #include "i915_drv.h" 11 #include "i915_reg.h" 12 #include "i915_sysfs.h" 13 #include "intel_gt.h" 14 #include "intel_gt_print.h" 15 #include "intel_gt_regs.h" 16 #include "intel_gt_sysfs.h" 17 #include "intel_gt_sysfs_pm.h" 18 #include "intel_pcode.h" 19 #include "intel_rc6.h" 20 #include "intel_rps.h" 21 22 enum intel_gt_sysfs_op { 23 INTEL_GT_SYSFS_MIN = 0, 24 INTEL_GT_SYSFS_MAX, 25 }; 26 27 static int 28 sysfs_gt_attribute_w_func(struct kobject *kobj, struct attribute *attr, 29 int (func)(struct intel_gt *gt, u32 val), u32 val) 30 { 31 struct intel_gt *gt; 32 int ret; 33 34 if (!is_object_gt(kobj)) { 35 int i; 36 struct device *dev = kobj_to_dev(kobj); 37 struct drm_i915_private *i915 = kdev_minor_to_i915(dev); 38 39 for_each_gt(gt, i915, i) { 40 ret = func(gt, val); 41 if (ret) 42 break; 43 } 44 } else { 45 gt = intel_gt_sysfs_get_drvdata(kobj, attr->name); 46 ret = func(gt, val); 47 } 48 49 return ret; 50 } 51 52 static u32 53 sysfs_gt_attribute_r_func(struct kobject *kobj, struct attribute *attr, 54 u32 (func)(struct intel_gt *gt), 55 enum intel_gt_sysfs_op op) 56 { 57 struct intel_gt *gt; 58 u32 ret; 59 60 ret = (op == INTEL_GT_SYSFS_MAX) ? 0 : (u32) -1; 61 62 if (!is_object_gt(kobj)) { 63 int i; 64 struct device *dev = kobj_to_dev(kobj); 65 struct drm_i915_private *i915 = kdev_minor_to_i915(dev); 66 67 for_each_gt(gt, i915, i) { 68 u32 val = func(gt); 69 70 switch (op) { 71 case INTEL_GT_SYSFS_MIN: 72 if (val < ret) 73 ret = val; 74 break; 75 76 case INTEL_GT_SYSFS_MAX: 77 if (val > ret) 78 ret = val; 79 break; 80 } 81 } 82 } else { 83 gt = intel_gt_sysfs_get_drvdata(kobj, attr->name); 84 ret = func(gt); 85 } 86 87 return ret; 88 } 89 90 /* RC6 interfaces will show the minimum RC6 residency value */ 91 #define sysfs_gt_attribute_r_min_func(d, a, f) \ 92 sysfs_gt_attribute_r_func(d, a, f, INTEL_GT_SYSFS_MIN) 93 94 /* Frequency interfaces will show the maximum frequency value */ 95 #define sysfs_gt_attribute_r_max_func(d, a, f) \ 96 sysfs_gt_attribute_r_func(d, a, f, INTEL_GT_SYSFS_MAX) 97 98 #define INTEL_GT_SYSFS_SHOW(_name, _attr_type) \ 99 static ssize_t _name##_show_common(struct kobject *kobj, \ 100 struct attribute *attr, char *buff) \ 101 { \ 102 u32 val = sysfs_gt_attribute_r_##_attr_type##_func(kobj, attr, \ 103 __##_name##_show); \ 104 \ 105 return sysfs_emit(buff, "%u\n", val); \ 106 } \ 107 static ssize_t _name##_show(struct kobject *kobj, \ 108 struct kobj_attribute *attr, char *buff) \ 109 { \ 110 return _name ##_show_common(kobj, &attr->attr, buff); \ 111 } \ 112 static ssize_t _name##_dev_show(struct device *dev, \ 113 struct device_attribute *attr, char *buff) \ 114 { \ 115 return _name##_show_common(&dev->kobj, &attr->attr, buff); \ 116 } 117 118 #define INTEL_GT_SYSFS_STORE(_name, _func) \ 119 static ssize_t _name##_store_common(struct kobject *kobj, \ 120 struct attribute *attr, \ 121 const char *buff, size_t count) \ 122 { \ 123 int ret; \ 124 u32 val; \ 125 \ 126 ret = kstrtou32(buff, 0, &val); \ 127 if (ret) \ 128 return ret; \ 129 \ 130 ret = sysfs_gt_attribute_w_func(kobj, attr, _func, val); \ 131 \ 132 return ret ?: count; \ 133 } \ 134 static ssize_t _name##_store(struct kobject *kobj, \ 135 struct kobj_attribute *attr, const char *buff, \ 136 size_t count) \ 137 { \ 138 return _name##_store_common(kobj, &attr->attr, buff, count); \ 139 } \ 140 static ssize_t _name##_dev_store(struct device *dev, \ 141 struct device_attribute *attr, \ 142 const char *buff, size_t count) \ 143 { \ 144 return _name##_store_common(&dev->kobj, &attr->attr, buff, count); \ 145 } 146 147 #define INTEL_GT_SYSFS_SHOW_MAX(_name) INTEL_GT_SYSFS_SHOW(_name, max) 148 #define INTEL_GT_SYSFS_SHOW_MIN(_name) INTEL_GT_SYSFS_SHOW(_name, min) 149 150 #define INTEL_GT_ATTR_RW(_name) \ 151 static struct kobj_attribute attr_##_name = __ATTR_RW(_name) 152 153 #define INTEL_GT_ATTR_RO(_name) \ 154 static struct kobj_attribute attr_##_name = __ATTR_RO(_name) 155 156 #define INTEL_GT_DUAL_ATTR_RW(_name) \ 157 static struct device_attribute dev_attr_##_name = __ATTR(_name, 0644, \ 158 _name##_dev_show, \ 159 _name##_dev_store); \ 160 INTEL_GT_ATTR_RW(_name) 161 162 #define INTEL_GT_DUAL_ATTR_RO(_name) \ 163 static struct device_attribute dev_attr_##_name = __ATTR(_name, 0444, \ 164 _name##_dev_show, \ 165 NULL); \ 166 INTEL_GT_ATTR_RO(_name) 167 168 static u32 get_residency(struct intel_gt *gt, enum intel_rc6_res_type id) 169 { 170 intel_wakeref_t wakeref; 171 u64 res = 0; 172 173 with_intel_runtime_pm(gt->uncore->rpm, wakeref) 174 res = intel_rc6_residency_us(>->rc6, id); 175 176 return DIV_ROUND_CLOSEST_ULL(res, 1000); 177 } 178 179 static ssize_t rc6_enable_show(struct kobject *kobj, 180 struct kobj_attribute *attr, 181 char *buff) 182 { 183 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 184 185 return sysfs_emit(buff, "%x\n", gt->rc6.enabled); 186 } 187 188 static ssize_t rc6_enable_dev_show(struct device *dev, 189 struct device_attribute *attr, 190 char *buff) 191 { 192 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(&dev->kobj, attr->attr.name); 193 194 return sysfs_emit(buff, "%x\n", gt->rc6.enabled); 195 } 196 197 static u32 __rc6_residency_ms_show(struct intel_gt *gt) 198 { 199 return get_residency(gt, INTEL_RC6_RES_RC6); 200 } 201 202 static u32 __rc6p_residency_ms_show(struct intel_gt *gt) 203 { 204 return get_residency(gt, INTEL_RC6_RES_RC6p); 205 } 206 207 static u32 __rc6pp_residency_ms_show(struct intel_gt *gt) 208 { 209 return get_residency(gt, INTEL_RC6_RES_RC6pp); 210 } 211 212 static u32 __media_rc6_residency_ms_show(struct intel_gt *gt) 213 { 214 return get_residency(gt, INTEL_RC6_RES_VLV_MEDIA); 215 } 216 217 INTEL_GT_SYSFS_SHOW_MIN(rc6_residency_ms); 218 INTEL_GT_SYSFS_SHOW_MIN(rc6p_residency_ms); 219 INTEL_GT_SYSFS_SHOW_MIN(rc6pp_residency_ms); 220 INTEL_GT_SYSFS_SHOW_MIN(media_rc6_residency_ms); 221 222 INTEL_GT_DUAL_ATTR_RO(rc6_enable); 223 INTEL_GT_DUAL_ATTR_RO(rc6_residency_ms); 224 INTEL_GT_DUAL_ATTR_RO(rc6p_residency_ms); 225 INTEL_GT_DUAL_ATTR_RO(rc6pp_residency_ms); 226 INTEL_GT_DUAL_ATTR_RO(media_rc6_residency_ms); 227 228 static struct attribute *rc6_attrs[] = { 229 &attr_rc6_enable.attr, 230 &attr_rc6_residency_ms.attr, 231 NULL 232 }; 233 234 static struct attribute *rc6p_attrs[] = { 235 &attr_rc6p_residency_ms.attr, 236 &attr_rc6pp_residency_ms.attr, 237 NULL 238 }; 239 240 static struct attribute *media_rc6_attrs[] = { 241 &attr_media_rc6_residency_ms.attr, 242 NULL 243 }; 244 245 static struct attribute *rc6_dev_attrs[] = { 246 &dev_attr_rc6_enable.attr, 247 &dev_attr_rc6_residency_ms.attr, 248 NULL 249 }; 250 251 static struct attribute *rc6p_dev_attrs[] = { 252 &dev_attr_rc6p_residency_ms.attr, 253 &dev_attr_rc6pp_residency_ms.attr, 254 NULL 255 }; 256 257 static struct attribute *media_rc6_dev_attrs[] = { 258 &dev_attr_media_rc6_residency_ms.attr, 259 NULL 260 }; 261 262 static const struct attribute_group rc6_attr_group[] = { 263 { .attrs = rc6_attrs, }, 264 { .name = power_group_name, .attrs = rc6_dev_attrs, }, 265 }; 266 267 static const struct attribute_group rc6p_attr_group[] = { 268 { .attrs = rc6p_attrs, }, 269 { .name = power_group_name, .attrs = rc6p_dev_attrs, }, 270 }; 271 272 static const struct attribute_group media_rc6_attr_group[] = { 273 { .attrs = media_rc6_attrs, }, 274 { .name = power_group_name, .attrs = media_rc6_dev_attrs, }, 275 }; 276 277 static int __intel_gt_sysfs_create_group(struct kobject *kobj, 278 const struct attribute_group *grp) 279 { 280 return is_object_gt(kobj) ? 281 sysfs_create_group(kobj, &grp[0]) : 282 sysfs_merge_group(kobj, &grp[1]); 283 } 284 285 static void intel_sysfs_rc6_init(struct intel_gt *gt, struct kobject *kobj) 286 { 287 int ret; 288 289 if (!IS_ENABLED(CONFIG_PM) || !HAS_RC6(gt->i915)) 290 return; 291 292 ret = __intel_gt_sysfs_create_group(kobj, rc6_attr_group); 293 if (ret) 294 gt_warn(gt, "failed to create RC6 sysfs files (%pe)\n", ERR_PTR(ret)); 295 296 /* 297 * cannot use the is_visible() attribute because 298 * the upper object inherits from the parent group. 299 */ 300 if (HAS_RC6p(gt->i915)) { 301 ret = __intel_gt_sysfs_create_group(kobj, rc6p_attr_group); 302 if (ret) 303 gt_warn(gt, "failed to create RC6p sysfs files (%pe)\n", ERR_PTR(ret)); 304 } 305 306 if (IS_VALLEYVIEW(gt->i915) || IS_CHERRYVIEW(gt->i915)) { 307 ret = __intel_gt_sysfs_create_group(kobj, media_rc6_attr_group); 308 if (ret) 309 gt_warn(gt, "failed to create media RC6 sysfs files (%pe)\n", ERR_PTR(ret)); 310 } 311 } 312 313 static u32 __act_freq_mhz_show(struct intel_gt *gt) 314 { 315 return intel_rps_read_actual_frequency(>->rps); 316 } 317 318 static u32 __cur_freq_mhz_show(struct intel_gt *gt) 319 { 320 return intel_rps_get_requested_frequency(>->rps); 321 } 322 323 static u32 __boost_freq_mhz_show(struct intel_gt *gt) 324 { 325 return intel_rps_get_boost_frequency(>->rps); 326 } 327 328 static int __boost_freq_mhz_store(struct intel_gt *gt, u32 val) 329 { 330 return intel_rps_set_boost_frequency(>->rps, val); 331 } 332 333 static u32 __RP0_freq_mhz_show(struct intel_gt *gt) 334 { 335 return intel_rps_get_rp0_frequency(>->rps); 336 } 337 338 static u32 __RPn_freq_mhz_show(struct intel_gt *gt) 339 { 340 return intel_rps_get_rpn_frequency(>->rps); 341 } 342 343 static u32 __RP1_freq_mhz_show(struct intel_gt *gt) 344 { 345 return intel_rps_get_rp1_frequency(>->rps); 346 } 347 348 static u32 __max_freq_mhz_show(struct intel_gt *gt) 349 { 350 return intel_rps_get_max_frequency(>->rps); 351 } 352 353 static int __set_max_freq(struct intel_gt *gt, u32 val) 354 { 355 return intel_rps_set_max_frequency(>->rps, val); 356 } 357 358 static u32 __min_freq_mhz_show(struct intel_gt *gt) 359 { 360 return intel_rps_get_min_frequency(>->rps); 361 } 362 363 static int __set_min_freq(struct intel_gt *gt, u32 val) 364 { 365 return intel_rps_set_min_frequency(>->rps, val); 366 } 367 368 static u32 __vlv_rpe_freq_mhz_show(struct intel_gt *gt) 369 { 370 struct intel_rps *rps = >->rps; 371 372 return intel_gpu_freq(rps, rps->efficient_freq); 373 } 374 375 INTEL_GT_SYSFS_SHOW_MAX(act_freq_mhz); 376 INTEL_GT_SYSFS_SHOW_MAX(boost_freq_mhz); 377 INTEL_GT_SYSFS_SHOW_MAX(cur_freq_mhz); 378 INTEL_GT_SYSFS_SHOW_MAX(RP0_freq_mhz); 379 INTEL_GT_SYSFS_SHOW_MAX(RP1_freq_mhz); 380 INTEL_GT_SYSFS_SHOW_MAX(RPn_freq_mhz); 381 INTEL_GT_SYSFS_SHOW_MAX(max_freq_mhz); 382 INTEL_GT_SYSFS_SHOW_MIN(min_freq_mhz); 383 INTEL_GT_SYSFS_SHOW_MAX(vlv_rpe_freq_mhz); 384 INTEL_GT_SYSFS_STORE(boost_freq_mhz, __boost_freq_mhz_store); 385 INTEL_GT_SYSFS_STORE(max_freq_mhz, __set_max_freq); 386 INTEL_GT_SYSFS_STORE(min_freq_mhz, __set_min_freq); 387 388 #define INTEL_GT_RPS_SYSFS_ATTR(_name, _mode, _show, _store, _show_dev, _store_dev) \ 389 static struct device_attribute dev_attr_gt_##_name = __ATTR(gt_##_name, _mode, \ 390 _show_dev, _store_dev); \ 391 static struct kobj_attribute attr_rps_##_name = __ATTR(rps_##_name, _mode, \ 392 _show, _store) 393 394 #define INTEL_GT_RPS_SYSFS_ATTR_RO(_name) \ 395 INTEL_GT_RPS_SYSFS_ATTR(_name, 0444, _name##_show, NULL, \ 396 _name##_dev_show, NULL) 397 #define INTEL_GT_RPS_SYSFS_ATTR_RW(_name) \ 398 INTEL_GT_RPS_SYSFS_ATTR(_name, 0644, _name##_show, _name##_store, \ 399 _name##_dev_show, _name##_dev_store) 400 401 /* The below macros generate static structures */ 402 INTEL_GT_RPS_SYSFS_ATTR_RO(act_freq_mhz); 403 INTEL_GT_RPS_SYSFS_ATTR_RO(cur_freq_mhz); 404 INTEL_GT_RPS_SYSFS_ATTR_RW(boost_freq_mhz); 405 INTEL_GT_RPS_SYSFS_ATTR_RO(RP0_freq_mhz); 406 INTEL_GT_RPS_SYSFS_ATTR_RO(RP1_freq_mhz); 407 INTEL_GT_RPS_SYSFS_ATTR_RO(RPn_freq_mhz); 408 INTEL_GT_RPS_SYSFS_ATTR_RW(max_freq_mhz); 409 INTEL_GT_RPS_SYSFS_ATTR_RW(min_freq_mhz); 410 INTEL_GT_RPS_SYSFS_ATTR_RO(vlv_rpe_freq_mhz); 411 412 #define GEN6_ATTR(p, s) { \ 413 &p##attr_##s##_act_freq_mhz.attr, \ 414 &p##attr_##s##_cur_freq_mhz.attr, \ 415 &p##attr_##s##_boost_freq_mhz.attr, \ 416 &p##attr_##s##_max_freq_mhz.attr, \ 417 &p##attr_##s##_min_freq_mhz.attr, \ 418 &p##attr_##s##_RP0_freq_mhz.attr, \ 419 &p##attr_##s##_RP1_freq_mhz.attr, \ 420 &p##attr_##s##_RPn_freq_mhz.attr, \ 421 NULL, \ 422 } 423 424 #define GEN6_RPS_ATTR GEN6_ATTR(, rps) 425 #define GEN6_GT_ATTR GEN6_ATTR(dev_, gt) 426 427 static const struct attribute * const gen6_rps_attrs[] = GEN6_RPS_ATTR; 428 static const struct attribute * const gen6_gt_attrs[] = GEN6_GT_ATTR; 429 430 static ssize_t punit_req_freq_mhz_show(struct kobject *kobj, 431 struct kobj_attribute *attr, 432 char *buff) 433 { 434 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 435 u32 preq = intel_rps_read_punit_req_frequency(>->rps); 436 437 return sysfs_emit(buff, "%u\n", preq); 438 } 439 440 static ssize_t slpc_ignore_eff_freq_show(struct kobject *kobj, 441 struct kobj_attribute *attr, 442 char *buff) 443 { 444 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 445 struct intel_guc_slpc *slpc = >_to_guc(gt)->slpc; 446 447 return sysfs_emit(buff, "%u\n", slpc->ignore_eff_freq); 448 } 449 450 static ssize_t slpc_ignore_eff_freq_store(struct kobject *kobj, 451 struct kobj_attribute *attr, 452 const char *buff, size_t count) 453 { 454 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 455 struct intel_guc_slpc *slpc = >_to_guc(gt)->slpc; 456 int err; 457 u32 val; 458 459 err = kstrtou32(buff, 0, &val); 460 if (err) 461 return err; 462 463 err = intel_guc_slpc_set_ignore_eff_freq(slpc, val); 464 return err ?: count; 465 } 466 467 struct intel_gt_bool_throttle_attr { 468 struct attribute attr; 469 ssize_t (*show)(struct kobject *kobj, struct kobj_attribute *attr, 470 char *buf); 471 i915_reg_t (*reg32)(struct intel_gt *gt); 472 u32 mask; 473 }; 474 475 static ssize_t throttle_reason_bool_show(struct kobject *kobj, 476 struct kobj_attribute *attr, 477 char *buff) 478 { 479 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 480 struct intel_gt_bool_throttle_attr *t_attr = 481 (struct intel_gt_bool_throttle_attr *) attr; 482 bool val = rps_read_mask_mmio(>->rps, t_attr->reg32(gt), t_attr->mask); 483 484 return sysfs_emit(buff, "%u\n", val); 485 } 486 487 #define INTEL_GT_RPS_BOOL_ATTR_RO(sysfs_func__, mask__) \ 488 struct intel_gt_bool_throttle_attr attr_##sysfs_func__ = { \ 489 .attr = { .name = __stringify(sysfs_func__), .mode = 0444 }, \ 490 .show = throttle_reason_bool_show, \ 491 .reg32 = intel_gt_perf_limit_reasons_reg, \ 492 .mask = mask__, \ 493 } 494 495 INTEL_GT_ATTR_RO(punit_req_freq_mhz); 496 static INTEL_GT_RPS_BOOL_ATTR_RO(throttle_reason_status, GT0_PERF_LIMIT_REASONS_MASK); 497 static INTEL_GT_RPS_BOOL_ATTR_RO(throttle_reason_pl1, POWER_LIMIT_1_MASK); 498 static INTEL_GT_RPS_BOOL_ATTR_RO(throttle_reason_pl2, POWER_LIMIT_2_MASK); 499 static INTEL_GT_RPS_BOOL_ATTR_RO(throttle_reason_pl4, POWER_LIMIT_4_MASK); 500 static INTEL_GT_RPS_BOOL_ATTR_RO(throttle_reason_thermal, THERMAL_LIMIT_MASK); 501 static INTEL_GT_RPS_BOOL_ATTR_RO(throttle_reason_prochot, PROCHOT_MASK); 502 static INTEL_GT_RPS_BOOL_ATTR_RO(throttle_reason_ratl, RATL_MASK); 503 static INTEL_GT_RPS_BOOL_ATTR_RO(throttle_reason_vr_thermalert, VR_THERMALERT_MASK); 504 static INTEL_GT_RPS_BOOL_ATTR_RO(throttle_reason_vr_tdc, VR_TDC_MASK); 505 506 static const struct attribute *throttle_reason_attrs[] = { 507 &attr_throttle_reason_status.attr, 508 &attr_throttle_reason_pl1.attr, 509 &attr_throttle_reason_pl2.attr, 510 &attr_throttle_reason_pl4.attr, 511 &attr_throttle_reason_thermal.attr, 512 &attr_throttle_reason_prochot.attr, 513 &attr_throttle_reason_ratl.attr, 514 &attr_throttle_reason_vr_thermalert.attr, 515 &attr_throttle_reason_vr_tdc.attr, 516 NULL 517 }; 518 519 /* 520 * Scaling for multipliers (aka frequency factors). 521 * The format of the value in the register is u8.8. 522 * 523 * The presentation to userspace is inspired by the perf event framework. 524 * See: 525 * Documentation/ABI/testing/sysfs-bus-event_source-devices-events 526 * for description of: 527 * /sys/bus/event_source/devices/<pmu>/events/<event>.scale 528 * 529 * Summary: Expose two sysfs files for each multiplier. 530 * 531 * 1. File <attr> contains a raw hardware value. 532 * 2. File <attr>.scale contains the multiplicative scale factor to be 533 * used by userspace to compute the actual value. 534 * 535 * So userspace knows that to get the frequency_factor it multiplies the 536 * provided value by the specified scale factor and vice-versa. 537 * 538 * That way there is no precision loss in the kernel interface and API 539 * is future proof should one day the hardware register change to u16.u16, 540 * on some platform. (Or any other fixed point representation.) 541 * 542 * Example: 543 * File <attr> contains the value 2.5, represented as u8.8 0x0280, which 544 * is comprised of: 545 * - an integer part of 2 546 * - a fractional part of 0x80 (representing 0x80 / 2^8 == 0x80 / 256). 547 * File <attr>.scale contains a string representation of floating point 548 * value 0.00390625 (which is (1 / 256)). 549 * Userspace computes the actual value: 550 * 0x0280 * 0.00390625 -> 2.5 551 * or converts an actual value to the value to be written into <attr>: 552 * 2.5 / 0.00390625 -> 0x0280 553 */ 554 555 #define U8_8_VAL_MASK 0xffff 556 #define U8_8_SCALE_TO_VALUE "0.00390625" 557 558 static ssize_t freq_factor_scale_show(struct kobject *kobj, 559 struct kobj_attribute *attr, 560 char *buff) 561 { 562 return sysfs_emit(buff, "%s\n", U8_8_SCALE_TO_VALUE); 563 } 564 565 static u32 media_ratio_mode_to_factor(u32 mode) 566 { 567 /* 0 -> 0, 1 -> 256, 2 -> 128 */ 568 return !mode ? mode : 256 / mode; 569 } 570 571 static ssize_t media_freq_factor_show(struct kobject *kobj, 572 struct kobj_attribute *attr, 573 char *buff) 574 { 575 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 576 intel_wakeref_t wakeref; 577 u32 mode; 578 579 /* 580 * Retrieve media_ratio_mode from GEN6_RPNSWREQ bit 13 set by 581 * GuC. GEN6_RPNSWREQ:13 value 0 represents 1:2 and 1 represents 1:1 582 */ 583 with_intel_runtime_pm(gt->uncore->rpm, wakeref) 584 mode = intel_uncore_read(gt->uncore, GEN6_RPNSWREQ); 585 586 mode = REG_FIELD_GET(GEN12_MEDIA_FREQ_RATIO, mode) ? 587 SLPC_MEDIA_RATIO_MODE_FIXED_ONE_TO_ONE : 588 SLPC_MEDIA_RATIO_MODE_FIXED_ONE_TO_TWO; 589 590 return sysfs_emit(buff, "%u\n", media_ratio_mode_to_factor(mode)); 591 } 592 593 static ssize_t media_freq_factor_store(struct kobject *kobj, 594 struct kobj_attribute *attr, 595 const char *buff, size_t count) 596 { 597 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 598 struct intel_guc_slpc *slpc = >_to_guc(gt)->slpc; 599 u32 factor, mode; 600 int err; 601 602 err = kstrtou32(buff, 0, &factor); 603 if (err) 604 return err; 605 606 for (mode = SLPC_MEDIA_RATIO_MODE_DYNAMIC_CONTROL; 607 mode <= SLPC_MEDIA_RATIO_MODE_FIXED_ONE_TO_TWO; mode++) 608 if (factor == media_ratio_mode_to_factor(mode)) 609 break; 610 611 if (mode > SLPC_MEDIA_RATIO_MODE_FIXED_ONE_TO_TWO) 612 return -EINVAL; 613 614 err = intel_guc_slpc_set_media_ratio_mode(slpc, mode); 615 if (!err) { 616 slpc->media_ratio_mode = mode; 617 DRM_DEBUG("Set slpc->media_ratio_mode to %d", mode); 618 } 619 return err ?: count; 620 } 621 622 static ssize_t media_RP0_freq_mhz_show(struct kobject *kobj, 623 struct kobj_attribute *attr, 624 char *buff) 625 { 626 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 627 u32 val; 628 int err; 629 630 err = snb_pcode_read_p(gt->uncore, XEHP_PCODE_FREQUENCY_CONFIG, 631 PCODE_MBOX_FC_SC_READ_FUSED_P0, 632 PCODE_MBOX_DOMAIN_MEDIAFF, &val); 633 634 if (err) 635 return err; 636 637 /* Fused media RP0 read from pcode is in units of 50 MHz */ 638 val *= GT_FREQUENCY_MULTIPLIER; 639 640 return sysfs_emit(buff, "%u\n", val); 641 } 642 643 static ssize_t media_RPn_freq_mhz_show(struct kobject *kobj, 644 struct kobj_attribute *attr, 645 char *buff) 646 { 647 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 648 u32 val; 649 int err; 650 651 err = snb_pcode_read_p(gt->uncore, XEHP_PCODE_FREQUENCY_CONFIG, 652 PCODE_MBOX_FC_SC_READ_FUSED_PN, 653 PCODE_MBOX_DOMAIN_MEDIAFF, &val); 654 655 if (err) 656 return err; 657 658 /* Fused media RPn read from pcode is in units of 50 MHz */ 659 val *= GT_FREQUENCY_MULTIPLIER; 660 661 return sysfs_emit(buff, "%u\n", val); 662 } 663 664 INTEL_GT_ATTR_RW(media_freq_factor); 665 static struct kobj_attribute attr_media_freq_factor_scale = 666 __ATTR(media_freq_factor.scale, 0444, freq_factor_scale_show, NULL); 667 INTEL_GT_ATTR_RO(media_RP0_freq_mhz); 668 INTEL_GT_ATTR_RO(media_RPn_freq_mhz); 669 670 INTEL_GT_ATTR_RW(slpc_ignore_eff_freq); 671 672 static const struct attribute *media_perf_power_attrs[] = { 673 &attr_media_freq_factor.attr, 674 &attr_media_freq_factor_scale.attr, 675 &attr_media_RP0_freq_mhz.attr, 676 &attr_media_RPn_freq_mhz.attr, 677 NULL 678 }; 679 680 static ssize_t 681 rps_up_threshold_pct_show(struct kobject *kobj, struct kobj_attribute *attr, 682 char *buf) 683 { 684 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 685 struct intel_rps *rps = >->rps; 686 687 return sysfs_emit(buf, "%u\n", intel_rps_get_up_threshold(rps)); 688 } 689 690 static ssize_t 691 rps_up_threshold_pct_store(struct kobject *kobj, struct kobj_attribute *attr, 692 const char *buf, size_t count) 693 { 694 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 695 struct intel_rps *rps = >->rps; 696 int ret; 697 u8 val; 698 699 ret = kstrtou8(buf, 10, &val); 700 if (ret) 701 return ret; 702 703 ret = intel_rps_set_up_threshold(rps, val); 704 705 return ret == 0 ? count : ret; 706 } 707 708 static struct kobj_attribute rps_up_threshold_pct = 709 __ATTR(rps_up_threshold_pct, 710 0664, 711 rps_up_threshold_pct_show, 712 rps_up_threshold_pct_store); 713 714 static ssize_t 715 rps_down_threshold_pct_show(struct kobject *kobj, struct kobj_attribute *attr, 716 char *buf) 717 { 718 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 719 struct intel_rps *rps = >->rps; 720 721 return sysfs_emit(buf, "%u\n", intel_rps_get_down_threshold(rps)); 722 } 723 724 static ssize_t 725 rps_down_threshold_pct_store(struct kobject *kobj, struct kobj_attribute *attr, 726 const char *buf, size_t count) 727 { 728 struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name); 729 struct intel_rps *rps = >->rps; 730 int ret; 731 u8 val; 732 733 ret = kstrtou8(buf, 10, &val); 734 if (ret) 735 return ret; 736 737 ret = intel_rps_set_down_threshold(rps, val); 738 739 return ret == 0 ? count : ret; 740 } 741 742 static struct kobj_attribute rps_down_threshold_pct = 743 __ATTR(rps_down_threshold_pct, 744 0664, 745 rps_down_threshold_pct_show, 746 rps_down_threshold_pct_store); 747 748 static const struct attribute * const gen6_gt_rps_attrs[] = { 749 &rps_up_threshold_pct.attr, 750 &rps_down_threshold_pct.attr, 751 NULL 752 }; 753 754 static ssize_t 755 default_min_freq_mhz_show(struct kobject *kobj, struct kobj_attribute *attr, char *buf) 756 { 757 struct intel_gt *gt = kobj_to_gt(kobj->parent); 758 759 return sysfs_emit(buf, "%u\n", gt->defaults.min_freq); 760 } 761 762 static struct kobj_attribute default_min_freq_mhz = 763 __ATTR(rps_min_freq_mhz, 0444, default_min_freq_mhz_show, NULL); 764 765 static ssize_t 766 default_max_freq_mhz_show(struct kobject *kobj, struct kobj_attribute *attr, char *buf) 767 { 768 struct intel_gt *gt = kobj_to_gt(kobj->parent); 769 770 return sysfs_emit(buf, "%u\n", gt->defaults.max_freq); 771 } 772 773 static struct kobj_attribute default_max_freq_mhz = 774 __ATTR(rps_max_freq_mhz, 0444, default_max_freq_mhz_show, NULL); 775 776 static ssize_t 777 default_rps_up_threshold_pct_show(struct kobject *kobj, 778 struct kobj_attribute *attr, 779 char *buf) 780 { 781 struct intel_gt *gt = kobj_to_gt(kobj->parent); 782 783 return sysfs_emit(buf, "%u\n", gt->defaults.rps_up_threshold); 784 } 785 786 static struct kobj_attribute default_rps_up_threshold_pct = 787 __ATTR(rps_up_threshold_pct, 0444, default_rps_up_threshold_pct_show, NULL); 788 789 static ssize_t 790 default_rps_down_threshold_pct_show(struct kobject *kobj, 791 struct kobj_attribute *attr, 792 char *buf) 793 { 794 struct intel_gt *gt = kobj_to_gt(kobj->parent); 795 796 return sysfs_emit(buf, "%u\n", gt->defaults.rps_down_threshold); 797 } 798 799 static struct kobj_attribute default_rps_down_threshold_pct = 800 __ATTR(rps_down_threshold_pct, 0444, default_rps_down_threshold_pct_show, NULL); 801 802 static const struct attribute * const rps_defaults_attrs[] = { 803 &default_min_freq_mhz.attr, 804 &default_max_freq_mhz.attr, 805 &default_rps_up_threshold_pct.attr, 806 &default_rps_down_threshold_pct.attr, 807 NULL 808 }; 809 810 static int intel_sysfs_rps_init(struct intel_gt *gt, struct kobject *kobj) 811 { 812 const struct attribute * const *attrs; 813 struct attribute *vlv_attr; 814 int ret; 815 816 if (GRAPHICS_VER(gt->i915) < 6) 817 return 0; 818 819 if (is_object_gt(kobj)) { 820 attrs = gen6_rps_attrs; 821 vlv_attr = &attr_rps_vlv_rpe_freq_mhz.attr; 822 } else { 823 attrs = gen6_gt_attrs; 824 vlv_attr = &dev_attr_gt_vlv_rpe_freq_mhz.attr; 825 } 826 827 ret = sysfs_create_files(kobj, attrs); 828 if (ret) 829 return ret; 830 831 if (IS_VALLEYVIEW(gt->i915) || IS_CHERRYVIEW(gt->i915)) 832 ret = sysfs_create_file(kobj, vlv_attr); 833 834 if (is_object_gt(kobj) && !intel_uc_uses_guc_slpc(>->uc)) { 835 ret = sysfs_create_files(kobj, gen6_gt_rps_attrs); 836 if (ret) 837 return ret; 838 } 839 840 return ret; 841 } 842 843 void intel_gt_sysfs_pm_init(struct intel_gt *gt, struct kobject *kobj) 844 { 845 int ret; 846 847 intel_sysfs_rc6_init(gt, kobj); 848 849 ret = intel_sysfs_rps_init(gt, kobj); 850 if (ret) 851 gt_warn(gt, "failed to create RPS sysfs files (%pe)", ERR_PTR(ret)); 852 853 /* end of the legacy interfaces */ 854 if (!is_object_gt(kobj)) 855 return; 856 857 ret = sysfs_create_file(kobj, &attr_punit_req_freq_mhz.attr); 858 if (ret) 859 gt_warn(gt, "failed to create punit_req_freq_mhz sysfs (%pe)", ERR_PTR(ret)); 860 861 if (intel_uc_uses_guc_slpc(>->uc)) { 862 ret = sysfs_create_file(kobj, &attr_slpc_ignore_eff_freq.attr); 863 if (ret) 864 gt_warn(gt, "failed to create ignore_eff_freq sysfs (%pe)", ERR_PTR(ret)); 865 } 866 867 if (i915_mmio_reg_valid(intel_gt_perf_limit_reasons_reg(gt))) { 868 ret = sysfs_create_files(kobj, throttle_reason_attrs); 869 if (ret) 870 gt_warn(gt, "failed to create throttle sysfs files (%pe)", ERR_PTR(ret)); 871 } 872 873 if (HAS_MEDIA_RATIO_MODE(gt->i915) && intel_uc_uses_guc_slpc(>->uc)) { 874 ret = sysfs_create_files(kobj, media_perf_power_attrs); 875 if (ret) 876 gt_warn(gt, "failed to create media_perf_power_attrs sysfs (%pe)\n", 877 ERR_PTR(ret)); 878 } 879 880 ret = sysfs_create_files(gt->sysfs_defaults, rps_defaults_attrs); 881 if (ret) 882 gt_warn(gt, "failed to add rps defaults (%pe)\n", ERR_PTR(ret)); 883 } 884