[Intel-gfx] [PATCH v3 06/23] drm/i915: Do not read PSR2 register in transcoders without PSR2

Lucas De Marchi lucas.demarchi at intel.com
Mon Aug 26 16:32:31 UTC 2019


On Mon, Aug 26, 2019 at 05:21:56PM +0300, Imre Deak wrote:
>On Fri, Aug 23, 2019 at 01:20:38AM -0700, Lucas De Marchi wrote:
>> From: José Roberto de Souza <jose.souza at intel.com>
>>
>> This fix unclaimed access warnings:
>>
>> [  245.525788] ------------[ cut here ]------------
>> [  245.525884] Unclaimed read from register 0x62900
>> [  245.526154] WARNING: CPU: 0 PID: 1234 at drivers/gpu/drm/i915/intel_uncore.c:1100 __unclaimed_reg_debug+0x40/0x50 [i915]
>> [  245.526160] Modules linked in: i915 x86_pkg_temp_thermal ax88179_178a coretemp usbnet crct10dif_pclmul mii crc32_pclmul ghash_clmulni_intel e1000e [last unloaded: i915]
>> [  245.526191] CPU: 0 PID: 1234 Comm: kms_fullmodeset Not tainted 5.1.0-rc6+ #915
>> [  245.526197] Hardware name: Intel Corporation Tiger Lake Client Platform/TigerLake U DDR4 SODIMM RVP, BIOS TGLSFWR1.D00.2081.A10.1904182155 04/18/2019
>> [  245.526273] RIP: 0010:__unclaimed_reg_debug+0x40/0x50 [i915]
>> [  245.526281] Code: 74 05 5b 5d 41 5c c3 45 84 e4 48 c7 c0 76 97 21 a0 48 c7 c6 6c 97 21 a0 89 ea 48 0f 44 f0 48 c7 c7 7f 97 21 a0 e8 4f 1e fe e0 <0f> 0b 83 2d 6f d9 1c 00 01 5b 5d 41 5c c3 66 90 41 57 41 56 41 55
>> [  245.526288] RSP: 0018:ffffc900006bf7d8 EFLAGS: 00010086
>> [  245.526297] RAX: 0000000000000000 RBX: 0000000000000000 RCX: 0000000000000000
>> [  245.526304] RDX: 0000000000000007 RSI: 0000000000000000 RDI: 00000000ffffffff
>> [  245.526310] RBP: 0000000000061900 R08: 0000000000000000 R09: 0000000000000001
>> [  245.526317] R10: 0000000000000006 R11: 0000000000000000 R12: 0000000000000001
>> [  245.526324] R13: 0000000000000000 R14: ffff8882914f0d58 R15: 0000000000000206
>> [  245.526332] FS:  00007fed2a3c39c0(0000) GS:ffff8882a8600000(0000) knlGS:0000000000000000
>> [  245.526340] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
>> [  245.526347] CR2: 00007fed28dff000 CR3: 00000002a086c006 CR4: 0000000000760ef0
>> [  245.526354] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
>> [  245.526361] DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400
>> [  245.526367] PKRU: 55555554
>> [  245.526373] Call Trace:
>> [  245.526454]  gen11_fwtable_read32+0x219/0x250 [i915]
>> [  245.526576]  intel_psr_activate+0x57/0x400 [i915]
>> [  245.526697]  intel_psr_enable_locked+0x367/0x4b0 [i915]
>> [  245.526828]  intel_psr_enable+0xa4/0xd0 [i915]
>> [  245.526946]  intel_enable_ddi+0x127/0x2f0 [i915]
>> [  245.527075]  intel_encoders_enable.isra.79+0x62/0x90 [i915]
>> [  245.527202]  haswell_crtc_enable+0x2a2/0x850 [i915]
>> [  245.527337]  intel_update_crtc+0x51/0x360 [i915]
>> [  245.527466]  skl_update_crtcs+0x26c/0x300 [i915]
>> [  245.527603]  intel_atomic_commit_tail+0x3e5/0x13c0 [i915]
>> [  245.527757]  intel_atomic_commit+0x24d/0x2d0 [i915]
>> [  245.527782]  drm_atomic_helper_set_config+0x7b/0x90
>> [  245.527799]  drm_mode_setcrtc+0x1b4/0x6f0
>> [  245.527856]  ? drm_mode_getcrtc+0x180/0x180
>> [  245.527867]  drm_ioctl_kernel+0xad/0xf0
>> [  245.527886]  drm_ioctl+0x2f4/0x3b0
>> [  245.527902]  ? drm_mode_getcrtc+0x180/0x180
>> [  245.527935]  ? rcu_read_lock_sched_held+0x6f/0x80
>> [  245.527956]  do_vfs_ioctl+0xa0/0x6d0
>> [  245.527970]  ? __task_pid_nr_ns+0xb6/0x200
>> [  245.527991]  ksys_ioctl+0x35/0x70
>> [  245.528009]  __x64_sys_ioctl+0x11/0x20
>> [  245.528020]  do_syscall_64+0x55/0x180
>> [  245.528034]  entry_SYSCALL_64_after_hwframe+0x49/0xbe
>> [  245.528042] RIP: 0033:0x7fed2cc7c3c7
>> [  245.528050] Code: 00 00 90 48 8b 05 c9 3a 0d 00 64 c7 00 26 00 00 00 48 c7 c0 ff ff ff ff c3 66 2e 0f 1f 84 00 00 00 00 00 b8 10 00 00 00 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 8b 0d 99 3a 0d 00 f7 d8 64 89 01 48
>> [  245.528057] RSP: 002b:00007ffe36944378 EFLAGS: 00000246 ORIG_RAX: 0000000000000010
>> [  245.528067] RAX: ffffffffffffffda RBX: 00007ffe369443b0 RCX: 00007fed2cc7c3c7
>> [  245.528074] RDX: 00007ffe369443b0 RSI: 00000000c06864a2 RDI: 0000000000000003
>> [  245.528081] RBP: 00007ffe369443b0 R08: 0000000000000000 R09: 0000564c0173ae98
>> [  245.528088] R10: 0000564c0173aeb8 R11: 0000000000000246 R12: 00000000c06864a2
>> [  245.528095] R13: 0000000000000003 R14: 0000000000000000 R15: 0000000000000000
>> [  245.528128] irq event stamp: 140866
>> [  245.528138] hardirqs last  enabled at (140865): [<ffffffff819a63dc>] _raw_spin_unlock_irqrestore+0x4c/0x60
>> [  245.528148] hardirqs last disabled at (140866): [<ffffffff819a624d>] _raw_spin_lock_irqsave+0xd/0x50
>> [  245.528158] softirqs last  enabled at (140860): [<ffffffff81c0038c>] __do_softirq+0x38c/0x499
>> [  245.528170] softirqs last disabled at (140853): [<ffffffff810b4a09>] irq_exit+0xa9/0xc0
>> [  245.528247] WARNING: CPU: 0 PID: 1234 at drivers/gpu/drm/i915/intel_uncore.c:1100 __unclaimed_reg_debug+0x40/0x50 [i915]
>> [  245.528254] ---[ end trace 366069676e98a410 ]---
>>
>> Signed-off-by: José Roberto de Souza <jose.souza at intel.com>
>> Signed-off-by: Lucas De Marchi <lucas.demarchi at intel.com>
>> ---
>>  drivers/gpu/drm/i915/display/intel_psr.c | 6 ++++--
>>  1 file changed, 4 insertions(+), 2 deletions(-)
>>
>> diff --git a/drivers/gpu/drm/i915/display/intel_psr.c b/drivers/gpu/drm/i915/display/intel_psr.c
>> index cf07ab3d9280..4e6b3ae8a872 100644
>> --- a/drivers/gpu/drm/i915/display/intel_psr.c
>> +++ b/drivers/gpu/drm/i915/display/intel_psr.c
>> @@ -631,7 +631,8 @@ static void intel_psr_activate(struct intel_dp *intel_dp)
>>  {
>>  	struct drm_i915_private *dev_priv = dp_to_i915(intel_dp);
>>
>> -	if (INTEL_GEN(dev_priv) >= 9)
>> +	if (INTEL_GEN(dev_priv) >= 9 &&
>> +	    psr2_supported(dev_priv, dev_priv->psr.transcoder))
>	    ^transcoder_has_psr2()

yep, it diverged on patch that got applied.

>
>nit: Move the GEN check to transcoder_has_psr2()?

Done and queued for the next rev.

>
>Either way:
>Reviewed-by: Imre Deak <imre.deak at intel.com>

Thanks
Lucas De Marchi

>
>>  		WARN_ON(I915_READ(EDP_PSR2_CTL(dev_priv->psr.transcoder)) & EDP_PSR2_ENABLE);
>>  	WARN_ON(I915_READ(EDP_PSR_CTL(dev_priv->psr.transcoder)) & EDP_PSR_ENABLE);
>>  	WARN_ON(dev_priv->psr.active);
>> @@ -785,7 +786,8 @@ static void intel_psr_exit(struct drm_i915_private *dev_priv)
>>  	u32 val;
>>
>>  	if (!dev_priv->psr.active) {
>> -		if (INTEL_GEN(dev_priv) >= 9) {
>> +		if (INTEL_GEN(dev_priv) >= 9 &&
>> +		    psr2_supported(dev_priv, dev_priv->psr.transcoder)) {
>>  			val = I915_READ(EDP_PSR2_CTL(dev_priv->psr.transcoder));
>>  			WARN_ON(val & EDP_PSR2_ENABLE);
>>  		}
>> --
>> 2.23.0
>>
>> _______________________________________________
>> Intel-gfx mailing list
>> Intel-gfx at lists.freedesktop.org
>> https://lists.freedesktop.org/mailman/listinfo/intel-gfx


More information about the Intel-gfx mailing list