i915_ioctl.c 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. // SPDX-License-Identifier: MIT
  2. /*
  3. * Copyright © 2022 Intel Corporation
  4. */
  5. #include "gt/intel_engine_regs.h"
  6. #include "i915_drv.h"
  7. #include "i915_gem.h"
  8. #include "i915_ioctl.h"
  9. #include "i915_reg.h"
  10. #include "intel_runtime_pm.h"
  11. #include "intel_uncore.h"
  12. /*
  13. * This file is for small ioctl functions that are out of place everywhere else,
  14. * and not big enough to warrant a file of their own.
  15. *
  16. * This is not the dumping ground for random ioctls.
  17. */
  18. struct reg_whitelist {
  19. i915_reg_t offset_ldw;
  20. i915_reg_t offset_udw;
  21. u8 min_graphics_ver;
  22. u8 max_graphics_ver;
  23. u8 size;
  24. };
  25. static const struct reg_whitelist reg_read_whitelist[] = {
  26. {
  27. .offset_ldw = RING_TIMESTAMP(RENDER_RING_BASE),
  28. .offset_udw = RING_TIMESTAMP_UDW(RENDER_RING_BASE),
  29. .min_graphics_ver = 4,
  30. .max_graphics_ver = 12,
  31. .size = 8
  32. }
  33. };
  34. int i915_reg_read_ioctl(struct drm_device *dev,
  35. void *data, struct drm_file *unused)
  36. {
  37. struct drm_i915_private *i915 = to_i915(dev);
  38. struct intel_uncore *uncore = &i915->uncore;
  39. struct drm_i915_reg_read *reg = data;
  40. struct reg_whitelist const *entry;
  41. intel_wakeref_t wakeref;
  42. unsigned int flags;
  43. int remain;
  44. int ret = 0;
  45. entry = reg_read_whitelist;
  46. remain = ARRAY_SIZE(reg_read_whitelist);
  47. while (remain) {
  48. u32 entry_offset = i915_mmio_reg_offset(entry->offset_ldw);
  49. GEM_BUG_ON(!is_power_of_2(entry->size));
  50. GEM_BUG_ON(entry->size > 8);
  51. GEM_BUG_ON(entry_offset & (entry->size - 1));
  52. if (IS_GRAPHICS_VER(i915, entry->min_graphics_ver, entry->max_graphics_ver) &&
  53. entry_offset == (reg->offset & -entry->size))
  54. break;
  55. entry++;
  56. remain--;
  57. }
  58. if (!remain)
  59. return -EINVAL;
  60. flags = reg->offset & (entry->size - 1);
  61. with_intel_runtime_pm(&i915->runtime_pm, wakeref) {
  62. if (entry->size == 8 && flags == I915_REG_READ_8B_WA)
  63. reg->val = intel_uncore_read64_2x32(uncore,
  64. entry->offset_ldw,
  65. entry->offset_udw);
  66. else if (entry->size == 8 && flags == 0)
  67. reg->val = intel_uncore_read64(uncore,
  68. entry->offset_ldw);
  69. else if (entry->size == 4 && flags == 0)
  70. reg->val = intel_uncore_read(uncore, entry->offset_ldw);
  71. else if (entry->size == 2 && flags == 0)
  72. reg->val = intel_uncore_read16(uncore,
  73. entry->offset_ldw);
  74. else if (entry->size == 1 && flags == 0)
  75. reg->val = intel_uncore_read8(uncore,
  76. entry->offset_ldw);
  77. else
  78. ret = -EINVAL;
  79. }
  80. return ret;
  81. }