Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp7106697rwb; Tue, 15 Nov 2022 07:46:49 -0800 (PST) X-Google-Smtp-Source: AA0mqf5n+ABfwbuNiQUn1SMnafLbVp6rRxRkumqcvMIFYmww6ltwX3S1rGGi0G9wmvaEuzGdckNg X-Received: by 2002:a17:906:1ed0:b0:78d:9e77:1f8c with SMTP id m16-20020a1709061ed000b0078d9e771f8cmr14256716ejj.236.1668527208874; Tue, 15 Nov 2022 07:46:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1668527208; cv=none; d=google.com; s=arc-20160816; b=n34Lya7HSYOlLDNvdrr3P+M9TmIkC2p2F2CHEiAhhyU8X6CffBKN3VVbAS6JUbnlvo K9uo8qan0D7c4JzWkUq75oUIqBSdu3dxWIFAklYN9OxCWfimusBlH7MK12bskYK0yykf SxCEFliowj1SKRaMzRtn1tRQbXXpFsOmH9XUWT7Z4LK8SFgmdM+hlyjcPZbI5csX6X1H tlE+kSm7nZulNr0t56SsBZYOYCrfFhDpRAsr57/SMd5+70mm/mFsz/7wkQra/WzuLgki vnNuFuM9ayUvUPiJ9zX+GJXleb9belpf+naaXBl3jBKRYmGQbyL0Rkslb9fzm1/iCqKn ZpyQ== 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:dkim-signature; bh=fx1pabvdNXR/4MZEXdvaDvbLnLLLuOpiVQF5f9g0kBo=; b=syQ7xhx856Z9ipouB6F7wkxUqW3x0yhpxojhZFHsyCU9dYmrMbVtaM8VJD4wgA+Opb p0XICNkhWIHWb7Iuw6lPKe1QZ+Z67siAWC1hd5Iytyg+3mJs38LtegPqEm9MYS8R0LiS zUvrqqAeozkZrG1xNObR3SUTK2LzOV1PD0cwcH274R1o6ssgozFwY6OD99gzw93sxRZ8 cOtO+zzt4kZWdUQYeFjgiofu6Tn4KD+va8wwPCbF318Z8zqRYHEGmkz74NDLgo0WsWUJ olobtpN4exCgoBhcK3qugNWZ8mlZhUnFR6ynSZTX+PwsdrjXCcxaWnYinHNVH6cOm4e4 JRsA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.com header.s=susede1 header.b=PRNvaJAr; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=suse.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id qb24-20020a1709077e9800b0078e1a6fbe12si13950728ejc.16.2022.11.15.07.46.25; Tue, 15 Nov 2022 07:46:48 -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=@suse.com header.s=susede1 header.b=PRNvaJAr; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=suse.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237906AbiKOPeW (ORCPT + 91 others); Tue, 15 Nov 2022 10:34:22 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35390 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232405AbiKOPeN (ORCPT ); Tue, 15 Nov 2022 10:34:13 -0500 Received: from smtp-out1.suse.de (smtp-out1.suse.de [IPv6:2001:67c:2178:6::1c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 104E0DFEF for ; Tue, 15 Nov 2022 07:34:12 -0800 (PST) Received: from relay2.suse.de (relay2.suse.de [149.44.160.134]) by smtp-out1.suse.de (Postfix) with ESMTP id B918833688; Tue, 15 Nov 2022 15:34:10 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.com; s=susede1; t=1668526450; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=fx1pabvdNXR/4MZEXdvaDvbLnLLLuOpiVQF5f9g0kBo=; b=PRNvaJAr2b0ao2L6bSSuW4Eg76ey9yIIDFlheQf0a9IdwAjz/NHdGLvWOyV0TnRBtm8ASz hUKcCG9qws8J2HJpGP0lY+Jsn8Xq8pByubsJXX+HvcUupIkR+I+huCwHl8KFvfT4faSJ1w gdOJ0YqwXl2/NEzOgP0bhBCjG6teMO4= Received: from suse.cz (unknown [10.100.208.146]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by relay2.suse.de (Postfix) with ESMTPS id 8CE642C142; Tue, 15 Nov 2022 15:34:10 +0000 (UTC) Date: Tue, 15 Nov 2022 16:34:10 +0100 From: Petr Mladek To: John Ogness Cc: Sergey Senozhatsky , Steven Rostedt , Thomas Gleixner , linux-kernel@vger.kernel.org Subject: replay log: Re: [PATCH printk v4 38/39] printk: relieve console_lock of list synchronization duties Message-ID: References: <20221114162932.141883-1-john.ogness@linutronix.de> <20221114162932.141883-39-john.ogness@linutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20221114162932.141883-39-john.ogness@linutronix.de> X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_PASS autolearn=ham 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 On Mon 2022-11-14 17:35:31, John Ogness wrote: > The console_list_lock provides synchronization for console list and > console->flags updates. All call sites that were using the console_lock > for this synchronization have either switched to use the > console_list_lock or the SRCU list iterator. > > Remove console_lock usage for console list updates and console->flags > updates. > > Signed-off-by: John Ogness > --- a/kernel/printk/printk.c > +++ b/kernel/printk/printk.c > @@ -3334,6 +3330,11 @@ void register_console(struct console *newcon) > * boot console that is the furthest behind. > */ > if (bootcon_registered && !keep_bootcon) { > + /* > + * Hold the console_lock to guarantee safe access to > + * console->seq. > + */ > + console_lock(); > for_each_console(con) { > if ((con->flags & CON_BOOT) && > (con->flags & CON_ENABLED) && > @@ -3341,6 +3342,7 @@ void register_console(struct console *newcon) > newcon->seq = con->seq; > } > } > + console_unlock(); Thinking more about it. This console_unlock() will actually cause flushing the boot consoles. A solution would be to call console_flush_all() here. And we could/should solve this in a separate patch. This code was not locked before. It is a corner case. It could be solved later. > } > } > Best Regards, Petr