From nobody Tue May 21 21:30:23 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass(p=none dis=none) header.from=redhat.com ARC-Seal: i=1; a=rsa-sha256; t=1662482320; cv=none; d=zohomail.com; s=zohoarc; b=lDramgFQ9Vdv4sWyhWbHuQKw9nNHRGu2Bd+3h7Tdrv5uGApFcOMPXuXF4smp0tX+h7eozT9Pk/n+IoOoDCoI/h/YrL55h89bmC6xhZPCrFX7+0dvbiOLjURXjEA2Xt3gbbrk56AU5ByQeDAXwA7n4FAnEv3kfp5q/JkgyLK3spg= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1662482320; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=OYCLbgtLx1pJHD2pvYNbWroV/3ZdXeXWRb+InzQMaQM=; b=XuifwYUd7a7w2kIHnTjizEOEw6RYu4a0nBohbi3VX2gTHRhWV18P/e2Mo1QbQQ7QuotVEi8llbvD6y1CXUFA70+vyFFzk2SryVOp5PTMq/GOHTWh9ovOJQMMPQWOTQgdUHuL4DCbiw69tQzRgADJNAzrtRgEO+VYSMKpe91CF2A= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass header.from= (p=none dis=none) Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1662482320739786.9898250888879; Tue, 6 Sep 2022 09:38:40 -0700 (PDT) Received: from localhost ([::1]:49564 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1oVbax-0006T7-4E for importer@patchew.org; Tue, 06 Sep 2022 12:38:39 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:56358) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1oVbZ1-0004EV-PP for qemu-devel@nongnu.org; Tue, 06 Sep 2022 12:36:40 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.129.124]:53158) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1oVbYy-00019V-Sv for qemu-devel@nongnu.org; Tue, 06 Sep 2022 12:36:38 -0400 Received: from mimecast-mx02.redhat.com (mx3-rdu2.redhat.com [66.187.233.73]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-655-lH7Q5Q5RNO6iq7Ml3AoOsw-1; Tue, 06 Sep 2022 12:36:30 -0400 Received: from smtp.corp.redhat.com (int-mx10.intmail.prod.int.rdu2.redhat.com [10.11.54.10]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id B2AA43802BBC; Tue, 6 Sep 2022 16:36:29 +0000 (UTC) Received: from eperezma.remote.csb (unknown [10.39.195.176]) by smtp.corp.redhat.com (Postfix) with ESMTP id CE203492C3B; Tue, 6 Sep 2022 16:36:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1662482194; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=OYCLbgtLx1pJHD2pvYNbWroV/3ZdXeXWRb+InzQMaQM=; b=B8WK67UwXF2EqfX4pQfAlD3fQQ6LJkbYFps652vrYJUXSboWKQdRI+Gkw0Chh05LTr0u/N 8XtZ7uNimOcURElhGGBnMR5GAxKxWm2UGKG/OfKwNKsRteTspE0lllrP9YYEwTyYRdhEHx vuYp8PIcnmFAccQuZtS/Xcvr98UcQf8= X-MC-Unique: lH7Q5Q5RNO6iq7Ml3AoOsw-1 From: =?UTF-8?q?Eugenio=20P=C3=A9rez?= To: qemu-devel@nongnu.org Cc: Paolo Bonzini , Harpreet Singh Anand , Cindy Lu , Liuxiangdong , Stefano Garzarella , "Michael S. Tsirkin" , Zhu Lingshan , Gautam Dawar , Si-Wei Liu , Eli Cohen , "Gonglei (Arei)" , Laurent Vivier , Cornelia Huck , Stefan Hajnoczi , Parav Pandit , Jason Wang Subject: [PATCH 1/3] virtio-net: do not reset vlan filtering at set_features Date: Tue, 6 Sep 2022 18:36:19 +0200 Message-Id: <20220906163621.1144675-2-eperezma@redhat.com> In-Reply-To: <20220906163621.1144675-1-eperezma@redhat.com> References: <20220906163621.1144675-1-eperezma@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable X-Scanned-By: MIMEDefang 2.85 on 10.11.54.10 Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=170.10.129.124; envelope-from=eperezma@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -27 X-Spam_score: -2.8 X-Spam_bar: -- X-Spam_report: (-2.8 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_LOW=-0.7, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: pass (identity @redhat.com) X-ZM-MESSAGEID: 1662482322170100001 This function is called after virtio_load, so all vlan configuration is lost in migration case. Just allow all the vlan-tagged packets if vlan is not configured, and trust device reset to clear all filtered vlans. Fixes: 0b1eaa8803 ("virtio-net: Do not filter VLANs without F_CTRL_VLAN") Signed-off-by: Eugenio P=C3=A9rez --- hw/net/virtio-net.c | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/hw/net/virtio-net.c b/hw/net/virtio-net.c index 63a8332cd0..c1bea3fd42 100644 --- a/hw/net/virtio-net.c +++ b/hw/net/virtio-net.c @@ -920,9 +920,7 @@ static void virtio_net_set_features(VirtIODevice *vdev,= uint64_t features) vhost_net_ack_features(get_vhost_net(nc->peer), features); } =20 - if (virtio_has_feature(features, VIRTIO_NET_F_CTRL_VLAN)) { - memset(n->vlans, 0, MAX_VLAN >> 3); - } else { + if (!virtio_has_feature(features, VIRTIO_NET_F_CTRL_VLAN)) { memset(n->vlans, 0xff, MAX_VLAN >> 3); } =20 --=20 2.31.1 From nobody Tue May 21 21:30:23 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass(p=none dis=none) header.from=redhat.com ARC-Seal: i=1; a=rsa-sha256; t=1662482325; cv=none; d=zohomail.com; s=zohoarc; b=CQT2C0AwrXe5/ObXS7Gcd0JDVo6F1C/OqDTtMJAV33cf+RaxxBuB/C7DaZeP61ec2p1tqgSz1yYPZKBPcjtFOaztfXrQdUlVTB+swn4FiUL6DTWP9Iu/bnNmT6k5p++MTMkpVFcoilHOruZwyk5gb7dvw+VN7G56hOliDL+pX9k= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1662482325; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=0/snyyw/WEVjIAx3YSMW+h3i4bkzEDABbuMagtE5LOU=; b=l3Apg5miunAw3l6tsOw6B77k3VKKcEfKppnoK8lnsgp8guFz8R3gRca53eyHA6ihH1BuUclANQR0wQ0Jsal8M5X+dlJxbhzZRng9LS7uFo33TFF3p3zADFEtqxCNtLd4S6ZaU0atzJB0JhgA3kklpwk90il1DL67k2cKGJcesak= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass header.from= (p=none dis=none) Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1662482325559199.43531306198815; Tue, 6 Sep 2022 09:38:45 -0700 (PDT) Received: from localhost ([::1]:48562 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1oVbb2-0006es-Jm for importer@patchew.org; Tue, 06 Sep 2022 12:38:44 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:56360) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1oVbZ1-0004Ek-St for qemu-devel@nongnu.org; Tue, 06 Sep 2022 12:36:40 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:28382) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1oVbYz-00019k-4b for qemu-devel@nongnu.org; Tue, 06 Sep 2022 12:36:38 -0400 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-504-m2vsuY0yOL6NIDhtTYM0UQ-1; Tue, 06 Sep 2022 12:36:35 -0400 Received: from smtp.corp.redhat.com (int-mx10.intmail.prod.int.rdu2.redhat.com [10.11.54.10]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id 52CA6803916; Tue, 6 Sep 2022 16:36:34 +0000 (UTC) Received: from eperezma.remote.csb (unknown [10.39.195.176]) by smtp.corp.redhat.com (Postfix) with ESMTP id 0DDA9492C3B; Tue, 6 Sep 2022 16:36:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1662482196; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=0/snyyw/WEVjIAx3YSMW+h3i4bkzEDABbuMagtE5LOU=; b=h/sI+VIgPCHnRE9ZIgaGoCYIJp8Nj1U3TAhlxsWLCkxIhw1IMK+DIrCU5jgU1l8d4paGDq r6o96awb0eSoFubJrDeSf4jdT/EY8ZH0vKPbWBr5miZ997ro3Wgi3SPCHXl9FhNhvQTJFk 9VY88hW8j9aJDtxRPjGF1hmFOKVwCuw= X-MC-Unique: m2vsuY0yOL6NIDhtTYM0UQ-1 From: =?UTF-8?q?Eugenio=20P=C3=A9rez?= To: qemu-devel@nongnu.org Cc: Paolo Bonzini , Harpreet Singh Anand , Cindy Lu , Liuxiangdong , Stefano Garzarella , "Michael S. Tsirkin" , Zhu Lingshan , Gautam Dawar , Si-Wei Liu , Eli Cohen , "Gonglei (Arei)" , Laurent Vivier , Cornelia Huck , Stefan Hajnoczi , Parav Pandit , Jason Wang Subject: [PATCH 2/3] vdpa: load vlan configuration at NIC startup Date: Tue, 6 Sep 2022 18:36:20 +0200 Message-Id: <20220906163621.1144675-3-eperezma@redhat.com> In-Reply-To: <20220906163621.1144675-1-eperezma@redhat.com> References: <20220906163621.1144675-1-eperezma@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable X-Scanned-By: MIMEDefang 2.85 on 10.11.54.10 Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=170.10.133.124; envelope-from=eperezma@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: pass (identity @redhat.com) X-ZM-MESSAGEID: 1662482326134100001 To have enabled vlans at device startup may happen in the destination of a live migration, so this configuration must be restored. At this moment the code is not accessible, since SVQ refuses to start if vlan feature is exposed by the device. Signed-off-by: Eugenio P=C3=A9rez --- net/vhost-vdpa.c | 46 ++++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 44 insertions(+), 2 deletions(-) diff --git a/net/vhost-vdpa.c b/net/vhost-vdpa.c index 4bc3fd01a8..ecbfd08eb9 100644 --- a/net/vhost-vdpa.c +++ b/net/vhost-vdpa.c @@ -100,6 +100,8 @@ static const uint64_t vdpa_svq_device_features =3D BIT_ULL(VIRTIO_NET_F_RSC_EXT) | BIT_ULL(VIRTIO_NET_F_STANDBY); =20 +#define MAX_VLAN (1 << 12) /* Per 802.1Q definition */ + VHostNetState *vhost_vdpa_get_vhost_net(NetClientState *nc) { VhostVDPAState *s =3D DO_UPCAST(VhostVDPAState, nc, nc); @@ -423,6 +425,47 @@ static int vhost_vdpa_net_load_mq(VhostVDPAState *s, return *s->status !=3D VIRTIO_NET_OK; } =20 +static int vhost_vdpa_net_load_single_vlan(VhostVDPAState *s, + const VirtIONet *n, + uint16_t vid) +{ + ssize_t dev_written =3D vhost_vdpa_net_load_cmd(s, VIRTIO_NET_CTRL_VLA= N, + VIRTIO_NET_CTRL_VLAN_ADD, + &vid, sizeof(vid)); + if (unlikely(dev_written < 0)) { + return dev_written; + } + + if (unlikely(*s->status !=3D VIRTIO_NET_OK)) { + return -EINVAL; + } + + return 0; +} + +static int vhost_vdpa_net_load_vlan(VhostVDPAState *s, + const VirtIONet *n) +{ + uint64_t features =3D n->parent_obj.guest_features; + + if (!(features & BIT_ULL(VIRTIO_NET_F_CTRL_VLAN))) { + return 0; + } + + for (int i =3D 0; i < MAX_VLAN >> 5; i++) { + for (int j =3D 0; n->vlans[i] && j <=3D 0x1f; j++) { + if (n->vlans[i] & (1U << j)) { + int r =3D vhost_vdpa_net_load_single_vlan(s, n, (i << 5) += j); + if (unlikely(r !=3D 0)) { + return r; + } + } + } + } + + return 0; +} + static int vhost_vdpa_net_load(NetClientState *nc) { VhostVDPAState *s =3D DO_UPCAST(VhostVDPAState, nc, nc); @@ -445,8 +488,7 @@ static int vhost_vdpa_net_load(NetClientState *nc) if (unlikely(r)) { return r; } - - return 0; + return vhost_vdpa_net_load_vlan(s, n); } =20 static NetClientInfo net_vhost_vdpa_cvq_info =3D { --=20 2.31.1 From nobody Tue May 21 21:30:23 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass(p=none dis=none) header.from=redhat.com ARC-Seal: i=1; a=rsa-sha256; t=1662482500; cv=none; d=zohomail.com; s=zohoarc; b=EgT6b1TPa9N6gbeinHpXSnbeSo1QYnGQ9IQ0NlrEcbdAwRXC9Wi0a438eaN6Ec1iGb/SproqmbK2SAgODeiU/dS9Jqn8bljF4rtxjK1RIb4siRFilhqescgSA+90Rvm2cw0F22QKqs9rYG6MVrTs1EdUQb+gED+CCWqc6/bt0oU= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1662482500; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=uAG5vvx0dc4U+p0OlwxEIJp96aLvStB6XTeITvPepQU=; b=l34hOzbsZjZEyEsDalbvFEn1/p3W6fX64ruSDzuUC2RraSZo2Pqqq5NWPlIRqj4IGCx2/1zJ72xsw4wUaqoCIXgWN93TjJHnpZ+dcg3IETUmEuqZV/9jh0vsy9wBVvIy0JE7a2b7gPbKsFJ7rYAARspLUHClcZrDDGa6DClpktY= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass header.from= (p=none dis=none) Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1662482500794501.6228134933358; Tue, 6 Sep 2022 09:41:40 -0700 (PDT) Received: from localhost ([::1]:54784 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1oVbdq-0001s8-N3 for importer@patchew.org; Tue, 06 Sep 2022 12:41:38 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:56362) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1oVbZ6-0004Kl-2R for qemu-devel@nongnu.org; Tue, 06 Sep 2022 12:36:44 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:51457) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1oVbZ4-0001AB-JO for qemu-devel@nongnu.org; Tue, 06 Sep 2022 12:36:43 -0400 Received: from mimecast-mx02.redhat.com (mx3-rdu2.redhat.com [66.187.233.73]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-672-pqvaccugMMCSSElmSIgxyA-1; Tue, 06 Sep 2022 12:36:37 -0400 Received: from smtp.corp.redhat.com (int-mx10.intmail.prod.int.rdu2.redhat.com [10.11.54.10]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id 712A13C0ED49; Tue, 6 Sep 2022 16:36:37 +0000 (UTC) Received: from eperezma.remote.csb (unknown [10.39.195.176]) by smtp.corp.redhat.com (Postfix) with ESMTP id 9A9A6403349; Tue, 6 Sep 2022 16:36:34 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1662482202; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=uAG5vvx0dc4U+p0OlwxEIJp96aLvStB6XTeITvPepQU=; b=hg1viELJj9QMF2rjONWt/1o1qVRDfhEoDLwGmvk5H1DVeqQU7LUwBNV+EfsYmX7/9NbIpW L9he17J63qc5c4J+QgqxWmTWaO3elw5xA+GhpGXMsuFdgytf6hvShpaps/TDQGH0Czs/jD ON80k6Di14ECm5rsb9unyglVInw6hjM= X-MC-Unique: pqvaccugMMCSSElmSIgxyA-1 From: =?UTF-8?q?Eugenio=20P=C3=A9rez?= To: qemu-devel@nongnu.org Cc: Paolo Bonzini , Harpreet Singh Anand , Cindy Lu , Liuxiangdong , Stefano Garzarella , "Michael S. Tsirkin" , Zhu Lingshan , Gautam Dawar , Si-Wei Liu , Eli Cohen , "Gonglei (Arei)" , Laurent Vivier , Cornelia Huck , Stefan Hajnoczi , Parav Pandit , Jason Wang Subject: [PATCH 3/3] vdpa: Support VLAN on nic control shadow virtqueue Date: Tue, 6 Sep 2022 18:36:21 +0200 Message-Id: <20220906163621.1144675-4-eperezma@redhat.com> In-Reply-To: <20220906163621.1144675-1-eperezma@redhat.com> References: <20220906163621.1144675-1-eperezma@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable X-Scanned-By: MIMEDefang 2.85 on 10.11.54.10 Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=170.10.133.124; envelope-from=eperezma@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: pass (identity @redhat.com) X-ZM-MESSAGEID: 1662482502928100001 Update the virtio-net device model with each guest's update of vlan through control virtqueue, and accept creating a SVQ with a device exposing vlan feature bit. Done in the same commit since a malicious guest could send vlan commands otherwise. Signed-off-by: Eugenio P=C3=A9rez --- net/vhost-vdpa.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/net/vhost-vdpa.c b/net/vhost-vdpa.c index ecbfd08eb9..40f7c60399 100644 --- a/net/vhost-vdpa.c +++ b/net/vhost-vdpa.c @@ -94,6 +94,7 @@ static const uint64_t vdpa_svq_device_features =3D BIT_ULL(VIRTIO_NET_F_MRG_RXBUF) | BIT_ULL(VIRTIO_NET_F_STATUS) | BIT_ULL(VIRTIO_NET_F_CTRL_VQ) | + BIT_ULL(VIRTIO_NET_F_CTRL_VLAN) | BIT_ULL(VIRTIO_NET_F_MQ) | BIT_ULL(VIRTIO_F_ANY_LAYOUT) | BIT_ULL(VIRTIO_NET_F_CTRL_MAC_ADDR) | @@ -538,6 +539,16 @@ static bool vhost_vdpa_net_cvq_validate_cmd(const void= *out_buf, size_t len) __func__, ctrl.cmd); }; break; + case VIRTIO_NET_CTRL_VLAN: + switch (ctrl->cmd) { + case VIRTIO_NET_CTRL_VLAN_ADD: + case VIRTIO_NET_CTRL_VLAN_DEL: + return true; + default: + qemu_log_mask(LOG_GUEST_ERROR, "%s: invalid vlan cmd %u\n", + __func__, ctrl->cmd); + }; + break; default: qemu_log_mask(LOG_GUEST_ERROR, "%s: invalid control class %u\n", __func__, ctrl.class); --=20 2.31.1