Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp1069525pxb; Wed, 6 Apr 2022 08:02:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzZtG9eiVsZmgZYpGPX6V+pghpMtrmZ16PbdCiGU0r2JWSLjFHziqDEJjsH8pTYyHaifuKC X-Received: by 2002:a17:90b:33c4:b0:1c6:8598:d4bf with SMTP id lk4-20020a17090b33c400b001c68598d4bfmr10376753pjb.81.1649257334727; Wed, 06 Apr 2022 08:02:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649257334; cv=none; d=google.com; s=arc-20160816; b=HINp+qq+7yw+vUlH7TtK7blNgtEQf+XRFhlf7dfQNo7cB7u1TeBoShpxcdhfA1WhqM caiaj+PDIdCpWup09ym7zU/XsPscGXY45YfVN8bP+VNAHmCwXfXDXCM6OXIQheu8Ffch WiFFjF0GciSZU5gx6lUlim7Y56xXqXgRbUszuAFnEhOCG5xfYMWxDCU0sqlL80QrKCMd MKTccp3abu9c1OUzqwS+K7sIcbtnHlKT4V7sJvTlwmnK1thYJ2pqY139n8FlrVmsUqII Vze2Knedn3OaMonZUEMIZlcXvbmaGT4Hc/RQX1WENggXPlVo+Fu6lapR5aRl6N7yF3w+ L+AA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=/3YhGhX98tXHPwykWkG6BkL+HnhGiXnNU5siRoG2nw4=; b=bR+1QzC6vhvYKpTFt8Ye6j/zHbngTHUF5lU52yDSisjZ13yEvCbeatRjkwWuHBsh3g S3dbj/SgEW4U6F+PJ+fziEso8iMbRin5hbHT73Hj15+ah7pPHHfMcn519IlfWRIpuh5X QNAf60oYiPTSFJw2OnPHXgRkkqfmXPL2le85vxnUSLOPiGoMJ1tl1W7iEyix4MSrC8js bNXtN8vg0Fzl8aaCNZ//RHGi2zi25JiEikYY0P2xzw6BGiPCBRf4pdnJ1wiDQ7k7swBb JubhH2Qzry6V0I7oWzbn4GOs1PI5ddpgsB6GG0/mfO4Kq3cqpZrIKJmxkRA6elAVLUKO UP+A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=Tq7Y3n2s; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id q12-20020a63cc4c000000b003991d7df4b8si9556084pgi.652.2022.04.06.08.02.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 06 Apr 2022 08:02:14 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=Tq7Y3n2s; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 479C548D30D; Wed, 6 Apr 2022 05:49:06 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230052AbiDFMgg (ORCPT + 99 others); Wed, 6 Apr 2022 08:36:36 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60652 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234073AbiDFMd4 (ORCPT ); Wed, 6 Apr 2022 08:33:56 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id A2494480C3F for ; Wed, 6 Apr 2022 01:36:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1649234183; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=/3YhGhX98tXHPwykWkG6BkL+HnhGiXnNU5siRoG2nw4=; b=Tq7Y3n2szdc5maCld7Qy1iqdvdGJE6hbGCPT57kjRZHisDT2ttnjknRNILLO7OunmDtLrk 3qYUidraaCA4TVV6evliiLZD3i0W7i6DdXxYVsyCKY/MoQXJIOJYWPJiq/ezlU2a5BhCHd LhOfpK0YJ9noxl5LOjiOHIrRdnq9UYo= Received: from mimecast-mx02.redhat.com (mimecast-mx02.redhat.com [66.187.233.88]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-208-4tELYOGvP8ysDnXvHeBj-g-1; Wed, 06 Apr 2022 04:36:20 -0400 X-MC-Unique: 4tELYOGvP8ysDnXvHeBj-g-1 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.rdu2.redhat.com [10.11.54.3]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id 2F61B811E81; Wed, 6 Apr 2022 08:36:20 +0000 (UTC) Received: from localhost.localdomain (ovpn-12-58.pek2.redhat.com [10.72.12.58]) by smtp.corp.redhat.com (Postfix) with ESMTP id C1A6F112132D; Wed, 6 Apr 2022 08:36:10 +0000 (UTC) From: Jason Wang To: mst@redhat.com, jasowang@redhat.com Cc: virtualization@lists.linux-foundation.org, linux-kernel@vger.kernel.org, maz@kernel.org, tglx@linutronix.de, peterz@infradead.org, sgarzare@redhat.com, "Paul E. McKenney" Subject: [PATCH V2 4/5] virtio-pci: implement synchronize_vqs() Date: Wed, 6 Apr 2022 16:35:37 +0800 Message-Id: <20220406083538.16274-5-jasowang@redhat.com> In-Reply-To: <20220406083538.16274-1-jasowang@redhat.com> References: <20220406083538.16274-1-jasowang@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.78 on 10.11.54.3 X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch implements PCI version of synchronize_vqs(). Cc: Thomas Gleixner Cc: Peter Zijlstra Cc: "Paul E. McKenney" Cc: Marc Zyngier Signed-off-by: Jason Wang --- drivers/virtio/virtio_pci_common.c | 14 ++++++++++++++ drivers/virtio/virtio_pci_common.h | 2 ++ drivers/virtio/virtio_pci_legacy.c | 1 + drivers/virtio/virtio_pci_modern.c | 2 ++ 4 files changed, 19 insertions(+) diff --git a/drivers/virtio/virtio_pci_common.c b/drivers/virtio/virtio_pci_common.c index d724f676608b..b78c8bc93a97 100644 --- a/drivers/virtio/virtio_pci_common.c +++ b/drivers/virtio/virtio_pci_common.c @@ -37,6 +37,20 @@ void vp_synchronize_vectors(struct virtio_device *vdev) synchronize_irq(pci_irq_vector(vp_dev->pci_dev, i)); } +void vp_synchronize_vqs(struct virtio_device *vdev) +{ + struct virtio_pci_device *vp_dev = to_vp_device(vdev); + int i; + + if (vp_dev->intx_enabled) { + synchronize_irq(vp_dev->pci_dev->irq); + return; + } + + for (i = 0; i < vp_dev->msix_vectors; ++i) + synchronize_irq(pci_irq_vector(vp_dev->pci_dev, i)); +} + /* the notify function used when creating a virt queue */ bool vp_notify(struct virtqueue *vq) { diff --git a/drivers/virtio/virtio_pci_common.h b/drivers/virtio/virtio_pci_common.h index eb17a29fc7ef..2b84d5c1b5bc 100644 --- a/drivers/virtio/virtio_pci_common.h +++ b/drivers/virtio/virtio_pci_common.h @@ -105,6 +105,8 @@ static struct virtio_pci_device *to_vp_device(struct virtio_device *vdev) void vp_synchronize_vectors(struct virtio_device *vdev); /* the notify function used when creating a virt queue */ bool vp_notify(struct virtqueue *vq); +/* synchronize with callbacks */ +void vp_synchronize_vqs(struct virtio_device *vdev); /* the config->del_vqs() implementation */ void vp_del_vqs(struct virtio_device *vdev); /* the config->find_vqs() implementation */ diff --git a/drivers/virtio/virtio_pci_legacy.c b/drivers/virtio/virtio_pci_legacy.c index 6f4e34ce96b8..5a9e62320edc 100644 --- a/drivers/virtio/virtio_pci_legacy.c +++ b/drivers/virtio/virtio_pci_legacy.c @@ -192,6 +192,7 @@ static const struct virtio_config_ops virtio_pci_config_ops = { .reset = vp_reset, .find_vqs = vp_find_vqs, .del_vqs = vp_del_vqs, + .synchronize_vqs = vp_synchronize_vqs, .get_features = vp_get_features, .finalize_features = vp_finalize_features, .bus_name = vp_bus_name, diff --git a/drivers/virtio/virtio_pci_modern.c b/drivers/virtio/virtio_pci_modern.c index a2671a20ef77..584850389855 100644 --- a/drivers/virtio/virtio_pci_modern.c +++ b/drivers/virtio/virtio_pci_modern.c @@ -394,6 +394,7 @@ static const struct virtio_config_ops virtio_pci_config_nodev_ops = { .reset = vp_reset, .find_vqs = vp_modern_find_vqs, .del_vqs = vp_del_vqs, + .synchronize_vqs = vp_synchronize_vqs, .get_features = vp_get_features, .finalize_features = vp_finalize_features, .bus_name = vp_bus_name, @@ -411,6 +412,7 @@ static const struct virtio_config_ops virtio_pci_config_ops = { .reset = vp_reset, .find_vqs = vp_modern_find_vqs, .del_vqs = vp_del_vqs, + .synchronize_vqs = vp_synchronize_vqs, .get_features = vp_get_features, .finalize_features = vp_finalize_features, .bus_name = vp_bus_name, -- 2.25.1