Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp2214453ybv; Fri, 14 Feb 2020 13:50:54 -0800 (PST) X-Google-Smtp-Source: APXvYqxWRVSLCZMr5Qc1A4whOFSL+q3abfAMGg2q3Lk52gwuTqne/viiM1LVW5D2LLJEOjkUuc4d X-Received: by 2002:a9d:5888:: with SMTP id x8mr3759665otg.361.1581717054822; Fri, 14 Feb 2020 13:50:54 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581717054; cv=none; d=google.com; s=arc-20160816; b=VHdZa9od+nAI1Rd5sS1+SkPdCqOIalcvmrzuNSSTBSLk9bRZhv1fbpYQFmiguEplli dMcbuTH+NstbmAG9z3O8n2NHmbnnSE/0umx1Ak0AgxmB81j5VktViTbVjoTAnA2tB3Rc hZPJIo6F4zUe9Aznl60xCGFpZizYhgJl8pFU/ngXfngDveWfG2NSt5+flR86YZaPuLZn b5MzmNcQ53In52g6m8JZZcIA26+tXYOnukfAuVB1LvSXVuWyb58zq5K0hGZoDxSpD8PL DMwjI/hrcJaZM/jGsw8cthEutUM4DBBFJgFIKvOXiz9HsU1t9wt6wSRBpLRrZ6oTD21G E06A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=muyQF7/b2Bxrwz2kVesgpTYnE/3qxSslhUJbBnb3gDc=; b=Nf4ik13hEyLJ0pFLYGoA8uhEwPajvfOkfcUm26jty4Ek5EdRd6XGphYBO/dgIBDGO2 JZJohoKapX9XqJPSMukKjfdHH9ax1kwIB3cDBcfIAM3iL3Flpuq4OEn0ui1yVtal/AKz HHsmX+o326L+qalVL/GxE5OMfAkO04BALCw/aA0mrfbwfoFkmtujPHxaIKKd5h5ppFpy 2W6FafKtsBOkdAOpBeLI0oe6p/zQaHyrsLkb521gySxekc4Z1fv8xWMaDhnUhKmuQB1j 6LDTpvekols6kpBk32CWXkSw1xae+AsrpxVZWcdJFD0T7qaOsN+zjkYF+hB4GQLwYpIj bf2g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2020-01-29 header.b="UMO/71So"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v141si3125041oif.161.2020.02.14.13.50.40; Fri, 14 Feb 2020 13:50:54 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2020-01-29 header.b="UMO/71So"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730464AbgBNVtE (ORCPT + 99 others); Fri, 14 Feb 2020 16:49:04 -0500 Received: from aserp2120.oracle.com ([141.146.126.78]:34312 "EHLO aserp2120.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729473AbgBNVtE (ORCPT ); Fri, 14 Feb 2020 16:49:04 -0500 Received: from pps.filterd (aserp2120.oracle.com [127.0.0.1]) by aserp2120.oracle.com (8.16.0.42/8.16.0.42) with SMTP id 01ELmm4r192255; Fri, 14 Feb 2020 21:48:48 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=from : to : cc : subject : date : message-id : in-reply-to : references : mime-version : content-transfer-encoding; s=corp-2020-01-29; bh=muyQF7/b2Bxrwz2kVesgpTYnE/3qxSslhUJbBnb3gDc=; b=UMO/71SovORFSPWxgVVLxV9Ch03K+uNFy91H/fov697lIucRpx6zXvKa1tEdPY1HMJQ2 2iJJ6oYc+Z807SEhmVY9a+P7LDozVcEKkQImLw97xISoFwB4XanusVa3ZWsNQlBBFddA cIllXoRMkIA6R1OrZfkzPgh/yZZCaBtw0rDcIFdsEoI+dNW+D33F/dSy9bJMsSOwycL0 ImTqATmNqN1mLRM61Nf1RIKyxpf4qv9BGOxAJMwoMAYV8lo2tGPRSGFdnYbCB5G1TSFw PfMd7jCZXVsSbQio0rI1BhNctZodjqSZ3jWXWwJC5d8X+erKFJA3vbrdYxIKps+YgOFK Ww== Received: from aserp3030.oracle.com (aserp3030.oracle.com [141.146.126.71]) by aserp2120.oracle.com with ESMTP id 2y2jx6v3a2-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Fri, 14 Feb 2020 21:48:48 +0000 Received: from pps.filterd (aserp3030.oracle.com [127.0.0.1]) by aserp3030.oracle.com (8.16.0.42/8.16.0.42) with SMTP id 01ELlvW9040202; Fri, 14 Feb 2020 21:48:42 GMT Received: from userv0122.oracle.com (userv0122.oracle.com [156.151.31.75]) by aserp3030.oracle.com with ESMTP id 2y4k82vu03-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Fri, 14 Feb 2020 21:48:42 +0000 Received: from abhmp0009.oracle.com (abhmp0009.oracle.com [141.146.116.15]) by userv0122.oracle.com (8.14.4/8.14.4) with ESMTP id 01ELmeWw032758; Fri, 14 Feb 2020 21:48:40 GMT Received: from localhost.localdomain (/98.229.125.203) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Fri, 14 Feb 2020 13:48:39 -0800 From: Daniel Jordan To: Greg Kroah-Hartman , Sasha Levin Cc: Steffen Klassert , linux-kernel@vger.kernel.org, Herbert Xu , stable@vger.kernel.org, Daniel Jordan Subject: [PATCH v2 4.9] padata: Remove broken queue flushing Date: Fri, 14 Feb 2020 16:48:34 -0500 Message-Id: <20200214214834.621513-1-daniel.m.jordan@oracle.com> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200213151856.812892483@linuxfoundation.org> References: <20200213151856.812892483@linuxfoundation.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Proofpoint-Virus-Version: vendor=nai engine=6000 definitions=9531 signatures=668685 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 mlxlogscore=999 adultscore=0 suspectscore=2 mlxscore=0 bulkscore=0 malwarescore=0 phishscore=0 spamscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2001150001 definitions=main-2002140159 X-Proofpoint-Virus-Version: vendor=nai engine=6000 definitions=9531 signatures=668685 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 mlxlogscore=999 malwarescore=0 priorityscore=1501 adultscore=0 phishscore=0 impostorscore=0 spamscore=0 bulkscore=0 lowpriorityscore=0 mlxscore=0 suspectscore=2 clxscore=1015 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2001150001 definitions=main-2002140159 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Herbert Xu [ Upstream commit 07928d9bfc81640bab36f5190e8725894d93b659 ] The function padata_flush_queues is fundamentally broken because it cannot force padata users to complete the request that is underway. IOW padata has to passively wait for the completion of any outstanding work. As it stands flushing is used in two places. Its use in padata_stop is simply unnecessary because nothing depends on the queues to be flushed afterwards. The other use in padata_replace is more substantial as we depend on it to free the old pd structure. This patch instead uses the pd->refcnt to dynamically free the pd structure once all requests are complete. Fixes: 2b73b07ab8a4 ("padata: Flush the padata queues actively") Cc: Signed-off-by: Herbert Xu Reviewed-by: Daniel Jordan Signed-off-by: Herbert Xu [dj: leave "pd->pinst = pinst" assignment in padata_alloc_pd()] Signed-off-by: Daniel Jordan --- kernel/padata.c | 45 ++++++++++++--------------------------------- 1 file changed, 12 insertions(+), 33 deletions(-) diff --git a/kernel/padata.c b/kernel/padata.c index 63449fc584da..286c5142a0f7 100644 --- a/kernel/padata.c +++ b/kernel/padata.c @@ -34,6 +34,8 @@ #define MAX_OBJ_NUM 1000 +static void padata_free_pd(struct parallel_data *pd); + static int padata_index_to_cpu(struct parallel_data *pd, int cpu_index) { int cpu, target_cpu; @@ -301,6 +303,7 @@ static void padata_serial_worker(struct work_struct *serial_work) struct padata_serial_queue *squeue; struct parallel_data *pd; LIST_HEAD(local_list); + int cnt; local_bh_disable(); squeue = container_of(serial_work, struct padata_serial_queue, work); @@ -310,6 +313,8 @@ static void padata_serial_worker(struct work_struct *serial_work) list_replace_init(&squeue->serial.list, &local_list); spin_unlock(&squeue->serial.lock); + cnt = 0; + while (!list_empty(&local_list)) { struct padata_priv *padata; @@ -319,9 +324,12 @@ static void padata_serial_worker(struct work_struct *serial_work) list_del_init(&padata->list); padata->serial(padata); - atomic_dec(&pd->refcnt); + cnt++; } local_bh_enable(); + + if (atomic_sub_and_test(cnt, &pd->refcnt)) + padata_free_pd(pd); } /** @@ -444,7 +452,7 @@ static struct parallel_data *padata_alloc_pd(struct padata_instance *pinst, setup_timer(&pd->timer, padata_reorder_timer, (unsigned long)pd); atomic_set(&pd->seq_nr, -1); atomic_set(&pd->reorder_objects, 0); - atomic_set(&pd->refcnt, 0); + atomic_set(&pd->refcnt, 1); pd->pinst = pinst; spin_lock_init(&pd->lock); @@ -469,31 +477,6 @@ static void padata_free_pd(struct parallel_data *pd) kfree(pd); } -/* Flush all objects out of the padata queues. */ -static void padata_flush_queues(struct parallel_data *pd) -{ - int cpu; - struct padata_parallel_queue *pqueue; - struct padata_serial_queue *squeue; - - for_each_cpu(cpu, pd->cpumask.pcpu) { - pqueue = per_cpu_ptr(pd->pqueue, cpu); - flush_work(&pqueue->work); - } - - del_timer_sync(&pd->timer); - - if (atomic_read(&pd->reorder_objects)) - padata_reorder(pd); - - for_each_cpu(cpu, pd->cpumask.cbcpu) { - squeue = per_cpu_ptr(pd->squeue, cpu); - flush_work(&squeue->work); - } - - BUG_ON(atomic_read(&pd->refcnt) != 0); -} - static void __padata_start(struct padata_instance *pinst) { pinst->flags |= PADATA_INIT; @@ -507,10 +490,6 @@ static void __padata_stop(struct padata_instance *pinst) pinst->flags &= ~PADATA_INIT; synchronize_rcu(); - - get_online_cpus(); - padata_flush_queues(pinst->pd); - put_online_cpus(); } /* Replace the internal control structure with a new one. */ @@ -531,8 +510,8 @@ static void padata_replace(struct padata_instance *pinst, if (!cpumask_equal(pd_old->cpumask.cbcpu, pd_new->cpumask.cbcpu)) notification_mask |= PADATA_CPU_SERIAL; - padata_flush_queues(pd_old); - padata_free_pd(pd_old); + if (atomic_dec_and_test(&pd_old->refcnt)) + padata_free_pd(pd_old); if (notification_mask) blocking_notifier_call_chain(&pinst->cpumask_change_notifier, -- 2.25.0