From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-13.5 required=3.0 tests=BAYES_00, DKIM_ADSP_CUSTOM_MED,DKIM_INVALID,DKIM_SIGNED,FREEMAIL_FORGED_FROMDOMAIN, FREEMAIL_FROM,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER, INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id D53AAC56202 for ; Wed, 25 Nov 2020 19:37:31 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 53B492063A for ; Wed, 25 Nov 2020 19:37:31 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=fail reason="signature verification failed" (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="b8ECt+Qn" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 53B492063A Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=gmail.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id B3D236B0075; Wed, 25 Nov 2020 14:37:28 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 9FD4D6B0078; Wed, 25 Nov 2020 14:37:28 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 7DB606B007B; Wed, 25 Nov 2020 14:37:28 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0155.hostedemail.com [216.40.44.155]) by kanga.kvack.org (Postfix) with ESMTP id 620476B0075 for ; Wed, 25 Nov 2020 14:37:28 -0500 (EST) Received: from smtpin06.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay02.hostedemail.com (Postfix) with ESMTP id 2A8DB3637 for ; Wed, 25 Nov 2020 19:37:28 +0000 (UTC) X-FDA: 77523949776.06.wing02_520785e27379 Received: from filter.hostedemail.com (10.5.16.251.rfc1918.com [10.5.16.251]) by smtpin06.hostedemail.com (Postfix) with ESMTP id 062011003DAEC for ; Wed, 25 Nov 2020 19:37:28 +0000 (UTC) X-HE-Tag: wing02_520785e27379 X-Filterd-Recvd-Size: 4661 Received: from mail-io1-f65.google.com (mail-io1-f65.google.com [209.85.166.65]) by imf42.hostedemail.com (Postfix) with ESMTP for ; Wed, 25 Nov 2020 19:37:27 +0000 (UTC) Received: by mail-io1-f65.google.com with SMTP id z5so2570046iob.11 for ; Wed, 25 Nov 2020 11:37:27 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=ZLPfmI/xJGGGJxd0CmpcCFxQgQrAkx7EEyyWSE1b3PU=; b=b8ECt+QnI1AYyGfspPRuFOAbuoZGbcEGUClKgcZik0b07PscmuryYvVcmnvlblN6SN nl4agS7v1ajmG5Q3oz7je+sHHEW6IpvF3lFp2lqDnnxAaTu8rNitFkoTS/MoCmnzKr3w pJcQiDyuO8x3s3rm3ytST+mcCq6RY2iClincb4SSSCr39ODsH+SroZ47EJD/qRwl8yqk bkZSxZ9CUp8OmFeswwoFRAihxulhF/TWeyglOaJD84ZY7t7Lod4VzRJoNXamsPXpopIM B1hXCDHQXUSFBr36ls2euoBQpt/aV0rqRNpYDf6g7re3WeEo8YjF1ODDvFLkyaW6kzvy nzWw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=ZLPfmI/xJGGGJxd0CmpcCFxQgQrAkx7EEyyWSE1b3PU=; b=ASZdYqC/jTzekcNU9wuWPdg/plsn/OwAAtZ2SmlkcOXmiWRohE0H3mzI27qkG21Fp4 GPoH6pcRBAgwYqB7GP98EHAEjgVIbjs9GWHNK9jsBqS/1PO7L4Qgae3fgQ9F9JnCfNe9 qBgYb8OSJdCR0CCM9Ch+m/ORwwm7H0psunFflXl5XGx/7aO0dPQV/N3Oqz84JRdh4AMy wB4D0vUzk/tfK1gc4zFxf/+v7WbDqWI1niXUx5TqBwegti35tjc5for0Cv0FKuYDFabu 8FrHl9+fZcB8jx4OT6cIsZbIVWiwyAtqSVNkRIUGVV2Q6uXcxDfISaLRChQusbcpBcAv cryQ== X-Gm-Message-State: AOAM533MNbRKbW4YjAv61ahpFKdAV3MHdr1fsUnZFfSIqgyPwkfN0/UB TXwf2OaRuw95hH3I3DdeYV+Q+zM9ZmwnlQ== X-Google-Smtp-Source: ABdhPJxNEvPVBjizk2xNlBVx4Wnkr/1JCC/ssyZuJ7uPIZjKAM49kAbHuL+BrLgWJvcve7oCItgWEg== X-Received: by 2002:a02:1007:: with SMTP id 7mr3626403jay.73.1606333046791; Wed, 25 Nov 2020 11:37:26 -0800 (PST) Received: from frodo.mearth (c-24-9-77-57.hsd1.co.comcast.net. [24.9.77.57]) by smtp.googlemail.com with ESMTPSA id f8sm1435548ioc.24.2020.11.25.11.37.25 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 25 Nov 2020 11:37:26 -0800 (PST) From: Jim Cromie To: linux-mm@kvack.org Cc: gregkh@linuxfoundation.org, linux@rasmusvillemoes.dk, Jim Cromie , Jason Baron , linux-kernel@vger.kernel.org Subject: [PATCH 6/7] dyndbg: add locking around zpool-add loop in zpool-init Date: Wed, 25 Nov 2020 12:36:25 -0700 Message-Id: <20201125193626.2266995-7-jim.cromie@gmail.com> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20201125193626.2266995-1-jim.cromie@gmail.com> References: <20201125193626.2266995-1-jim.cromie@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: This commit doesnt improve things, last commit was working, next one still breaks, despite this "fix". I keep it separate to isolate it and the reasoning for review, which now stated, will be refuted as needed. ;-) Locking review: ddebug_zpool_init(), like other ddebug_*_init() routines, does no locking itself. Unlike them, it runs later, at late_init. This patch doesnt fix the kernel panic that HEAD+1 does. ddebug_callsite_get/put() are called as a pair under mutex-lock for all 3 callsite users. 2 of them; ddebug_change() and dynamic_emit_prefix(), do their own ABBA-ish LGPU (Lock-Get-Put-Unlock). ddebug_proc_show() does the GP part, and is wrapped by ddebug_proc_start|stop() with LU. ddebug_add_module() does LU to protect list_add(), HEAD~1 added ddebug_zpool_add() loop inside that protection. This commit adds locking to ddebug_zpool_init(), around the loop of ddebug_zpool_add(), to match the locking in ddebug_add_module(). Signed-off-by: Jim Cromie --- lib/dynamic_debug.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lib/dynamic_debug.c b/lib/dynamic_debug.c index 473406b069a7..534d73e45844 100644 --- a/lib/dynamic_debug.c +++ b/lib/dynamic_debug.c @@ -1195,8 +1195,10 @@ static void __init ddebug_zpool_init(void) } =20 /* add-module normally does this, but not in time for builtins */ + mutex_lock(&ddebug_lock); for (iter =3D __start___dyndbg; iter < __stop___dyndbg; iter++) ddebug_zpool_add(iter); + mutex_unlock(&ddebug_lock); =20 v2pr_info("total pages: %lu compaction: %lu\n", zs_get_total_pages(dd_callsite_zpool), --=20 2.28.0