Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp549785imu; Thu, 3 Jan 2019 02:52:56 -0800 (PST) X-Google-Smtp-Source: ALg8bN61HDfI25/19k1ED4lNS5QCQFrU+9OAYPu24DFyS7Y642Hu1qie4mhWrejxfdx2HAnxVswL X-Received: by 2002:a63:557:: with SMTP id 84mr16201679pgf.411.1546512776036; Thu, 03 Jan 2019 02:52:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546512776; cv=none; d=google.com; s=arc-20160816; b=TAhyFeNrkIg9tVgX3Po6hxbfHnn21NRZ2XMpv3l+3D3Ho/aWoeA7OdV8F5UgUjkL3m h8hFniK87XYqGz3HeK6l/bknQKop034osSdKRPdwupqvxNYMxKiEYxwO+EFRMNEzl3t0 /b7LEIuySuGxW4KuGCQuUaDrOjD5uQeTFHo7pbTbjJvWTvRhy/rjsUMd8s58waaBoFGt K8hf8RfIL22nVG+QHe84uI7Kbp0mWuoSbycT8b5a+LVRCsyl2nyr4Jvuylr3XhP3Koc+ aaQDowD9gYFvIXKc1Ojln7wP6PSshhQendj/kdBvPlFTpUzfi7Y+1jkbhUIRvjoiMriN 5Asg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=r1i2fkU7yO6iN1lUVkQlAI/8K7ztdA+P3d5ImwC+Cv0=; b=Rzn3zhJ3UbVS6JrgVC9YBJcfYlCqPAuZ5T1nisvJbiDt2Cswzko7iAs3SjVpa/7Prr QnI9LG/0ZhzTMCyVzfxD+1LZ+s0kqK2U19ZyW4iGHXkmdWY32/LriZASfw19/bQ5rzY4 6MMjl6Ns3v4FA64yfY/6PQGER5aViwHYnIAu19rF/frxCZ9sAS+WRBfeRcJuuz+y4WEn a7ozMSxrcgXwj+/Xayu8Hm5VNAvGrrxL6nC6pDt910r/OHgc0e2AjLvnLhMa3Z2+A4Qv lgx9pWHhDax+XrymzVn1wQ/FSLU6/vyKc3fn438tYg49Dm4ZxSHb3BwFSuM0xhziu11u 7+sw== 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 i4si12524806pfg.218.2019.01.03.02.52.37; Thu, 03 Jan 2019 02:52:55 -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; 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 S1730228AbfACHqC (ORCPT + 99 others); Thu, 3 Jan 2019 02:46:02 -0500 Received: from smtp2207-205.mail.aliyun.com ([121.197.207.205]:56705 "EHLO smtp2207-205.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730177AbfACHqA (ORCPT ); Thu, 3 Jan 2019 02:46:00 -0500 X-Alimail-AntiSpam: AC=CONTINUE;BC=0.07555554|-1;CH=green;FP=0|0|0|0|0|-1|-1|-1;HT=e02c03305;MF=liaoweixiong@allwinnertech.com;NM=1;PH=DS;RN=6;RT=6;SR=0;TI=SMTPD_---.DgqvJY-_1546501546; Received: from PC-liaoweixiong.allwinnertech.com(mailfrom:liaoweixiong@allwinnertech.com fp:SMTPD_---.DgqvJY-_1546501546) by smtp.aliyun-inc.com(10.147.43.230); Thu, 03 Jan 2019 15:45:55 +0800 From: liaoweixiong To: Kees Cook , Anton Vorontsov , Colin Cross , Tony Luck Cc: linux-kernel@vger.kernel.org, liaoweixiong Subject: [RFC v4 2/3] pstore/rom: add sample for pstore_rom Date: Thu, 3 Jan 2019 15:45:32 +0800 Message-Id: <1546501533-1855-3-git-send-email-liaoweixiong@allwinnertech.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1546501533-1855-1-git-send-email-liaoweixiong@allwinnertech.com> References: <1546501533-1855-1-git-send-email-liaoweixiong@allwinnertech.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org It is a sample for pstore_rom, using general ram rather than block device. According to pstore_rom, the data will be saved to ram buffer if not register device path and apis for panic. So, it can only used to dump Oops and some things will not reboot. Signed-off-by: liaoweixiong --- fs/pstore/Kconfig | 9 +++++++++ fs/pstore/Makefile | 2 ++ fs/pstore/rombuf.c | 46 ++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 57 insertions(+) create mode 100644 fs/pstore/rombuf.c diff --git a/fs/pstore/Kconfig b/fs/pstore/Kconfig index abf0453..426b5ea 100644 --- a/fs/pstore/Kconfig +++ b/fs/pstore/Kconfig @@ -159,3 +159,12 @@ config PSTORE_ROM help This enables panic and oops message to be logged to a block dev where it can be read back at some later point. + +config PSTORE_ROMBUF + tristate "romoop buffer sample" + depends on PSTORE_ROM + help + This is a sample for pstore rom, but do NOT have a block dev. + According to pstore_rom, the data will be saved to ram buffer and + dropped when reboot. So, it can only used to dump Oops and some + things will not reboot. diff --git a/fs/pstore/Makefile b/fs/pstore/Makefile index ea38d6e..21c1226 100644 --- a/fs/pstore/Makefile +++ b/fs/pstore/Makefile @@ -15,3 +15,5 @@ obj-$(CONFIG_PSTORE_RAM) += ramoops.o obj-$(CONFIG_PSTORE_ROM) += romoops.o romoops-y += romzone.o + +obj-$(CONFIG_PSTORE_ROMBUF) += rombuf.o diff --git a/fs/pstore/rombuf.c b/fs/pstore/rombuf.c new file mode 100644 index 0000000..bb21a85 --- /dev/null +++ b/fs/pstore/rombuf.c @@ -0,0 +1,46 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * + * rombuf.c: ROM Oops/Panic logger + * + * Copyright (C) 2019 liaoweixiong + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + */ +#define pr_fmt(fmt) "rombuf: " fmt + +#include +#include +#include + +struct romz_info rombuf_info = { + .owner = THIS_MODULE, + .name = "rombuf", + .part_size = 512 * 1024, + .dmesg_size = 64 * 1024, + .dump_oops = true, +}; + +static int __init rombuf_init(void) +{ + return romz_register(&rombuf_info); +} +module_init(rombuf_init); + +static void __exit rombuf_exit(void) +{ + romz_unregister(&rombuf_info); +} +module_exit(rombuf_exit); + +MODULE_LICENSE("GPL"); +MODULE_AUTHOR("liaoweixiong "); +MODULE_DESCRIPTION("Sample for Pstore ROM with Oops logger"); -- 1.9.1