Received: by 2002:a05:7412:3290:b0:fa:6e18:a558 with SMTP id ev16csp97042rdb; Thu, 25 Jan 2024 09:12:41 -0800 (PST) X-Google-Smtp-Source: AGHT+IHqg5RNplATE4gXAb1vHqgChSn0ysDkghRU+m4Y+1LKHynF8ktx7sidmMqrddpBQExpEbtB X-Received: by 2002:a05:6214:20ec:b0:684:cd1b:8013 with SMTP id 12-20020a05621420ec00b00684cd1b8013mr1722720qvk.77.1706202761774; Thu, 25 Jan 2024 09:12:41 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1706202761; cv=pass; d=google.com; s=arc-20160816; b=lEt9uduPz59e/Sq0Bi3b7CjpZZM+5lkEFrDrAklpCKFAPqbpz8+dwhIZ2UrUZWaloD nv3SM3AYTOzYeNJyUBFJOws6OZwyaZSGYaFpCkwnZ6lCrvelmIH9esENb6aazGEUrA+K 3tuFu60ZIUTxL2KYAwQ4iSQOQDVvnOP2L0dbRDsJNv3EjgalCpvbE6ol7Nzn5c+2tRbk doFKGZfG2G2jno9GsEFDh2Ks7+5VK1AUlDqrNFz3hvhnSPMdGP9Fx3YzlumTpbBgcLfB 7xyeNjtTIF0zZhgEq1/AapaB3t39mIN0reIM4BmWxU5RgGlYW87KI7YsD+s0nCyyDgdf rNcA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:sender:dkim-signature; bh=YOYkM/qLWTiwy9Fw63ezSNvZi7VG4jWrtKoEUh14gqg=; fh=es77rsUC8OixoDFH1oB3/WG5bTQvXv6TAWW5Ou/zXa8=; b=AtlQ2yAHNfZW+v864PTUubvuOr+5MyRBrqdB1y37RyuIFISbP+4gUgDewj3DWp8W2z aUwcXNCjclQvHr2YCfZ1BAKv9JNrFIrNrNLEgPqwSXalpiNPDSZSqD8BzGZQ9jmW7iiG mqXLpv3ELR914dshE/6EOsoUcUDX248ACmz0akgcMn2Hosd0C+YVlhdvITGS37QvCTJ3 MsHUwBIKa88dz7UaaRrDsbb5YSV5ngyNV+DdK8O3GtTkjI+M7dXLdC6XO8o1ZVcCaGHC KeplnohUsxbN6/uw+dMq8OqxKAgu4IfagIh7Do6RoL/zFgTuKA1HrUFqvxgGVhS9ndJP pNSg== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=K6FtVgb9; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-39000-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-39000-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id q6-20020a0cf5c6000000b006854a852bc5si12906173qvm.556.2024.01.25.09.12.41 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 25 Jan 2024 09:12:41 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-39000-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=K6FtVgb9; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-39000-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-39000-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 878D31C20943 for ; Thu, 25 Jan 2024 17:12:41 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 1A1E8136656; Thu, 25 Jan 2024 17:06:38 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="K6FtVgb9" Received: from mail-pf1-f175.google.com (mail-pf1-f175.google.com [209.85.210.175]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id D3CE213667D for ; Thu, 25 Jan 2024 17:06:35 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.210.175 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706202397; cv=none; b=oTCgfvmnkFRSBX0wBpbY6mjCV/esjamRAMB1/0YiLnoqzq2RvwTEuvIp3SNtnV3SZm+zkrgkd46yr9sOb11vhiBydXFInuG9C6r9O2WYSwYPsgcfJyRCAGLO5Lmc0ZRCEAPXAwHxEUdduUaOF63+l3G+UGdbRsbskslvnB++HTs= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706202397; c=relaxed/simple; bh=M9m/Jy9Gw+jdj/vfc/MJd5VwxVDjgNlm5eObswq3By8=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=lYF17t+1U+LZzzMkY48cu3aJuaLrq/SXEHb0K1dqLDXJNnHmHlN1PBy6H6CfU+LA39Ux3ng/PRjVbnGqUcriRFR+YAy3+espyjyf2oBhzwre0v+DvXSf+ffQXisW3QMvLalVXKsjgOUU4hdO3RPpp8K0W/lJDun9eAjZpl83HHg= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=fail (p=none dis=none) header.from=kernel.org; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=K6FtVgb9; arc=none smtp.client-ip=209.85.210.175 Authentication-Results: smtp.subspace.kernel.org; dmarc=fail (p=none dis=none) header.from=kernel.org Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Received: by mail-pf1-f175.google.com with SMTP id d2e1a72fcca58-6ddd19552e6so504689b3a.1 for ; Thu, 25 Jan 2024 09:06:35 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1706202395; x=1706807195; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:sender:from:to:cc:subject:date :message-id:reply-to; bh=YOYkM/qLWTiwy9Fw63ezSNvZi7VG4jWrtKoEUh14gqg=; b=K6FtVgb9Mh7uxqoCmHsYuEV5mQYiyjjKDHcoiJaSSAZ4S/ze29mQRaqHWxZOut8aK8 rkeoh8XZbPSed9J/GT33OcL8vQZhf0SzelT+ZbdFPl+mh8ctcToaJMgjoTp9KDCIpidD se0P5wqNnuojxOeVxQGeMa39KD5mDeLdztYbaTULRlrLSTB0zZYtgTraJDtW+Dya5heH n2W4pYx7UmSdCsaH7KC6J7r8Sg/00KntRaCQDUiME77/4iax7yVpq6mgPP/6u1/hh8Va UP9qkMUog4i1DPggSYiVevwiUr+iBAuG010w4Q17/pB0aSbMvUBYiRVLDQAzDcrBYrY0 Kxog== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1706202395; x=1706807195; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:sender:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=YOYkM/qLWTiwy9Fw63ezSNvZi7VG4jWrtKoEUh14gqg=; b=pY0jPVqplE56/jKTdVzKmAe3+rxMODWCqIHhqHnK38Y6PT6E66vC4BQ/k7aCJUm/t0 N50PqAToI/w6LQelTkka7wZFPg8FXZNMK6HoThb9oZgcdcfIe/jICfXqeRRTZUauRc+d yW2ncP82QkBmdBHZGl0XtEaiBGGpT0Hcl4cN0l1G/B3rmFlZeRGRjq4o/ausswmbGndQ 9Qerv9wwNACd5Umcxx2GFJIcwqwNJdO4iDmQ4Dyzolx5BrORaptWvxqPoQ3hrLJlIud/ 9T6JIzPov/nqbeHsGTEoTXDp03YdTNngv12GjUetIGjLDd64GGZcqsJPbWvQv4cvgBW0 UlOA== X-Gm-Message-State: AOJu0Yy3U8CWgJb17qN/WDfInaYiB9q6/e+KFcwWPLooLCWLqvqz92ny 9zzCfGnww0hb+PzVuu9nbAayrZ5U1uIxaTe6nExr6kd7cAGzhp9t X-Received: by 2002:a17:902:e54e:b0:1d4:bcfa:2b0e with SMTP id n14-20020a170902e54e00b001d4bcfa2b0emr1264727plf.93.1706202395118; Thu, 25 Jan 2024 09:06:35 -0800 (PST) Received: from localhost (dhcp-141-239-144-21.hawaiiantel.net. [141.239.144.21]) by smtp.gmail.com with ESMTPSA id s17-20020a170903321100b001d738e94557sm8227996plh.4.2024.01.25.09.06.34 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 25 Jan 2024 09:06:34 -0800 (PST) Sender: Tejun Heo From: Tejun Heo To: jiangshanlai@gmail.com Cc: linux-kernel@vger.kernel.org, Naohiro.Aota@wdc.com, kernel-team@meta.com, Tejun Heo Subject: [PATCH 03/10] workqueue: Replace pwq_activate_inactive_work() with [__]pwq_activate_work() Date: Thu, 25 Jan 2024 07:05:56 -1000 Message-ID: <20240125170628.2017784-4-tj@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240125170628.2017784-1-tj@kernel.org> References: <20240125170628.2017784-1-tj@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit To prepare for unbound nr_active handling improvements, move work activation part of pwq_activate_inactive_work() into __pwq_activate_work() and add pwq_activate_work() which tests WORK_STRUCT_INACTIVE and updates nr_active. pwq_activate_first_inactive() and try_to_grab_pending() are updated to use pwq_activate_work(). The latter conversion is functionally identical. For the former, this conversion adds an unnecessary WORK_STRUCT_INACTIVE testing. This is temporary and will be removed by the next patch. Signed-off-by: Tejun Heo --- kernel/workqueue.c | 31 +++++++++++++++++++++++++------ 1 file changed, 25 insertions(+), 6 deletions(-) diff --git a/kernel/workqueue.c b/kernel/workqueue.c index 9e75535c4aeb..3a4c269204f3 100644 --- a/kernel/workqueue.c +++ b/kernel/workqueue.c @@ -1461,16 +1461,36 @@ static bool pwq_is_empty(struct pool_workqueue *pwq) return !pwq->nr_active && list_empty(&pwq->inactive_works); } -static void pwq_activate_inactive_work(struct work_struct *work) +static void __pwq_activate_work(struct pool_workqueue *pwq, + struct work_struct *work) { - struct pool_workqueue *pwq = get_work_pwq(work); - trace_workqueue_activate_work(work); if (list_empty(&pwq->pool->worklist)) pwq->pool->watchdog_ts = jiffies; move_linked_works(work, &pwq->pool->worklist, NULL); __clear_bit(WORK_STRUCT_INACTIVE_BIT, work_data_bits(work)); +} + +/** + * pwq_activate_work - Activate a work item if inactive + * @pwq: pool_workqueue @work belongs to + * @work: work item to activate + * + * Returns %true if activated. %false if already active. + */ +static bool pwq_activate_work(struct pool_workqueue *pwq, + struct work_struct *work) +{ + struct worker_pool *pool = pwq->pool; + + lockdep_assert_held(&pool->lock); + + if (!(*work_data_bits(work) & WORK_STRUCT_INACTIVE)) + return false; + pwq->nr_active++; + __pwq_activate_work(pwq, work); + return true; } static void pwq_activate_first_inactive(struct pool_workqueue *pwq) @@ -1478,7 +1498,7 @@ static void pwq_activate_first_inactive(struct pool_workqueue *pwq) struct work_struct *work = list_first_entry(&pwq->inactive_works, struct work_struct, entry); - pwq_activate_inactive_work(work); + pwq_activate_work(pwq, work); } /** @@ -1616,8 +1636,7 @@ static int try_to_grab_pending(struct work_struct *work, bool is_dwork, * management later on and cause stall. Make sure the work * item is activated before grabbing. */ - if (*work_data_bits(work) & WORK_STRUCT_INACTIVE) - pwq_activate_inactive_work(work); + pwq_activate_work(pwq, work); list_del_init(&work->entry); pwq_dec_nr_in_flight(pwq, *work_data_bits(work)); -- 2.43.0