summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrew Jeffery <andrew@aj.id.au>2017-04-12 14:08:03 +0930
committerAndrew Jeffery <andrew@aj.id.au>2017-04-26 07:38:48 +0000
commit41f211bcb7f75b395df665449c7723789a809e11 (patch)
treea25d74d2ee497902e0c2ba4ef7eab8994466d1d0
parent2c461f0a37965659e910a3a49c63ec99b12536ad (diff)
downloadphosphor-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.am2
-rw-r--r--common.c37
-rw-r--r--mtd.c43
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)
diff --git a/common.c b/common.c
index a0fe9e2..c9d5d85 100644
--- a/common.c
+++ b/common.c
@@ -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;
-}
diff --git a/mtd.c b/mtd.c
new file mode 100644
index 0000000..46d660e
--- /dev/null
+++ b/mtd.c
@@ -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;
+}
OpenPOWER on IntegriCloud