Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751905AbdHCNGb (ORCPT ); Thu, 3 Aug 2017 09:06:31 -0400 Received: from regular1.263xmail.com ([211.150.99.140]:40690 "EHLO regular1.263xmail.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751158AbdHCNGa (ORCPT ); Thu, 3 Aug 2017 09:06:30 -0400 X-263anti-spam: KSV:0; X-MAIL-GRAY: 0 X-MAIL-DELIVERY: 1 X-KSVirus-check: 0 X-ABS-CHECKED: 4 X-RL-SENDER: hjc@rock-chips.com X-FST-TO: linux-kernel@vger.kernel.org X-SENDER-IP: 58.22.7.114 X-LOGIN-NAME: hjc@rock-chips.com X-UNIQUE-TAG: <566d148e305ee5b81dceb231daeb02b3> X-ATTACHMENT-NUM: 0 X-DNS-TYPE: 0 Subject: Re: [PATCH 2/6] drm/rockchip: vop: fix iommu page fault when resume To: Mark Yao , David Airlie , Heiko Stuebner Cc: linux-rockchip@lists.infradead.org, linux-arm-kernel@lists.infradead.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <1501494569-6825-1-git-send-email-mark.yao@rock-chips.com> <1501494582-6934-1-git-send-email-mark.yao@rock-chips.com> From: Sandy Huang Message-ID: <5c613e33-f5f2-6b5f-69a6-cc3a7aa93a71@rock-chips.com> Date: Thu, 3 Aug 2017 21:06:27 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 In-Reply-To: <1501494582-6934-1-git-send-email-mark.yao@rock-chips.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1238 Lines: 30 Hi mark, 在 2017/7/31 17:49, Mark Yao 写道: > Iommu would get page fault with following path: > vop_disable: > 1, disable all windows and set vop config done > 2, vop enter to standy, all windows not works, but their registers > are not clean, when you read window's enable bit, may found the > window is enable. > > vop_enable: > 1, memcpy(vop->regsbak, vop->regs, len) > save current vop registers to vop->regsbak, then you can found > window is enable on regsbak. > 2, VOP_WIN_SET(vop, win, gate, 1); > force enable window gate, but gate and enable are on same > hardware register, then window enable bit rewrite to vop hardware. > 3, vop power on, and vop might try to scan destroyed buffer, > then iommu get page fault. > > Move windows disable after vop regsbak restore, then vop regsbak mechanism > would keep tracing the modify, everything would be safe. > > Signed-off-by: Mark Yao > --- > drivers/gpu/drm/rockchip/rockchip_drm_vop.c | 33 +++++++++++++---------------- > 1 file changed, 15 insertions(+), 18 deletions(-) > Reviewed-by: Sandy huang