pstore: Switch pstore_mkfile to pass record
authorKees Cook <keescook@chromium.org>
Sat, 4 Mar 2017 02:16:32 +0000 (18:16 -0800)
committerKees Cook <keescook@chromium.org>
Tue, 7 Mar 2017 22:00:55 +0000 (14:00 -0800)
Instead of the long list of arguments, just pass the new record struct.

Signed-off-by: Kees Cook <keescook@chromium.org>
fs/pstore/inode.c
fs/pstore/internal.h
fs/pstore/platform.c

index 57c0646479f51cc0baa9bd82ba3cbb5689f41696..a98787bab3e64da3b09a2eac7c2783f39f3be734 100644 (file)
@@ -302,9 +302,7 @@ bool pstore_is_mounted(void)
  * Load it up with "size" bytes of data from "buf".
  * 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,
-                 char *data, bool compressed, size_t size,
-                 struct timespec time, struct pstore_info *psi)
+int pstore_mkfile(struct pstore_record *record)
 {
        struct dentry           *root = pstore_sb->s_root;
        struct dentry           *dentry;
@@ -313,12 +311,13 @@ int pstore_mkfile(enum pstore_type_id type, char *psname, u64 id, int count,
        char                    name[PSTORE_NAMELEN];
        struct pstore_private   *private, *pos;
        unsigned long           flags;
+       size_t                  size = record->size + record->ecc_notice_size;
 
        spin_lock_irqsave(&allpstore_lock, flags);
        list_for_each_entry(pos, &allpstore, list) {
-               if (pos->type == type &&
-                   pos->id == id &&
-                   pos->psi == psi) {
+               if (pos->type == record->type &&
+                   pos->id == record->id &&
+                   pos->psi == record->psi) {
                        rc = -EEXIST;
                        break;
                }
@@ -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);
        if (!private)
                goto fail_alloc;
-       private->type = type;
-       private->id = id;
-       private->count = count;
-       private->psi = psi;
+       private->type = record->type;
+       private->id = record->id;
+       private->count = record->count;
+       private->psi = record->psi;
 
-       switch (type) {
+       switch (record->type) {
        case PSTORE_TYPE_DMESG:
                scnprintf(name, sizeof(name), "dmesg-%s-%lld%s",
-                         psname, id, compressed ? ".enc.z" : "");
+                         record->psi->name, record->id,
+                         record->compressed ? ".enc.z" : "");
                break;
        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;
        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;
        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;
        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;
        case PSTORE_TYPE_PPC_OF:
                scnprintf(name, sizeof(name), "powerpc-ofw-%s-%lld",
-                         psname, id);
+                         record->psi->name, record->id);
                break;
        case PSTORE_TYPE_PPC_COMMON:
                scnprintf(name, sizeof(name), "powerpc-common-%s-%lld",
-                         psname, id);
+                         record->psi->name, record->id);
                break;
        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;
        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;
        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;
        default:
                scnprintf(name, sizeof(name), "type%d-%s-%lld",
-                         type, psname, id);
+                         record->type, record->psi->name, record->id);
                break;
        }
 
@@ -387,13 +394,13 @@ int pstore_mkfile(enum pstore_type_id type, char *psname, u64 id, int count,
        if (!dentry)
                goto fail_lockedalloc;
 
-       memcpy(private->data, data, size);
+       memcpy(private->data, record->buf, size);
        inode->i_size = private->size = size;
 
        inode->i_private = private;
 
-       if (time.tv_sec)
-               inode->i_mtime = inode->i_ctime = time;
+       if (record->time.tv_sec)
+               inode->i_mtime = inode->i_ctime = record->time;
 
        d_add(dentry, inode);
 
index da416e6591c9d91cd937b36438e31a51bde6bfa4..af1df5a36d860bba6989744169821c3d5c71c807 100644 (file)
@@ -25,10 +25,7 @@ extern struct pstore_info *psinfo;
 
 extern void    pstore_set_kmsg_bytes(int);
 extern void    pstore_get_records(int);
-extern int     pstore_mkfile(enum pstore_type_id, char *psname, u64 id,
-                             int count, char *data, bool compressed,
-                             size_t size, struct timespec time,
-                             struct pstore_info *psi);
+extern int     pstore_mkfile(struct pstore_record *record);
 extern bool    pstore_is_mounted(void);
 
 #endif
index 0503380704debf69a0781ecfb1011898caa5b784..168e03fd5e5843f9ac1d4279a2dc299dbfbed02d 100644 (file)
@@ -814,11 +814,7 @@ void pstore_get_records(int quiet)
                                 record.psi)) > 0) {
 
                decompress_record(&record);
-               rc = pstore_mkfile(record.type, psi->name, record.id,
-                                  record.count, record.buf,
-                                  record.compressed,
-                                  record.size + record.ecc_notice_size,
-                                  record.time, record.psi);
+               rc = pstore_mkfile(&record);
 
                /* Free buffer other than big oops */
                if (record.buf != big_oops_buf)