Received: by 2002:a25:824b:0:0:0:0:0 with SMTP id d11csp1397304ybn; Wed, 25 Sep 2019 17:44:44 -0700 (PDT) X-Google-Smtp-Source: APXvYqxxbuyUhRQHApgguDqwf+XE2jUkxY6XkPj+RUMCb98REOlbUSz0i4vrUYigFjBnAbB0q+hd X-Received: by 2002:a17:906:4a11:: with SMTP id w17mr822307eju.21.1569458684686; Wed, 25 Sep 2019 17:44:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569458684; cv=none; d=google.com; s=arc-20160816; b=ImvGlPsi1AN6YnsQB2RLAXpMPENm3Fpv/6ypcLRNr2y5G1RF0+nX1wrfnXbVn24DcI RtP6zshMAMXtpNXE6TL5NsQ1h+K8kT6dGRM7ldZZ6tIBkLQGc3jMw+kbRdUqQLmxPKMe FC2AldiV6pW2hJFXLUsloAYceOiqZ/g8qL9u7shsibR7/fNQf9YHVGesUIfMgSxklSLg 6prR7QF9lrxVn+KdOSSG74xQ5mqs8gXz5Rd7lga3akLpLA+ZLRvlyYJXChvh0wcKbc7x dv8AeLQVbvWxeYUp7KGc5r4/3UQ+9rEkKfYH8+yqumHwbrknHCLUFePEOmxggZUflufT znvQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:to :from; bh=qTBmiFGeEshGpk+G4z7xw6qx+nughZtduYHqQY+pqiA=; b=mhWVLjtAXbrTmR9d/9FcX+3u2RypWJEs36Zgy6vdRD5FIqH8Amv+JZgL+4mdfcPJY7 /Urz92EO5PARTDm4oneLyYzxAGz41lULBs1Cxwc4YXQTeOsZnWi1we72/v9833ZyvvIz m+VXRcQTApF3nWP+CREd6OhAIew4+sCb25Zp+HZ5EnE3avaL1N1PtkmO8aYjVcojX2Oy F2sBJlt34T3Y2sOukDPvBymCliScIifejWYX7Q3gk46zsFOHkw/VcTaTJFkA8lFsZypM NMWDDt9p7SlMiK8ak50rDagvO9DjM4ojk34S/+OZKsgJZhFSWtolh0F323puJXak1upd IUBA== ARC-Authentication-Results: i=1; mx.google.com; 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 z55si405101edz.254.2019.09.25.17.44.21; Wed, 25 Sep 2019 17:44:44 -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; 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 S2438148AbfIXH1F (ORCPT + 99 others); Tue, 24 Sep 2019 03:27:05 -0400 Received: from mail.windriver.com ([147.11.1.11]:64617 "EHLO mail.windriver.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2409268AbfIXH1F (ORCPT ); Tue, 24 Sep 2019 03:27:05 -0400 Received: from ALA-HCA.corp.ad.wrs.com ([147.11.189.40]) by mail.windriver.com (8.15.2/8.15.1) with ESMTPS id x8O7QkLK001049 (version=TLSv1 cipher=AES128-SHA bits=128 verify=FAIL); Tue, 24 Sep 2019 00:26:46 -0700 (PDT) Received: from pek-lpg-core3.wrs.com (128.224.153.232) by ALA-HCA.corp.ad.wrs.com (147.11.189.40) with Microsoft SMTP Server id 14.3.468.0; Tue, 24 Sep 2019 00:26:41 -0700 From: To: , , , Subject: [PATCH RT] printk: devkmsg: read: Return EPIPE when the first message user-space wants has gone Date: Tue, 24 Sep 2019 15:26:39 +0800 Message-ID: <20190924072639.25986-1-zhe.he@windriver.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: He Zhe When user-space wants to read the first message, that is when user->seq is 0, and that message has gone, it currently automatically resets user->seq to current first seq. This mis-aligns with mainline kernel. https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/Documentation/ABI/testing/dev-kmsg#n39 https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/kernel/printk/printk.c#n899 We should inform user-space that what it wants has gone by returning EPIPE in such scenario. Signed-off-by: He Zhe --- kernel/printk/printk.c | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/kernel/printk/printk.c b/kernel/printk/printk.c index e3fa33f2e23c..58c545a528b3 100644 --- a/kernel/printk/printk.c +++ b/kernel/printk/printk.c @@ -703,14 +703,10 @@ static ssize_t devkmsg_read(struct file *file, char __user *buf, goto out; } - if (user->seq == 0) { - user->seq = seq; - } else { - user->seq++; - if (user->seq < seq) { - ret = -EPIPE; - goto restore_out; - } + user->seq++; + if (user->seq < seq) { + ret = -EPIPE; + goto restore_out; } msg = (struct printk_log *)&user->msgbuf[0]; -- 2.17.1