ARM: rockchip: rk3228: add grf definition
[firefly-linux-kernel-4.4.55.git] / include / linux / pstore.h
1 /*
2  * Persistent Storage - pstore.h
3  *
4  * Copyright (C) 2010 Intel Corporation <tony.luck@intel.com>
5  *
6  * This code is the generic layer to export data records from platform
7  * level persistent storage via a file system.
8  *
9  *  This program is free software; you can redistribute it and/or modify
10  *  it under the terms of the GNU General Public License version 2 as
11  *  published by the Free Software Foundation.
12  *
13  *  This program is distributed in the hope that it will be useful,
14  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
15  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  *  GNU General Public License for more details.
17  *
18  *  You should have received a copy of the GNU General Public License
19  *  along with this program; if not, write to the Free Software
20  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
21  */
22 #ifndef _LINUX_PSTORE_H
23 #define _LINUX_PSTORE_H
24
25 #include <linux/time.h>
26 #include <linux/kmsg_dump.h>
27 #include <linux/mutex.h>
28 #include <linux/types.h>
29 #include <linux/spinlock.h>
30 #include <linux/errno.h>
31
32 /* types */
33 enum pstore_type_id {
34         PSTORE_TYPE_DMESG       = 0,
35         PSTORE_TYPE_MCE         = 1,
36         PSTORE_TYPE_CONSOLE     = 2,
37         PSTORE_TYPE_FTRACE      = 3,
38         PSTORE_TYPE_PMSG        = 4, /* Backport: 7 in upstream 3.19.0-rc3 */
39         PSTORE_TYPE_UNKNOWN     = 255
40 };
41
42 struct module;
43
44 struct pstore_info {
45         struct module   *owner;
46         char            *name;
47         spinlock_t      buf_lock;       /* serialize access to 'buf' */
48         char            *buf;
49         size_t          bufsize;
50         struct mutex    read_mutex;     /* serialize open/read/close */
51         int             (*open)(struct pstore_info *psi);
52         int             (*close)(struct pstore_info *psi);
53         ssize_t         (*read)(u64 *id, enum pstore_type_id *type,
54                         int *count, struct timespec *time, char **buf,
55                         struct pstore_info *psi);
56         int             (*write)(enum pstore_type_id type,
57                         enum kmsg_dump_reason reason, u64 *id,
58                         unsigned int part, int count, size_t size,
59                         struct pstore_info *psi);
60         int             (*write_buf)(enum pstore_type_id type,
61                         enum kmsg_dump_reason reason, u64 *id,
62                         unsigned int part, const char *buf, size_t size,
63                         struct pstore_info *psi);
64         int             (*erase)(enum pstore_type_id type, u64 id,
65                         int count, struct timespec time,
66                         struct pstore_info *psi);
67         void            *data;
68 };
69
70 #ifdef CONFIG_PSTORE
71 extern int pstore_register(struct pstore_info *);
72 extern bool pstore_cannot_block_path(enum kmsg_dump_reason reason);
73 #else
74 static inline int
75 pstore_register(struct pstore_info *psi)
76 {
77         return -ENODEV;
78 }
79 static inline bool
80 pstore_cannot_block_path(enum kmsg_dump_reason reason)
81 {
82         return false;
83 }
84 #endif
85
86 #endif /*_LINUX_PSTORE_H*/