From nobody Sun Oct 26 22:52:56 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=1652512105; cv=none; d=zohomail.com; s=zohoarc; b=Be49WI0abXmku2MMfWV6YPLctmRQf3aIu+C5O5SbV3reOaJDtPaLBOdeMBqf+3aHR8OLMUM4MjQYviGTihRtpr8Iw3IY22L/7ZJTmPV+daxKjZHfx7phw370tA9U5LQR0YgMqG0iB5FWlDdjy8z+NvjOJ70Z8exfh8lHS/7qjNQ= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1652512105; 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=FEUjVCbP7E9+0iLTdLAwCl6ilV5z1Ymdz2a6B1RFVzE=; b=la4232sG0IwfhZLgQ5X9LSyKHaXiBSACKvBVEYIBgdOzNmiKUZ0iyzoQ06raVfaEyEn20eEbD0IstWVxtnjQFVensA7FtC6A2YidlPiAGLaUic6DX3E0mSvn0OFtWbcQ+3OZHUl4NA3jOLZKq1AeHuA4uJzm8y8iEw2h9+zs3B0= 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 1652512105238895.5442585117494; Sat, 14 May 2022 00:08:25 -0700 (PDT) Received: from localhost ([::1]:54432 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1nplt1-0000A1-Qt for importer2@patchew.org; Sat, 14 May 2022 03:08:24 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:33224) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1nplbb-0008BQ-2o for qemu-devel@nongnu.org; Sat, 14 May 2022 02:50:23 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:25242) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1nplbY-0007fT-9y for qemu-devel@nongnu.org; Sat, 14 May 2022 02:50:21 -0400 Received: from mail-wm1-f72.google.com (mail-wm1-f72.google.com [209.85.128.72]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-90-QFphSwiCO_ul-46whtrJxw-1; Sat, 14 May 2022 02:50:18 -0400 Received: by mail-wm1-f72.google.com with SMTP id h6-20020a7bc926000000b0039470bcb9easo3856420wml.1 for ; Fri, 13 May 2022 23:50:18 -0700 (PDT) Received: from [192.168.10.118] ([2001:b07:6468:f312:c8dd:75d4:99ab:290a]) by smtp.gmail.com with ESMTPSA id c13-20020adfa70d000000b0020c5253d8bfsm4091945wrd.11.2022.05.13.23.50.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 13 May 2022 23:50:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1652511019; 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=FEUjVCbP7E9+0iLTdLAwCl6ilV5z1Ymdz2a6B1RFVzE=; b=B30DE5gg07iM0A2Fp5jivjiwYefoiFO5DWkigfVua8hT9j/1pp7nLKETWAUtZ43uBw8noC nVJLgzBR+55WILfu36XB75xJMAKtajoWPozXeQCLK7FLfmzFAWCecd4Lk+pHbHRflWr+Sn h7MRdZhlcRBBHlfik2xYhdhU4QKssU0= X-MC-Unique: QFphSwiCO_ul-46whtrJxw-1 X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=FEUjVCbP7E9+0iLTdLAwCl6ilV5z1Ymdz2a6B1RFVzE=; b=FwXOAfuKzanvKN9cXT7966yZzl0s6MGnbaMBodeJoa2HGTxVonrMljY06pCDL4+zeM 8fgOq3IM5TIe85AiPprY01u8vlHNy6pQWSgifrDV6ZDejCniG7I8+g4OY43ZtJhtguWZ votLeA11SFduUci4F0cFzOq02m+oJOBtXTGls4BuhfuoKbXrz3/Vv7nPNrZFDZxhgd1G iPfdNWIQX3C2pdZagwEq5Ap0C/xywN8BhBHUIu780NTbMIe+AfqJTCwRtP5rbp3gbRFQ cmB2mid4l6079sLQO6mEWtB0/g3oKKfStoIegMl9tvS68QY4E3GYb+UKwKvb9bBzT2B7 oezA== X-Gm-Message-State: AOAM531bJaoeBIAeefDsZR3aClKxnY6jhx4ZKf44mjU0u22ISKIg4PpT O2IwVgX7q4FEwMrSVkOGcxy9WpU+cI5DhLs4Z3CRKywGo8J5fpw0pW8UWb3C+lyEVoH96kM/ynQ L7ZBlZFbriuwqZ1hQPa78yC79V6piUevXQ/2mU+76ny+QozrTjk1UAPJ70iaQKF8nAlo= X-Received: by 2002:a05:6000:38b:b0:20c:53af:747d with SMTP id u11-20020a056000038b00b0020c53af747dmr6540628wrf.22.1652511017032; Fri, 13 May 2022 23:50:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzvfJ822hbg6rnyGOARRrMbPSjySxb4bbLEu26XdrixLVS5JoUT5VTYLu5dFcbBqg2cLw88rA== X-Received: by 2002:a05:6000:38b:b0:20c:53af:747d with SMTP id u11-20020a056000038b00b0020c53af747dmr6540615wrf.22.1652511016774; Fri, 13 May 2022 23:50:16 -0700 (PDT) From: Paolo Bonzini To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, nsaenzju@redhat.com Subject: [PATCH v3 1/3] thread-pool: optimize scheduling of completion bottom half Date: Sat, 14 May 2022 08:50:10 +0200 Message-Id: <20220514065012.1149539-2-pbonzini@redhat.com> X-Mailer: git-send-email 2.36.0 In-Reply-To: <20220514065012.1149539-1-pbonzini@redhat.com> References: <20220514065012.1149539-1-pbonzini@redhat.com> MIME-Version: 1.0 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+importer2=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=170.10.133.124; envelope-from=pbonzini@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -28 X-Spam_score: -2.9 X-Spam_bar: -- X-Spam_report: (-2.9 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.082, 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+importer2=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: pass (identity @redhat.com) X-ZM-MESSAGEID: 1652512106415100001 Content-Type: text/plain; charset="utf-8" The completion bottom half was scheduled within the pool->lock critical section. That actually results in worse performance, because the worker thread can run its own small critical section and go to sleep before the bottom half starts running. Note that this simple change does not produce an improvement without changing the thread pool QemuSemaphore to a condition variable. Signed-off-by: Paolo Bonzini Signed-off-by: Paolo Bonzini Reviewed-by: Nicolas Saenz Julienne Reviewed-by: Stefan Hajnoczi --- util/thread-pool.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/util/thread-pool.c b/util/thread-pool.c index 196835b4d3..4979f30ca3 100644 --- a/util/thread-pool.c +++ b/util/thread-pool.c @@ -127,9 +127,8 @@ static void *worker_thread(void *opaque) smp_wmb(); req->state =3D THREAD_DONE; =20 - qemu_mutex_lock(&pool->lock); - qemu_bh_schedule(pool->completion_bh); + qemu_mutex_lock(&pool->lock); } =20 pool->cur_threads--; --=20 2.36.0 From nobody Sun Oct 26 22:52:56 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=1652512441; cv=none; d=zohomail.com; s=zohoarc; b=L5ZXSM7BG/8XZ1YFkf9q3JKMvi3DqvgNkholz2PXXQWWPQDfGK/q4j0HbLTJv+7bgw8UJIZuncCRpj89lqlJWoXKdnVSeHnbgrWoahKtWsOtAmRGibONTGYJx6nbQ4m16mVUrn9rk93e7vQdyhVnVPIdj+VYQC+N2JxejWY2E3s= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1652512441; 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=Goert/XybtEtVkrF/ANLn1NzOTmfBrnUeEE5CL4GFx0=; b=AIab4m8Ev6evzzWQDSLLEBnLFPqkG2TVDJFsU22dZgMTzp+T9vOVRZ0pF/iGhVnyYIkOAKCYUcVNku8WMRR+zk6hj7fr+/6q1iCLnkuiu/83ElRmvjOu0lzP1C9dI1OxDTgmbmlGH7NlbEOR569368t9NwEt0uhGOQKIq5cyCeg= 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 1652512441022860.5729205443914; Sat, 14 May 2022 00:14:01 -0700 (PDT) Received: from localhost ([::1]:33538 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1nplyR-0005vm-DU for importer2@patchew.org; Sat, 14 May 2022 03:13:59 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:33246) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1nplbc-0008De-7u for qemu-devel@nongnu.org; Sat, 14 May 2022 02:50:24 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.129.124]:45152) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1nplba-0007gJ-Bl for qemu-devel@nongnu.org; Sat, 14 May 2022 02:50:23 -0400 Received: from mail-wm1-f72.google.com (mail-wm1-f72.google.com [209.85.128.72]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-421-qQ3I1U0aP4mBqkZZHkFpHQ-1; Sat, 14 May 2022 02:50:20 -0400 Received: by mail-wm1-f72.google.com with SMTP id 205-20020a1c02d6000000b003928cd3853aso7053713wmc.9 for ; Fri, 13 May 2022 23:50:19 -0700 (PDT) Received: from [192.168.10.118] ([2001:b07:6468:f312:c8dd:75d4:99ab:290a]) by smtp.gmail.com with ESMTPSA id e9-20020adfc849000000b0020c5253d926sm4032689wrh.114.2022.05.13.23.50.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 13 May 2022 23:50:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1652511021; 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-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=Goert/XybtEtVkrF/ANLn1NzOTmfBrnUeEE5CL4GFx0=; b=jVYF5wKc9ELTvK3FprzFkLI4rrhS1JjAStANB5Uz3xcUEX7PXfG5CMBWDVB6l4tXu455uG GD0S68Oi3UgR1pTutwII8jDz20GDHAKIHFo7QvGhgkRcB6jCJ43K3v8F+E4GtlA52zDJwW u8ZMr+VKkhg8spDtCN+AN4hJHBClTxw= X-MC-Unique: qQ3I1U0aP4mBqkZZHkFpHQ-1 X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Goert/XybtEtVkrF/ANLn1NzOTmfBrnUeEE5CL4GFx0=; b=6McQ91oUh3LuLWLGnMzsNYUyf6c9ncN8mqh+jFCUlHntrqb7iAs2oxKY/6KvUq0hBQ RTaIeFP5MlXowqQp1WvkoGU/hyXj719cS63Qf264N8V577ydtQJTfDpulubkm+q+keki lvcqj4TQz+vidforw5HEOfYl6o5kiiUfwohLEs1+0+SzQJlNXc07e0ctzkYwEL4Ol9uu f0L6qCxg87n/XS2MBs3jZ87YdpViY7qWmI3kP6cYcbfXEa3uVg+mwkZwkcaIdOW7l5Hv i7x1ctm1OWWhGO5XMJ9F+sgn17HiYFrqNMCdBfegsf3nKJ3FypMkQyqyq3IuFmHkdh+j qJIA== X-Gm-Message-State: AOAM532gL2vIZ73+dznCUmZTXAGxuvXOCgmjgOTaxE74XrjsubLHoHw5 4CEBZaj+4vGGqVWDFDMntHYYFlYQQJ/oW5lpd9cg/hwhZ9DWO38armOFc5YWDRlLQea+9K3Onk9 TEE7Zx7BNNeQ0giOUDN6DtiOgyjSyXJOz4n6V8G+/0g+tx49WJFPC+Ajw1PAsyuRh5Nc= X-Received: by 2002:a05:600c:19ca:b0:394:8dc0:b5c2 with SMTP id u10-20020a05600c19ca00b003948dc0b5c2mr7718428wmq.167.1652511018508; Fri, 13 May 2022 23:50:18 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwHlfxk0oEY3E4mo/7i1NOHNYsQ+BMxFZ4qZ8LR5Yxo1lUW5E94WY4uZ07KiDiNhxqE9chCZg== X-Received: by 2002:a05:600c:19ca:b0:394:8dc0:b5c2 with SMTP id u10-20020a05600c19ca00b003948dc0b5c2mr7718408wmq.167.1652511018207; Fri, 13 May 2022 23:50:18 -0700 (PDT) From: Paolo Bonzini To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, nsaenzju@redhat.com, =?UTF-8?q?Luk=C3=A1=C5=A1=20Doktor?= Subject: [PATCH v3 2/3] thread-pool: replace semaphore with condition variable Date: Sat, 14 May 2022 08:50:11 +0200 Message-Id: <20220514065012.1149539-3-pbonzini@redhat.com> X-Mailer: git-send-email 2.36.0 In-Reply-To: <20220514065012.1149539-1-pbonzini@redhat.com> References: <20220514065012.1149539-1-pbonzini@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Type: text/plain 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+importer2=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=170.10.129.124; envelope-from=pbonzini@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -18 X-Spam_score: -1.9 X-Spam_bar: - X-Spam_report: (-1.9 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.082, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, PP_MIME_FAKE_ASCII_TEXT=0.999, 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+importer2=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: pass (identity @redhat.com) X-ZM-MESSAGEID: 1652512442381100001 Since commit f9fc8932b1 ("thread-posix: remove the posix semaphore support", 2022-04-06) QemuSemaphore has its own mutex and condition variable; this adds unnecessary overhead on I/O with small block sizes. Check the QTAILQ directly instead of adding the indirection of a semaphore's count. Using a semaphore has not been necessary since qemu_cond_timedwait was introduced; the new code has to be careful about spurious wakeups but it is simpler, for example thread_pool_cancel does not have to worry about synchronizing the semaphore count with the number of elements of pool->request_list. Note that the return value of qemu_cond_timedwait (0 for timeout, 1 for signal or spurious wakeup) is different from that of qemu_sem_timedwait (-1 for timeout, 0 for success). Reported-by: Luk=C3=A1=C5=A1 Doktor Suggested-by: Stefan Hajnoczi Signed-off-by: Paolo Bonzini Reviewed-by: Nicolas Saenz Julienne --- util/thread-pool.c | 68 +++++++++++++++++++--------------------------- 1 file changed, 28 insertions(+), 40 deletions(-) diff --git a/util/thread-pool.c b/util/thread-pool.c index 4979f30ca3..6bbf24754a 100644 --- a/util/thread-pool.c +++ b/util/thread-pool.c @@ -57,7 +57,7 @@ struct ThreadPool { QEMUBH *completion_bh; QemuMutex lock; QemuCond worker_stopped; - QemuSemaphore sem; + QemuCond request_cond; QEMUBH *new_thread_bh; =20 /* The following variables are only accessed from one AioContext. */ @@ -74,23 +74,6 @@ struct ThreadPool { int max_threads; }; =20 -static inline bool back_to_sleep(ThreadPool *pool, int ret) -{ - /* - * The semaphore timed out, we should exit the loop except when: - * - There is work to do, we raced with the signal. - * - The max threads threshold just changed, we raced with the signal. - * - The thread pool forces a minimum number of readily available thr= eads. - */ - if (ret =3D=3D -1 && (!QTAILQ_EMPTY(&pool->request_list) || - pool->cur_threads > pool->max_threads || - pool->cur_threads <=3D pool->min_threads)) { - return true; - } - - return false; -} - static void *worker_thread(void *opaque) { ThreadPool *pool =3D opaque; @@ -99,20 +82,25 @@ static void *worker_thread(void *opaque) pool->pending_threads--; do_spawn_thread(pool); =20 - while (!pool->stopping) { + while (!pool->stopping && pool->cur_threads <=3D pool->max_threads) { ThreadPoolElement *req; int ret; =20 - do { + if (QTAILQ_EMPTY(&pool->request_list)) { pool->idle_threads++; - qemu_mutex_unlock(&pool->lock); - ret =3D qemu_sem_timedwait(&pool->sem, 10000); - qemu_mutex_lock(&pool->lock); + ret =3D qemu_cond_timedwait(&pool->request_cond, &pool->lock, = 10000); pool->idle_threads--; - } while (back_to_sleep(pool, ret)); - if (ret =3D=3D -1 || pool->stopping || - pool->cur_threads > pool->max_threads) { - break; + if (ret =3D=3D 0 && + QTAILQ_EMPTY(&pool->request_list) && + pool->cur_threads > pool->min_threads) { + /* Timed out + no work to do + no need for warm threads = =3D exit. */ + break; + } + /* + * Even if there was some work to do, check if there aren't + * too many worker threads before picking it up. + */ + continue; } =20 req =3D QTAILQ_FIRST(&pool->request_list); @@ -134,6 +122,12 @@ static void *worker_thread(void *opaque) pool->cur_threads--; qemu_cond_signal(&pool->worker_stopped); qemu_mutex_unlock(&pool->lock); + + /* + * Wake up another thread, in case we got a wakeup but decided + * to exit due to pool->cur_threads > pool->max_threads. + */ + qemu_cond_signal(&pool->worker_stopped); return NULL; } =20 @@ -229,13 +223,7 @@ static void thread_pool_cancel(BlockAIOCB *acb) trace_thread_pool_cancel(elem, elem->common.opaque); =20 QEMU_LOCK_GUARD(&pool->lock); - if (elem->state =3D=3D THREAD_QUEUED && - /* No thread has yet started working on elem. we can try to "steal" - * the item from the worker if we can get a signal from the - * semaphore. Because this is non-blocking, we can do it with - * the lock taken and ensure that elem will remain THREAD_QUEUED. - */ - qemu_sem_timedwait(&pool->sem, 0) =3D=3D 0) { + if (elem->state =3D=3D THREAD_QUEUED) { QTAILQ_REMOVE(&pool->request_list, elem, reqs); qemu_bh_schedule(pool->completion_bh); =20 @@ -280,7 +268,7 @@ BlockAIOCB *thread_pool_submit_aio(ThreadPool *pool, } QTAILQ_INSERT_TAIL(&pool->request_list, req, reqs); qemu_mutex_unlock(&pool->lock); - qemu_sem_post(&pool->sem); + qemu_cond_signal(&pool->request_cond); return &req->common; } =20 @@ -323,7 +311,7 @@ void thread_pool_update_params(ThreadPool *pool, AioCon= text *ctx) * We either have to: * - Increase the number available of threads until over the min_thre= ads * threshold. - * - Decrease the number of available threads until under the max_thr= eads + * - Bump the worker threads so that they exit, until under the max_t= hreads * threshold. * - Do nothing. The current number of threads fall in between the mi= n and * max thresholds. We'll let the pool manage itself. @@ -333,7 +321,7 @@ void thread_pool_update_params(ThreadPool *pool, AioCon= text *ctx) } =20 for (int i =3D pool->cur_threads; i > pool->max_threads; i--) { - qemu_sem_post(&pool->sem); + qemu_cond_signal(&pool->request_cond); } =20 qemu_mutex_unlock(&pool->lock); @@ -350,7 +338,7 @@ static void thread_pool_init_one(ThreadPool *pool, AioC= ontext *ctx) pool->completion_bh =3D aio_bh_new(ctx, thread_pool_completion_bh, poo= l); qemu_mutex_init(&pool->lock); qemu_cond_init(&pool->worker_stopped); - qemu_sem_init(&pool->sem, 0); + qemu_cond_init(&pool->request_cond); pool->new_thread_bh =3D aio_bh_new(ctx, spawn_thread_bh_fn, pool); =20 QLIST_INIT(&pool->head); @@ -383,15 +371,15 @@ void thread_pool_free(ThreadPool *pool) =20 /* Wait for worker threads to terminate */ pool->stopping =3D true; + qemu_cond_broadcast(&pool->request_cond); while (pool->cur_threads > 0) { - qemu_sem_post(&pool->sem); qemu_cond_wait(&pool->worker_stopped, &pool->lock); } =20 qemu_mutex_unlock(&pool->lock); =20 qemu_bh_delete(pool->completion_bh); - qemu_sem_destroy(&pool->sem); + qemu_cond_destroy(&pool->request_cond); qemu_cond_destroy(&pool->worker_stopped); qemu_mutex_destroy(&pool->lock); g_free(pool); --=20 2.36.0 From nobody Sun Oct 26 22:52:56 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=1652511381; cv=none; d=zohomail.com; s=zohoarc; b=GHZuEMLOSaUSIIduv/JOEwysiWbWReX3eEPc/cN8WumGHV/wjWMolhxVFW1yma5khK2rnFbMup/cpgwI2+RW3q6RuhrMKhJ9oFdiR3umFJOCdH7DZ9D6NGc3uUwKdMrBYHA6I6+wZk3DY6Lqc/bXw5Xk6HofJV87kGll2LAXDWs= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1652511381; 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=edU4OXAwzh264fIq2BVPPoCPtmc3OUf+gsAgJ6ZekKs=; b=CJ+PlgyYBd8rjcyHAYlKBEZunIW9/vJoWTva5P9SaGSPppw/wP1lpn0czBdv4LBuXJuC3Kb+cWoymvB+WVNQdmc+ahjtfCDV/t9dafY4+cZyW2NDI7EODc9aMxZ/pzTQH4VYmaaDplcS/Rma27KTISDSPzjkATVhRPRhc/B6ZeA= 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 1652511381123398.4259037468895; Fri, 13 May 2022 23:56:21 -0700 (PDT) Received: from localhost ([::1]:46272 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1nplhM-0002f0-19 for importer2@patchew.org; Sat, 14 May 2022 02:56:20 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:33254) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1nplbd-0008Eg-3b for qemu-devel@nongnu.org; Sat, 14 May 2022 02:50:28 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:57999) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1nplbb-0007gt-Ja for qemu-devel@nongnu.org; Sat, 14 May 2022 02:50:24 -0400 Received: from mail-wm1-f72.google.com (mail-wm1-f72.google.com [209.85.128.72]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-164-45hPsQ_gNEi0TloNbX0lqw-1; Sat, 14 May 2022 02:50:21 -0400 Received: by mail-wm1-f72.google.com with SMTP id g14-20020a1c4e0e000000b0039425ef54d6so3839290wmh.9 for ; Fri, 13 May 2022 23:50:21 -0700 (PDT) Received: from [192.168.10.118] ([2001:b07:6468:f312:c8dd:75d4:99ab:290a]) by smtp.gmail.com with ESMTPSA id h16-20020adfaa90000000b0020c5253d8d4sm3799550wrc.32.2022.05.13.23.50.18 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 13 May 2022 23:50:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1652511023; 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=edU4OXAwzh264fIq2BVPPoCPtmc3OUf+gsAgJ6ZekKs=; b=cXsw9GJnyrO0xSolACVquzZzs0LIK9NzcWdZb0hzJdMyAAxWmSE9VFo0frFmtflvviLlz+ ZSdY1bwhVOgFgvhIyUyb/UnDg2w4fswXPzZ5YEMUhtNUWnJHRWri41UROXDzXFIC2XMp2N 2LsQg8FTeGmtIBc4x8BK0puKVQD5AAo= X-MC-Unique: 45hPsQ_gNEi0TloNbX0lqw-1 X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=edU4OXAwzh264fIq2BVPPoCPtmc3OUf+gsAgJ6ZekKs=; b=A0xu7tQeLAip4gkL0S1yoeKPKfpO+uIpSNxM47qNFBZXBnms1YlR2K2vTAnGTFl+iK u1vWI6fMfueic5GP4StRfzYl2n6PUk97w5/g5qHLRldSCI2nPRIr89jABzsYWFSNayHA D3Gxf+X4KVgdxLI5EbZaDvKKcDAlJMlY9exlgfLqzIYHmd7cINkk3H9vkvoL7vQTasuY oS+KbP+lb5nltsI9kPx2Jgmiucy6XjYtn38lj/p7RWkFORY5L8rHOrYIwo+tK68lKqUV IOVJuP+Rgd8J1hV0U6LZoXSCmdBftGUMQDsYnxrCLXEWBI3itdiVCcInemdGLgJIRhXS Syyw== X-Gm-Message-State: AOAM533nc//wv+q03nvrp+rP32z6uQmYkBlfYpX5vw/k14W7zMbcH3r3 mO+cy5xIqAZvwtWxLqauYbI3jGvuVXHmBKs/H+OHiu9oiLeqDdqmvs9YEgMvqP1qAWQeRpwe2xt XW4dkkSEKhY2wlGICk/tJgqJxKPMxYWf48638ZCpEfCBeBdSr3lyFqcL0vvCi9R4NuOk= X-Received: by 2002:a05:600c:3b10:b0:394:69a0:9d73 with SMTP id m16-20020a05600c3b1000b0039469a09d73mr7600502wms.193.1652511020010; Fri, 13 May 2022 23:50:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzUWFldmOZy3bydDHwX3l44L/qHR92KxMTACUgjxcaK8hv1SnQ8XDlYWSjM+h2+BP2hZexuRA== X-Received: by 2002:a05:600c:3b10:b0:394:69a0:9d73 with SMTP id m16-20020a05600c3b1000b0039469a09d73mr7600481wms.193.1652511019720; Fri, 13 May 2022 23:50:19 -0700 (PDT) From: Paolo Bonzini To: qemu-devel@nongnu.org Cc: stefanha@redhat.com, nsaenzju@redhat.com Subject: [PATCH v3 3/3] thread-pool: remove stopping variable Date: Sat, 14 May 2022 08:50:12 +0200 Message-Id: <20220514065012.1149539-4-pbonzini@redhat.com> X-Mailer: git-send-email 2.36.0 In-Reply-To: <20220514065012.1149539-1-pbonzini@redhat.com> References: <20220514065012.1149539-1-pbonzini@redhat.com> MIME-Version: 1.0 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+importer2=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=170.10.133.124; envelope-from=pbonzini@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -28 X-Spam_score: -2.9 X-Spam_bar: -- X-Spam_report: (-2.9 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.082, 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+importer2=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: pass (identity @redhat.com) X-ZM-MESSAGEID: 1652511382826100002 Content-Type: text/plain; charset="utf-8" Just setting the max threads to 0 is enough to stop all workers. Signed-off-by: Paolo Bonzini Reviewed-by: Nicolas Saenz Julienne Reviewed-by: Stefan Hajnoczi --- util/thread-pool.c | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/util/thread-pool.c b/util/thread-pool.c index 6bbf24754a..507c998827 100644 --- a/util/thread-pool.c +++ b/util/thread-pool.c @@ -69,7 +69,6 @@ struct ThreadPool { int idle_threads; int new_threads; /* backlog of threads we need to create */ int pending_threads; /* threads created but not running yet */ - bool stopping; int min_threads; int max_threads; }; @@ -82,7 +81,7 @@ static void *worker_thread(void *opaque) pool->pending_threads--; do_spawn_thread(pool); =20 - while (!pool->stopping && pool->cur_threads <=3D pool->max_threads) { + while (pool->cur_threads <=3D pool->max_threads) { ThreadPoolElement *req; int ret; =20 @@ -370,7 +369,7 @@ void thread_pool_free(ThreadPool *pool) pool->new_threads =3D 0; =20 /* Wait for worker threads to terminate */ - pool->stopping =3D true; + pool->max_threads =3D 0; qemu_cond_broadcast(&pool->request_cond); while (pool->cur_threads > 0) { qemu_cond_wait(&pool->worker_stopped, &pool->lock); --=20 2.36.0