提交 b05c9506 编写于 作者: J Joel Fernandes (Google) 提交者: Kees Cook

pstore/ram: Simplify ramoops_get_next_prz() arguments

(1) remove type argument from ramoops_get_next_prz()

Since we store the type of the prz when we initialize it, we no longer
need to pass it again in ramoops_get_next_prz() since we can just use
that to setup the pstore record. So lets remove it from the argument list.

(2) remove max argument from ramoops_get_next_prz()

Looking at the code flow, the 'max' checks are already being done on
the prz passed to ramoops_get_next_prz(). Lets remove it to simplify
this function and reduce its arguments.

(3) further reduce ramoops_get_next_prz() arguments by passing record

Both the id and type fields of a pstore_record are set by
ramoops_get_next_prz(). So we can just pass a pointer to the pstore_record
instead of passing individual elements. This results in cleaner more
readable code and fewer lines.

In addition lets also remove the 'update' argument since we can detect
that. Changes are squashed into a single patch to reduce fixup conflicts.
Signed-off-by: NJoel Fernandes (Google) <joel@joelfernandes.org>
Signed-off-by: NKees Cook <keescook@chromium.org>
上级 f0f23e54
...@@ -124,19 +124,17 @@ static int ramoops_pstore_open(struct pstore_info *psi) ...@@ -124,19 +124,17 @@ static int ramoops_pstore_open(struct pstore_info *psi)
} }
static struct persistent_ram_zone * static struct persistent_ram_zone *
ramoops_get_next_prz(struct persistent_ram_zone *przs[], uint *c, uint max, ramoops_get_next_prz(struct persistent_ram_zone *przs[], int id,
u64 *id, struct pstore_record *record)
enum pstore_type_id *typep, enum pstore_type_id type,
bool update)
{ {
struct persistent_ram_zone *prz; struct persistent_ram_zone *prz;
int i = (*c)++; bool update = (record->type == PSTORE_TYPE_DMESG);
/* Give up if we never existed or have hit the end. */ /* Give up if we never existed or have hit the end. */
if (!przs || i >= max) if (!przs)
return NULL; return NULL;
prz = przs[i]; prz = przs[id];
if (!prz) if (!prz)
return NULL; return NULL;
...@@ -147,8 +145,8 @@ ramoops_get_next_prz(struct persistent_ram_zone *przs[], uint *c, uint max, ...@@ -147,8 +145,8 @@ ramoops_get_next_prz(struct persistent_ram_zone *przs[], uint *c, uint max,
if (!persistent_ram_old_size(prz)) if (!persistent_ram_old_size(prz))
return NULL; return NULL;
*typep = type; record->type = prz->type;
*id = i; record->id = id;
return prz; return prz;
} }
...@@ -255,10 +253,8 @@ static ssize_t ramoops_pstore_read(struct pstore_record *record) ...@@ -255,10 +253,8 @@ static ssize_t ramoops_pstore_read(struct pstore_record *record)
/* Find the next valid persistent_ram_zone for DMESG */ /* Find the next valid persistent_ram_zone for DMESG */
while (cxt->dump_read_cnt < cxt->max_dump_cnt && !prz) { while (cxt->dump_read_cnt < cxt->max_dump_cnt && !prz) {
prz = ramoops_get_next_prz(cxt->dprzs, &cxt->dump_read_cnt, prz = ramoops_get_next_prz(cxt->dprzs, cxt->dump_read_cnt++,
cxt->max_dump_cnt, &record->id, record);
&record->type,
PSTORE_TYPE_DMESG, 1);
if (!prz_ok(prz)) if (!prz_ok(prz))
continue; continue;
header_length = ramoops_read_kmsg_hdr(persistent_ram_old(prz), header_length = ramoops_read_kmsg_hdr(persistent_ram_old(prz),
...@@ -272,22 +268,18 @@ static ssize_t ramoops_pstore_read(struct pstore_record *record) ...@@ -272,22 +268,18 @@ static ssize_t ramoops_pstore_read(struct pstore_record *record)
} }
} }
if (!prz_ok(prz)) if (!prz_ok(prz) && !cxt->console_read_cnt++)
prz = ramoops_get_next_prz(&cxt->cprz, &cxt->console_read_cnt, prz = ramoops_get_next_prz(&cxt->cprz, 0 /* single */, record);
1, &record->id, &record->type,
PSTORE_TYPE_CONSOLE, 0);
if (!prz_ok(prz)) if (!prz_ok(prz) && !cxt->pmsg_read_cnt++)
prz = ramoops_get_next_prz(&cxt->mprz, &cxt->pmsg_read_cnt, prz = ramoops_get_next_prz(&cxt->mprz, 0 /* single */, record);
1, &record->id, &record->type,
PSTORE_TYPE_PMSG, 0);
/* ftrace is last since it may want to dynamically allocate memory. */ /* ftrace is last since it may want to dynamically allocate memory. */
if (!prz_ok(prz)) { if (!prz_ok(prz)) {
if (!(cxt->flags & RAMOOPS_FLAG_FTRACE_PER_CPU)) { if (!(cxt->flags & RAMOOPS_FLAG_FTRACE_PER_CPU) &&
prz = ramoops_get_next_prz(cxt->fprzs, !cxt->ftrace_read_cnt++) {
&cxt->ftrace_read_cnt, 1, &record->id, prz = ramoops_get_next_prz(cxt->fprzs, 0 /* single */,
&record->type, PSTORE_TYPE_FTRACE, 0); record);
} else { } else {
/* /*
* Build a new dummy record which combines all the * Build a new dummy record which combines all the
...@@ -303,11 +295,7 @@ static ssize_t ramoops_pstore_read(struct pstore_record *record) ...@@ -303,11 +295,7 @@ static ssize_t ramoops_pstore_read(struct pstore_record *record)
while (cxt->ftrace_read_cnt < cxt->max_ftrace_cnt) { while (cxt->ftrace_read_cnt < cxt->max_ftrace_cnt) {
prz_next = ramoops_get_next_prz(cxt->fprzs, prz_next = ramoops_get_next_prz(cxt->fprzs,
&cxt->ftrace_read_cnt, cxt->ftrace_read_cnt++, record);
cxt->max_ftrace_cnt,
&record->id,
&record->type,
PSTORE_TYPE_FTRACE, 0);
if (!prz_ok(prz_next)) if (!prz_ok(prz_next))
continue; continue;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册