Commit 8092e792 authored by Andrey Smirnov's avatar Andrey Smirnov Committed by Greg Kroah-Hartman

ihex: Share code between ihex_validate_fw() and ihex_next_binrec()

Convert both ihex_validate_fw() and ihex_next_binrec() to use a helper
function to calculate next record offest. This way we only have one
place implementing next record offset calculation logic. No functional
change intended.

Cc: Chris Healy <cphealy@gmail.com>
Cc: Kyle McMartin <kyle@kernel.org>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Masahiro Yamada <yamada.masahiro@socionext.com>
Cc: David Woodhouse <dwmw2@infradead.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: linux-kernel <linux-kernel@vger.kernel.org>
Signed-off-by: default avatarAndrey Smirnov <andrew.smirnov@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 570d0200
...@@ -23,29 +23,34 @@ struct ihex_binrec { ...@@ -23,29 +23,34 @@ struct ihex_binrec {
/* Find the next record, taking into account the 4-byte alignment */ /* Find the next record, taking into account the 4-byte alignment */
static inline const struct ihex_binrec * static inline const struct ihex_binrec *
ihex_next_binrec(const struct ihex_binrec *rec) __ihex_next_binrec(const struct ihex_binrec *rec)
{ {
int next = ((be16_to_cpu(rec->len) + 5) & ~3) - 2; int next = ((be16_to_cpu(rec->len) + 5) & ~3) - 2;
rec = (void *)&rec->data[next]; rec = (void *)&rec->data[next];
return rec;
}
static inline const struct ihex_binrec *
ihex_next_binrec(const struct ihex_binrec *rec)
{
rec = __ihex_next_binrec(rec);
return be16_to_cpu(rec->len) ? rec : NULL; return be16_to_cpu(rec->len) ? rec : NULL;
} }
/* Check that ihex_next_binrec() won't take us off the end of the image... */ /* Check that ihex_next_binrec() won't take us off the end of the image... */
static inline int ihex_validate_fw(const struct firmware *fw) static inline int ihex_validate_fw(const struct firmware *fw)
{ {
const struct ihex_binrec *rec; const struct ihex_binrec *end, *rec;
size_t ofs = 0;
while (ofs <= fw->size - sizeof(*rec)) { rec = (const void *)fw->data;
rec = (void *)&fw->data[ofs]; end = (const void *)&fw->data[fw->size - sizeof(*end)];
for (; rec <= end; rec = __ihex_next_binrec(rec)) {
/* Zero length marks end of records */ /* Zero length marks end of records */
if (!be16_to_cpu(rec->len)) if (!be16_to_cpu(rec->len))
return 0; return 0;
/* Point to next record... */
ofs += (sizeof(*rec) + be16_to_cpu(rec->len) + 3) & ~3;
} }
return -EINVAL; return -EINVAL;
} }
......
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