From nobody Thu Jul 17 14:01:19 2025 Delivered-To: importer2@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+importer2=patchew.org@nongnu.org; dmarc=pass(p=none dis=none) header.from=redhat.com ARC-Seal: i=1; a=rsa-sha256; t=1674563286; cv=none; d=zohomail.com; s=zohoarc; b=lvA4DDfROlrWo7/wHiGXOMRRt3nrIiAXjf3kSWdkx5z2RPUCfnq4yeZKAgVwr+5pwEB6qx2AIMFXF7ETRuxnnxTOmhTsWwF5SBxWCGZu4Dsng4KDnB5M8dtFQ+Ev7iDnbTXvZvhp/NJkzE06jmZ4J1jwUGssMhdvMLZz66ML5U0= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1674563286; 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=ax6lznNIc9851/0eevMLC7z6+mVrD+w2yWYkAGGf6Zs=; b=iZZCORxVnQCnj7XsEJqFNNrhqA1LBGPov6xLBYwLzczgkvmxzJkkyFdwKj9dMN08jZNHGofY6a34kNO/uhameYhazgCYCU0L4NxAsUK+FVDi4A4tnXfkW+50mq5mBuSgOg7uz98xLpbsVXiG2feiFa/QSLvdzvrZnWZPrA8I9C0= 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+importer2=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 1674563286402744.6570214890916; Tue, 24 Jan 2023 04:28:06 -0800 (PST) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1pKIHX-00021z-OX; Tue, 24 Jan 2023 07:20:07 -0500 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1pKIHV-0001zx-9J for qemu-devel@nongnu.org; Tue, 24 Jan 2023 07:20:05 -0500 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1pKIHL-0006R3-Nl for qemu-devel@nongnu.org; Tue, 24 Jan 2023 07:20:05 -0500 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-492-lPwcBDrKP8ykKO3LOszyMw-1; Tue, 24 Jan 2023 07:19:50 -0500 Received: from smtp.corp.redhat.com (int-mx09.intmail.prod.int.rdu2.redhat.com [10.11.54.9]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id B635938123AC; Tue, 24 Jan 2023 12:19:49 +0000 (UTC) Received: from blackfin.pond.sub.org (unknown [10.39.192.70]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 3507D492C14; Tue, 24 Jan 2023 12:19:49 +0000 (UTC) Received: by blackfin.pond.sub.org (Postfix, from userid 1000) id 9927421E6A28; Tue, 24 Jan 2023 13:19:46 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1674562794; 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=ax6lznNIc9851/0eevMLC7z6+mVrD+w2yWYkAGGf6Zs=; b=L2FrpQnl0ONri96CObxvhqe7gAHOjJaHTiSpKUJ92gLG/ZU83EDqBmgH316qx6GkvkVYWO 2v+AfGeSNLh9DZlgDmy3Om4AGT9IfhVd/yE94xNREZGy7jB++OIfAd9xS21HjSbUIYgYSn g2QyPGLLFKDLnGPXCcRzAmXZ5nQxbkk= X-MC-Unique: lPwcBDrKP8ykKO3LOszyMw-1 From: Markus Armbruster To: qemu-devel@nongnu.org Cc: pbonzini@redhat.com, kraxel@redhat.com, kwolf@redhat.com, hreitz@redhat.com, marcandre.lureau@redhat.com, dgilbert@redhat.com, mst@redhat.com, imammedo@redhat.com, ani@anisinha.ca, eduardo@habkost.net, marcel.apfelbaum@gmail.com, philmd@linaro.org, wangyanan55@huawei.com, jasowang@redhat.com, jiri@resnulli.us, berrange@redhat.com, thuth@redhat.com, quintela@redhat.com, stefanb@linux.vnet.ibm.com, stefanha@redhat.com, kvm@vger.kernel.org, qemu-block@nongnu.org Subject: [PATCH 08/32] trace: Move HMP commands from monitor/ to trace/ Date: Tue, 24 Jan 2023 13:19:22 +0100 Message-Id: <20230124121946.1139465-9-armbru@redhat.com> In-Reply-To: <20230124121946.1139465-1-armbru@redhat.com> References: <20230124121946.1139465-1-armbru@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Scanned-By: MIMEDefang 3.1 on 10.11.54.9 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+importer2=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=170.10.133.124; envelope-from=armbru@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, RCVD_IN_MSPIKE_H2=-0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=unavailable 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+importer2=patchew.org@nongnu.org Sender: qemu-devel-bounces+importer2=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @redhat.com) X-ZM-MESSAGEID: 1674563288263100001 Content-Type: text/plain; charset="utf-8" This moves these commands from MAINTAINERS sections "Human Monitor (HMP)" and "QMP" to "Tracing". Signed-off-by: Markus Armbruster Reviewed-by: Philippe Mathieu-Daud=C3=A9 Reviewed-by: Stefan Hajnoczi --- include/monitor/hmp.h | 3 + monitor/misc.c | 119 --------------------------------- trace/trace-hmp-cmds.c | 148 +++++++++++++++++++++++++++++++++++++++++ trace/meson.build | 1 + 4 files changed, 152 insertions(+), 119 deletions(-) create mode 100644 trace/trace-hmp-cmds.c diff --git a/include/monitor/hmp.h b/include/monitor/hmp.h index 5a75f4659c..58ed1bec62 100644 --- a/include/monitor/hmp.h +++ b/include/monitor/hmp.h @@ -155,5 +155,8 @@ void hmp_pcie_aer_inject_error(Monitor *mon, const QDic= t *qdict); void hmp_info_capture(Monitor *mon, const QDict *qdict); void hmp_stopcapture(Monitor *mon, const QDict *qdict); void hmp_wavcapture(Monitor *mon, const QDict *qdict); +void hmp_trace_event(Monitor *mon, const QDict *qdict); +void hmp_trace_file(Monitor *mon, const QDict *qdict); +void hmp_info_trace_events(Monitor *mon, const QDict *qdict); =20 #endif diff --git a/monitor/misc.c b/monitor/misc.c index 240d137327..2a6bc13e7f 100644 --- a/monitor/misc.c +++ b/monitor/misc.c @@ -39,12 +39,8 @@ #include "qapi/qmp/qdict.h" #include "qapi/qmp/qerror.h" #include "qom/object_interfaces.h" -#include "trace/control.h" #include "monitor/hmp-target.h" #include "monitor/hmp.h" -#ifdef CONFIG_TRACE_SIMPLE -#include "trace/simple.h" -#endif #include "exec/address-spaces.h" #include "exec/ioport.h" #include "block/qapi.h" @@ -54,7 +50,6 @@ #include "qapi/qapi-commands-misc.h" #include "qapi/qapi-commands-qom.h" #include "qapi/qapi-commands-run-state.h" -#include "qapi/qapi-commands-trace.h" #include "qapi/qapi-commands-machine.h" #include "qapi/qapi-init-commands.h" #include "qapi/error.h" @@ -156,50 +151,6 @@ static void do_help_cmd(Monitor *mon, const QDict *qdi= ct) hmp_help_cmd(mon, qdict_get_try_str(qdict, "name")); } =20 -static void hmp_trace_event(Monitor *mon, const QDict *qdict) -{ - const char *tp_name =3D qdict_get_str(qdict, "name"); - bool new_state =3D qdict_get_bool(qdict, "option"); - bool has_vcpu =3D qdict_haskey(qdict, "vcpu"); - int vcpu =3D qdict_get_try_int(qdict, "vcpu", 0); - Error *local_err =3D NULL; - - if (vcpu < 0) { - monitor_printf(mon, "argument vcpu must be positive"); - return; - } - - qmp_trace_event_set_state(tp_name, new_state, true, true, has_vcpu, vc= pu, &local_err); - if (local_err) { - error_report_err(local_err); - } -} - -#ifdef CONFIG_TRACE_SIMPLE -static void hmp_trace_file(Monitor *mon, const QDict *qdict) -{ - const char *op =3D qdict_get_try_str(qdict, "op"); - const char *arg =3D qdict_get_try_str(qdict, "arg"); - - if (!op) { - st_print_trace_file_status(); - } else if (!strcmp(op, "on")) { - st_set_trace_file_enabled(true); - } else if (!strcmp(op, "off")) { - st_set_trace_file_enabled(false); - } else if (!strcmp(op, "flush")) { - st_flush_trace_buffer(); - } else if (!strcmp(op, "set")) { - if (arg) { - st_set_trace_file(arg); - } - } else { - monitor_printf(mon, "unexpected argument \"%s\"\n", op); - hmp_help_cmd(mon, "trace-file"); - } -} -#endif - static void hmp_info_help(Monitor *mon, const QDict *qdict) { hmp_help_cmd(mon, "info"); @@ -344,37 +295,6 @@ static void hmp_info_history(Monitor *mon, const QDict= *qdict) } } =20 -static void hmp_info_trace_events(Monitor *mon, const QDict *qdict) -{ - const char *name =3D qdict_get_try_str(qdict, "name"); - bool has_vcpu =3D qdict_haskey(qdict, "vcpu"); - int vcpu =3D qdict_get_try_int(qdict, "vcpu", 0); - TraceEventInfoList *events; - TraceEventInfoList *elem; - Error *local_err =3D NULL; - - if (name =3D=3D NULL) { - name =3D "*"; - } - if (vcpu < 0) { - monitor_printf(mon, "argument vcpu must be positive"); - return; - } - - events =3D qmp_trace_event_get_state(name, has_vcpu, vcpu, &local_err); - if (local_err) { - error_report_err(local_err); - return; - } - - for (elem =3D events; elem !=3D NULL; elem =3D elem->next) { - monitor_printf(mon, "%s : state %u\n", - elem->value->name, - elem->value->state =3D=3D TRACE_EVENT_STATE_ENABLED= ? 1 : 0); - } - qapi_free_TraceEventInfoList(events); -} - void qmp_client_migrate_info(const char *protocol, const char *hostname, bool has_port, int64_t port, bool has_tls_port, int64_t tls_port, @@ -1535,45 +1455,6 @@ void netdev_del_completion(ReadLineState *rs, int nb= _args, const char *str) } } =20 -void info_trace_events_completion(ReadLineState *rs, int nb_args, const ch= ar *str) -{ - size_t len; - - len =3D strlen(str); - readline_set_completion_index(rs, len); - if (nb_args =3D=3D 2) { - TraceEventIter iter; - TraceEvent *ev; - char *pattern =3D g_strdup_printf("%s*", str); - trace_event_iter_init_pattern(&iter, pattern); - while ((ev =3D trace_event_iter_next(&iter)) !=3D NULL) { - readline_add_completion(rs, trace_event_get_name(ev)); - } - g_free(pattern); - } -} - -void trace_event_completion(ReadLineState *rs, int nb_args, const char *st= r) -{ - size_t len; - - len =3D strlen(str); - readline_set_completion_index(rs, len); - if (nb_args =3D=3D 2) { - TraceEventIter iter; - TraceEvent *ev; - char *pattern =3D g_strdup_printf("%s*", str); - trace_event_iter_init_pattern(&iter, pattern); - while ((ev =3D trace_event_iter_next(&iter)) !=3D NULL) { - readline_add_completion(rs, trace_event_get_name(ev)); - } - g_free(pattern); - } else if (nb_args =3D=3D 3) { - readline_add_completion_of(rs, str, "on"); - readline_add_completion_of(rs, str, "off"); - } -} - void watchdog_action_completion(ReadLineState *rs, int nb_args, const char= *str) { int i; diff --git a/trace/trace-hmp-cmds.c b/trace/trace-hmp-cmds.c new file mode 100644 index 0000000000..792876c34a --- /dev/null +++ b/trace/trace-hmp-cmds.c @@ -0,0 +1,148 @@ +/* + * HMP commands related to tracing + * + * Copyright (c) 2003-2004 Fabrice Bellard + * + * Permission is hereby granted, free of charge, to any person obtaining a= copy + * of this software and associated documentation files (the "Software"), t= o deal + * in the Software without restriction, including without limitation the r= ights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or se= ll + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included= in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS= OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OT= HER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING= FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS = IN + * THE SOFTWARE. + */ + +#include "qemu/osdep.h" +#include "monitor/hmp.h" +#include "monitor/monitor.h" +#include "qapi/error.h" +#include "qapi/qapi-commands-trace.h" +#include "qapi/qmp/qdict.h" +#include "trace/control.h" +#ifdef CONFIG_TRACE_SIMPLE +#include "trace/simple.h" +#endif + +void hmp_trace_event(Monitor *mon, const QDict *qdict) +{ + const char *tp_name =3D qdict_get_str(qdict, "name"); + bool new_state =3D qdict_get_bool(qdict, "option"); + bool has_vcpu =3D qdict_haskey(qdict, "vcpu"); + int vcpu =3D qdict_get_try_int(qdict, "vcpu", 0); + Error *local_err =3D NULL; + + if (vcpu < 0) { + monitor_printf(mon, "argument vcpu must be positive"); + return; + } + + qmp_trace_event_set_state(tp_name, new_state, true, true, has_vcpu, vc= pu, &local_err); + if (local_err) { + error_report_err(local_err); + } +} + +#ifdef CONFIG_TRACE_SIMPLE +void hmp_trace_file(Monitor *mon, const QDict *qdict) +{ + const char *op =3D qdict_get_try_str(qdict, "op"); + const char *arg =3D qdict_get_try_str(qdict, "arg"); + + if (!op) { + st_print_trace_file_status(); + } else if (!strcmp(op, "on")) { + st_set_trace_file_enabled(true); + } else if (!strcmp(op, "off")) { + st_set_trace_file_enabled(false); + } else if (!strcmp(op, "flush")) { + st_flush_trace_buffer(); + } else if (!strcmp(op, "set")) { + if (arg) { + st_set_trace_file(arg); + } + } else { + monitor_printf(mon, "unexpected argument \"%s\"\n", op); + hmp_help_cmd(mon, "trace-file"); + } +} +#endif + +void hmp_info_trace_events(Monitor *mon, const QDict *qdict) +{ + const char *name =3D qdict_get_try_str(qdict, "name"); + bool has_vcpu =3D qdict_haskey(qdict, "vcpu"); + int vcpu =3D qdict_get_try_int(qdict, "vcpu", 0); + TraceEventInfoList *events; + TraceEventInfoList *elem; + Error *local_err =3D NULL; + + if (name =3D=3D NULL) { + name =3D "*"; + } + if (vcpu < 0) { + monitor_printf(mon, "argument vcpu must be positive"); + return; + } + + events =3D qmp_trace_event_get_state(name, has_vcpu, vcpu, &local_err); + if (local_err) { + error_report_err(local_err); + return; + } + + for (elem =3D events; elem !=3D NULL; elem =3D elem->next) { + monitor_printf(mon, "%s : state %u\n", + elem->value->name, + elem->value->state =3D=3D TRACE_EVENT_STATE_ENABLED= ? 1 : 0); + } + qapi_free_TraceEventInfoList(events); +} + +void info_trace_events_completion(ReadLineState *rs, int nb_args, const ch= ar *str) +{ + size_t len; + + len =3D strlen(str); + readline_set_completion_index(rs, len); + if (nb_args =3D=3D 2) { + TraceEventIter iter; + TraceEvent *ev; + char *pattern =3D g_strdup_printf("%s*", str); + trace_event_iter_init_pattern(&iter, pattern); + while ((ev =3D trace_event_iter_next(&iter)) !=3D NULL) { + readline_add_completion(rs, trace_event_get_name(ev)); + } + g_free(pattern); + } +} + +void trace_event_completion(ReadLineState *rs, int nb_args, const char *st= r) +{ + size_t len; + + len =3D strlen(str); + readline_set_completion_index(rs, len); + if (nb_args =3D=3D 2) { + TraceEventIter iter; + TraceEvent *ev; + char *pattern =3D g_strdup_printf("%s*", str); + trace_event_iter_init_pattern(&iter, pattern); + while ((ev =3D trace_event_iter_next(&iter)) !=3D NULL) { + readline_add_completion(rs, trace_event_get_name(ev)); + } + g_free(pattern); + } else if (nb_args =3D=3D 3) { + readline_add_completion_of(rs, str, "on"); + readline_add_completion_of(rs, str, "off"); + } +} diff --git a/trace/meson.build b/trace/meson.build index 26b54714d5..d565948b09 100644 --- a/trace/meson.build +++ b/trace/meson.build @@ -1,3 +1,4 @@ +softmmu_ss.add(files('trace-hmp-cmds.c')) =20 specific_ss.add(files('control-target.c')) =20 --=20 2.39.0