Commit 1edd1aa3 authored by Kees Cook's avatar Kees Cook

pstore: Switch pstore_mkfile to pass record

Instead of the long list of arguments, just pass the new record struct.
Signed-off-by: default avatarKees Cook <keescook@chromium.org>
parent 634f8f51
...@@ -302,9 +302,7 @@ bool pstore_is_mounted(void) ...@@ -302,9 +302,7 @@ bool pstore_is_mounted(void)
* Load it up with "size" bytes of data from "buf". * Load it up with "size" bytes of data from "buf".
* Set the mtime & ctime to the date that this record was originally stored. * Set the mtime & ctime to the date that this record was originally stored.
*/ */
int pstore_mkfile(enum pstore_type_id type, char *psname, u64 id, int count, int pstore_mkfile(struct pstore_record *record)
char *data, bool compressed, size_t size,
struct timespec time, struct pstore_info *psi)
{ {
struct dentry *root = pstore_sb->s_root; struct dentry *root = pstore_sb->s_root;
struct dentry *dentry; struct dentry *dentry;
...@@ -313,12 +311,13 @@ int pstore_mkfile(enum pstore_type_id type, char *psname, u64 id, int count, ...@@ -313,12 +311,13 @@ int pstore_mkfile(enum pstore_type_id type, char *psname, u64 id, int count,
char name[PSTORE_NAMELEN]; char name[PSTORE_NAMELEN];
struct pstore_private *private, *pos; struct pstore_private *private, *pos;
unsigned long flags; unsigned long flags;
size_t size = record->size + record->ecc_notice_size;
spin_lock_irqsave(&allpstore_lock, flags); spin_lock_irqsave(&allpstore_lock, flags);
list_for_each_entry(pos, &allpstore, list) { list_for_each_entry(pos, &allpstore, list) {
if (pos->type == type && if (pos->type == record->type &&
pos->id == id && pos->id == record->id &&
pos->psi == psi) { pos->psi == record->psi) {
rc = -EEXIST; rc = -EEXIST;
break; break;
} }
...@@ -336,48 +335,56 @@ int pstore_mkfile(enum pstore_type_id type, char *psname, u64 id, int count, ...@@ -336,48 +335,56 @@ int pstore_mkfile(enum pstore_type_id type, char *psname, u64 id, int count,
private = kmalloc(sizeof *private + size, GFP_KERNEL); private = kmalloc(sizeof *private + size, GFP_KERNEL);
if (!private) if (!private)
goto fail_alloc; goto fail_alloc;
private->type = type; private->type = record->type;
private->id = id; private->id = record->id;
private->count = count; private->count = record->count;
private->psi = psi; private->psi = record->psi;
switch (type) { switch (record->type) {
case PSTORE_TYPE_DMESG: case PSTORE_TYPE_DMESG:
scnprintf(name, sizeof(name), "dmesg-%s-%lld%s", scnprintf(name, sizeof(name), "dmesg-%s-%lld%s",
psname, id, compressed ? ".enc.z" : ""); record->psi->name, record->id,
record->compressed ? ".enc.z" : "");
break; break;
case PSTORE_TYPE_CONSOLE: case PSTORE_TYPE_CONSOLE:
scnprintf(name, sizeof(name), "console-%s-%lld", psname, id); scnprintf(name, sizeof(name), "console-%s-%lld",
record->psi->name, record->id);
break; break;
case PSTORE_TYPE_FTRACE: case PSTORE_TYPE_FTRACE:
scnprintf(name, sizeof(name), "ftrace-%s-%lld", psname, id); scnprintf(name, sizeof(name), "ftrace-%s-%lld",
record->psi->name, record->id);
break; break;
case PSTORE_TYPE_MCE: case PSTORE_TYPE_MCE:
scnprintf(name, sizeof(name), "mce-%s-%lld", psname, id); scnprintf(name, sizeof(name), "mce-%s-%lld",
record->psi->name, record->id);
break; break;
case PSTORE_TYPE_PPC_RTAS: case PSTORE_TYPE_PPC_RTAS:
scnprintf(name, sizeof(name), "rtas-%s-%lld", psname, id); scnprintf(name, sizeof(name), "rtas-%s-%lld",
record->psi->name, record->id);
break; break;
case PSTORE_TYPE_PPC_OF: case PSTORE_TYPE_PPC_OF:
scnprintf(name, sizeof(name), "powerpc-ofw-%s-%lld", scnprintf(name, sizeof(name), "powerpc-ofw-%s-%lld",
psname, id); record->psi->name, record->id);
break; break;
case PSTORE_TYPE_PPC_COMMON: case PSTORE_TYPE_PPC_COMMON:
scnprintf(name, sizeof(name), "powerpc-common-%s-%lld", scnprintf(name, sizeof(name), "powerpc-common-%s-%lld",
psname, id); record->psi->name, record->id);
break; break;
case PSTORE_TYPE_PMSG: case PSTORE_TYPE_PMSG:
scnprintf(name, sizeof(name), "pmsg-%s-%lld", psname, id); scnprintf(name, sizeof(name), "pmsg-%s-%lld",
record->psi->name, record->id);
break; break;
case PSTORE_TYPE_PPC_OPAL: case PSTORE_TYPE_PPC_OPAL:
sprintf(name, "powerpc-opal-%s-%lld", psname, id); scnprintf(name, sizeof(name), "powerpc-opal-%s-%lld",
record->psi->name, record->id);
break; break;
case PSTORE_TYPE_UNKNOWN: case PSTORE_TYPE_UNKNOWN:
scnprintf(name, sizeof(name), "unknown-%s-%lld", psname, id); scnprintf(name, sizeof(name), "unknown-%s-%lld",
record->psi->name, record->id);
break; break;
default: default:
scnprintf(name, sizeof(name), "type%d-%s-%lld", scnprintf(name, sizeof(name), "type%d-%s-%lld",
type, psname, id); record->type, record->psi->name, record->id);
break; break;
} }
...@@ -387,13 +394,13 @@ int pstore_mkfile(enum pstore_type_id type, char *psname, u64 id, int count, ...@@ -387,13 +394,13 @@ int pstore_mkfile(enum pstore_type_id type, char *psname, u64 id, int count,
if (!dentry) if (!dentry)
goto fail_lockedalloc; goto fail_lockedalloc;
memcpy(private->data, data, size); memcpy(private->data, record->buf, size);
inode->i_size = private->size = size; inode->i_size = private->size = size;
inode->i_private = private; inode->i_private = private;
if (time.tv_sec) if (record->time.tv_sec)
inode->i_mtime = inode->i_ctime = time; inode->i_mtime = inode->i_ctime = record->time;
d_add(dentry, inode); d_add(dentry, inode);
......
...@@ -25,10 +25,7 @@ extern struct pstore_info *psinfo; ...@@ -25,10 +25,7 @@ extern struct pstore_info *psinfo;
extern void pstore_set_kmsg_bytes(int); extern void pstore_set_kmsg_bytes(int);
extern void pstore_get_records(int); extern void pstore_get_records(int);
extern int pstore_mkfile(enum pstore_type_id, char *psname, u64 id, extern int pstore_mkfile(struct pstore_record *record);
int count, char *data, bool compressed,
size_t size, struct timespec time,
struct pstore_info *psi);
extern bool pstore_is_mounted(void); extern bool pstore_is_mounted(void);
#endif #endif
...@@ -814,11 +814,7 @@ void pstore_get_records(int quiet) ...@@ -814,11 +814,7 @@ void pstore_get_records(int quiet)
record.psi)) > 0) { record.psi)) > 0) {
decompress_record(&record); decompress_record(&record);
rc = pstore_mkfile(record.type, psi->name, record.id, rc = pstore_mkfile(&record);
record.count, record.buf,
record.compressed,
record.size + record.ecc_notice_size,
record.time, record.psi);
/* Free buffer other than big oops */ /* Free buffer other than big oops */
if (record.buf != big_oops_buf) if (record.buf != big_oops_buf)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment