From mboxrd@z Thu Jan 1 00:00:00 1970 From: Peter Zijlstra Subject: Re: [RFC][PATCHv2 2/4] printk: move printk_safe macros to printk header Date: Wed, 17 Oct 2018 09:57:28 +0200 Message-ID: <20181017075728.GF3121@hirez.programming.kicks-ass.net> References: <20181016050428.17966-1-sergey.senozhatsky@gmail.com> <20181016050428.17966-3-sergey.senozhatsky@gmail.com> <20181016072719.GB4030@hirez.programming.kicks-ass.net> <20181016122734.GA1259@jagdpanzerIV> <20181016125415.GA3121@hirez.programming.kicks-ass.net> <20181017043251.GC1068@jagdpanzerIV> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline In-Reply-To: <20181017043251.GC1068@jagdpanzerIV> Sender: linux-kernel-owner@vger.kernel.org To: Sergey Senozhatsky Cc: linux-kernel@vger.kernel.org, Petr Mladek , Steven Rostedt , Daniel Wang , Andrew Morton , Linus Torvalds , Greg Kroah-Hartman , Alan Cox , Jiri Slaby , Peter Feiner , linux-serial@vger.kernel.org, Sergey Senozhatsky List-Id: linux-serial@vger.kernel.org On Wed, Oct 17, 2018 at 01:32:51PM +0900, Sergey Senozhatsky wrote: > This probably will be a bit more hairy. logbuf is written to by many > sources and is read from by many sides, including user-space [both read() > and write()]. So we will need more flags/magic around memcpy(). A simple, > "grab the logbuf entry, set the proper offset to point to the next available > logbuf record and then do memcpy()" won't suffice. We need a flag for > "memcpy() complete, we can read this entry". Otherwise: Sure, but lockless buffers mostly have reserve and commit stages anyway. Exactly to avoid that problem. > All right. OK. So we are on the same page here: > - Have more opinions on this. People please speak out. > - Have clear "let's do it" from Cc-ed people. > > > If we are really doing this, then let's split it and have > incremental changes. Namely, what I suggest is: I'd start by replacing logbuf with the lockless buffer and ripping out the current nmi/safe/etc.. bollocks. There is absolutely no point what so ever in doing anything until that is sorted. After that, move the console output to a kthread, but keep earlycon (if set) synchronous. Also avoid the whole panic/warn special case when earlycon is set, no point in doing dodgy crap when you know you have a good option already.