blob: 5d10ad51c1c43e514206313055c6678e20245bb4 [file] [log] [blame]
Anton Vorontsovcddb87512012-05-17 00:15:08 -07001/*
2 * Copyright (C) 2010 Marco Stornelli <marco.stornelli@gmail.com>
3 * Copyright (C) 2011 Kees Cook <keescook@chromium.org>
4 * Copyright (C) 2011 Google, Inc.
5 *
6 * This software is licensed under the terms of the GNU General Public
7 * License version 2, as published by the Free Software Foundation, and
8 * may be copied, distributed, and modified under those terms.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 */
16
Anton Vorontsov1894a252012-05-16 05:43:08 -070017#ifndef __LINUX_PSTORE_RAM_H__
18#define __LINUX_PSTORE_RAM_H__
Kyungmin Parkc3b92ce2010-10-27 15:34:52 -070019
Mark Salyzyn5bf6d1b2016-09-01 08:13:46 -070020#include <linux/compiler.h>
Anton Vorontsovcddb87512012-05-17 00:15:08 -070021#include <linux/device.h>
Mark Salyzyn5bf6d1b2016-09-01 08:13:46 -070022#include <linux/init.h>
Anton Vorontsovcddb87512012-05-17 00:15:08 -070023#include <linux/kernel.h>
24#include <linux/list.h>
25#include <linux/types.h>
Anton Vorontsovcddb87512012-05-17 00:15:08 -070026
Joel Fernandes663deb42016-10-20 00:34:01 -070027/*
28 * Choose whether access to the RAM zone requires locking or not. If a zone
29 * can be written to from different CPUs like with ftrace for example, then
30 * PRZ_FLAG_NO_LOCK is used. For all other cases, locking is required.
31 */
32#define PRZ_FLAG_NO_LOCK BIT(0)
Kees Cookc208f7d2018-11-01 15:11:47 -070033/*
34 * If a PRZ should only have a single-boot lifetime, this marks it as
35 * getting wiped after its contents get copied out after boot.
36 */
Peng Wang7684bd32018-10-30 15:52:34 +080037#define PRZ_FLAG_ZAP_OLD BIT(1)
Joel Fernandes663deb42016-10-20 00:34:01 -070038
Anton Vorontsovcddb87512012-05-17 00:15:08 -070039struct persistent_ram_buffer;
Anton Vorontsov67a101f2012-07-17 11:37:07 -070040struct rs_control;
Anton Vorontsovcddb87512012-05-17 00:15:08 -070041
Arve Hjønnevågc31ad082012-05-22 16:33:23 -070042struct persistent_ram_ecc_info {
43 int block_size;
44 int ecc_size;
45 int symsize;
46 int poly;
Kees Cookf2531f12018-03-07 12:18:33 -080047 uint16_t *par;
Arve Hjønnevågc31ad082012-05-22 16:33:23 -070048};
49
Kees Cookc208f7d2018-11-01 15:11:47 -070050/**
51 * struct persistent_ram_zone - Details of a persistent RAM zone (PRZ)
52 * used as a pstore backend
53 *
54 * @paddr: physical address of the mapped RAM area
55 * @size: size of mapping
56 * @label: unique name of this PRZ
57 * @flags: holds PRZ_FLAGS_* bits
58 *
59 * @buffer_lock:
60 * locks access to @buffer "size" bytes and "start" offset
61 * @buffer:
62 * pointer to actual RAM area managed by this PRZ
63 * @buffer_size:
64 * bytes in @buffer->data (not including any trailing ECC bytes)
65 *
66 * @par_buffer:
67 * pointer into @buffer->data containing ECC bytes for @buffer->data
68 * @par_header:
69 * pointer into @buffer->data containing ECC bytes for @buffer header
70 * (i.e. all fields up to @data)
71 * @rs_decoder:
72 * RSLIB instance for doing ECC calculations
73 * @corrected_bytes:
74 * ECC corrected bytes accounting since boot
75 * @bad_blocks:
76 * ECC uncorrectable bytes accounting since boot
77 * @ecc_info:
78 * ECC configuration details
79 *
80 * @old_log:
81 * saved copy of @buffer->data prior to most recent wipe
82 * @old_log_size:
83 * bytes contained in @old_log
84 *
85 */
Anton Vorontsovcddb87512012-05-17 00:15:08 -070086struct persistent_ram_zone {
87 phys_addr_t paddr;
88 size_t size;
89 void *vaddr;
Kees Cook1227daa2018-10-17 17:20:35 -070090 char *label;
Kees Cookc208f7d2018-11-01 15:11:47 -070091 u32 flags;
92
93 raw_spinlock_t buffer_lock;
Anton Vorontsovcddb87512012-05-17 00:15:08 -070094 struct persistent_ram_buffer *buffer;
95 size_t buffer_size;
96
Anton Vorontsovcddb87512012-05-17 00:15:08 -070097 char *par_buffer;
98 char *par_header;
99 struct rs_control *rs_decoder;
100 int corrected_bytes;
101 int bad_blocks;
Arve Hjønnevågc31ad082012-05-22 16:33:23 -0700102 struct persistent_ram_ecc_info ecc_info;
Anton Vorontsovcddb87512012-05-17 00:15:08 -0700103
104 char *old_log;
105 size_t old_log_size;
106};
107
Greg Kroah-Hartmanf568f6c2012-12-21 15:02:05 -0800108struct persistent_ram_zone *persistent_ram_new(phys_addr_t start, size_t size,
Tony Lindgren027bc8b2014-09-16 13:50:01 -0700109 u32 sig, struct persistent_ram_ecc_info *ecc_info,
Kees Cook1227daa2018-10-17 17:20:35 -0700110 unsigned int memtype, u32 flags, char *label);
Anton Vorontsovcddb87512012-05-17 00:15:08 -0700111void persistent_ram_free(struct persistent_ram_zone *prz);
Anton Vorontsovfce39792012-05-26 06:07:51 -0700112void persistent_ram_zap(struct persistent_ram_zone *prz);
Anton Vorontsovcddb87512012-05-17 00:15:08 -0700113
114int persistent_ram_write(struct persistent_ram_zone *prz, const void *s,
Mark Salyzyn5bf6d1b2016-09-01 08:13:46 -0700115 unsigned int count);
116int persistent_ram_write_user(struct persistent_ram_zone *prz,
117 const void __user *s, unsigned int count);
Anton Vorontsovcddb87512012-05-17 00:15:08 -0700118
Anton Vorontsov201e4ac2012-05-26 06:07:49 -0700119void persistent_ram_save_old(struct persistent_ram_zone *prz);
Anton Vorontsovcddb87512012-05-17 00:15:08 -0700120size_t persistent_ram_old_size(struct persistent_ram_zone *prz);
121void *persistent_ram_old(struct persistent_ram_zone *prz);
122void persistent_ram_free_old(struct persistent_ram_zone *prz);
123ssize_t persistent_ram_ecc_string(struct persistent_ram_zone *prz,
124 char *str, size_t len);
125
Kyungmin Parkc3b92ce2010-10-27 15:34:52 -0700126/*
127 * Ramoops platform data
128 * @mem_size memory size for ramoops
129 * @mem_address physical memory address to contain ramoops
130 */
131
Joel Fernandesa1cf53a2016-10-20 00:34:04 -0700132#define RAMOOPS_FLAG_FTRACE_PER_CPU BIT(0)
133
Kyungmin Parkc3b92ce2010-10-27 15:34:52 -0700134struct ramoops_platform_data {
135 unsigned long mem_size;
Wiebe, Wladislav (Nokia - DE/Ulm)764fd6392015-11-13 12:10:05 +0000136 phys_addr_t mem_address;
Tony Lindgren027bc8b2014-09-16 13:50:01 -0700137 unsigned int mem_type;
Sergiu Iordache3e5c4fa2011-07-26 16:08:59 -0700138 unsigned long record_size;
Anton Vorontsovb5d38e92012-05-26 06:20:23 -0700139 unsigned long console_size;
Anton Vorontsova694d1b2012-07-09 17:10:44 -0700140 unsigned long ftrace_size;
Mark Salyzyn9d5438f2015-01-16 16:01:10 -0800141 unsigned long pmsg_size;
Sergiu Iordache6b4d2a22011-07-26 16:08:58 -0700142 int dump_oops;
Joel Fernandesa1cf53a2016-10-20 00:34:04 -0700143 u32 flags;
Arve Hjønnevågc31ad082012-05-22 16:33:23 -0700144 struct persistent_ram_ecc_info ecc_info;
Kyungmin Parkc3b92ce2010-10-27 15:34:52 -0700145};
146
147#endif