Received: by 10.223.164.202 with SMTP id h10csp2798839wrb; Sun, 12 Nov 2017 19:02:32 -0800 (PST) X-Google-Smtp-Source: AGs4zMZBxozTj3+NfRj67jZI9J4nuIq7wut2DH3UUgsZpAtEW1hicjpygBvAa+FFfGr6ywL/pMHa X-Received: by 10.159.244.4 with SMTP id x4mr7503741plr.31.1510542152258; Sun, 12 Nov 2017 19:02:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1510542152; cv=none; d=google.com; s=arc-20160816; b=gAiMauiiLqgun+XlaakEDPPD9gTed96y+xVss9JMzbTWxq8KiYiAY8Re/L444HI3RH uheebxk8i/W8WVFSyK6i9AQet47ffHrdLsRBBJgbNvxQBbz4x+BUpAdrhc0SXJHU3Oiy 9LPxVdIAaZacD6Iu47mhrdERZaMSq9kly97JlXodY6uOpMLo9NsYNPVu2++GO6DQPFu1 1mbaUVcjB6bEGU0zMll/wAiHvdLmGC50G4g93frxaDIZd/W83T6WaUhmpXpCaeMIbgUr 3e/75fofHJ81iS876WfNm6impn/XLjaPR9etfM3sW7x/LuxZThqgY3RRvlNQqwt4Zp/5 ji6Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=AqnLa5hUmghnaOvw4ffQxYZRogPl7W9DhMma5/899vU=; b=rGHeARXTXsctJkPdBAulQYb1IKPhjm9TkNpZ+bIgtdSyMreXi7D2TaoLGCNPfi7VLK M709Svva/9/Fc4F+6cx5WtwK1DWPgp4yh8uJboXjwaH0uwR0GOIxs38oJg+nCgY6VMXV MRqPt97U+GbN2x+C0rWO4LFr8MPNxB++/Cw3DrqpnbS7kGXqQrArIpsB1W8i8AInOZGS 6IpPv3/mtO3t0TJYS9Uw+Sc95FVyoFfYDaS134jA5jP69I0fYWxFWkNiBkPxm2pSsWZS wRlc2fXLZCOw+IOK4dtMhb32lIxCBbv0SA5e/iffQ9OOAWHszxsWGZAyjJOfY6O/KoUF jgOA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p189si8072213pfp.251.2017.11.12.19.02.20; Sun, 12 Nov 2017 19:02:32 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751880AbdKMDB3 (ORCPT + 87 others); Sun, 12 Nov 2017 22:01:29 -0500 Received: from regular1.263xmail.com ([211.150.99.134]:35735 "EHLO regular1.263xmail.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751293AbdKMDB1 (ORCPT ); Sun, 12 Nov 2017 22:01:27 -0500 Received: from mark.yao?rock-chips.com (unknown [192.168.167.242]) by regular1.263xmail.com (Postfix) with ESMTP id 89EBC9192; Mon, 13 Nov 2017 11:01:21 +0800 (CST) X-263anti-spam: KSV:0;BIG:0; X-MAIL-GRAY: 0 X-MAIL-DELIVERY: 1 X-KSVirus-check: 0 X-ADDR-CHECKED4: 1 X-ABS-CHECKED: 1 X-SKE-CHECKED: 1 X-ANTISPAM-LEVEL: 2 Received: from [192.168.1.209] (localhost [127.0.0.1]) by smtp.263.net (Postfix) with ESMTPA id 001D4399; Mon, 13 Nov 2017 11:01:19 +0800 (CST) X-RL-SENDER: mark.yao@rock-chips.com X-FST-TO: linux-kernel@vger.kernel.org X-SENDER-IP: 103.29.142.67 X-LOGIN-NAME: mark.yao@rock-chips.com X-UNIQUE-TAG: X-ATTACHMENT-NUM: 0 X-SENDER: yzq@rock-chips.com X-DNS-TYPE: 0 Received: from [192.168.1.209] (unknown [103.29.142.67]) by smtp.263.net (Postfix) whith ESMTP id 430401KWE4; Mon, 13 Nov 2017 11:01:21 +0800 (CST) Subject: Re: [PATCH] drm/rockchip: analogix_dp: Use mutex rather than spinlock To: Enric Balletbo Serra , Emil Renner Berthing Cc: Heiko Stuebner , "open list:ARM/Rockchip SoC..." , linux-kernel References: <20171004175346.11956-1-kernel@esmil.dk> From: Mark yao Message-ID: <65e4cb05-a30c-ba42-ea9c-d7375a7d9769@rock-chips.com> Date: Mon, 13 Nov 2017 11:01:17 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.4.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2017年11月10日 20:07, Enric Balletbo Serra wrote: > 2017-10-04 19:53 GMT+02:00 Emil Renner Berthing : >> On the Samsung Chromebook Plus I get this error with 4.14-rc3: >> >> BUG: scheduling while atomic: kworker/3:1/50/0x00000002 >> Modules linked in: >> CPU: 3 PID: 50 Comm: kworker/3:1 Not tainted 4.14.0-0.rc3-kevin #2 >> Hardware name: Google Kevin (DT) >> Workqueue: events analogix_dp_psr_work >> Call trace: >> [] dump_backtrace+0x0/0x320 >> [] show_stack+0x14/0x20 >> [] dump_stack+0x9c/0xbc >> [] __schedule_bug+0x4c/0x70 >> [] __schedule+0x3f0/0x458 >> [] schedule+0x38/0xa0 >> [] schedule_hrtimeout_range_clock+0x84/0xe8 >> [] schedule_hrtimeout_range+0x10/0x18 >> [] usleep_range+0x64/0x78 >> [] analogix_dp_transfer+0x16c/0x340 >> [] analogix_dpaux_transfer+0x10/0x18 >> [] drm_dp_dpcd_access+0x4c/0xf0 >> [] drm_dp_dpcd_write+0x1c/0x28 >> [] analogix_dp_disable_psr+0x60/0xa8 >> [] analogix_dp_psr_work+0x4c/0x90 >> [] process_one_work+0x1d4/0x348 >> [] worker_thread+0x48/0x478 >> [] kthread+0x12c/0x130 >> [] ret_from_fork+0x10/0x18 >> >> Changing rockchip_dp_device::psr_lock to a mutex rather >> than spinlock seems to fix the issue. >> >> Signed-off-by: Emil Renner Berthing >> --- >> drivers/gpu/drm/rockchip/analogix_dp-rockchip.c | 14 ++++++-------- >> 1 file changed, 6 insertions(+), 8 deletions(-) >> >> diff --git a/drivers/gpu/drm/rockchip/analogix_dp-rockchip.c b/drivers/gpu/drm/rockchip/analogix_dp-rockchip.c >> index 9606121fa185..d8f72d87ef08 100644 >> --- a/drivers/gpu/drm/rockchip/analogix_dp-rockchip.c >> +++ b/drivers/gpu/drm/rockchip/analogix_dp-rockchip.c >> @@ -72,7 +72,7 @@ struct rockchip_dp_device { >> struct reset_control *rst; >> >> struct work_struct psr_work; >> - spinlock_t psr_lock; >> + struct mutex psr_lock; >> unsigned int psr_state; >> >> const struct rockchip_dp_chip_data *data; >> @@ -83,21 +83,20 @@ struct rockchip_dp_device { >> static void analogix_dp_psr_set(struct drm_encoder *encoder, bool enabled) >> { >> struct rockchip_dp_device *dp = to_dp(encoder); >> - unsigned long flags; >> >> if (!analogix_dp_psr_supported(dp->dev)) >> return; >> >> dev_dbg(dp->dev, "%s PSR...\n", enabled ? "Entry" : "Exit"); >> >> - spin_lock_irqsave(&dp->psr_lock, flags); >> + mutex_lock(&dp->psr_lock); >> if (enabled) >> dp->psr_state = EDP_VSC_PSR_STATE_ACTIVE; >> else >> dp->psr_state = ~EDP_VSC_PSR_STATE_ACTIVE; >> >> schedule_work(&dp->psr_work); >> - spin_unlock_irqrestore(&dp->psr_lock, flags); >> + mutex_unlock(&dp->psr_lock); >> } >> >> static void analogix_dp_psr_work(struct work_struct *work) >> @@ -105,7 +104,6 @@ static void analogix_dp_psr_work(struct work_struct *work) >> struct rockchip_dp_device *dp = >> container_of(work, typeof(*dp), psr_work); >> int ret; >> - unsigned long flags; >> >> ret = rockchip_drm_wait_vact_end(dp->encoder.crtc, >> PSR_WAIT_LINE_FLAG_TIMEOUT_MS); >> @@ -114,12 +112,12 @@ static void analogix_dp_psr_work(struct work_struct *work) >> return; >> } >> >> - spin_lock_irqsave(&dp->psr_lock, flags); >> + mutex_lock(&dp->psr_lock); >> if (dp->psr_state == EDP_VSC_PSR_STATE_ACTIVE) >> analogix_dp_enable_psr(dp->dev); >> else >> analogix_dp_disable_psr(dp->dev); >> - spin_unlock_irqrestore(&dp->psr_lock, flags); >> + mutex_unlock(&dp->psr_lock); >> } >> >> static int rockchip_dp_pre_init(struct rockchip_dp_device *dp) >> @@ -381,7 +379,7 @@ static int rockchip_dp_bind(struct device *dev, struct device *master, >> dp->plat_data.power_off = rockchip_dp_powerdown; >> dp->plat_data.get_modes = rockchip_dp_get_modes; >> >> - spin_lock_init(&dp->psr_lock); >> + mutex_init(&dp->psr_lock); >> dp->psr_state = ~EDP_VSC_PSR_STATE_ACTIVE; >> INIT_WORK(&dp->psr_work, analogix_dp_psr_work); >> >> -- >> 2.14.2 >> > Right this patch fixes the issue for me too. > > Tested-by: Enric Balletbo i Serra > > > Right, it's a bug using spinlock with sleep, Pushed to drm-misc-fixes Thanks. -- Mark Yao From 1583680774860864428@xxx Fri Nov 10 12:08:00 +0000 2017 X-GM-THRID: 1580350542031504453 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread