From: "Eugenio Pérez" <eperezma@redhat.com>
To: qemu-devel@nongnu.org
Cc: Cindy Lu <lulu@redhat.com>,
Harpreet Singh Anand <hanand@xilinx.com>,
"Gonglei (Arei)" <arei.gonglei@huawei.com>,
Stefano Garzarella <sgarzare@redhat.com>,
Parav Pandit <parav@mellanox.com>, Eric Blake <eblake@redhat.com>,
Gautam Dawar <gdawar@xilinx.com>,
Markus Armbruster <armbru@redhat.com>,
Paolo Bonzini <pbonzini@redhat.com>,
Laurent Vivier <lvivier@redhat.com>,
"Michael S. Tsirkin" <mst@redhat.com>,
Jason Wang <jasowang@redhat.com>,
Stefan Hajnoczi <stefanha@redhat.com>,
Liuxiangdong <liuxiangdong5@huawei.com>,
Eli Cohen <eli@mellanox.com>, Cornelia Huck <cohuck@redhat.com>,
Zhu Lingshan <lingshan.zhu@intel.com>
Subject: [PATCH v7 06/12] vhost_net: Add NetClientInfo stop callback
Date: Thu, 4 Aug 2022 20:28:46 +0200 [thread overview]
Message-ID: <20220804182852.703398-7-eperezma@redhat.com> (raw)
In-Reply-To: <20220804182852.703398-1-eperezma@redhat.com>
Used by the backend to perform actions after the device is stopped.
In particular, vdpa net use it to unmap CVQ buffers to the device,
cleaning the actions performend in prepare().
Signed-off-by: Eugenio Pérez <eperezma@redhat.com>
---
include/net/net.h | 2 ++
hw/net/vhost_net.c | 3 +++
2 files changed, 5 insertions(+)
diff --git a/include/net/net.h b/include/net/net.h
index 3416bb3d46..7aa1ec0974 100644
--- a/include/net/net.h
+++ b/include/net/net.h
@@ -45,6 +45,7 @@ typedef struct NICConf {
typedef void (NetPoll)(NetClientState *, bool enable);
typedef bool (NetCanReceive)(NetClientState *);
typedef int (NetPrepare)(NetClientState *);
+typedef void (NetStop)(NetClientState *);
typedef ssize_t (NetReceive)(NetClientState *, const uint8_t *, size_t);
typedef ssize_t (NetReceiveIOV)(NetClientState *, const struct iovec *, int);
typedef void (NetCleanup) (NetClientState *);
@@ -73,6 +74,7 @@ typedef struct NetClientInfo {
NetReceiveIOV *receive_iov;
NetCanReceive *can_receive;
NetPrepare *prepare;
+ NetStop *stop;
NetCleanup *cleanup;
LinkStatusChanged *link_status_changed;
QueryRxFilter *query_rx_filter;
diff --git a/hw/net/vhost_net.c b/hw/net/vhost_net.c
index e1150d7532..10bca15446 100644
--- a/hw/net/vhost_net.c
+++ b/hw/net/vhost_net.c
@@ -320,6 +320,9 @@ static void vhost_net_stop_one(struct vhost_net *net,
net->nc->info->poll(net->nc, true);
}
vhost_dev_stop(&net->dev, dev);
+ if (net->nc->info->stop) {
+ net->nc->info->stop(net->nc);
+ }
vhost_dev_disable_notifiers(&net->dev, dev);
}
--
2.31.1
next prev parent reply other threads:[~2022-08-04 18:55 UTC|newest]
Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-08-04 18:28 [PATCH v7 00/12] NIC vhost-vdpa state restore via Shadow CVQ Eugenio Pérez
2022-08-04 18:28 ` [PATCH v7 01/12] vhost: stop transfer elem ownership in vhost_handle_guest_kick Eugenio Pérez
2022-08-05 3:48 ` Jason Wang
2022-08-04 18:28 ` [PATCH v7 02/12] vhost: use SVQ element ndescs instead of opaque data for desc validation Eugenio Pérez
2022-08-05 3:48 ` Jason Wang
2022-08-04 18:28 ` [PATCH v7 03/12] vhost: Delete useless read memory barrier Eugenio Pérez
2022-08-05 3:48 ` Jason Wang
2022-08-04 18:28 ` [PATCH v7 04/12] vhost: Do not depend on !NULL VirtQueueElement on vhost_svq_flush Eugenio Pérez
2022-08-05 3:50 ` Jason Wang
2022-08-04 18:28 ` [PATCH v7 05/12] vhost_net: Add NetClientInfo prepare callback Eugenio Pérez
2022-08-09 6:53 ` Jason Wang
2022-08-09 7:34 ` Eugenio Perez Martin
2022-08-04 18:28 ` Eugenio Pérez [this message]
2022-08-04 18:28 ` [PATCH v7 07/12] vdpa: add net_vhost_vdpa_cvq_info NetClientInfo Eugenio Pérez
2022-08-04 18:28 ` [PATCH v7 08/12] vdpa: Move command buffers map to start of net device Eugenio Pérez
2022-08-09 7:03 ` Jason Wang
2022-08-09 7:33 ` Eugenio Perez Martin
2022-08-09 7:48 ` Jason Wang
2022-08-09 8:03 ` Eugenio Perez Martin
2022-08-09 8:13 ` Jason Wang
2022-08-04 18:28 ` [PATCH v7 09/12] vdpa: Extract vhost_vdpa_net_cvq_add from vhost_vdpa_net_handle_ctrl_avail Eugenio Pérez
2022-08-09 7:11 ` Jason Wang
2022-08-04 18:28 ` [PATCH v7 10/12] vhost_net: add NetClientState->load() callback Eugenio Pérez
2022-08-04 18:28 ` [PATCH v7 11/12] vdpa: Add virtio-net mac address via CVQ at start Eugenio Pérez
2022-08-09 7:16 ` Jason Wang
2022-08-09 7:35 ` Eugenio Perez Martin
2022-08-09 7:49 ` Jason Wang
2022-08-04 18:28 ` [PATCH v7 12/12] vdpa: Delete CVQ migration blocker Eugenio Pérez
2022-08-09 7:17 ` Jason Wang
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20220804182852.703398-7-eperezma@redhat.com \
--to=eperezma@redhat.com \
--cc=arei.gonglei@huawei.com \
--cc=armbru@redhat.com \
--cc=cohuck@redhat.com \
--cc=eblake@redhat.com \
--cc=eli@mellanox.com \
--cc=gdawar@xilinx.com \
--cc=hanand@xilinx.com \
--cc=jasowang@redhat.com \
--cc=lingshan.zhu@intel.com \
--cc=liuxiangdong5@huawei.com \
--cc=lulu@redhat.com \
--cc=lvivier@redhat.com \
--cc=mst@redhat.com \
--cc=parav@mellanox.com \
--cc=pbonzini@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=sgarzare@redhat.com \
--cc=stefanha@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).