1. 24 6月, 2016 1 次提交
    • M
      drm/atomic: Make drm_atomic_legacy_backoff reset crtc->acquire_ctx · 81e257e9
      Maarten Lankhorst 提交于
      Atomic updates may acquire more state than initially locked through
      drm_modeset_lock_crtc, running with heavy stress can cause a
      WARN_ON(crtc->acquire_ctx) in drm_modeset_lock_crtc:
      
      [  601.491296] ------------[ cut here ]------------
      [  601.491366] WARNING: CPU: 0 PID: 2411 at
      drivers/gpu/drm/drm_modeset_lock.c:191 drm_modeset_lock_crtc+0xeb/0xf0 [drm]
      [  601.491369] Modules linked in: drm i915 drm_kms_helper
      [  601.491414] CPU: 0 PID: 2411 Comm: kms_cursor_lega Tainted: G     U 4.7.0-rc4-patser+ #4798
      [  601.491417] Hardware name: Intel Corporation Skylake Client
      [  601.491420]  0000000000000000 ffff88044d153c98 ffffffff812ead28 0000000000000000
      [  601.491425]  0000000000000000 ffff88044d153cd8 ffffffff810868e6 000000bf58058030
      [  601.491431]  ffff880088b415e8 ffff880458058030 ffff88008a271548 ffff88008a271568
      [  601.491436] Call Trace:
      [  601.491443]  [<ffffffff812ead28>] dump_stack+0x4d/0x65
      [  601.491447]  [<ffffffff810868e6>] __warn+0xc6/0xe0
      [  601.491452]  [<ffffffff81086968>] warn_slowpath_null+0x18/0x20
      [  601.491472]  [<ffffffffc00d4ffb>] drm_modeset_lock_crtc+0xeb/0xf0 [drm]
      [  601.491491]  [<ffffffffc00c5526>] drm_mode_cursor_common+0x66/0x180 [drm]
      [  601.491509]  [<ffffffffc00c91cc>] drm_mode_cursor_ioctl+0x3c/0x40 [drm]
      [  601.491524]  [<ffffffffc00bc94d>] drm_ioctl+0x14d/0x530 [drm]
      [  601.491540]  [<ffffffffc00c9190>] ? drm_mode_setcrtc+0x520/0x520 [drm]
      [  601.491545]  [<ffffffff81176aeb>] ? handle_mm_fault+0x106b/0x1430
      [  601.491550]  [<ffffffff81108441>] ? stop_one_cpu+0x61/0x70
      [  601.491556]  [<ffffffff811bb71d>] do_vfs_ioctl+0x8d/0x570
      [  601.491560]  [<ffffffff81290d7e>] ? security_file_ioctl+0x3e/0x60
      [  601.491565]  [<ffffffff811bbc74>] SyS_ioctl+0x74/0x80
      [  601.491571]  [<ffffffff810e321c>] ? posix_get_monotonic_raw+0xc/0x10
      [  601.491576]  [<ffffffff8175b11b>] entry_SYSCALL_64_fastpath+0x13/0x8f
      [  601.491581] ---[ end trace 56f3d3d85f000d00 ]---
      
      For good measure, test mode_config.acquire_ctx too, although this should
      never happen.
      
      Testcase: kms_cursor_legacy
      Signed-off-by: NMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
      Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      Cc: stable@vger.kernel.org
      Signed-off-by: NDave Airlie <airlied@redhat.com>
      81e257e9
  2. 01 6月, 2016 1 次提交
  3. 18 5月, 2016 1 次提交
  4. 05 5月, 2016 2 次提交
  5. 03 5月, 2016 1 次提交
    • M
      drm/atomic: Add WARN_ON when state->acquire_ctx is not set. · 7f4eaa89
      Maarten Lankhorst 提交于
      When I was writing an atomic wrapper for rmfb, I ran into the
      following backtrace from lockdep:
      
      =============================================
      [ INFO: possible recursive locking detected ]
      4.5.0-patser+ #4696 Tainted: G     U
      ---------------------------------------------
      kworker/2:2/2608 is trying to acquire lock:
       (crtc_ww_class_mutex){+.+.+.}, at: [<ffffffffc00c9ddc>] drm_modeset_lock+0x7c/0x120 [drm]
      
      but task is already holding lock:
       (crtc_ww_class_mutex){+.+.+.}, at: [<ffffffffc00c98cd>] modeset_backoff+0x8d/0x220 [drm]
      
      other info that might help us debug this:
       Possible unsafe locking scenario:
      
             CPU0
             ----
        lock(crtc_ww_class_mutex);
        lock(crtc_ww_class_mutex);
      
       *** DEADLOCK ***
      
       May be due to missing lock nesting notation
      
      4 locks held by kworker/2:2/2608:
       #0:  ("events"){.+.+.+}, at: [<ffffffff810a5eea>] process_one_work+0x15a/0x6c0
       #1:  ((&arg.work)){+.+.+.}, at: [<ffffffff810a5eea>] process_one_work+0x15a/0x6c0
       #2:  (crtc_ww_class_acquire){+.+.+.}, at: [<ffffffffc004532a>] drm_atomic_helper_remove_fb+0x4a/0x1d0 [drm_kms_helper]
       #3:  (crtc_ww_class_mutex){+.+.+.}, at: [<ffffffffc00c98cd>] modeset_backoff+0x8d/0x220 [drm]
      
      While lockdep probably catches this bug when it happens, it's better
      to explicitly warn when state->acquire_ctx is not set.
      Signed-off-by: NMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      Link: http://patchwork.freedesktop.org/patch/msgid/1462266751-29123-1-git-send-email-maarten.lankhorst@linux.intel.com
      7f4eaa89
  6. 02 5月, 2016 1 次提交
  7. 28 4月, 2016 1 次提交
  8. 20 3月, 2016 1 次提交
  9. 08 3月, 2016 1 次提交
  10. 19 2月, 2016 1 次提交
    • M
      drm/atomic: Allow for holes in connector state, v2. · 5fff80bb
      Maarten Lankhorst 提交于
      Because we record connector_mask using 1 << drm_connector_index now
      the connector_mask should stay the same even when other connectors
      are removed. This was not the case with MST, in that case when removing
      a connector all other connectors may change their index.
      
      This is fixed by waiting until the first get_connector_state to allocate
      connector_state, and force reallocation when state is too small.
      
      As a side effect connector arrays no longer have to be preallocated,
      and can be allocated on first use which means a less allocations in
      the page flip only path.
      
      Changes since v1:
      - Whitespace. (Ville)
      - Call ida_remove when destroying the connector. (Ville)
      - u32 alloc -> int. (Ville)
      
      Fixes: 14de6c44 ("drm/atomic: Remove drm_atomic_connectors_for_crtc.")
      Signed-off-by: NMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
      Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
      Reviewed-by: NLyude <cpaul@redhat.com>
      Reviewed-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Signed-off-by: NDave Airlie <airlied@redhat.com>
      5fff80bb
  11. 25 1月, 2016 1 次提交
  12. 06 1月, 2016 1 次提交
  13. 05 1月, 2016 2 次提交
  14. 11 12月, 2015 2 次提交
  15. 08 12月, 2015 1 次提交
  16. 03 12月, 2015 1 次提交
    • T
      drm: Implement drm_modeset_lock_all_ctx() · 06eaae46
      Thierry Reding 提交于
      This function is like drm_modeset_lock_all(), but it takes the lock
      acquisition context as a parameter rather than storing it in the DRM
      device's mode_config structure.
      
      Implement drm_modeset_{,un}lock_all() in terms of the new function for
      better code reuse, and add a note to the kerneldoc that new code should
      use the new functions.
      
      v2: improve kerneldoc
      v4: rename drm_modeset_lock_all_crtcs() to drm_modeset_lock_all_ctx()
          and take mode_config's .connection_mutex instead of .mutex lock to
          avoid lock inversion (Daniel Vetter), use drm_modeset_drop_locks()
          which is now the equivalent of drm_modeset_unlock_all_ctx()
      v5: do not take the dev->mode_config.connection_mutex in
          drm_atomic_legacy_backoff() since drm_modeset_lock_all_ctx()
          already keeps it, enhance kerneldoc for drm_modeset_lock_all_ctx()
          (Daniel Vetter)
      Signed-off-by: NThierry Reding <treding@nvidia.com>
      Link: http://patchwork.freedesktop.org/patch/msgid/1449075005-13937-1-git-send-email-thierry.reding@gmail.comSigned-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      06eaae46
  17. 24 11月, 2015 2 次提交
  18. 17 11月, 2015 2 次提交
  19. 25 9月, 2015 1 次提交
  20. 08 9月, 2015 1 次提交
    • D
      drm/atomic: refuse changing CRTC for planes directly · f8aeb41c
      Daniel Vetter 提交于
      Very strictly speaking this is possible if you have special hw and
      genlocked CRTCs. In general switching a plane between two active CRTC
      just won't work so well and is probably not tested at all. Just forbid
      it.
      
      I've put this into the core since right now no helper or driver copes
      with it, no userspace has code for it and no one asks for it. Yes
      there's piles of corner-cases where this would be possible to do this
      like:
      - switch from inactive crtc to active crtc
      - switch from active crtc to inactive crtc
      - genlocked display
      - invisible plane (to do whatever)
      - idle plane hw due to dsi cmd mode/psr
      - whatever
      but looking at details it's not that easy to implement this correctly.
      Hence just put it into the core and add a comment, since the only
      userspace we have right now for atomic (weston) doesn't want to use
      direct plane switching either.
      
      v2: don't bother with complexity and just outright disallow plane
      switching without the intermediate OFF state. Simplifies drivers, we
      don't have any hw that could do it anyway and current atomic userspace
      (weston) works like this already anyway.
      
      v3: Bikeshed function name (Ville) and add comment (Rob).
      
      v4: Also bikeshed commit message (Rob).
      
      v5: Fix compile warnings reported by 0-day.
      
      Cc: Thierry Reding <thierry.reding@gmail.com>
      Cc: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
      Cc: Daniel Stone <daniels@collabora.com>
      Acked-by: NDaniel Stone <daniels@collabora.com>
      Reviewed-by: NRob Clark <robdclark@gmail.com>
      Acked-by: NMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@intel.com>
      f8aeb41c
  21. 01 9月, 2015 1 次提交
  22. 25 8月, 2015 1 次提交
  23. 11 8月, 2015 2 次提交
  24. 22 7月, 2015 1 次提交
    • D
      drm: Roll out drm_for_each_connector more · 9a9f5ce8
      Daniel Vetter 提交于
      Now that we also grab the connection_mutex and so fixed the race with
      atomic modeset we can use the iterator there too.
      
      The other special case is drm_connector_unplug_all which would have a
      locking inversion with the sysfs store/show functions if we'd grab the
      mode_config.mutex around the unplug. We could just grab
      connection_mutex instead, but that's a bit too much a dirty trick for
      my taste. Also it's only used by udl, which doesn't do any other kind
      of connector hotplugging, so should be race-free. Hence just stick
      with a comment for now.
      Reviewed-by: NMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@intel.com>
      9a9f5ce8
  25. 07 7月, 2015 1 次提交
  26. 02 7月, 2015 1 次提交
  27. 19 6月, 2015 1 次提交
  28. 26 5月, 2015 3 次提交
  29. 21 5月, 2015 1 次提交
  30. 18 5月, 2015 1 次提交
  31. 13 5月, 2015 1 次提交
  32. 12 4月, 2015 1 次提交