From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([209.51.188.92]:57126) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gonBL-0005B0-Rf for qemu-devel@nongnu.org; Wed, 30 Jan 2019 05:33:24 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gonBI-0003Sy-4C for qemu-devel@nongnu.org; Wed, 30 Jan 2019 05:33:22 -0500 Received: from mx1.redhat.com ([209.132.183.28]:46212) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gonBG-0003R4-0e for qemu-devel@nongnu.org; Wed, 30 Jan 2019 05:33:18 -0500 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 1976F58E38 for ; Wed, 30 Jan 2019 10:33:17 +0000 (UTC) From: "Dr. David Alan Gilbert (git)" Date: Wed, 30 Jan 2019 10:32:34 +0000 Message-Id: <20190130103236.18302-8-dgilbert@redhat.com> In-Reply-To: <20190130103236.18302-1-dgilbert@redhat.com> References: <20190130103236.18302-1-dgilbert@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Subject: [Qemu-devel] [PATCH v2 7/9] qmp: Add announce-self command List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org, jasowang@redhat.com, quintela@redhat.com, mst@redhat.com, eblake@redhat.com, armbru@redhat.com, berrange@redhat.com Cc: germano@redhat.com From: "Dr. David Alan Gilbert" Add a qmp command that can trigger guest announcements. It uses its own announce-timer instance, and parameters passed to it explicitly in the command. Like most qmp commands, it's in the main thread/bql, so there's no racing with any outstanding timer. Based on work of Germano Veit Michel and Vladislav Yasevich Signed-off-by: Dr. David Alan Gilbert --- net/announce.c | 8 ++++++++ qapi/net.json | 21 +++++++++++++++++++++ 2 files changed, 29 insertions(+) diff --git a/net/announce.c b/net/announce.c index 070f37a7fa..8cd9f4d909 100644 --- a/net/announce.c +++ b/net/announce.c @@ -12,6 +12,7 @@ #include "net/net.h" #include "qapi/clone-visitor.h" #include "qapi/qapi-visit-net.h" +#include "qapi/qapi-commands-net.h" #include "trace.h" =20 int64_t qemu_announce_timer_step(AnnounceTimer *timer) @@ -131,3 +132,10 @@ void qemu_announce_self(AnnounceTimer *timer, Announ= ceParameters *params) qemu_announce_timer_del(timer); } } + +void qmp_announce_self(AnnounceParameters *params, Error **errp) +{ + static AnnounceTimer announce_timer; + qemu_announce_self(&announce_timer, params); +} + diff --git a/qapi/net.json b/qapi/net.json index 5face0c14b..0710390747 100644 --- a/qapi/net.json +++ b/qapi/net.json @@ -707,3 +707,24 @@ 'max': 'int', 'rounds': 'int', 'step': 'int' } } + +## +# @announce-self: +# +# Trigger generation of broadcast RARP frames to update network switches= . +# This can be useful when network bonds fail-over the active slave. +# +# @params: AnnounceParameters giving timing and repetition count of anno= unce +# +# Example: +# +# -> { "execute": "announce-self" +# "arguments": { "params:" { +# "initial": 50, "max": 550, "rounds": 10, "step": 50 } } } +# <- { "return": {} } +# +# Since: 4.0 +## +{ 'command': 'announce-self', + 'data' : {'params': 'AnnounceParameters'} } + --=20 2.20.1