|
|
@ -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, |
|
|
|
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, |
|
|
|
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, |
|
|
|
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); |
|
|
|
|
|
|
|
|
|
|
|