1. 04 9月, 2020 2 次提交
  2. 18 8月, 2020 2 次提交
  3. 09 7月, 2020 4 次提交
  4. 23 6月, 2020 1 次提交
    • J
      drm/i915/params: switch to device specific parameters · 8a25c4be
      Jani Nikula 提交于
      Start using device specific parameters instead of module parameters for
      most things. The module parameters become the immutable initial values
      for i915 parameters. The device specific parameters in i915->params
      start life as a copy of i915_modparams. Any later changes are only
      reflected in the debugfs.
      
      The stragglers are:
      
      * i915.force_probe and i915.modeset. Needed before dev_priv is
        available. This is fine because the parameters are read-only and never
        modified.
      
      * i915.verbose_state_checks. Passing dev_priv to I915_STATE_WARN and
        I915_STATE_WARN_ON would result in massive and ugly churn. This is
        handled by not exposing the parameter via debugfs, and leaving the
        parameter writable in sysfs. This may be fixed up in follow-up work.
      
      * i915.inject_probe_failure. Only makes sense in terms of the module,
        not the device. This is handled by not exposing the parameter via
        debugfs.
      
      v2: Fix uc i915 lookup code (Michał Winiarski)
      
      Cc: Juha-Pekka Heikkilä <juha-pekka.heikkila@intel.com>
      Cc: Venkata Sandeep Dhanalakota <venkata.s.dhanalakota@intel.com>
      Cc: Michał Winiarski <michal.winiarski@intel.com>
      Reviewed-by: NRodrigo Vivi <rodrigo.vivi@intel.com>
      Acked-by: NMichał Winiarski <michal.winiarski@intel.com>
      Signed-off-by: NJani Nikula <jani.nikula@intel.com>
      Link: http://patchwork.freedesktop.org/patch/msgid/20200618150402.14022-1-jani.nikula@intel.com
      8a25c4be
  5. 29 4月, 2020 1 次提交
  6. 18 4月, 2020 2 次提交
    • M
      drm/i915: Refactor setting dma info to a common helper · 31a02eb7
      Michael J. Ruhl 提交于
      DMA_MASK bit values are different for different generations.
      
      This will become more difficult to manage over time with the open
      coded usage of different versions of the device.
      
      Fix by:
        disallow setting of dma mask in AGP path (< GEN(5) for i915,
        add dma_mask_size to the device info configuration,
        updating open code call sequence to the latest interface,
        refactoring into a common function for setting the dma segment
        and mask info
      Reviewed-by: NChris Wilson <chris@chris-wilson.co.uk>
      Signed-off-by: NMichael J. Ruhl <michael.j.ruhl@intel.com>
      cc: Brian Welty <brian.welty@intel.com>
      cc: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
      Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
      Link: https://patchwork.freedesktop.org/patch/msgid/20200417195107.68732-1-michael.j.ruhl@intel.com
      31a02eb7
    • J
      drm/i915: Add missing deinitialization cases of load failure · c0ff9e5e
      José Roberto de Souza 提交于
      The intel_display_power_put_async() used in TC cold sequences made
      easy to hit the missing deinitialization of driver in case of load
      failure as seen in the stack trace bellow.
      
      intel_modeset_driver_remove_noirq() had to be removed from
      i915_driver_modeset_remove_noirq() as those are different
      initialialition steps with IRQ and GEM initialization in between then.
      
      [drm:__intel_engine_init_ctx_wa [i915]] Initialized 3 context workarounds on rcs'0
      [drm:__i915_inject_probe_error [i915]] Injecting failure -19 at checkpoint 36 [__uc_init:294]
      [drm:i915_hdcp_component_unbind [i915]] I915 HDCP comp unbind
      [drm:edp_panel_vdd_off_sync [i915]] Turning [ENCODER:275:DDI A] VDD off
      [drm:edp_panel_vdd_off_sync [i915]] PP_STATUS: 0x00000000 PP_CONTROL: 0x00000060
      [drm:intel_power_well_disable [i915]] disabling AUX A
      general protection fault, probably for non-canonical address 0x6b6b6b6b6b6b6b6b: 0000 [#1] PREEMPT SMP NOPTI
      CPU: 3 PID: 1142 Comm: kworker/u16:20 Tainted: G     U            5.6.0-CI-Patchwork_17226+ #1
      Hardware name: Intel Corporation Tiger Lake Client Platform/TigerLake U DDR4 SODIMM RVP, BIOS TGLSFWI1.R00.2457.A16.1912270059 12/27/2019
      Workqueue: events_unbound intel_display_power_put_async_work [i915]
      RIP: 0010:__intel_display_power_put_domain+0xa5/0x180 [i915]
      Code: 48 85 c0 78 54 44 89 e1 41 bd 01 00 00 00 49 c7 c4 80 44 41 a0 49 d3 e5 eb 0d 48 83 eb 10 48 3b 9d 08 ad 00 00 78 32 48 8b 03 <4c> 85 68 10 74 ea 8b 53 08 85 d2 74 2d 83 ea 01 85 d2 89 53 08 75
      RSP: 0018:ffffc9000061fdb0 EFLAGS: 00010206
      RAX: 6b6b6b6b6b6b6b6b RBX: ffff8884948f5df0 RCX: 000000000000003d
      RDX: 0000000080000001 RSI: 0000000000000000 RDI: 0000000000000000
      RBP: ffff888479be0000 R08: ffff88849a180920 R09: 0000000000000000
      R10: 0000000000000000 R11: 0000000000000000 R12: ffffffffa0414480
      R13: 2000000000000000 R14: ffff888479beb320 R15: 2000000000000000
      FS:  0000000000000000(0000) GS:ffff88849ff80000(0000) knlGS:0000000000000000
      CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      CR2: 00005634fa8ed670 CR3: 0000000005610004 CR4: 0000000000760ee0
      PKRU: 55555554
      Call Trace:
       release_async_put_domains+0x9b/0x110 [i915]
       intel_display_power_put_async_work+0x91/0xf0 [i915]
       process_one_work+0x260/0x600
       ? worker_thread+0xc9/0x380
       worker_thread+0x37/0x380
       ? process_one_work+0x600/0x600
       kthread+0x119/0x130
       ? kthread_park+0x80/0x80
       ret_from_fork+0x24/0x50
      Modules linked in: i915(+) vgem snd_hda_codec_hdmi mei_hdcp x86_pkg_temp_thermal coretemp crct10dif_pclmul crc32_pclmul cdc_ether usbnet mii snd_intel_dspcfg ghash_clmulni_intel snd_hda_codec snd_hwdep snd_hda_core e1000e ptp mei_me snd_pcm pps_core mei intel_lpss_pci prime_numbers [last unloaded: i915]
      ---[ end trace b402d1b4060f8b97 ]---
      BUG: sleeping function called from invalid context at kernel/sched/completion.c:99
      in_atomic(): 0, irqs_disabled(): 0, non_block: 0, pid: 1142, name: kworker/u16:20
      INFO: lockdep is turned off.
      Preemption disabled at:
      [<0000000000000000>] 0x0
      CPU: 3 PID: 1142 Comm: kworker/u16:20 Tainted: G     UD           5.6.0-CI-Patchwork_17226+ #1
      Hardware name: Intel Corporation Tiger Lake Client Platform/TigerLake U DDR4 SODIMM RVP, BIOS TGLSFWI1.R00.2457.A16.1912270059 12/27/2019
      Workqueue: events_unbound intel_display_power_put_async_work [i915]
      Call Trace:
       dump_stack+0x71/0x9b
       ___might_sleep+0x178/0x260
       wait_for_completion+0x37/0x1a0
       virt_efi_query_variable_info+0x161/0x1b0
       efi_query_variable_store+0xb3/0x1a0
       ? efivar_entry_set_safe+0x19c/0x220
       efivar_entry_set_safe+0x19c/0x220
       ? efi_pstore_write+0x10b/0x150
       ? efi_pstore_write+0xa0/0x150
       efi_pstore_write+0x10b/0x150
       pstore_dump+0x123/0x340
       kmsg_dump+0x87/0x1b0
       oops_end+0x3e/0x90
       do_general_protection+0x1c3/0x2f0
       general_protection+0x2d/0x40
      RIP: 0010:__intel_display_power_put_domain+0xa5/0x180 [i915]
      Code: 48 85 c0 78 54 44 89 e1 41 bd 01 00 00 00 49 c7 c4 80 44 41 a0 49 d3 e5 eb 0d 48 83 eb 10 48 3b 9d 08 ad 00 00 78 32 48 8b 03 <4c> 85 68 10 74 ea 8b 53 08 85 d2 74 2d 83 ea 01 85 d2 89 53 08 75
      RSP: 0018:ffffc9000061fdb0 EFLAGS: 00010206
      RAX: 6b6b6b6b6b6b6b6b RBX: ffff8884948f5df0 RCX: 000000000000003d
      RDX: 0000000080000001 RSI: 0000000000000000 RDI: 0000000000000000
      RBP: ffff888479be0000 R08: ffff88849a180920 R09: 0000000000000000
      R10: 0000000000000000 R11: 0000000000000000 R12: ffffffffa0414480
      R13: 2000000000000000 R14: ffff888479beb320 R15: 2000000000000000
       release_async_put_domains+0x9b/0x110 [i915]
       intel_display_power_put_async_work+0x91/0xf0 [i915]
       process_one_work+0x260/0x600
       ? worker_thread+0xc9/0x380
       worker_thread+0x37/0x380
       ? process_one_work+0x600/0x600
       kthread+0x119/0x130
       ? kthread_park+0x80/0x80
       ret_from_fork+0x24/0x50
      ------------[ cut here ]------------
      WARNING: CPU: 3 PID: 1142 at kernel/rcu/tree_plugin.h:293 rcu_note_context_switch+0x87/0x650
      Modules linked in: i915(+) vgem snd_hda_codec_hdmi mei_hdcp x86_pkg_temp_thermal coretemp crct10dif_pclmul crc32_pclmul cdc_ether usbnet mii snd_intel_dspcfg ghash_clmulni_intel snd_hda_codec snd_hwdep snd_hda_core e1000e ptp mei_me snd_pcm pps_core mei intel_lpss_pci prime_numbers [last unloaded: i915]
      
      v2:
      - fixed handling in case of failure in drm_vblank_init()
      - moved i915_gem_driver_remove() call to before
      i915_driver_modeset_remove_noirq() this match initialization order too
      
      v3:
      - reverting call swap between i915_reset_error_state() and i915_gem_driver_remove()
      call order
      - improved label naming in i915_driver_modeset_probe_noirq()
      
      Closes: https://gitlab.freedesktop.org/drm/intel/issues/1647
      Cc: Imre Deak <imre.deak@intel.com>
      Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
      Cc: Jani Nikula <jani.nikula@intel.com>
      Reviewed-by: NImre Deak <imre.deak@intel.com>
      Reviewed-by: NChris Wilson <chris@chris-wilson.co.uk>
      Signed-off-by: NJosé Roberto de Souza <jose.souza@intel.com>
      Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
      Link: https://patchwork.freedesktop.org/patch/msgid/20200416185841.125686-1-jose.souza@intel.com
      c0ff9e5e
  7. 26 3月, 2020 3 次提交
    • D
      drm: Garbage collect drm_dev_fini · d33b58d0
      Daniel Vetter 提交于
      It has become empty. Given the few users I figured not much point
      splitting this up.
      
      v2: Rebase over i915 changes.
      
      v3: Rebase over patch split fix.
      Acked-by: NSam Ravnborg <sam@ravnborg.org>
      Signed-off-by: NDaniel Vetter <daniel.vetter@intel.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/20200323144950.3018436-26-daniel.vetter@ffwll.ch
      d33b58d0
    • D
      drm/i915: Use drmm_add_final_kfree · 7fb81e9d
      Daniel Vetter 提交于
      With this we can drop the final kfree from the release function.
      
      The mock device in the selftests needed it's pci_device split
      up from the drm_device. In the future we could simplify this again
      by allocating the pci_device as a managed allocation too.
      
      v2: I overlooked that i915_driver_destroy is also called in the
      unwind code of the error path. There we need a drm_dev_put.
      Similar for the mock object.
      
      Now the problem with that is that the drm_driver->release callbacks
      for both the real driver and the mock one assume everything has been
      set up. Hence going through that path for a partially set up driver
      will result in issues. Quickest fix is to disable the ->release() hook
      until the driver is fully initialized, and keep the onion unwinding.
      Long term would be cleanest to move everything over to drmm_ release
      actions, but that's a lot of work for a big driver like i915. Plus
      more core work needed first anyway.
      
      v3: Fix i915_drm pointer wrangling in mock_gem_device. Also switch
      over to start using drm_dev_put() to clean up even on the error path.
      Aside I think the current error path is leaking the allocation.
      
      v4: more fixes for intel-gfx-ci, some if it damage from v3 :-/
      Reviewed-by: NJani Nikula <jani.nikula@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@intel.com>
      Cc: Jani Nikula <jani.nikula@linux.intel.com>
      Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
      Cc: Rodrigo Vivi <rodrigo.vivi@intel.com>
      Cc: Chris Wilson <chris@chris-wilson.co.uk>
      Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
      Cc: Matthew Auld <matthew.auld@intel.com>
      Cc: Andi Shyti <andi.shyti@intel.com>
      Cc: Mika Kuoppala <mika.kuoppala@linux.intel.com>
      Cc: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
      Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
      Cc: Abdiel Janulgue <abdiel.janulgue@linux.intel.com>
      Cc: intel-gfx@lists.freedesktop.org
      Link: https://patchwork.freedesktop.org/patch/msgid/20200323144950.3018436-9-daniel.vetter@ffwll.ch
      7fb81e9d
    • D
      drm/i915: Don't clear drvdata in ->release · 0ce542f7
      Daniel Vetter 提交于
      For two reasons:
      
      - The driver core clears this already for us after we're unloaded in
        __device_release_driver().
      
      - It's way too late, the drm_device ->release callback might massively
        outlive the underlying physical device, since a drm_device can be
        kept alive by open drm_file or well really anything else userspace
        is still hanging onto. So if we clear this ourselves, we should
        clear it in the pci ->remove callback, not in the drm_device
        ->release callback.
      
      Looking at git history this was fixed in the driver core with
      
      commit 0998d063
      Author: Hans de Goede <hdegoede@redhat.com>
      Date:   Wed May 23 00:09:34 2012 +0200
      
          device-core: Ensure drvdata = NULL when no driver is bound
      
      v2: Cite the core fix in the commit message (Chris).
      
      v3: Fix commit message and unused variable warning (Jani).
      
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Cc: Chris Wilson <chris@chris-wilson.co.uk>
      Reviewed-by: NJani Nikula <jani.nikula@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@intel.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/20200323144950.3018436-3-daniel.vetter@ffwll.ch
      0ce542f7
  8. 17 3月, 2020 2 次提交
  9. 03 3月, 2020 2 次提交
  10. 02 3月, 2020 3 次提交
  11. 28 2月, 2020 1 次提交
  12. 27 2月, 2020 3 次提交
  13. 26 2月, 2020 2 次提交
  14. 25 2月, 2020 1 次提交
    • J
      drm/i915/psr: Force PSR probe only after full initialization · df1a5bfc
      José Roberto de Souza 提交于
      Commit 60c6a14b ("drm/i915/display: Force the state compute phase
      once to enable PSR") was forcing the state compute too earlier
      causing errors because not everything was initialized, so here
      moving to the end of i915_driver_modeset_probe() when the display is
      all initialized.
      
      Also fixing the place where it disarm the force probe as during the
      atomic check phase errors could happen like the ones due locking and
      it would cause PSR to never be enabled if that happens.
      Leaving the disarm to the atomic commit phase, intel_psr_enable() or
      intel_psr_update() will be called even if the current state do not
      allow PSR to be enabled.
      
      v2: Check if intel_dp is null in intel_psr_force_mode_changed_set()
      v3: Check intel_dp before get dev_priv
      v4:
      - renamed intel_psr_force_mode_changed_set() to
      intel_psr_set_force_mode_changed()
      - removed the set parameter from intel_psr_set_force_mode_changed()
      - not calling intel_psr_set_force_mode_changed() from
      intel_psr_enable/update(), directly setting it after the same checks
      that intel_psr_set_force_mode_changed() does
      - moved intel_psr_set_force_mode_changed() arm call to
      i915_driver_modeset_probe() as it is a better for a PSR call, all the
      functions calls happening between the old and the new function call
      will cause issue
      
      Fixes: 60c6a14b ("drm/i915/display: Force the state compute phase once to enable PSR")
      Closes: https://gitlab.freedesktop.org/drm/intel/issues/1151Tested-by: NRoss Zwisler <zwisler@google.com>
      Reported-by: NRoss Zwisler <zwisler@google.com>
      Cc: Gwan-gyeong Mun <gwan-gyeong.mun@intel.com>
      Cc: Jani Nikula <jani.nikula@intel.com>
      Cc: Anshuman Gupta <anshuman.gupta@intel.com>
      Reviewed-by: NGwan-gyeong Mun <gwan-gyeong.mun@intel.com>
      Signed-off-by: NJosé Roberto de Souza <jose.souza@intel.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/20200221212635.11614-1-jose.souza@intel.com
      df1a5bfc
  15. 23 2月, 2020 1 次提交
  16. 22 2月, 2020 1 次提交
  17. 19 2月, 2020 2 次提交
  18. 17 2月, 2020 1 次提交
  19. 14 2月, 2020 5 次提交
  20. 13 2月, 2020 1 次提交