diff options
author | Andrew Jeffery <andrew@aj.id.au> | 2017-04-12 14:08:03 +0930 |
---|---|---|
committer | Andrew Jeffery <andrew@aj.id.au> | 2017-04-26 07:38:48 +0000 |
commit | 41f211bcb7f75b395df665449c7723789a809e11 (patch) | |
tree | a25d74d2ee497902e0c2ba4ef7eab8994466d1d0 | |
parent | 2c461f0a37965659e910a3a49c63ec99b12536ad (diff) | |
download | phosphor-mboxd-41f211bcb7f75b395df665449c7723789a809e11.tar.gz phosphor-mboxd-41f211bcb7f75b395df665449c7723789a809e11.zip |
common: Move get_dev_mtd() to mtd.c
Allows tests to link in alternative implementations of get_dev_mtd()
without losing other functions available in common.c.
Change-Id: I606a83aa9bc59b5fbab1fb11ee1e2574c7f6d127
Signed-off-by: Andrew Jeffery <andrew@aj.id.au>
-rw-r--r-- | Makefile.am | 2 | ||||
-rw-r--r-- | common.c | 37 | ||||
-rw-r--r-- | mtd.c | 43 |
3 files changed, 44 insertions, 38 deletions
diff --git a/Makefile.am b/Makefile.am index c5b821f..4dbab78 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,7 +1,7 @@ ACLOCAL_AMFLAGS = -I m4 sbin_PROGRAMS = mboxd mboxctl -mboxd_SOURCES = mboxd.c common.c mboxd_dbus.c mboxd_flash.c mboxd_lpc.c mboxd_msg.c mboxd_windows.c +mboxd_SOURCES = mboxd.c common.c mboxd_dbus.c mboxd_flash.c mboxd_lpc.c mboxd_msg.c mboxd_windows.c mtd.c mboxd_LDFLAGS = $(LIBSYSTEMD_LIBS) mboxd_CFLAGS = $(LIBSYSTEMD_CFLAGS) @@ -68,40 +68,3 @@ void put_u32(uint8_t *ptr, uint32_t val) memcpy(ptr, &val, sizeof(val)); } - -static bool is_pnor_part(const char *str) -{ - return strcasestr(str, "pnor") != NULL; -} - -char *get_dev_mtd(void) -{ - FILE *f; - char *ret = NULL, *pos = NULL; - char line[255]; - - f = fopen("/proc/mtd", "r"); - if (!f) - return NULL; - - while (!pos && fgets(line, sizeof(line), f) != NULL) { - /* Going to have issues if we didn't get the full line */ - if (line[strlen(line) - 1] != '\n') - break; - - if (is_pnor_part(line)) { - pos = strchr(line, ':'); - if (!pos) - break; - } - } - fclose(f); - - if (pos) { - *pos = '\0'; - if (asprintf(&ret, "/dev/%s", line) == -1) - ret = NULL; - } - - return ret; -} @@ -0,0 +1,43 @@ +#define _GNU_SOURCE +#include <stdbool.h> +#include <stdio.h> +#include <string.h> + +#include "common.h" + +static bool is_pnor_part(const char *str) +{ + return strcasestr(str, "pnor") != NULL; +} + +char *get_dev_mtd(void) +{ + FILE *f; + char *ret = NULL, *pos = NULL; + char line[255]; + + f = fopen("/proc/mtd", "r"); + if (!f) + return NULL; + + while (!pos && fgets(line, sizeof(line), f) != NULL) { + /* Going to have issues if we didn't get the full line */ + if (line[strlen(line) - 1] != '\n') + break; + + if (is_pnor_part(line)) { + pos = strchr(line, ':'); + if (!pos) + break; + } + } + fclose(f); + + if (pos) { + *pos = '\0'; + if (asprintf(&ret, "/dev/%s", line) == -1) + ret = NULL; + } + + return ret; +} |