Received: by 10.223.148.5 with SMTP id 5csp6313483wrq; Wed, 17 Jan 2018 12:07:46 -0800 (PST) X-Google-Smtp-Source: ACJfBotIjXkvn7ZURCmu2PcZWZf/B+IpOrnaAqu9o0gQXu+rotl/BhwZZSFIv/17cLrE33iq9jVm X-Received: by 10.99.171.12 with SMTP id p12mr7209490pgf.304.1516219666256; Wed, 17 Jan 2018 12:07:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516219666; cv=none; d=google.com; s=arc-20160816; b=0WaGU2NBtv3/HKdUwevGBGJbHShVJKRcbODRc7u1SOKX4h0DkMHGhJU+/sz0TcQ/He wLJhcQoLfwzFd1hkmbGoSjhrDvmmkQUjfaXPn97Zh824ngsWH2rHCtZvbqBVYSRhDjhk Q0TOaL/zGJ/pjm+eL7GkSXcUWOPERw9OOH6BTJkw37uluwpSlXwfOtxzQXddeY00NYS6 oGsdZS1BKvKcInGY9yqI7df4WICH+NqV36emhaKwB0WB/Wd/GwrCk1XpfR1CBbp2cgeL iUlM2euKvmE2K2EgDhhskHeBG0npzTAHWoqxwhxldmpnMCoqseGaT95/GZOV2cQ+K96q sPjQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature:arc-authentication-results; bh=HdfXMGTjpqxOoHQUYiwgqOEftb5tUs5bqY9kBBzN10c=; b=dCX2kDh9EsOQjryGQpzuqX/amXGu/jASQCBEU9cKdn+LPiX0Bfm14BogyFF26Xg/Eg weHuxgvQ6ZevIqP3fDbTGaIdmG2JwHYrEYcw0AXMZcv7bB7ItRqyxFHGutauvrGE/3ic VHiUwe/thoWgN1u5m7NbBw89imzPQtOyR+L+o0Mc80m88sP/wMF/8v441O/VJNq1tPOx tXB4CCUuXDj/DHhCgmJP2GZZBH/AmUFq7b/z9b+8bZEzwcKcGJkbqVZRBPwdHICAZPTn WiXpH+tkyX7BjGeSEpVsFezzW8Dg9dSMqdoeeA7BetmJtNQXFDmlAe2TdBVF36GK/avU /DeQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=gDeWzVOO; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d15si5051940plj.681.2018.01.17.12.07.31; Wed, 17 Jan 2018 12:07:46 -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=fail header.i=@gmail.com header.s=20161025 header.b=gDeWzVOO; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753163AbeAQUGC (ORCPT + 99 others); Wed, 17 Jan 2018 15:06:02 -0500 Received: from mail-qt0-f193.google.com ([209.85.216.193]:44743 "EHLO mail-qt0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753129AbeAQUGA (ORCPT ); Wed, 17 Jan 2018 15:06:00 -0500 Received: by mail-qt0-f193.google.com with SMTP id m59so24683800qte.11 for ; Wed, 17 Jan 2018 12:06:00 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=HdfXMGTjpqxOoHQUYiwgqOEftb5tUs5bqY9kBBzN10c=; b=gDeWzVOOYA9qybY8hspzChNddlB+J1w+gFK27vM3TsG6S7R833U/ohblfRl/aG3t8B nRD71yiOZHvxwXQxYjMcMUt+wMExlnpuBB6sC6Oq/Pvq1O4LZ/luL4lASBB2YGtTMJGr G2M41YzkxtVHVioGDnIvKYSmw+DooJObZoRKAMk+pHz9ODd+vD/+pyfLorQKW+Og6kx1 JLd4FBF+/sXxFz8IPNCLyb7KDYwI/8hig9j/SdfHTavuI34AE9kVyF+1tDLsSITrV90S J8srBP6vmF25W5or7i8rs/jLjrQ5cN8AXOwBkTaoaxJGmtQpIdvI1a8GNtiYFEOTrC45 6csw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:from:to:cc:subject:message-id :references:mime-version:content-disposition:in-reply-to:user-agent; bh=HdfXMGTjpqxOoHQUYiwgqOEftb5tUs5bqY9kBBzN10c=; b=P0GIoM3AAI0GzkyOrG2S1awzMLcbNtTSJlAcVz9p+akBXUEcEreYM2XQj7pN2wISpE XwCxZ/kaBDJjKTc93vauVcavuz9zhIORBFTLckk4uUMjPSayah4qVlOCxFmWJCY2/3Cr P6ONLQ8v/Zq/iR4ve0eBsCvNp03YLLq8jqXCJnXdLYpS9A4EmItf71TXXxfIm3NqTnDe lS7+HZFvWIYOh/6cCPqJfo4hxsnBc8dYmAy3ZFEIMgGeLuVompH7B1ttNJsQYgruA1h5 A+MLjM1kb9WqM7dXhWbyzxmdkcXco+AbYsEw0mNH0xDvE52CpA/C6HbXoDBMaQMBKZRd GBAA== X-Gm-Message-State: AKwxytdPpgSpSJVmsKwnNwQ/Z1GhHb4Q0EbGNz07QlfuZ+8fCLtvQUbB mUaFnUOm4IglmBNSDOW94xw= X-Received: by 10.55.179.2 with SMTP id c2mr24355662qkf.88.1516219559914; Wed, 17 Jan 2018 12:05:59 -0800 (PST) Received: from localhost (dhcp-ec-8-6b-ed-7a-cf.cpe.echoes.net. [72.28.5.223]) by smtp.gmail.com with ESMTPSA id s22sm3760774qta.66.2018.01.17.12.05.58 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 17 Jan 2018 12:05:58 -0800 (PST) Date: Wed, 17 Jan 2018 12:05:51 -0800 From: Tejun Heo To: Steven Rostedt Cc: Petr Mladek , Sergey Senozhatsky , Sergey Senozhatsky , akpm@linux-foundation.org, linux-mm@kvack.org, Cong Wang , Dave Hansen , Johannes Weiner , Mel Gorman , Michal Hocko , Vlastimil Babka , Peter Zijlstra , Linus Torvalds , Jan Kara , Mathieu Desnoyers , Tetsuo Handa , rostedt@home.goodmis.org, Byungchul Park , Pavel Machek , linux-kernel@vger.kernel.org Subject: Re: [PATCH v5 0/2] printk: Console owner and waiter logic cleanup Message-ID: <20180117200551.GW3460072@devbig577.frc2.facebook.com> References: <20180111045817.GA494@jagdpanzerIV> <20180111093435.GA24497@linux.suse> <20180111103845.GB477@jagdpanzerIV> <20180111112908.50de440a@vmware.local.home> <20180111203057.5b1a8f8f@gandalf.local.home> <20180111215547.2f66a23a@gandalf.local.home> <20180116194456.GS3460072@devbig577.frc2.facebook.com> <20180117091208.ezvuhumnsarz5thh@pathway.suse.cz> <20180117151509.GT3460072@devbig577.frc2.facebook.com> <20180117121251.7283a56e@gandalf.local.home> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180117121251.7283a56e@gandalf.local.home> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello, Steven. On Wed, Jan 17, 2018 at 12:12:51PM -0500, Steven Rostedt wrote: > From what I gathered, you said an OOM would trigger, and then the > network console would not be able to allocate memory and it would > trigger a printk too, and cause an infinite amount of printks. Yeah, it falls into back-and-forth loop between the OOM code and netconsole path. > This could very well be a great place to force offloading. If a printk > is called from within a printk, at the same context (normal, softirq, > irq or NMI), then we should trigger the offloading. I was thinking more of a timeout based approach (ie. if stuck for longer than X or X messages, offload), but if local feedback loop is the only thing we're missing after your improvements, detecting that specific condition definitely works and is likely a better approach in terms of message delivery guarantee. > +static void kick_offload_thread(void) > +{ > + /* > + * Consoles are triggering printks, offload the printks > + * to another CPU to hopefully avoid a lockup. > + */ > +} ... > @@ -2333,6 +2390,7 @@ void console_unlock(void) > > for (;;) { > struct printk_log *msg; > + bool offload; > size_t ext_len = 0; > size_t len; > > @@ -2393,15 +2451,20 @@ void console_unlock(void) > * waiter waiting to take over. > */ > console_lock_spinning_enable(); > + offload = recursion_check_start(); > > stop_critical_timings(); /* don't trace print latency */ > call_console_drivers(ext_text, ext_len, text, len); > start_critical_timings(); > > + recursion_check_finish(offload); > + > if (console_lock_spinning_disable_and_check()) { > printk_safe_exit_irqrestore(flags); > return; > } > + if (offload) > + kick_offload_thread(); Yeah, something like this would definitely work. Thanks a lot. -- tejun