1. 05 12月, 2018 1 次提交
  2. 04 12月, 2018 5 次提交
  3. 01 12月, 2018 1 次提交
  4. 30 11月, 2018 3 次提交
  5. 29 11月, 2018 1 次提交
    • V
      drm/i915: Move ddb/wm programming into plane update/disable hooks on skl+ · ff43bc37
      Ville Syrjälä 提交于
      On SKL+ the plane WM/BUF_CFG registers are a proper part of each
      plane's register set. That means accessing them will cancel any
      pending plane update, and we would need a PLANE_SURF register write
      to arm the wm/ddb change as well.
      
      To avoid all the problems with that let's just move the wm/ddb
      programming into the plane update/disable hooks. Now all plane
      registers get written in one (hopefully atomic) operation.
      
      To make that feasible we'll move the plane ddb tracking into
      the crtc state. Watermarks were already tracked there.
      
      v2: Rebase due to input CSC
      v3: Split out a bunch of junk (Matt)
      v4: Add skl_wm_add_affected_planes() to deal with
          cursor special case and non-zero wm register reset value
      v5: Drop the unrelated for_each_intel_plane_mask() fix (Matt)
          Remove the redundant ddb memset() (Matt)
      
      Cc: Matt Roper <matthew.d.roper@intel.com>
      Cc: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
      Reviewed-by: Maarten Lankhorst <maarten.lankhorst@linux.intel.com> #v3
      Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/20181127165900.31298-1-ville.syrjala@linux.intel.com
      ff43bc37
  6. 23 11月, 2018 2 次提交
  7. 22 11月, 2018 2 次提交
  8. 20 11月, 2018 1 次提交
  9. 19 11月, 2018 1 次提交
  10. 15 11月, 2018 3 次提交
  11. 13 11月, 2018 1 次提交
  12. 09 11月, 2018 2 次提交
  13. 08 11月, 2018 1 次提交
    • L
      drm/i915: Add short HPD IRQ storm detection for non-MST systems · 9a64c650
      Lyude Paul 提交于
      Unfortunately, it seems that the HPD IRQ storm problem from the early
      days of Intel GPUs was never entirely solved, only mostly. Within the
      last couple of days, I got a bug report from one of our customers who
      had been having issues with their machine suddenly booting up very
      slowly after having updated. The amount of time it took to boot went
      from around 30 seconds, to over 6 minutes consistently.
      
      After some investigation, I discovered that i915 was reporting massive
      amounts of short HPD IRQ spam on this system from the DisplayPort port,
      despite there not being anything actually connected. The symptoms would
      start with one "long" HPD IRQ being detected at boot:
      
      [    1.891398] [drm:intel_get_hpd_pins [i915]] hotplug event received, stat 0x00440000, dig 0x00440000, pins 0x000000a0
      [    1.891436] [drm:intel_hpd_irq_handler [i915]] digital hpd port B - long
      [    1.891472] [drm:intel_hpd_irq_handler [i915]] Received HPD interrupt on PIN 5 - cnt: 0
      [    1.891508] [drm:intel_hpd_irq_handler [i915]] digital hpd port D - long
      [    1.891544] [drm:intel_hpd_irq_handler [i915]] Received HPD interrupt on PIN 7 - cnt: 0
      [    1.891592] [drm:intel_dp_hpd_pulse [i915]] got hpd irq on port B - long
      [    1.891628] [drm:intel_dp_hpd_pulse [i915]] got hpd irq on port D - long
      …
      
      followed by constant short IRQs afterwards:
      
      [    1.895091] [drm:intel_encoder_hotplug [i915]] [CONNECTOR:66:DP-1] status updated from unknown to disconnected
      [    1.895129] [drm:i915_hotplug_work_func [i915]] Connector DP-3 (pin 7) received hotplug event.
      [    1.895165] [drm:intel_dp_detect [i915]] [CONNECTOR:72:DP-3]
      [    1.895275] [drm:intel_get_hpd_pins [i915]] hotplug event received, stat 0x00200000, dig 0x00200000, pins 0x00000080
      [    1.895312] [drm:intel_hpd_irq_handler [i915]] digital hpd port D - short
      [    1.895762] [drm:intel_get_hpd_pins [i915]] hotplug event received, stat 0x00200000, dig 0x00200000, pins 0x00000080
      [    1.895799] [drm:intel_hpd_irq_handler [i915]] digital hpd port D - short
      [    1.896239] [drm:intel_dp_aux_xfer [i915]] dp_aux_ch timeout status 0x71450085
      [    1.896293] [drm:intel_get_hpd_pins [i915]] hotplug event received, stat 0x00200000, dig 0x00200000, pins 0x00000080
      [    1.896330] [drm:intel_hpd_irq_handler [i915]] digital hpd port D - short
      [    1.896781] [drm:intel_get_hpd_pins [i915]] hotplug event received, stat 0x00200000, dig 0x00200000, pins 0x00000080
      [    1.896817] [drm:intel_hpd_irq_handler [i915]] digital hpd port D - short
      [    1.897275] [drm:intel_get_hpd_pins [i915]] hotplug event received, stat 0x00200000, dig 0x00200000, pins 0x00000080
      
      The customer's system in question has a GM45 GPU, which is apparently
      well known for hotplugging storms.
      
      So, workaround this impressively broken hardware by changing the default
      HPD storm threshold from 5 to 50. Then, make long IRQs count for 10, and
      short IRQs count for 1. This makes it so that 5 long IRQs will trigger
      an HPD storm, and on systems with short HPD storm detection 50 short
      IRQs will trigger an HPD storm. 50 short IRQs amounts to 100ms of
      constant pulsing, which seems like a good middleground between being too
      sensitive and not being sensitive enough (which would cause visible
      stutters in userspace every time a storm occurs).
      
      And just to be extra safe: we don't enable this by default on systems
      with MST support. There's too high of a chance of MST support triggering
      storm detection, and systems that are new enough to support MST are a
      lot less likely to have issues with IRQ storms anyway.
      
      As a note: this patch was tested using a ThinkPad T450s and a Chamelium
      to simulate the short IRQ storms.
      
      Changes since v1:
      - Don't use two separate thresholds, just make long IRQs count for 10
        each and short IRQs count for 1. This simplifies the code a bit
        - Ville Syrjälä
      Changes since v2:
      - Document @long_hpd in intel_hpd_irq_storm_detect, no functional
        changes
      Changes since v4:
      - Remove !! in long_hpd assignment - Ville Syrjälä
      - queue_hp = true - Ville Syrjälä
      Signed-off-by: NLyude Paul <lyude@redhat.com>
      Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
      Cc: Rodrigo Vivi <rodrigo.vivi@intel.com>
      Reviewed-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/20181106213017.14563-6-lyude@redhat.com
      9a64c650
  14. 06 11月, 2018 1 次提交
  15. 02 11月, 2018 3 次提交
  16. 30 10月, 2018 1 次提交
    • R
      drm/i915: Kill GEN_FOREVER · 5bc0e89f
      Rodrigo Vivi 提交于
      commit ac657f64 ("drm/i915: Introduce IS_GEN macro") introduced
      GEN_FOREVER that was never used.
      
      My first attempt was to rename it to FOREVER since GEN is
      already part of the macro. Then I used coccinelle to change all
      -INTEL_GEN(e1) >= e2
      +INTEL_GEN_RANGE(e1, e2, FOREVER)
      -INTEL_GEN(e1) <= e2
      +INTEL_GEN_RANGE(e1, 0, e2)
      
      and I liked it.
      
      However I didn't like very much the remaining
      INTEL_GEN(dev_priv) < n
      
      and:
      INTEL_GEN(e1) < n
      INTEL_GEN_RANGE(e1, 0, n - 1)
      
      didn't make much sense either.
      
      So INTEL_GEN use for > or < seems a better unified way for unlimited
      bounds. So, no reason to keep GEN_FOREVER here.
      
      Let's kill before someone start using it.
      
      v2: Remove remaining GEN_FOREVER forgotten in a comment. (Daniel)
      
      Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
      Signed-off-by: NRodrigo Vivi <rodrigo.vivi@intel.com>
      Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      Link: https://patchwork.freedesktop.org/patch/msgid/20181026195143.20353-2-rodrigo.vivi@intel.com
      5bc0e89f
  17. 24 10月, 2018 1 次提交
  18. 23 10月, 2018 3 次提交
  19. 10 10月, 2018 1 次提交
  20. 06 10月, 2018 2 次提交
  21. 02 10月, 2018 1 次提交
  22. 01 10月, 2018 1 次提交
  23. 27 9月, 2018 2 次提交