提交 b3b515bb 编写于 作者: A Aruna Balakrishnaiah 提交者: Tony Luck

pstore: Add new argument 'compressed' in pstore write callback

Addition of new argument 'compressed' in the write call back will
help the backend to know if the data passed from pstore is compressed
or not (In case where compression fails.). If compressed, the backend
can add a tag indicating the data is compressed while writing to
persistent store.
Signed-off-by: NAruna Balakrishnaiah <aruna@linux.vnet.ibm.com>
Reviewed-by: NKees Cook <keescook@chromium.org>
Signed-off-by: NTony Luck <tony.luck@intel.com>
上级 a3a5e941
...@@ -554,7 +554,7 @@ static int nvram_pstore_open(struct pstore_info *psi) ...@@ -554,7 +554,7 @@ static int nvram_pstore_open(struct pstore_info *psi)
* @part: pstore writes data to registered buffer in parts, * @part: pstore writes data to registered buffer in parts,
* part number will indicate the same. * part number will indicate the same.
* @count: Indicates oops count * @count: Indicates oops count
* @hsize: Size of header added by pstore * @compressed: Flag to indicate the log is compressed
* @size: number of bytes written to the registered buffer * @size: number of bytes written to the registered buffer
* @psi: registered pstore_info structure * @psi: registered pstore_info structure
* *
...@@ -565,7 +565,7 @@ static int nvram_pstore_open(struct pstore_info *psi) ...@@ -565,7 +565,7 @@ static int nvram_pstore_open(struct pstore_info *psi)
static int nvram_pstore_write(enum pstore_type_id type, static int nvram_pstore_write(enum pstore_type_id type,
enum kmsg_dump_reason reason, enum kmsg_dump_reason reason,
u64 *id, unsigned int part, int count, u64 *id, unsigned int part, int count,
size_t hsize, size_t size, bool compressed, size_t size,
struct pstore_info *psi) struct pstore_info *psi)
{ {
int rc; int rc;
......
...@@ -937,7 +937,7 @@ static ssize_t erst_reader(u64 *id, enum pstore_type_id *type, int *count, ...@@ -937,7 +937,7 @@ static ssize_t erst_reader(u64 *id, enum pstore_type_id *type, int *count,
struct timespec *time, char **buf, struct timespec *time, char **buf,
struct pstore_info *psi); struct pstore_info *psi);
static int erst_writer(enum pstore_type_id type, enum kmsg_dump_reason reason, static int erst_writer(enum pstore_type_id type, enum kmsg_dump_reason reason,
u64 *id, unsigned int part, int count, size_t hsize, u64 *id, unsigned int part, int count, bool compressed,
size_t size, struct pstore_info *psi); size_t size, struct pstore_info *psi);
static int erst_clearer(enum pstore_type_id type, u64 id, int count, static int erst_clearer(enum pstore_type_id type, u64 id, int count,
struct timespec time, struct pstore_info *psi); struct timespec time, struct pstore_info *psi);
...@@ -1057,7 +1057,7 @@ static ssize_t erst_reader(u64 *id, enum pstore_type_id *type, int *count, ...@@ -1057,7 +1057,7 @@ static ssize_t erst_reader(u64 *id, enum pstore_type_id *type, int *count,
} }
static int erst_writer(enum pstore_type_id type, enum kmsg_dump_reason reason, static int erst_writer(enum pstore_type_id type, enum kmsg_dump_reason reason,
u64 *id, unsigned int part, int count, size_t hsize, u64 *id, unsigned int part, int count, bool compressed,
size_t size, struct pstore_info *psi) size_t size, struct pstore_info *psi)
{ {
struct cper_pstore_record *rcd = (struct cper_pstore_record *) struct cper_pstore_record *rcd = (struct cper_pstore_record *)
......
...@@ -103,7 +103,7 @@ static ssize_t efi_pstore_read(u64 *id, enum pstore_type_id *type, ...@@ -103,7 +103,7 @@ static ssize_t efi_pstore_read(u64 *id, enum pstore_type_id *type,
static int efi_pstore_write(enum pstore_type_id type, static int efi_pstore_write(enum pstore_type_id type,
enum kmsg_dump_reason reason, u64 *id, enum kmsg_dump_reason reason, u64 *id,
unsigned int part, int count, size_t hsize, size_t size, unsigned int part, int count, bool compressed, size_t size,
struct pstore_info *psi) struct pstore_info *psi)
{ {
char name[DUMP_NAME_LEN]; char name[DUMP_NAME_LEN];
......
...@@ -149,6 +149,7 @@ static void pstore_dump(struct kmsg_dumper *dumper, ...@@ -149,6 +149,7 @@ static void pstore_dump(struct kmsg_dumper *dumper,
unsigned long size; unsigned long size;
int hsize; int hsize;
size_t len; size_t len;
bool compressed = false;
dst = psinfo->buf; dst = psinfo->buf;
hsize = sprintf(dst, "%s#%d Part%d\n", why, oopscount, part); hsize = sprintf(dst, "%s#%d Part%d\n", why, oopscount, part);
...@@ -159,7 +160,7 @@ static void pstore_dump(struct kmsg_dumper *dumper, ...@@ -159,7 +160,7 @@ static void pstore_dump(struct kmsg_dumper *dumper,
break; break;
ret = psinfo->write(PSTORE_TYPE_DMESG, reason, &id, part, ret = psinfo->write(PSTORE_TYPE_DMESG, reason, &id, part,
oopscount, hsize, hsize + len, psinfo); oopscount, compressed, hsize + len, psinfo);
if (ret == 0 && reason == KMSG_DUMP_OOPS && pstore_is_mounted()) if (ret == 0 && reason == KMSG_DUMP_OOPS && pstore_is_mounted())
pstore_new_entry = 1; pstore_new_entry = 1;
...@@ -221,10 +222,10 @@ static void pstore_register_console(void) {} ...@@ -221,10 +222,10 @@ static void pstore_register_console(void) {}
static int pstore_write_compat(enum pstore_type_id type, static int pstore_write_compat(enum pstore_type_id type,
enum kmsg_dump_reason reason, enum kmsg_dump_reason reason,
u64 *id, unsigned int part, int count, u64 *id, unsigned int part, int count,
size_t hsize, size_t size, bool compressed, size_t size,
struct pstore_info *psi) struct pstore_info *psi)
{ {
return psi->write_buf(type, reason, id, part, psinfo->buf, hsize, return psi->write_buf(type, reason, id, part, psinfo->buf, compressed,
size, psi); size, psi);
} }
......
...@@ -196,7 +196,7 @@ static int notrace ramoops_pstore_write_buf(enum pstore_type_id type, ...@@ -196,7 +196,7 @@ static int notrace ramoops_pstore_write_buf(enum pstore_type_id type,
enum kmsg_dump_reason reason, enum kmsg_dump_reason reason,
u64 *id, unsigned int part, u64 *id, unsigned int part,
const char *buf, const char *buf,
size_t hsize, size_t size, bool compressed, size_t size,
struct pstore_info *psi) struct pstore_info *psi)
{ {
struct ramoops_context *cxt = psi->data; struct ramoops_context *cxt = psi->data;
......
...@@ -58,11 +58,11 @@ struct pstore_info { ...@@ -58,11 +58,11 @@ struct pstore_info {
struct pstore_info *psi); struct pstore_info *psi);
int (*write)(enum pstore_type_id type, int (*write)(enum pstore_type_id type,
enum kmsg_dump_reason reason, u64 *id, enum kmsg_dump_reason reason, u64 *id,
unsigned int part, int count, size_t hsize, unsigned int part, int count, bool compressed,
size_t size, struct pstore_info *psi); size_t size, struct pstore_info *psi);
int (*write_buf)(enum pstore_type_id type, int (*write_buf)(enum pstore_type_id type,
enum kmsg_dump_reason reason, u64 *id, enum kmsg_dump_reason reason, u64 *id,
unsigned int part, const char *buf, size_t hsize, unsigned int part, const char *buf, bool compressed,
size_t size, struct pstore_info *psi); size_t size, struct pstore_info *psi);
int (*erase)(enum pstore_type_id type, u64 id, int (*erase)(enum pstore_type_id type, u64 id,
int count, struct timespec time, int count, struct timespec time,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册