1. 08 5月, 2015 1 次提交
  2. 16 4月, 2015 2 次提交
  3. 15 4月, 2015 1 次提交
    • R
      drm/i915: PSR: deprecate link_standby support for core platforms. · 89251b17
      Rodrigo Vivi 提交于
      On Haswell and Broadwell with link in standby when exit event happens
      between vblank and VSC packet, PSR exit on panel but DPA transmitter
      still sends black pixel. When this condition hits, panel will intermittently
      display black frame.
      
      The known W/A for this case involve the of single_frame update
      that isn't supported on Haswell and to be supported on Broadwell
      3 other workarounds would be required. So it is better and safe to
      just deprecate link_standby for now.
      
      Also, link fully off saves more power than link_standby and afwk
      no OEM is requesting link standby on VBT. There is no reason for that.
      
      For Skylake let's just consider it behaves like Broadwell until
      we prove otherwise.
      
      v2: Fix commit message (Durga).
      
      v3: Fix conflict with PSR2.
      
      Reference: HSD: bdwgfx/1912559
      Signed-off-by: NRodrigo Vivi <rodrigo.vivi@intel.com>
      Reviewed-by: NDurgadoss R <durgadoss.r@intel.com>
      Signed-off-by: NRodrigo Vivi <rodrigo.vivi@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      89251b17
  4. 13 4月, 2015 1 次提交
  5. 10 4月, 2015 6 次提交
  6. 09 4月, 2015 2 次提交
  7. 07 4月, 2015 1 次提交
    • J
      drm/i915: add i915 specific connector debugfs file for DPCD · aa7471d2
      Jani Nikula 提交于
      Occasionally it would be interesting to read some of the DPCD registers
      for debug purposes, without having to resort to logging. Add an i915
      specific i915_dpcd debugfs file for DP and eDP connectors to dump parts
      of the DPCD. Currently the DPCD addresses to be dumped are statically
      configured, and more can be added trivially.
      
      The implementation also makes it relatively easy to add other i915 and
      connector specific debugfs files in the future, as necessary.
      
      This is currently i915 specific just because there's no generic way to
      do AUX transactions given just a drm_connector. However it's all pretty
      straightforward to port to other drivers.
      
      v2: Add more DPCD registers to dump.
      Signed-off-by: NJani Nikula <jani.nikula@intel.com>
      Reviewed-by: NBob Paauwe <bob.j.paauwe@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      aa7471d2
  8. 01 4月, 2015 1 次提交
  9. 20 3月, 2015 2 次提交
  10. 18 3月, 2015 8 次提交
  11. 05 3月, 2015 1 次提交
  12. 26 2月, 2015 1 次提交
    • A
      drm/i915: Removed the read of RP_STATE_CAP from sysfs/debugfs functions · bc4d91f6
      Akash Goel 提交于
      The frequency values(Rp0, Rp1, Rpn) reported by RP_STATE_CAP register
      are stored, initially by the Driver, inside the dev_priv->rps structure.
      Since these values are expected to remain same throughout, there is no real
      need to read this register, on dynamic basis, from certain debugfs/sysfs
      functions and the values can be instead retrieved from the dev_priv->rps
      structure when needed.
      For the i915_frequency_info debugfs interface, the frequency values from the
      RP_STATE_CAP register only should be used, to indicate the actual Hw state,
      since it is principally used for the debugging purpose.
      
      v2: Reverted the changes in i915_frequency_info function, to continue report
          back the frequency values, as per the actual Hw state (Chris)
      Signed-off-by: NAkash Goel <akash.goel@intel.com>
      Reviewed-by: NChris Wilson <chris@chris-wilson.co.uk>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      bc4d91f6
  13. 25 2月, 2015 2 次提交
  14. 24 2月, 2015 2 次提交
    • J
      drm/i915/skl: Add SKL HW status to SSEU status · 7f992aba
      Jeff McGee 提交于
      Add a new section to the 'i915_sseu_status' debugfs entry to
      report the currently enabled counts of slice, subslice, and
      execution units on the device. The count of enabled subslice
      per slice represents the most enabled subslice on any one
      slice for devices where imbalances may exist. Similarly, the
      count of enabled EU per subslice represents the most enabled
      EU on any one subslice.
      
      Collect this device status for Skylake by reading the Gen9
      power gate control ack message registers. Power gate control
      operates on EU in pairs, therefore our reported counts of
      enabled EU can be overestimated by one for each pair in which
      one EU is fused-off.
      Signed-off-by: NJeff McGee <jeff.mcgee@intel.com>
      Reviewed-by: NDamien Lespiau <damien.lespiau@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      7f992aba
    • J
      drm/i915/skl: Determine SKL slice/subslice/EU info · 3873218f
      Jeff McGee 提交于
      Read fuse registers to determine the available slice total,
      subslice total, subslice per slice, EU total, and EU per subslice
      counts of the SKL device. The EU per subslice attribute is more
      precisely defined as the maximum EU available on any one subslice,
      since available EU counts may vary across subslices due to fusing.
      Set flags indicating the SKL device's slice/subslice/EU (SSEU)
      power gating capability. Make all values available via debugfs
      entry 'i915_sseu_status'.
      
      v2: Several small clean-ups suggested by Damien. Most notably,
          used smaller types for the new device info fields to reduce
          memory usage and improved the clarity/readability of the
          method used to extract attribute values from the fuse
          registers.
      Signed-off-by: NJeff McGee <jeff.mcgee@intel.com>
      Reviewed-by: NDamien Lespiau <damien.lespiau@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      3873218f
  15. 23 2月, 2015 1 次提交
  16. 14 2月, 2015 2 次提交
  17. 09 2月, 2015 1 次提交
  18. 30 1月, 2015 1 次提交
    • M
      drm/i915: Remove nested work in gpu error handling · b8d24a06
      Mika Kuoppala 提交于
      Now when we declare gpu errors only through our own dedicated
      hangcheck workqueue there is no need to have a separate workqueue
      for handling the resetting and waking up the clients as the deadlock
      concerns are no more.
      
      The only exception is i915_debugfs::i915_set_wedged, which triggers
      error handling through process context. However as this is only used through
      test harness it is responsibility for test harness not to introduce hangs
      through both debug interface and through hangcheck mechanism at the same time.
      
      Remove gpu_error.work and let the hangcheck work do the tasks it used to.
      
      v2: Add a big warning sign into i915_debugfs::i915_set_wedged (Chris)
      
      Cc: Chris Wilson <chris@chris-wilson.co.uk>
      Signed-off-by: NMika Kuoppala <mika.kuoppala@intel.com>
      Reviewed-by: NChris Wilson <chris@chris-wilson.co.uk>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      b8d24a06
  19. 29 1月, 2015 2 次提交
  20. 27 1月, 2015 2 次提交
    • V
      drm/i915: Use intel_gpu_freq() and intel_freq_opcode() · 7c59a9c1
      Ville Syrjälä 提交于
      Replace all the vlv_gpu_freq(), vlv_freq_opcode(),
      *GT_FREQUENCY_MULTIPLIER, and /GT_FREQUENCY_MULTIPLIER instances
      with intel_gpu_freq() and intel_freq_opcode() calls.
      
      Most of the change was performed with the following semantic patch:
      @@
      expression E;
      @@
      (
      - E * GT_FREQUENCY_MULTIPLIER
      + intel_gpu_freq(dev_priv, E)
      |
      - E *= GT_FREQUENCY_MULTIPLIER
      + E = intel_gpu_freq(dev_priv, E)
      |
      - E /= GT_FREQUENCY_MULTIPLIER
      + E = intel_freq_opcode(dev_priv, E)
      |
      - do_div(E, GT_FREQUENCY_MULTIPLIER)
      + E = intel_freq_opcode(dev_priv, E)
      )
      
      @@
      expression E1, E2;
      @@
      (
      - vlv_gpu_freq(E1, E2)
      + intel_gpu_freq(E1, E2)
      |
      - vlv_freq_opcode(E1, E2)
      + intel_freq_opcode(E1, E2)
      )
      
      @@
      expression E1, E2, E3, E4;
      @@
      (
      - if (IS_VALLEYVIEW(E1)) {
      -  E2 = intel_gpu_freq(E3, E4);
      - } else {
      -  E2 = intel_gpu_freq(E3, E4);
      - }
      + E2 = intel_gpu_freq(E3, E4);
      |
      - if (IS_VALLEYVIEW(E1)) {
      -  E2 = intel_freq_opcode(E3, E4);
      - } else {
      -  E2 = intel_freq_opcode(E3, E4);
      - }
      + E2 = intel_freq_opcode(E3, E4);
      )
      
      One hunk was manually undone as intel_gpu_freq() ended up
      calling itself. Supposedly it would be possible to exclude
      certain functions via !=~, but I couldn't get that to work.
      
      Also the removal of vlv_gpu_freq() and vlv_opcode_freq() compat
      wrappers was done manually.
      Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Reviewed-by: NChris Wilson <chris@chris-wilson.co.uk>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      7c59a9c1
    • S
      drm/i915/skl: Adding power domains for AUX controllers · 1407121a
      Satheeshakrishna M 提交于
      Adding new power doamins for AUX controllers
      
      v2: Added new power domains in power_domain_str per Imre's comment
      
      v3: Added AUX power domains to older platforms
      
      v4: Rebase on top of POWER_DOMAIN_PLLS.
      
      v5: Modified to address review comments from Imre
      Reviewed-by: NImre Deak <imre.deak@intel.com>
      Signed-off-by: NSatheeshakrishna M <satheeshakrishna.m@intel.com>
      Signed-off-by: Damien Lespiau <damien.lespiau@intel.com> (v3)
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      Signed-off-by: NDamien Lespiau <damien.lespiau@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      1407121a