i915_params.c 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. /*
  2. * Copyright © 2014 Intel Corporation
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a
  5. * copy of this software and associated documentation files (the
  6. * "Software"), to deal in the Software without restriction, including
  7. * without limitation the rights to use, copy, modify, merge, publish,
  8. * distribute, sub license, and/or sell copies of the Software, and to
  9. * permit persons to whom the Software is furnished to do so, subject to
  10. * the following conditions:
  11. *
  12. * The above copyright notice and this permission notice (including the
  13. * next paragraph) shall be included in all copies or substantial portions
  14. * of the Software.
  15. *
  16. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  17. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  18. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  19. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  20. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  21. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
  22. * IN THE SOFTWARE.
  23. */
  24. #include <drm/drm_print.h>
  25. #include "i915_params.h"
  26. #include "i915_drv.h"
  27. #define i915_param_named(name, T, perm, desc) \
  28. module_param_named(name, i915_modparams.name, T, perm); \
  29. MODULE_PARM_DESC(name, desc)
  30. #define i915_param_named_unsafe(name, T, perm, desc) \
  31. module_param_named_unsafe(name, i915_modparams.name, T, perm); \
  32. MODULE_PARM_DESC(name, desc)
  33. struct i915_params i915_modparams __read_mostly = {
  34. #define MEMBER(T, member, value) .member = (value),
  35. I915_PARAMS_FOR_EACH(MEMBER)
  36. #undef MEMBER
  37. };
  38. i915_param_named(modeset, int, 0400,
  39. "Use kernel modesetting [KMS] (0=disable, "
  40. "1=on, -1=force vga console preference [default])");
  41. i915_param_named_unsafe(enable_dc, int, 0400,
  42. "Enable power-saving display C-states. "
  43. "(-1=auto [default]; 0=disable; 1=up to DC5; 2=up to DC6)");
  44. i915_param_named_unsafe(enable_fbc, int, 0600,
  45. "Enable frame buffer compression for power savings "
  46. "(default: -1 (use per-chip default))");
  47. i915_param_named_unsafe(lvds_channel_mode, int, 0400,
  48. "Specify LVDS channel mode "
  49. "(0=probe BIOS [default], 1=single-channel, 2=dual-channel)");
  50. i915_param_named_unsafe(panel_use_ssc, int, 0600,
  51. "Use Spread Spectrum Clock with panels [LVDS/eDP] "
  52. "(default: auto from VBT)");
  53. i915_param_named_unsafe(vbt_sdvo_panel_type, int, 0400,
  54. "Override/Ignore selection of SDVO panel mode in the VBT "
  55. "(-2=ignore, -1=auto [default], index in VBT BIOS table)");
  56. i915_param_named_unsafe(reset, int, 0600,
  57. "Attempt GPU resets (0=disabled, 1=full gpu reset, 2=engine reset [default])");
  58. i915_param_named_unsafe(vbt_firmware, charp, 0400,
  59. "Load VBT from specified file under /lib/firmware");
  60. #if IS_ENABLED(CONFIG_DRM_I915_CAPTURE_ERROR)
  61. i915_param_named(error_capture, bool, 0600,
  62. "Record the GPU state following a hang. "
  63. "This information in /sys/class/drm/card<N>/error is vital for "
  64. "triaging and debugging hangs.");
  65. #endif
  66. i915_param_named_unsafe(enable_hangcheck, bool, 0644,
  67. "Periodically check GPU activity for detecting hangs. "
  68. "WARNING: Disabling this can cause system wide hangs. "
  69. "(default: true)");
  70. i915_param_named_unsafe(enable_ppgtt, int, 0400,
  71. "Override PPGTT usage. "
  72. "(-1=auto [default], 0=disabled, 1=aliasing, 2=full, 3=full with extended address space)");
  73. i915_param_named_unsafe(enable_psr, int, 0600,
  74. "Enable PSR "
  75. "(0=disabled, 1=enabled) "
  76. "Default: -1 (use per-chip default)");
  77. i915_param_named_unsafe(alpha_support, bool, 0400,
  78. "Enable alpha quality driver support for latest hardware. "
  79. "See also CONFIG_DRM_I915_ALPHA_SUPPORT.");
  80. i915_param_named_unsafe(disable_power_well, int, 0400,
  81. "Disable display power wells when possible "
  82. "(-1=auto [default], 0=power wells always on, 1=power wells disabled when possible)");
  83. i915_param_named_unsafe(enable_ips, int, 0600, "Enable IPS (default: true)");
  84. i915_param_named(fastboot, bool, 0600,
  85. "Try to skip unnecessary mode sets at boot time (default: false)");
  86. i915_param_named_unsafe(prefault_disable, bool, 0600,
  87. "Disable page prefaulting for pread/pwrite/reloc (default:false). "
  88. "For developers only.");
  89. i915_param_named_unsafe(load_detect_test, bool, 0600,
  90. "Force-enable the VGA load detect code for testing (default:false). "
  91. "For developers only.");
  92. i915_param_named_unsafe(force_reset_modeset_test, bool, 0600,
  93. "Force a modeset during gpu reset for testing (default:false). "
  94. "For developers only.");
  95. i915_param_named_unsafe(invert_brightness, int, 0600,
  96. "Invert backlight brightness "
  97. "(-1 force normal, 0 machine defaults, 1 force inversion), please "
  98. "report PCI device ID, subsystem vendor and subsystem device ID "
  99. "to dri-devel@lists.freedesktop.org, if your machine needs it. "
  100. "It will then be included in an upcoming module version.");
  101. i915_param_named(disable_display, bool, 0400,
  102. "Disable display (default: false)");
  103. i915_param_named(mmio_debug, int, 0600,
  104. "Enable the MMIO debug code for the first N failures (default: off). "
  105. "This may negatively affect performance.");
  106. i915_param_named(verbose_state_checks, bool, 0600,
  107. "Enable verbose logs (ie. WARN_ON()) in case of unexpected hw state conditions.");
  108. i915_param_named_unsafe(nuclear_pageflip, bool, 0400,
  109. "Force enable atomic functionality on platforms that don't have full support yet.");
  110. /* WA to get away with the default setting in VBT for early platforms.Will be removed */
  111. i915_param_named_unsafe(edp_vswing, int, 0400,
  112. "Ignore/Override vswing pre-emph table selection from VBT "
  113. "(0=use value from vbt [default], 1=low power swing(200mV),"
  114. "2=default swing(400mV))");
  115. i915_param_named_unsafe(enable_guc, int, 0400,
  116. "Enable GuC load for GuC submission and/or HuC load. "
  117. "Required functionality can be selected using bitmask values. "
  118. "(-1=auto, 0=disable [default], 1=GuC submission, 2=HuC load)");
  119. i915_param_named(guc_log_level, int, 0400,
  120. "GuC firmware logging level. Requires GuC to be loaded. "
  121. "(-1=auto [default], 0=disable, 1..4=enable with verbosity min..max)");
  122. i915_param_named_unsafe(guc_firmware_path, charp, 0400,
  123. "GuC firmware path to use instead of the default one");
  124. i915_param_named_unsafe(huc_firmware_path, charp, 0400,
  125. "HuC firmware path to use instead of the default one");
  126. i915_param_named_unsafe(dmc_firmware_path, charp, 0400,
  127. "DMC firmware path to use instead of the default one");
  128. i915_param_named_unsafe(enable_dp_mst, bool, 0600,
  129. "Enable multi-stream transport (MST) for new DisplayPort sinks. (default: true)");
  130. #if IS_ENABLED(CONFIG_DRM_I915_DEBUG)
  131. i915_param_named_unsafe(inject_load_failure, uint, 0400,
  132. "Force an error after a number of failure check points (0:disabled (default), N:force failure at the Nth failure check point)");
  133. #endif
  134. i915_param_named(enable_dpcd_backlight, bool, 0600,
  135. "Enable support for DPCD backlight control (default:false)");
  136. i915_param_named(enable_gvt, bool, 0400,
  137. "Enable support for Intel GVT-g graphics virtualization host support(default:false)");
  138. static __always_inline void _print_param(struct drm_printer *p,
  139. const char *name,
  140. const char *type,
  141. const void *x)
  142. {
  143. if (!__builtin_strcmp(type, "bool"))
  144. drm_printf(p, "i915.%s=%s\n", name, yesno(*(const bool *)x));
  145. else if (!__builtin_strcmp(type, "int"))
  146. drm_printf(p, "i915.%s=%d\n", name, *(const int *)x);
  147. else if (!__builtin_strcmp(type, "unsigned int"))
  148. drm_printf(p, "i915.%s=%u\n", name, *(const unsigned int *)x);
  149. else if (!__builtin_strcmp(type, "char *"))
  150. drm_printf(p, "i915.%s=%s\n", name, *(const char **)x);
  151. else
  152. BUILD_BUG();
  153. }
  154. /**
  155. * i915_params_dump - dump i915 modparams
  156. * @params: i915 modparams
  157. * @p: the &drm_printer
  158. *
  159. * Pretty printer for i915 modparams.
  160. */
  161. void i915_params_dump(const struct i915_params *params, struct drm_printer *p)
  162. {
  163. #define PRINT(T, x, ...) _print_param(p, #x, #T, &params->x);
  164. I915_PARAMS_FOR_EACH(PRINT);
  165. #undef PRINT
  166. }