From nobody Wed Nov 19 00:12:44 2025 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=1613150621; cv=none; d=zohomail.com; s=zohoarc; b=ZehhZmmlDE9pGnwvwkTUNg7dy1dBX50MFXDRkxPb+/lkIfAv9YFMNJWiNtOtny5aQcFnQ8QbYQCY8Ko1ohUvYTvOwIpeSFUFzUSUz1v+tE3VBTXpD3CYHzXhQGO+zCOhjpa8AzZPy4D/2opwHZ6ws9iDzQ7riONZ6rV6ML9eCzs= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1613150621; 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=S0kyGhpR8yB4K4YNl5zqpUon9HXiHudomNtiOKgzoaw=; b=fX4wOjUltPJ02MYvBL47/w1KIyjVg5WkrWuSGg2ZGJWzAPGSUBCrybhpgImwFdTSYgDrqv1XkB42Ogkr2D1jDn0A+ljFihgz8hl8z2DH0wX4GcjuHkD+v2U94nLD25OAVGhilMCVTrpXp5H4zvtyejaaSNQSQN6GeiuNoOimw2A= 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) header.from= Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1613150620972258.44920258569664; Fri, 12 Feb 2021 09:23:40 -0800 (PST) Received: from localhost ([::1]:37238 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1lAcAN-00080z-Co for importer@patchew.org; Fri, 12 Feb 2021 12:23:39 -0500 Received: from eggs.gnu.org ([2001:470:142:3::10]:44478) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1lAc7b-0005xB-CV for qemu-devel@nongnu.org; Fri, 12 Feb 2021 12:20:47 -0500 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:20255) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_CBC_SHA1:256) (Exim 4.90_1) (envelope-from ) id 1lAc7Y-00020s-Qv for qemu-devel@nongnu.org; Fri, 12 Feb 2021 12:20:47 -0500 Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-333-Kij5I4YxMD-wrJV7O-J8JA-1; Fri, 12 Feb 2021 12:20:42 -0500 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 47DBD192CC40 for ; Fri, 12 Feb 2021 17:20:41 +0000 (UTC) Received: from merkur.fritz.box (ovpn-112-163.ams2.redhat.com [10.36.112.163]) by smtp.corp.redhat.com (Postfix) with ESMTP id 89C9A5DF21; Fri, 12 Feb 2021 17:20:37 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1613150443; 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=S0kyGhpR8yB4K4YNl5zqpUon9HXiHudomNtiOKgzoaw=; b=eFY95le4TRaASZV2wRPZknujykLYeqgyQJ3vfAhf0TCHff0vRqkIGBhg+pB0EgloIiev79 GctT5Tlnlg3YnoedQi8wyfTUldXGKaDau8wMRYLV0vchWlo+4Mk0/XwYqihPel/5/Tafut phuV8PM42lcMJR08ha1B5+/ZtoYQcXw= X-MC-Unique: Kij5I4YxMD-wrJV7O-J8JA-1 From: Kevin Wolf To: qemu-devel@nongnu.org Subject: [PATCH 2/2] monitor/qmp: Stop processing requests when shutdown is requested Date: Fri, 12 Feb 2021 18:20:28 +0100 Message-Id: <20210212172028.288825-3-kwolf@redhat.com> In-Reply-To: <20210212172028.288825-1-kwolf@redhat.com> References: <20210212172028.288825-1-kwolf@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.14 Authentication-Results: relay.mimecast.com; auth=pass smtp.auth=CUSA124A263 smtp.mailfrom=kwolf@redhat.com X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: redhat.com Content-Transfer-Encoding: quoted-printable 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=216.205.24.124; envelope-from=kwolf@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -33 X-Spam_score: -3.4 X-Spam_bar: --- X-Spam_report: (-3.4 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.569, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_LOW=-0.7, RCVD_IN_MSPIKE_H3=0.001, RCVD_IN_MSPIKE_WL=0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: kwolf@redhat.com, armbru@redhat.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: pass (identity @redhat.com) Content-Type: text/plain; charset="utf-8" monitor_qmp_dispatcher_co() used to check whether shutdown is requested only when it would have to wait for new requests. If there were still some queued requests, it would try to execute all of them before shutting down. This can be surprising when the queued QMP commands take long or hang because Ctrl-C may not actually exit QEMU as soon as possible. Change monitor_qmp_dispatcher_co() so that it additionally checks whether shutdown is request before it gets a new request from the queue. Signed-off-by: Kevin Wolf --- monitor/qmp.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/monitor/qmp.c b/monitor/qmp.c index 43880fa623..2326bd7f9b 100644 --- a/monitor/qmp.c +++ b/monitor/qmp.c @@ -227,6 +227,11 @@ void coroutine_fn monitor_qmp_dispatcher_co(void *data) */ qatomic_mb_set(&qmp_dispatcher_co_busy, false); =20 + /* On shutdown, don't take any more requests from the queue */ + if (qmp_dispatcher_co_shutdown) { + return; + } + while (!(req_obj =3D monitor_qmp_requests_pop_any_with_lock())) { /* * No more requests to process. Wait to be reentered from --=20 2.29.2