Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4672696pxj; Wed, 12 May 2021 10:33:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzNUqI+hIo6HgSqNjratiSgbXewr1adwSht+Ws8Wj1WP1toqlnMnVMz7PblLi1JJDtMvGMy X-Received: by 2002:a17:907:1b06:: with SMTP id mp6mr39449721ejc.292.1620840814005; Wed, 12 May 2021 10:33:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620840814; cv=none; d=google.com; s=arc-20160816; b=pPWTJx9x5/ijjln9A8Xgy0eQATG/OQAOCYBg5rJ1dbMwWsbQnDKTZ2owczOZZ95azk JhFH86ldxh5w2Sv5szDtii1ZGIVf6UiuwHW2lFvauyyarX/Ygqp8QT3dS1fPUyI0rHdC zCn1TaE+C+XRIDLHvz+8YvlrFIXno/vL1mFJsfWt8JEQtcbU52noa03905742Q6lRYZG Lhsm7hKpl6m4teW2XBJC3p1M14PEfQ7vKTxlAUMFOxtArDHQcM4kKQYGpHsf+brx7Uti J2ZnE1sXiA9sXbWSI7DNF3GGGap5b+OkK7X6KDoXjb9A+0LccaplksNeQeMIxzo/pCBr OL/g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=KSinXs3AByfqvoSATkSWjdN7TtZC5A6GRVoFMIMRVOM=; b=eP9Ifx2REeuL2Jlch3VjXa6P2R3uP25mjWu2uLRTQi4B48OIlgNstDXRE9N6aKTHLA 3yR5PtSrzyNXnIVGlpiInWbGE4gMHQKO9RcOH7mAEma2tk2G1w0qy2w9EBmFrKLLRmb2 kpsT9ghzxmw8bjfxs9XkXgN8tVxkQroRKauNi1S8ljZ+wuHo2BtiweqW5uRq9RWB8Dof klWokJDL0l9oiDzY0z7nRP+N9kQ9sKIy5o45ReaE0/APHOTytAe8kmmOY5RebNZ+/OPn G1092zGfpiToq5dr6FULLOh6HRNBB0TwArs5gxYSJb4K30lSJiej1k0EcVKLlKZz5i24 uuug== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=gZhXzSy0; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bo20si346966edb.481.2021.05.12.10.33.10; Wed, 12 May 2021 10:33:33 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=gZhXzSy0; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1348034AbhELRaX (ORCPT + 99 others); Wed, 12 May 2021 13:30:23 -0400 Received: from mail.kernel.org ([198.145.29.99]:34630 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239336AbhELQHx (ORCPT ); Wed, 12 May 2021 12:07:53 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id AB07F61D1D; Wed, 12 May 2021 15:37:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620833851; bh=SfNP/GQECSkZeIGOR0B7vM9t5zWSbsxJFDeCrUlQTwQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=gZhXzSy0jFNFwO4Io06ggyCbFVvCM52UBpwgZEDgVvhImdVzZ0rxCfkpRBNdiJr6x RBuqpxg2Wle/P9T7ShFmcTeov/D2ECReHzkrlWSXGv2ruYJKldePkZzsNLpyls+k+/ dONJ4g1VxgZLHDOf66k21LA1+rJkWYsU/+oPEVYE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, John Ogness , Petr Mladek , Sasha Levin Subject: [PATCH 5.11 313/601] printk: limit second loop of syslog_print_all Date: Wed, 12 May 2021 16:46:30 +0200 Message-Id: <20210512144838.126082326@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210512144827.811958675@linuxfoundation.org> References: <20210512144827.811958675@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: John Ogness [ Upstream commit bb07b16c44b2c6ddbafa44bb06454719002e828e ] The second loop of syslog_print_all() subtracts lengths that were added in the first loop. With commit b031a684bfd0 ("printk: remove logbuf_lock writer-protection of ringbuffer") it is possible that records are (over)written during syslog_print_all(). This allows the possibility of the second loop subtracting lengths that were never added in the first loop. This situation can result in syslog_print_all() filling the buffer starting from a later record, even though there may have been room to fit the earlier record(s) as well. Fixes: b031a684bfd0 ("printk: remove logbuf_lock writer-protection of ringbuffer") Signed-off-by: John Ogness Reviewed-by: Petr Mladek Signed-off-by: Petr Mladek Link: https://lore.kernel.org/r/20210303101528.29901-4-john.ogness@linutronix.de Signed-off-by: Sasha Levin --- kernel/printk/printk.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/kernel/printk/printk.c b/kernel/printk/printk.c index 575a34b88936..77ae2704e979 100644 --- a/kernel/printk/printk.c +++ b/kernel/printk/printk.c @@ -1494,6 +1494,7 @@ static int syslog_print_all(char __user *buf, int size, bool clear) struct printk_info info; unsigned int line_count; struct printk_record r; + u64 max_seq; char *text; int len = 0; u64 seq; @@ -1512,9 +1513,15 @@ static int syslog_print_all(char __user *buf, int size, bool clear) prb_for_each_info(clear_seq, prb, seq, &info, &line_count) len += get_record_print_text_size(&info, line_count, true, time); + /* + * Set an upper bound for the next loop to avoid subtracting lengths + * that were never added. + */ + max_seq = seq; + /* move first record forward until length fits into the buffer */ prb_for_each_info(clear_seq, prb, seq, &info, &line_count) { - if (len <= size) + if (len <= size || info.seq >= max_seq) break; len -= get_record_print_text_size(&info, line_count, true, time); } -- 2.30.2