Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp412865imm; Thu, 13 Sep 2018 23:57:59 -0700 (PDT) X-Google-Smtp-Source: ANB0VdYkn7VlwNhdINnJldt4tb2OR6wnYl1hkit5JY3jIiX3vT8U6Zqz5cwLGrKDMRHowRVYMW3q X-Received: by 2002:aa7:86cb:: with SMTP id h11-v6mr10820985pfo.58.1536908279001; Thu, 13 Sep 2018 23:57:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1536908278; cv=none; d=google.com; s=arc-20160816; b=iuiKMySBYGtXiCnoiNza/WdyaEpkfRZo4db35w1mju1JOvMX8Op83KdpjgTS2YOYzW TysQ1NDC/kGZNCG2scVVB0rG/umPcx5+Ay2ktFEKWfoiRzhO3NylwuCKLw7/A1mjUJoR 2skjsxBjyx6jRIluRSxBjEcsRz2fiPomHEUipxITBNGryG6b/Q39/tyhkDY28k9Lcsnu F2a1XbxolEW9Y7ej+Gc03gDtndAO37UsLZq8gFISn+KbVFaMSl5dBCPXQbBFN9NSh/+g mLrzKsyRtqD3A/x9QCTQ39JdkQgbVfTC2kevj4mJn4ThJkHWqKNJCo9D5kbZBNoKlx8O uY/Q== 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; bh=1IuaYtbdSkVdT2fkhiUXKkbGR0yd7gehdZjtfOfY+Ts=; b=N6+mG5epD4cSUkiUySG87mzElNfNcT6QnNuQKiwvjhdCsxqgOWlSzL4JyIVin/k1bY hpZsSK/wH93rvrflcLZPBLQV6IJpUixjn1NW03sE7erlOFJX/z8cjgKKaCPIItjjPUzf 1jzrEeKYxF2GDOyNLlr/97HFlERVQnpoR4rgXNcmMXdNbH8NLhgbSTYzdi2qp37Y2cdz 8QV+ct68HDMJnVtp9KOwpqJNeQxme/RNCbdHRnmjvRVW8+KghUBYVTuSJ5JaVG+n6sJ/ tXsz8IaKysQ51RDYWM3WcD4Lvj8vAdZAA1UCGA8U89ywLE6+0aVUYVfk9zkKUXdiHfgP EBew== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=QWUODz5t; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w26-v6si5039273pgl.340.2018.09.13.23.57.42; Thu, 13 Sep 2018 23:57:58 -0700 (PDT) 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=@gmail.com header.s=20161025 header.b=QWUODz5t; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727691AbeINMKi (ORCPT + 99 others); Fri, 14 Sep 2018 08:10:38 -0400 Received: from mail-pg1-f194.google.com ([209.85.215.194]:42128 "EHLO mail-pg1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726955AbeINMKi (ORCPT ); Fri, 14 Sep 2018 08:10:38 -0400 Received: by mail-pg1-f194.google.com with SMTP id y4-v6so3924012pgp.9 for ; Thu, 13 Sep 2018 23:57:34 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=1IuaYtbdSkVdT2fkhiUXKkbGR0yd7gehdZjtfOfY+Ts=; b=QWUODz5t5eOTwExDTLoSav+1MrLWchzR5X2u5QudcRl21asUG3kxoavzmLrfsQ8nic AKZ3h49SftiHu5M7CFhB97xz+0fyA01jtXsR0HkV8Ms0FHMQYRl1P41+wvwGTYsK08GC M64GwsMmIGBRDRMJvlNpVhYXXaZ+Na73EqMsIj417hbD3uYP884JWz3FH8zXDYo/D1km AHLh4u5rVzsY9QNS31EK+C+xjfh0WhdedsMhT9Y1G6d2u/7LzH0mDD7lkZxv5jl5ddBy 9P3FYrPXGMbU4Q6dYJ0fSU/UgNJUJaMPTxGw4+xwGr3FLl1friuIsRh1Lwxaq6MkJ8kk au5Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=1IuaYtbdSkVdT2fkhiUXKkbGR0yd7gehdZjtfOfY+Ts=; b=r63t+jId8l4EMCMz6eCvBhFiWfNlOjgjN4Un38swgn9/QGMlbbvLFLzzbaRUfHwDHF P6ayPei/rgUGR7YXUqXzR/5QwtitsBXkBzP63LR1n9qVOdZQMNzHBbK9EY0nzXzg+RLO MrSR+IXI+rX21pwKUQUzwvDCsxScHR9ZPQBptKr9EwbwwohhB3OOQJRPIXqPceSanRyn CFJygxjS7OnhnQEIToV234NqlrMkB2kHWuFs6DpgNmdzzWP3604V1YYROUSLoalrz6Bu bwwzD9gVt+gHxBrSbRCqxPSMvCYJ/nTc3lkdUnyOCUrt5ICefInUXMVXjucyzUlObKKb qTww== X-Gm-Message-State: APzg51DU76YAHzB1fc3+tEmVqkTpKbMo3f14bXOWcWNYd1gyS193nNgi rS16Wgt6mmPx1bqjQAzT4Cs= X-Received: by 2002:a63:1316:: with SMTP id i22-v6mr10166212pgl.86.1536908253719; Thu, 13 Sep 2018 23:57:33 -0700 (PDT) Received: from localhost ([39.7.18.191]) by smtp.gmail.com with ESMTPSA id z11-v6sm8840579pfi.4.2018.09.13.23.57.31 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Thu, 13 Sep 2018 23:57:32 -0700 (PDT) Date: Fri, 14 Sep 2018 15:57:28 +0900 From: Sergey Senozhatsky To: Petr Mladek , Steven Rostedt Cc: Alexander Potapenko , Dmitriy Vyukov , penguin-kernel@i-love.sakura.ne.jp, kbuild test robot , syzkaller , LKML , Linus Torvalds , Andrew Morton , Sergey Senozhatsky , Sergey Senozhatsky Subject: Re: [PATCH] printk: inject caller information into the body of message Message-ID: <20180914065728.GA515@jagdpanzerIV> References: <20180620110759.GD444@jagdpanzerIV> <20180620130628.GA1000@tigerII.localdomain> <20180912065307.GA606@jagdpanzerIV> <20180912120548.4280f04a@vmware.local.home> <20180913071204.GA604@jagdpanzerIV> <20180913122625.6ieyexpcmlc5z2it@pathway.suse.cz> <20180913142802.GB517@tigerII.localdomain> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180913142802.GB517@tigerII.localdomain> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On (09/13/18 23:28), Sergey Senozhatsky wrote: > Not that I see any problems with pr_line_flush(). But can drop it, sure. > pr_line() is a replacement for pr_cont() and as such it's not for multi-line > buffering. OK, attached. Let me know if anything needs to improved (including broken English). Will we keep in the printk tree or shall I send a formal patch to Andrew? === From: Sergey Senozhatsky Subject: [PATCH] lib/seq_buf: add pr_line buffering API Signed-off-by: Sergey Senozhatsky --- include/linux/kern_levels.h | 3 ++ include/linux/seq_buf.h | 60 +++++++++++++++++++++++++++++++++++++ lib/seq_buf.c | 57 +++++++++++++++++++++++++++++++++++ 3 files changed, 120 insertions(+) diff --git a/include/linux/kern_levels.h b/include/linux/kern_levels.h index d237fe854ad9..9c281ac745b3 100644 --- a/include/linux/kern_levels.h +++ b/include/linux/kern_levels.h @@ -20,6 +20,9 @@ * Annotation for a "continued" line of log printout (only done after a * line that had no enclosing \n). Only to be used by core/arch code * during early bootup (a continued line is not SMP-safe otherwise). + * + * Please consider pr_line()/vpr_line() functions for SMP-safe continued + * line printing. */ #define KERN_CONT KERN_SOH "c" diff --git a/include/linux/seq_buf.h b/include/linux/seq_buf.h index aa5deb041c25..b33aeea14803 100644 --- a/include/linux/seq_buf.h +++ b/include/linux/seq_buf.h @@ -23,6 +23,62 @@ struct seq_buf { loff_t readpos; }; +#define __SEQ_BUF_INITIALIZER(buf, length) \ +{ \ + .buffer = (buf), \ + .size = (length), \ + .len = 0, \ + .readpos = 0, \ +} + +#ifdef CONFIG_PRINTK +#define __PR_LINE_BUF_SZ 80 +#else +#define __PR_LINE_BUF_SZ 0 +#endif + +/** + * pr_line - printk() line buffer structure + * @sb: underlying seq buffer, which holds the data + * @level: printk() log level (KERN_ERR, etc.) + */ +struct pr_line { + struct seq_buf sb; + char *level; +}; + +/** + * DEFINE_PR_LINE - define a new pr_line variable + * @lev: printk() log level + * @name: variable name + * + * Defines a new pr_line varialbe, which would use an implicit + * stack buffer of size __PR_LINE_BUF_SZ. + */ +#define DEFINE_PR_LINE(lev, name) \ + char __line_##name[__PR_LINE_BUF_SZ]; \ + struct pr_line name = { \ + .sb = __SEQ_BUF_INITIALIZER(__line_##name, \ + __PR_LINE_BUF_SZ), \ + .level = lev, \ + } + +/** + * DEFINE_PR_LINE_BUF - define a new pr_line variable + * @lev: printk() log level + * @name: variable name + * @buf: external buffer + * @sz: external buffer size + * + * Defines a new pr_line variable, which would use an external + * buffer for printk line. + */ +#define DEFINE_PR_LINE_BUF(lev, name, buf, sz) \ + struct pr_line name = { \ + .sb = __SEQ_BUF_INITIALIZER(buf, (sz)), \ + .level = lev, \ + } + static inline void seq_buf_clear(struct seq_buf *s) { s->len = 0; @@ -131,4 +187,8 @@ extern int seq_buf_bprintf(struct seq_buf *s, const char *fmt, const u32 *binary); #endif +extern __printf(2, 0) +int vpr_line(struct pr_line *pl, const char *fmt, va_list args); +extern __printf(2, 3) +int pr_line(struct pr_line *pl, const char *fmt, ...); #endif /* _LINUX_SEQ_BUF_H */ diff --git a/lib/seq_buf.c b/lib/seq_buf.c index 11f2ae0f9099..fada7623f168 100644 --- a/lib/seq_buf.c +++ b/lib/seq_buf.c @@ -324,3 +324,60 @@ int seq_buf_to_user(struct seq_buf *s, char __user *ubuf, int cnt) s->readpos += cnt; return cnt; } + +/** + * vpr_line - Append data to the printk() line buffer + * @pl: the pr_line descriptor + * @fmt: printf format string + * @args: va_list of arguments from a printf() type function + * + * Writes a vnprintf() format into the printk() pr_line buffer. + * Terminating new-line symbol flushes (prints) the buffer. + * + * Unlike pr_cont() and printk(KERN_CONT), this function is SMP-safe + * and shall be used for continued line printing. + * + * Returns zero on success, -1 on overflow. + */ +int vpr_line(struct pr_line *pl, const char *fmt, va_list args) +{ + struct seq_buf *s = &pl->sb; + int ret, len; + + ret = seq_buf_vprintf(s, fmt, args); + + len = seq_buf_used(s); + if (len && s->buffer[len - 1] == '\n') { + printk("%s%.*s", pl->level ? : KERN_DEFAULT, len, s->buffer); + seq_buf_clear(s); + } + + return ret; +} +EXPORT_SYMBOL(vpr_line); + +/** + * pr_line - Append data to the printk() line buffer + * @pl: the pr_line descriptor + * @fmt: printf format string + * + * Writes a printf() format into the printk() pr_line buffer. + * Terminating new-line symbol flushes (prints) the buffer. + * + * Unlike pr_cont() and printk(KERN_CONT), this function is SMP-safe + * and shall be used for continued line printing. + * + * Returns zero on success, -1 on overflow. + */ +int pr_line(struct pr_line *pl, const char *fmt, ...) +{ + va_list ap; + int ret; + + va_start(ap, fmt); + ret = vpr_line(pl, fmt, ap); + va_end(ap); + + return ret; +} +EXPORT_SYMBOL(pr_line); -- 2.19.0