Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp3527773ybl; Mon, 19 Aug 2019 21:05:18 -0700 (PDT) X-Google-Smtp-Source: APXvYqzzHpukcgguLOuP0Sz0j2YQS2siB8NgVRyTe6xN3PtIH+NqdK4xvDT+AdOS7y1BmhIEbDfV X-Received: by 2002:a17:90a:86c2:: with SMTP id y2mr24605961pjv.46.1566273918524; Mon, 19 Aug 2019 21:05:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566273918; cv=none; d=google.com; s=arc-20160816; b=CGDqAG5RVs4DtHderYeYNlVsV4whRZ+OBX3rwXWvAy8bAjkWfqrz+EZrwOU7sWKlZl 9foyUqSj/+L5JfttToO1c8LxGV3eKDRIyLalPSh9ClE9IcC1XJhnvKnTKBDf4yhKgalE t/qn0qxZynmvnDXeK4/xaJ/061SZtaOhG33jeK/Gl2ojVnXMV454mLu0Jr+OGt8AEFdh 6Fr+2ou0HUQLWgHHage9yaOsz64aCBx4qBclw/Bh5w+VsBQK0wMtvbX+7uJFXE2tVkvv vrnCFawJUFMR8E+dAb5x5L5pS/JqI9YZsFSojTEOdGU561pJeya1zSlzjvCCZ5nURI/v kqSQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:in-reply-to :mime-version:user-agent:date:message-id:from:references:cc:to :subject; bh=SVz+JhmNmZ8WccntyQCutQtLQtr4kwZtQ5CE9/sah1s=; b=n/GNf2MokhtXo+dkUtVK48St6K4oT5PwB9aHSt6ljdh7cyLoznpVh1nwWZoV26tdLR VCIN7FXPZoyNsHkxZeCcwjI+t/ouqi3xadYoTUFIpxWJHVpYFTTMEmkHR1UsPjoTn7X0 k9ZLpSU1uROQGk+4rODFcyl6Qc1MIfvCmDmgo539WbSPzhQ+WFzUoWPj8/x4Dtpr62+U l2+dyGGDLjt7z65dUGccjrLzCewlG7dYVcWI55bLPkepZn4szVMpMM8Qc7noerVDtUGm 17TozewI67BQWKbjz5TU5kErziCa6+/t35jx/hJsneuBdppXp74gnnlKLxo51gV6a30F c5bg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 36si11572482pld.289.2019.08.19.21.05.01; Mon, 19 Aug 2019 21:05:18 -0700 (PDT) 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728777AbfHTED7 (ORCPT + 99 others); Tue, 20 Aug 2019 00:03:59 -0400 Received: from out30-45.freemail.mail.aliyun.com ([115.124.30.45]:57177 "EHLO out30-45.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726535AbfHTED6 (ORCPT ); Tue, 20 Aug 2019 00:03:58 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R301e4;CH=green;DM=||false|;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04423;MF=luoben@linux.alibaba.com;NM=1;PH=DS;RN=7;SR=0;TI=SMTPD_---0TZyVkOR_1566273830; Received: from bn0418deMacBook-Pro.local(mailfrom:luoben@linux.alibaba.com fp:SMTPD_---0TZyVkOR_1566273830) by smtp.aliyun-inc.com(127.0.0.1); Tue, 20 Aug 2019 12:03:51 +0800 Subject: Re: [PATCH v3 0/3] genirq/vfio: Introduce update_irq_devid and optimize VFIO irq ops To: Alex Williamson Cc: tglx@linutronix.de, linux-kernel@vger.kernel.org, tao.ma@linux.alibaba.com, gerry@linux.alibaba.com, nanhai.zou@linux.alibaba.com, linyunsheng@huawei.com References: <20190819145150.2d30669b@x1.home> From: luoben Message-ID: Date: Tue, 20 Aug 2019 12:03:50 +0800 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.14; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: <20190819145150.2d30669b@x1.home> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 在 2019/8/20 上午4:51, Alex Williamson 写道: > On Thu, 15 Aug 2019 21:02:58 +0800 > Ben Luo wrote: > >> Currently, VFIO takes a lot of free-then-request-irq actions whenever >> a VM (with device passthru via VFIO) sets irq affinity or mask/unmask >> irq. Those actions only change the cookie data of irqaction or even >> change nothing. The free-then-request-irq not only adds more latency, >> but also increases the risk of losing interrupt, which may lead to a >> VM hung forever in waiting for IO completion > What guest environment is generating this? Typically I don't see that > Windows or Linux guests bounce the interrupt configuration much. > Thanks, > > Alex By tracing centos5u8 on host, I found it keep masking and unmasking interrupt like this: [1566032533709879] index:28 irte_hi:000000010004a601 irte_lo:adb54bc000b98001 [1566032533711242] index:28 irte_hi:0000000000000000 irte_lo:0000000000000000 [1566032533711258] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533711269] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533711291] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533711321] index:28 irte_hi:0000000000000000 irte_lo:0000000000000000 [1566032533711340] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533711361] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533711376] index:28 irte_hi:000000010004a601 irte_lo:adb54bc000b98001 [1566032533713368] index:28 irte_hi:0000000000000000 irte_lo:0000000000000000 [1566032533713385] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533713396] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533713416] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533713447] index:28 irte_hi:0000000000000000 irte_lo:0000000000000000 [1566032533713464] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533713485] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533713499] index:28 irte_hi:000000010004a601 irte_lo:adb54bc000b98001 [1566032533718855] index:28 irte_hi:0000000000000000 irte_lo:0000000000000000 [1566032533718871] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533718882] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533718902] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533718932] index:28 irte_hi:0000000000000000 irte_lo:0000000000000000 [1566032533718949] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533718969] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533718984] index:28 irte_hi:000000010004a601 irte_lo:adb54bc000b98001 [1566032533719873] index:28 irte_hi:0000000000000000 irte_lo:0000000000000000 [1566032533719889] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533719900] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533719921] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533719954] index:28 irte_hi:0000000000000000 irte_lo:0000000000000000 [1566032533719971] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533719992] index:28 irte_hi:000000000004a601 irte_lo:00003fff00ac002d [1566032533720007] index:28 irte_hi:000000010004a601 irte_lo:adb54bc000b98001 "[1566032533720007]" is timestamp in μs, so centos5u8 tiggers 30+ irte modification within 10ms Thanks,     Ben >> This patchset solved the issue by: >> Patch 2 introduces update_irq_devid to only update dev_id of irqaction >> Patch 3 make use of update_irq_devid and optimize irq operations in VFIO >> >> changes from v2: >> - reformat to avoid quoted string split across lines and etc. >> >> changes from v1: >> - add Patch 1 to enhance error recovery etc. in free irq per tglx's comments >> - enhance error recovery code and debugging info in update_irq_devid >> - use __must_check in external referencing of update_irq_devid >> - use EXPORT_SYMBOL_GPL for update_irq_devid >> - reformat code of patch 3 for better readability >> >> Ben Luo (3): >> genirq: enhance error recovery code in free irq >> genirq: introduce update_irq_devid() >> vfio_pci: make use of update_irq_devid and optimize irq ops >> >> drivers/vfio/pci/vfio_pci_intrs.c | 101 +++++++++++++++++++++------------- >> include/linux/interrupt.h | 3 ++ >> kernel/irq/manage.c | 110 +++++++++++++++++++++++++++++++++----- >> 3 files changed, 164 insertions(+), 50 deletions(-) >>