[PATCH 2/2] test: add mtd/ubi test helpers

Mike Frysinger vapier at gentoo.org
Thu May 2 19:44:42 UTC 2013


I used these to develop the mtd/ubi ioctl decoders.

* .gitignore: Add mtd/ubi.
* Makefile: Declare all tests in a PROGS var.  Declare build targets
.PHONY.
(all): Depend on $(PROGS) instead of hardcoded list.
(clean): Remove $(PROGS) instead of hardcoded list.
* mtd.c: New file.
* ubi.c: Likewise.
---
 test/.gitignore |  2 ++
 test/Makefile   | 13 ++++++++-----
 test/mtd.c      | 49 +++++++++++++++++++++++++++++++++++++++++++++++++
 test/ubi.c      | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
 4 files changed, 113 insertions(+), 5 deletions(-)
 create mode 100644 test/mtd.c
 create mode 100644 test/ubi.c

diff --git a/test/.gitignore b/test/.gitignore
index 7d2cd1e..ce242fd 100644
--- a/test/.gitignore
+++ b/test/.gitignore
@@ -8,3 +8,5 @@ childthread
 sigkill_rain
 wait_must_be_interruptible
 threaded_execve
+mtd
+ubi
diff --git a/test/Makefile b/test/Makefile
index 781e1f6..97ae746 100644
--- a/test/Makefile
+++ b/test/Makefile
@@ -1,14 +1,17 @@
 CFLAGS += -Wall
 
-all: \
+PROGS = \
     vfork fork sig skodic clone leaderkill childthread \
-    sigkill_rain wait_must_be_interruptible threaded_execve
+    sigkill_rain wait_must_be_interruptible threaded_execve \
+    mtd ubi
+
+all: $(PROGS)
 
 leaderkill: LDFLAGS += -pthread
 
 childthread: LDFLAGS += -pthread
 
 clean distclean:
-	rm -f *.o core \
-    vfork fork sig skodic clone leaderkill childthread \
-    sigkill_rain wait_must_be_interruptible threaded_execve
+	rm -f *.o core $(PROGS) *.gdb
+
+.PHONY: all clean distclean
diff --git a/test/mtd.c b/test/mtd.c
new file mode 100644
index 0000000..b9fc695
--- /dev/null
+++ b/test/mtd.c
@@ -0,0 +1,49 @@
+#include <fcntl.h>
+#include <stdio.h>
+#include <string.h>
+#include <termios.h>
+#include <unistd.h>
+#include <sys/ioctl.h>
+#include <mtd/mtd-user.h>
+
+int main() {
+	int fd = open("/dev/null", 0);
+	struct mtd_info_user minfo;
+	struct erase_info_user einfo;
+	struct erase_info_user64 einfo64;
+	struct mtd_oob_buf mbuf;
+	struct mtd_oob_buf64 mbuf64;
+	struct region_info_user rinfo;
+	/* struct otp_info oinfo; */
+	struct mtd_ecc_stats estat;
+	struct mtd_write_req mreq;
+	struct nand_oobinfo ninfo;
+	struct nand_ecclayout_user nlay;
+	off_t f = 333;
+
+	memset(&einfo, 0, sizeof(einfo));
+	memset(&einfo64, 0xff, sizeof(einfo64));
+
+	ioctl(fd, MEMGETINFO, &minfo);
+
+	ioctl(fd, MEMERASE, &einfo);
+	ioctl(fd, MEMERASE64, &einfo64);
+
+	ioctl(fd, MEMGETBADBLOCK, &f);
+	int i = 0;
+	ioctl(fd, OTPSELECT, &i);
+	ioctl(fd, MEMSETBADBLOCK, &f);
+
+	ioctl(fd, MEMREADOOB, &mbuf);
+	ioctl(fd, MEMREADOOB64, &mbuf64);
+
+	ioctl(fd, MEMGETREGIONINFO, &rinfo);
+
+	ioctl(fd, ECCGETSTATS, &estat);
+	ioctl(fd, MEMWRITE, &mreq);
+
+	ioctl(fd, MEMGETOOBSEL, &ninfo);
+	ioctl(fd, ECCGETLAYOUT, &nlay);
+
+	return 0;
+}
diff --git a/test/ubi.c b/test/ubi.c
new file mode 100644
index 0000000..5062c83
--- /dev/null
+++ b/test/ubi.c
@@ -0,0 +1,54 @@
+#include <fcntl.h>
+#include <stdint.h>
+#include <stdio.h>
+#include <string.h>
+#include <termios.h>
+#include <unistd.h>
+#include <sys/ioctl.h>
+#include <mtd/ubi-user.h>
+
+#define zero(x) memset(&x, 0, sizeof(x))
+
+int main() {
+	int fd = open("/dev/null", 0);
+	struct ubi_mkvol_req mkvol = {
+		.vol_id = 3,
+		.alignment = 124,
+		.bytes = 1125899906842624ULL,
+		.vol_type = 3,
+		.name_len = 7,
+		.name = "foobar",
+	};
+	struct ubi_rsvol_req rsvol = {
+		.bytes = 1125899906842624ULL,
+		.vol_id = -3,
+	};
+	struct ubi_rnvol_req rnvol = {
+		.count = 300,
+	};
+	struct ubi_attach_req attach;
+	struct ubi_map_req map;
+	struct ubi_set_vol_prop_req prop = {
+		.property = 1,
+		.value = 1125899906842624ULL,
+	};
+	uint64_t bytes = ((uint64_t)1 << 50) | 0x123;
+
+	ioctl(fd, UBI_IOCMKVOL, &mkvol);
+	ioctl(fd, UBI_IOCRSVOL, &rsvol);
+	ioctl(fd, UBI_IOCRNVOL, &rnvol);
+	ioctl(fd, UBI_IOCATT, &attach);
+	ioctl(fd, UBI_IOCVOLUP, &bytes);
+	ioctl(fd, UBI_IOCEBMAP, &map);
+	ioctl(fd, UBI_IOCSETVOLPROP, &prop);
+	zero(prop);
+	ioctl(fd, UBI_IOCSETVOLPROP, &prop);
+	ioctl(fd, UBI_IOCRMVOL, 1);
+	ioctl(fd, UBI_IOCDET, 2);
+	ioctl(fd, UBI_IOCEBER, 3);
+	ioctl(fd, UBI_IOCEBCH, 4);
+	ioctl(fd, UBI_IOCEBUNMAP, 5);
+	ioctl(fd, UBI_IOCEBISMAP, 6);
+
+	return 0;
+}
-- 
1.8.2.1





More information about the Strace-devel mailing list