blob: 4491e8ff36e661f19b4273cec473bd6cb6e1fd03 [file] [log] [blame]
Anton Vorontsovcddb8752012-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
Anton Vorontsovcddb8752012-05-17 00:15:08 -070020#include <linux/device.h>
21#include <linux/kernel.h>
22#include <linux/list.h>
23#include <linux/types.h>
24#include <linux/init.h>
25
26struct persistent_ram_buffer;
27
28struct persistent_ram_descriptor {
29 const char *name;
30 phys_addr_t size;
31};
32
33struct persistent_ram {
34 phys_addr_t start;
35 phys_addr_t size;
36
37 int num_descs;
38 struct persistent_ram_descriptor *descs;
39
40 struct list_head node;
41};
42
43struct persistent_ram_zone {
44 phys_addr_t paddr;
45 size_t size;
46 void *vaddr;
47 struct persistent_ram_buffer *buffer;
48 size_t buffer_size;
49
50 /* ECC correction */
51 bool ecc;
52 char *par_buffer;
53 char *par_header;
54 struct rs_control *rs_decoder;
55 int corrected_bytes;
56 int bad_blocks;
57 int ecc_block_size;
58 int ecc_size;
59 int ecc_symsize;
60 int ecc_poly;
61
62 char *old_log;
63 size_t old_log_size;
64};
65
66int persistent_ram_early_init(struct persistent_ram *ram);
67
68struct persistent_ram_zone * __init persistent_ram_new(phys_addr_t start,
69 size_t size,
70 bool ecc);
71void persistent_ram_free(struct persistent_ram_zone *prz);
72struct persistent_ram_zone *persistent_ram_init_ringbuffer(struct device *dev,
73 bool ecc);
74
75int persistent_ram_write(struct persistent_ram_zone *prz, const void *s,
76 unsigned int count);
77
Anton Vorontsov201e4ac2012-05-26 06:07:49 -070078void persistent_ram_save_old(struct persistent_ram_zone *prz);
Anton Vorontsovcddb8752012-05-17 00:15:08 -070079size_t persistent_ram_old_size(struct persistent_ram_zone *prz);
80void *persistent_ram_old(struct persistent_ram_zone *prz);
81void persistent_ram_free_old(struct persistent_ram_zone *prz);
82ssize_t persistent_ram_ecc_string(struct persistent_ram_zone *prz,
83 char *str, size_t len);
84
Kyungmin Parkc3b92ce2010-10-27 15:34:52 -070085/*
86 * Ramoops platform data
87 * @mem_size memory size for ramoops
88 * @mem_address physical memory address to contain ramoops
89 */
90
91struct ramoops_platform_data {
92 unsigned long mem_size;
93 unsigned long mem_address;
Sergiu Iordache3e5c4fa2011-07-26 16:08:59 -070094 unsigned long record_size;
Sergiu Iordache6b4d2a22011-07-26 16:08:58 -070095 int dump_oops;
Anton Vorontsov39eb7e972012-05-17 00:15:34 -070096 bool ecc;
Kyungmin Parkc3b92ce2010-10-27 15:34:52 -070097};
98
99#endif