Skip to content

Commit

Permalink
bootconfig: Share the checksum function with tools
Browse files Browse the repository at this point in the history
Move the checksum calculation function into the header for sharing it
with tools/bootconfig.

Link: https://lkml.kernel.org/r/162262197470.264090.16325743685807878807.stgit@devnote2

Signed-off-by: Masami Hiramatsu <[email protected]>
Signed-off-by: Steven Rostedt (VMware) <[email protected]>
  • Loading branch information
mhiramat authored and rostedt committed Jun 10, 2021
1 parent 0ff2bb7 commit 99f4f5d
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 24 deletions.
20 changes: 20 additions & 0 deletions include/linux/bootconfig.h
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,26 @@
#define BOOTCONFIG_ALIGN (1 << BOOTCONFIG_ALIGN_SHIFT)
#define BOOTCONFIG_ALIGN_MASK (BOOTCONFIG_ALIGN - 1)

/**
* xbc_calc_checksum() - Calculate checksum of bootconfig
* @data: Bootconfig data.
* @size: The size of the bootconfig data.
*
* Calculate the checksum value of the bootconfig data.
* The checksum will be used with the BOOTCONFIG_MAGIC and the size for
* embedding the bootconfig in the initrd image.
*/
static inline __init u32 xbc_calc_checksum(void *data, u32 size)
{
unsigned char *p = data;
u32 ret = 0;

while (size--)
ret += *p++;

return ret;
}

/* XBC tree node */
struct xbc_node {
u16 next;
Expand Down
12 changes: 1 addition & 11 deletions init/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -386,16 +386,6 @@ static char * __init xbc_make_cmdline(const char *key)
return new_cmdline;
}

static u32 boot_config_checksum(unsigned char *p, u32 size)
{
u32 ret = 0;

while (size--)
ret += *p++;

return ret;
}

static int __init bootconfig_params(char *param, char *val,
const char *unused, void *arg)
{
Expand Down Expand Up @@ -439,7 +429,7 @@ static void __init setup_boot_config(void)
return;
}

if (boot_config_checksum((unsigned char *)data, size) != csum) {
if (xbc_calc_checksum(data, size) != csum) {
pr_err("bootconfig checksum failed\n");
return;
}
Expand Down
15 changes: 2 additions & 13 deletions tools/bootconfig/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -126,17 +126,6 @@ static void xbc_show_list(void)
}
}

/* Simple real checksum */
static int checksum(unsigned char *buf, int len)
{
int i, sum = 0;

for (i = 0; i < len; i++)
sum += buf[i];

return sum;
}

#define PAGE_SIZE 4096

static int load_xbc_fd(int fd, char **buf, int size)
Expand Down Expand Up @@ -232,7 +221,7 @@ static int load_xbc_from_initrd(int fd, char **buf)
return ret;

/* Wrong Checksum */
rcsum = checksum((unsigned char *)*buf, size);
rcsum = xbc_calc_checksum(*buf, size);
if (csum != rcsum) {
pr_err("checksum error: %d != %d\n", csum, rcsum);
return -EINVAL;
Expand Down Expand Up @@ -381,7 +370,7 @@ static int apply_xbc(const char *path, const char *xbc_path)
return ret;
}
size = strlen(buf) + 1;
csum = checksum((unsigned char *)buf, size);
csum = xbc_calc_checksum(buf, size);

/* Backup the bootconfig data */
data = calloc(size + BOOTCONFIG_ALIGN +
Expand Down

0 comments on commit 99f4f5d

Please sign in to comment.