Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp8379829rwl; Tue, 10 Jan 2023 12:43:26 -0800 (PST) X-Google-Smtp-Source: AMrXdXvOrKJt2exdgYA4d9+t6K498E7UBDE9yYhMaTsbWJcF4vzYK8yxB21+EKW/ER8/opfdml/G X-Received: by 2002:a17:90a:db08:b0:226:ffe3:d189 with SMTP id g8-20020a17090adb0800b00226ffe3d189mr11454pjv.20.1673383406547; Tue, 10 Jan 2023 12:43:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673383406; cv=none; d=google.com; s=arc-20160816; b=iequfbNIi3Uaq0YNnEMme8j2VbKe24hGi443Wmrb83miGDzq/9RyriaLeYlcUfB4aN B5lyFwUsj/GhDTUxzwEzM1PqADSrRVNxjyCN/jMk+H46VEesHvRPuRmXXDhQx0HYzHRI xYKZ38wcNojPXRrWTOq4gQ3TFl7stoK2ERU0GfV2mE57+3Nv7G3lnU11qNhylT1Nf1Wt wjxw8ToFyaso5P5Fj7LaEyBj1hr7mzr1d3zGUgO5yvc7SBM6U2SniI1mdH7DuKMfbU9Z f5hP/H7WCe4R6wyZyfXF2OMaqp0FSAMTd24G5C7PABm6Z2sic1rcJJCuPrIsr30rL6ka PU9g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:sender:dkim-signature; bh=WNez16VMF4rRmKYhCe0O3ABHc5tdrND3Cm+xmlv4IIQ=; b=SATuUiCwP3DbT/eQP1W03TWLSP5AVaIK11bjvOBr6j44f/r5hlkWSyaxb6+Gyma1JH MbCJR0UhI+MCA3wBuQW0Nh+ECdBHWtTwh3NnVH7bCPxvofb9/7SPTW2vppMzdnmecmpd r1pK5HhXHE6ry1IWrR7UEvs+zBTy0lQOApY4WFdKWMY5ZXp4FGWuRehHik1hUtxOVwJh 7fKiFTILU64flFRQcKbN8/Ol8GWdn9NcXXet8EEP5B9tnST+yGqlalH62z3jqjqQo2xu TYrc8Z7hs1Ej2yP862wmd3GyIWWrU0l9kctQU49oBTJ51mz2AD/OX2lHO/IG+OI7l6rq j56g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=VDtEnRD0; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id lb18-20020a17090b4a5200b00218792fa2b3si18127528pjb.160.2023.01.10.12.43.19; Tue, 10 Jan 2023 12:43:26 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=VDtEnRD0; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233940AbjAJUbI (ORCPT + 53 others); Tue, 10 Jan 2023 15:31:08 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40670 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234969AbjAJUaY (ORCPT ); Tue, 10 Jan 2023 15:30:24 -0500 Received: from mail-pj1-x102c.google.com (mail-pj1-x102c.google.com [IPv6:2607:f8b0:4864:20::102c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E7851633A9 for ; Tue, 10 Jan 2023 12:28:47 -0800 (PST) Received: by mail-pj1-x102c.google.com with SMTP id c8-20020a17090a4d0800b00225c3614161so17699861pjg.5 for ; Tue, 10 Jan 2023 12:28:47 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:sender:from:to:cc:subject:date:message-id :reply-to; bh=WNez16VMF4rRmKYhCe0O3ABHc5tdrND3Cm+xmlv4IIQ=; b=VDtEnRD0IULnX2C+hz7ue9+Ox87DOT+65LNmd6Y8TrDOritXAKvpw5sE/xe22MNPgp 6fycVwPIDqgFeyrCKVBf9XMngexY72yWSKnWg/uznGFCiCahyGaZNBBgFq4g+oloYZBY HcKK5Rm9+BJEOXjeTHagp6I1GQZmyDZZw+HgJTxzmqEatwzESgqMaWS/vDSTBwN5tlMP ZF7ura2oe1p7EO8S3bl+NSPEiSLldLpC/Mr5mXFUCqUk3d8eA3H1zvpvSiNz9wE767w1 jzEBso/x4g5vvrBfa2bqya+2hG47870jxcjGjiNH7NZWJhwfLckBhg7eOeOpzb7C4iMO erTg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:sender:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=WNez16VMF4rRmKYhCe0O3ABHc5tdrND3Cm+xmlv4IIQ=; b=C0dbAYGc66K6h2uCPFnPZUyUDuP8MP9M6wQpG/9xE8Wj60BjIyLLhlVZZJVUwYw32W N2b6XqcI0xHl3CYC5ioFe7SO6nDWVwwAY+xoWVdPJRIugG6j/9YwpvRxqsS7dlwM0HXJ kVZyjcREs+GbTg05bk5dxGq8nPq1rJL4cbTfD8rzb0r2K/C52wYvwPqdwHzWcTEduaLL KNnG0+5NgomnPiGhyU5wL+jJgEoboP4Wid0wqw7blBtPxOcavRrxsN/GxwAOsyDpDfQX ag54aI5LS9LYTvtas+SN3M5oC+/PywtWpsE9ug//6d3AOMMpNJOxtIqpFcmRDedXAoHm n2Kg== X-Gm-Message-State: AFqh2kq5IGe0czgFnkamqGK2tCIDm79QfjR6R4QUr9MWAu4ZIxoAjiMV aXHRg6BmbUDBg4BXCmp7dSo= X-Received: by 2002:a05:6a20:c78d:b0:a3:878d:c126 with SMTP id hk13-20020a056a20c78d00b000a3878dc126mr89685965pzb.42.1673382523621; Tue, 10 Jan 2023 12:28:43 -0800 (PST) Received: from localhost (2603-800c-1a02-1bae-a7fa-157f-969a-4cde.res6.spectrum.com. [2603:800c:1a02:1bae:a7fa:157f:969a:4cde]) by smtp.gmail.com with ESMTPSA id n5-20020a634005000000b004a737a6e62fsm6989361pga.14.2023.01.10.12.28.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 10 Jan 2023 12:28:43 -0800 (PST) Sender: Tejun Heo Date: Tue, 10 Jan 2023 10:28:41 -1000 From: Tejun Heo To: Valentin Schneider Cc: linux-kernel@vger.kernel.org, Lai Jiangshan , Peter Zijlstra , Frederic Weisbecker , Juri Lelli , Phil Auld , Marcelo Tosatti Subject: Re: [PATCH v7 4/4] workqueue: Unbind kworkers before sending them to exit() Message-ID: References: <20230109133316.4026472-1-vschneid@redhat.com> <20230109133316.4026472-5-vschneid@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20230109133316.4026472-5-vschneid@redhat.com> X-Spam-Status: No, score=-1.7 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_EF,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE, SPF_PASS autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello, The series generally looks good to me. Just one thing. On Mon, Jan 09, 2023 at 01:33:16PM +0000, Valentin Schneider wrote: > @@ -3658,13 +3702,24 @@ static void put_unbound_pool(struct worker_pool *pool) > TASK_UNINTERRUPTIBLE); > pool->flags |= POOL_MANAGER_ACTIVE; > > + /* > + * We need to hold wq_pool_attach_mutex() while destroying the workers, > + * but we can't grab it in rcuwait_wait_event() as it can clobber > + * current's task state. We can drop pool->lock here as we've set > + * POOL_MANAGER_ACTIVE, no one else can steal our manager position. > + */ > + raw_spin_unlock_irq(&pool->lock); > + mutex_lock(&wq_pool_attach_mutex); > + raw_spin_lock_irq(&pool->lock); The original pattern was a bit weird to begin with and this makes it quite worse. Let's do something more straight forward like: while (true) { rcuwait_wait_event(&manager_wait, !(pool->flags & POOL_MANAGER_ACTIVE), TASK_UNINTERRUPTIBLE); mutex_lock(&wq_pool_attach_mutex); raw_spin_lock_irq(&pool->lock); if (!(pool->flags & POOL_MANAGER_ACTIVE)) { pool->flags |= POOL_MANAGER_ACTIVE; break; } raw_spin_unlock_irq(&pool->lock); mutex_unlock(&wq_pool_attach_mutex); } Thanks. -- tejun