Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3469110imu; Mon, 7 Jan 2019 04:04:48 -0800 (PST) X-Google-Smtp-Source: ALg8bN4ct/UiGsHVrEDTqy/y9kH07QKycdnfEi5u2Lt23kHxYJ3DASfDwgpB4Zq9EZiriR1bpqQO X-Received: by 2002:a65:6094:: with SMTP id t20mr10661302pgu.285.1546862688600; Mon, 07 Jan 2019 04:04:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546862688; cv=none; d=google.com; s=arc-20160816; b=cZNY2q7VCD4/s0iDUS0o3uDYo8q34pptY1bIT4g3gTaxNtbynUDxwZxrvAXsJbp2UB 0BxKiMIJxLaVGHpa2b0ZNeNYRizu9LnqhiRU9LWP3Zeja94fvNDsMu+EpQhFj6ESTj+c fqWBSXXOC9kDU6CfL9zGUveMj0dFDQWn/m1AE0SHJyhaquXNXs/6e1ZxltLUgIAkoh7B qf0/DjK2OIoucsbPkBH11YcPjfTJiqfXz+k0O04o2eKrberukLtdssZ2I2LLZtWyj1u7 7T52jsKfIG/Ku1iZsWi9iGoqR24pwnnUaOqD4ZfoHWWF98JvCeol/TXBQDICC88k0Gix D+MQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=X84TyZE9P8PtUZBkRuVn4g430obPcggzChvk7Wm/OG4=; b=0W8lZaPFdrkR1ENHgkYhA/7VMYl2kmeQwc2zInWZeka0BySavriI2SnFDZnn7fhclL TagG5RrxgEL+Kkd9X2El5Y1znIEp6vNQvi73zFZcBjnJzgVjDhREGxRgiqSLRWup4GGM jid/tBtsB7olKeoyQFU+DwqGVURRTFbk4/o6dl2rpKJ+P8p4c6yIW5v/9C4/WMWfQvqc tyFe2XIHb+jvifYREOJuvwlvpTdkMtX33+oTKqMNKHI1ol9ovVBbBrudv7yEn4C4Y4Or maTCUoIns+bDncbPupYqpGGVG5GidZSvclsGB7XmE29VQI/rqCOKqI8lZHK6XPn/s6/S 1AlA== 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 39si5637126pla.352.2019.01.07.04.04.33; Mon, 07 Jan 2019 04:04:48 -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 S1726821AbfAGMBv (ORCPT + 99 others); Mon, 7 Jan 2019 07:01:51 -0500 Received: from smtp2207-205.mail.aliyun.com ([121.197.207.205]:40368 "EHLO smtp2207-205.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726535AbfAGMBu (ORCPT ); Mon, 7 Jan 2019 07:01:50 -0500 X-Alimail-AntiSpam: AC=CONTINUE;BC=0.07436366|-1;CH=green;FP=0|0|0|0|0|-1|-1|-1;HT=e02c03303;MF=liaoweixiong@allwinnertech.com;NM=1;PH=DS;RN=14;RT=14;SR=0;TI=SMTPD_---.DibxlYK_1546862495; Received: from PC-liaoweixiong.allwinnertech.com(mailfrom:liaoweixiong@allwinnertech.com fp:SMTPD_---.DibxlYK_1546862495) by smtp.aliyun-inc.com(10.147.40.200); Mon, 07 Jan 2019 20:01:41 +0800 From: liaoweixiong To: Kees Cook , Anton Vorontsov , Colin Cross , Tony Luck , Jonathan Corbet , Mauro Carvalho Chehab , Greg Kroah-Hartman , "David S. Miller" , Andrew Morton , Nicolas Ferre , Arnd Bergmann Cc: linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, liaoweixiong Subject: [RFC v5 0/4] pstore/block: new support logger for block devices Date: Mon, 7 Jan 2019 20:00:58 +0800 Message-Id: <1546862462-19640-1-git-send-email-liaoweixiong@allwinnertech.com> X-Mailer: git-send-email 1.9.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Why should we need pstore_block? 1. Most embedded intelligent equipment have no persistent ram, which increases costs. We perfer to cheaper solutions, like block devices. In fast, there is already a sample for block device logger in driver MTD (drivers/mtd/mtdoops.c). 2. Do not any equipment have battery, which means that it lost all data on general ram if power failure. Pstore has little to do for these equipments. [PATCH v5] On patch 1: 1. rename pstore/rom to pstore/blk 2. Do not allocate any memory in the write path of panic. So, use local array instead in function romz_recover_dmesg_meta. 3. Add C header file "linux/fs.h" to fix implicit declaration of function 'filp_open','kernel_read'... On patch 3: 1. If panic, do not recover pmsg but flush if it is dirty. 2. Fix erase pmsg failed. On patch 4: 1. Create a document for pstore/blk [PATCH v4] On patch 1: 1. Fix always true condition '(--i >= 0) => (0-u32max >= 0)' in function romz_init_zones by defining variable i to 'int' rahter than 'unsigned int'. 2. To make codes more easily to read, we use macro READ_NEXT_ZONE for return value of romz_dmesg_read if it need to read next zone. Moveover, we assign READ_NEXT_ZONE -1024 rather than 0. 3. Add 'FLUSH_META' to 'enum romz_flush_mode' and rename 'NOT_FLUSH' to 'FLUSH_NONE' 4. Function romz_zone_write work badly with FLUSH_PART mode as badly address and offset to write. On patch 3: NEW SUPPORT psmg for pstore_rom. [PATCH v3] On patch 1: Fix build as module error for undefined 'vfs_read' and 'vfs_write' Both of 'vfs_read' and 'vfs_write' haven't be exproted yet, so we use 'kernel_read' and 'kernel_write' instead. [PATCH v2] On patch 1: Fix build as module error for redefinition of 'romz_unregister' and 'romz_register' [PATCH v1] On patch 1: Core codes of pstore_rom, which works well on allwinner(sunxi) platform. On patch 2: A sample for pstore_rom, using general ram rather than block device. liaoweixiong (4): pstore/blk: new support logger for block devices pstore/blk: add sample for pstore_blk pstore/blk: support pmsg for pstore block Documentation: pstore/blk: create document for pstore_blk Documentation/admin-guide/pstore-block.rst | 226 ++++++ MAINTAINERS | 1 + fs/pstore/Kconfig | 20 + fs/pstore/Makefile | 5 + fs/pstore/blkbuf.c | 46 ++ fs/pstore/blkzone.c | 1168 ++++++++++++++++++++++++++++ include/linux/pstore_blk.h | 62 ++ 7 files changed, 1528 insertions(+) create mode 100644 Documentation/admin-guide/pstore-block.rst create mode 100644 fs/pstore/blkbuf.c create mode 100644 fs/pstore/blkzone.c create mode 100644 include/linux/pstore_blk.h -- 1.9.1