[PATCH] devmem2: the source and patches moved to github repo


Denys Dmytriyenko
 

To cleanup metadata and improve source code management, github repo was
created here with all patches integrated:
https://github.com/denix0/devmem2

Update recipe accordingly, bump the version while at it to distinguish
from the original.

Signed-off-by: Denys Dmytriyenko <denis@...>
---
...word-is-32-bit-and-add-support-for-6.patch | 70 --------------
...ort-different-page-sizes-at-run-time.patch | 35 -------
.../devmem2/devmem2/devmem2-fixups-2.patch | 91 -------------------
.../devmem2/{devmem2.bb =3D> devmem2_2.0.bb} | 17 +---
4 files changed, 3 insertions(+), 210 deletions(-)
delete mode 100644 meta-oe/recipes-support/devmem2/devmem2/0001-devmem.c=
-ensure-word-is-32-bit-and-add-support-for-6.patch
delete mode 100644 meta-oe/recipes-support/devmem2/devmem2/0001-devmem2-=
support-different-page-sizes-at-run-time.patch
delete mode 100644 meta-oe/recipes-support/devmem2/devmem2/devmem2-fixup=
s-2.patch
rename meta-oe/recipes-support/devmem2/{devmem2.bb =3D> devmem2_2.0.bb} =
(40%)

diff --git a/meta-oe/recipes-support/devmem2/devmem2/0001-devmem.c-ensure=
-word-is-32-bit-and-add-support-for-6.patch b/meta-oe/recipes-support/dev=
mem2/devmem2/0001-devmem.c-ensure-word-is-32-bit-and-add-support-for-6.pa=
tch
deleted file mode 100644
index 2a57f2989..000000000
--- a/meta-oe/recipes-support/devmem2/devmem2/0001-devmem.c-ensure-word-i=
s-32-bit-and-add-support-for-6.patch
+++ /dev/null
@@ -1,70 +0,0 @@
-From 1360a907879dd24041797a3b709d49aeac2ab444 Mon Sep 17 00:00:00 2001
-From: Denys Dmytriyenko <denys@...>
-Date: Tue, 29 May 2018 16:55:42 -0400
-Subject: [PATCH] devmem.c: ensure word is 32-bit and add support for 64-=
bit
- long
-
-Signed-off-by: Denys Dmytriyenko <denys@...>
----
- devmem2.c | 23 +++++++++++++++++------
- 1 file changed, 17 insertions(+), 6 deletions(-)
-
-diff --git a/devmem2.c b/devmem2.c
-index 5845381..68131b2 100644
---- a/devmem2.c
-+++ b/devmem2.c
-@@ -39,6 +39,7 @@
-=20
- #include <stdio.h>
- #include <stdlib.h>
-+#include <stdint.h>
- #include <unistd.h>
- #include <string.h>
- #include <errno.h>
-@@ -69,7 +70,7 @@ int main(int argc, char **argv) {
- if(argc < 2) {
- fprintf(stderr, "\nUsage:\t%s { address } [ type [ data ] ]\n"
- "\taddress : memory address to act upon\n"
-- "\ttype : access operation type : [b]yte, [h]alfword, [w]ord\n"
-+ "\ttype : access operation type : [b]yte, [h]alfword, [w]ord, [l]=
ong\n"
- "\tdata : data to be written\n\n",
- argv[0]);
- exit(1);
-@@ -103,9 +104,14 @@ int main(int argc, char **argv) {
- read_result =3D *((unsigned short *) virt_addr);
- break;
- case 'w':
-- data_size =3D sizeof(unsigned long);
-+ data_size =3D sizeof(uint32_t);
- virt_addr =3D fixup_addr(virt_addr, data_size);
-- read_result =3D *((unsigned long *) virt_addr);
-+ read_result =3D *((uint32_t *) virt_addr);
-+ break;
-+ case 'l':
-+ data_size =3D sizeof(uint64_t);
-+ virt_addr =3D fixup_addr(virt_addr, data_size);
-+ read_result =3D *((uint64_t *) virt_addr);
- break;
- default:
- fprintf(stderr, "Illegal data type '%c'.\n", access_type);
-@@ -129,9 +135,14 @@ int main(int argc, char **argv) {
- read_result =3D *((unsigned short *) virt_addr);
- break;
- case 'w':
-- virt_addr =3D fixup_addr(virt_addr, sizeof(unsigned long));
-- *((unsigned long *) virt_addr) =3D write_val;
-- read_result =3D *((unsigned long *) virt_addr);
-+ virt_addr =3D fixup_addr(virt_addr, sizeof(uint32_t));
-+ *((uint32_t *) virt_addr) =3D write_val;
-+ read_result =3D *((uint32_t *) virt_addr);
-+ break;
-+ case 'l':
-+ virt_addr =3D fixup_addr(virt_addr, sizeof(uint64_t));
-+ *((uint64_t *) virt_addr) =3D write_val;
-+ read_result =3D *((uint64_t *) virt_addr);
- break;
- }
- sprintf(fmt_str, "Write at address 0x%%08lX (%%p): 0x%%0%dlX, "
---=20
-2.7.4
-
diff --git a/meta-oe/recipes-support/devmem2/devmem2/0001-devmem2-support=
-different-page-sizes-at-run-time.patch b/meta-oe/recipes-support/devmem2=
/devmem2/0001-devmem2-support-different-page-sizes-at-run-time.patch
deleted file mode 100644
index 0da0732c5..000000000
--- a/meta-oe/recipes-support/devmem2/devmem2/0001-devmem2-support-differ=
ent-page-sizes-at-run-time.patch
+++ /dev/null
@@ -1,35 +0,0 @@
-From 0f6af48b2fbc71ec8abe862d3e9eb6da7b03538b Mon Sep 17 00:00:00 2001
-From: Denys Dmytriyenko <denys@...>
-Date: Wed, 8 Aug 2018 14:38:00 -0400
-Subject: [PATCH] devmem2: support different page sizes at run-time
-
-Signed-off-by: Denys Dmytriyenko <denys@...>
----
- devmem2.c | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-diff --git a/devmem2.c b/devmem2.c
-index 68131b2..76af2d6 100644
---- a/devmem2.c
-+++ b/devmem2.c
-@@ -53,8 +53,6 @@
- #define FATAL do { fprintf(stderr, "Error at line %d, file %s (%d) [%s]=
\n", \
- __LINE__, __FILE__, errno, strerror(errno)); exit(1); } while(0)
- =20
--#define MAP_SIZE 4096UL
--#define MAP_MASK (MAP_SIZE - 1)
-=20
- static inline void *fixup_addr(void *addr, size_t size);
-=20
-@@ -66,6 +64,8 @@ int main(int argc, char **argv) {
- int access_type =3D 'w';
- char fmt_str[128];
- size_t data_size;
-+ unsigned long MAP_SIZE =3D sysconf(_SC_PAGE_SIZE);
-+ unsigned long MAP_MASK =3D (MAP_SIZE - 1);
- =09
- if(argc < 2) {
- fprintf(stderr, "\nUsage:\t%s { address } [ type [ data ] ]\n"
---=20
-2.7.4
-
diff --git a/meta-oe/recipes-support/devmem2/devmem2/devmem2-fixups-2.pat=
ch b/meta-oe/recipes-support/devmem2/devmem2/devmem2-fixups-2.patch
deleted file mode 100644
index 4517797fc..000000000
--- a/meta-oe/recipes-support/devmem2/devmem2/devmem2-fixups-2.patch
+++ /dev/null
@@ -1,91 +0,0 @@
---- devmem2.c 2004-08-05 01:55:25.000000000 +0200
-+++ devmem2_modif.c 2011-01-13 15:48:37.798799784 +0100
-@@ -45,12 +45,16 @@
- #define MAP_SIZE 4096UL
- #define MAP_MASK (MAP_SIZE - 1)
-=20
-+static inline void *fixup_addr(void *addr, size_t size);
-+
- int main(int argc, char **argv) {
- int fd;
- void *map_base, *virt_addr;=20
-- unsigned long read_result, writeval;
-+ unsigned long read_result, write_val;
- off_t target;
- int access_type =3D 'w';
-+ char fmt_str[128];
-+ size_t data_size;
- =09
- if(argc < 2) {
- fprintf(stderr, "\nUsage:\t%s { address } [ type [ data ] ]\n"
-@@ -79,38 +83,51 @@
- virt_addr =3D map_base + (target & MAP_MASK);
- switch(access_type) {
- case 'b':
-+ data_size =3D sizeof(unsigned char);
-+ virt_addr =3D fixup_addr(virt_addr, data_size);
- read_result =3D *((unsigned char *) virt_addr);
- break;
- case 'h':
-+ data_size =3D sizeof(unsigned short);
-+ virt_addr =3D fixup_addr(virt_addr, data_size);
- read_result =3D *((unsigned short *) virt_addr);
- break;
- case 'w':
-+ data_size =3D sizeof(unsigned long);
-+ virt_addr =3D fixup_addr(virt_addr, data_size);
- read_result =3D *((unsigned long *) virt_addr);
- break;
- default:
- fprintf(stderr, "Illegal data type '%c'.\n", access_type);
- exit(2);
- }
-- printf("Value at address 0x%X (%p): 0x%X\n", target, virt_addr, rea=
d_result);=20
-+ sprintf(fmt_str, "Read at address 0x%%08lX (%%p): 0x%%0%dlX\n", 2*dat=
a_size);
-+ printf(fmt_str, (unsigned long)target, virt_addr, read_result);
- fflush(stdout);
-=20
- if(argc > 3) {
-- writeval =3D strtoul(argv[3], 0, 0);
-+ write_val =3D strtoul(argv[3], 0, 0);
- switch(access_type) {
- case 'b':
-- *((unsigned char *) virt_addr) =3D writeval;
-+ virt_addr =3D fixup_addr(virt_addr, sizeof(unsigned char));
-+ *((unsigned char *) virt_addr) =3D write_val;
- read_result =3D *((unsigned char *) virt_addr);
- break;
- case 'h':
-- *((unsigned short *) virt_addr) =3D writeval;
-+ virt_addr =3D fixup_addr(virt_addr, sizeof(unsigned short));
-+ *((unsigned short *) virt_addr) =3D write_val;
- read_result =3D *((unsigned short *) virt_addr);
- break;
- case 'w':
-- *((unsigned long *) virt_addr) =3D writeval;
-+ virt_addr =3D fixup_addr(virt_addr, sizeof(unsigned long));
-+ *((unsigned long *) virt_addr) =3D write_val;
- read_result =3D *((unsigned long *) virt_addr);
- break;
- }
-- printf("Written 0x%X; readback 0x%X\n", writeval, read_result);=20
-+ sprintf(fmt_str, "Write at address 0x%%08lX (%%p): 0x%%0%dlX, "
-+ "readback 0x%%0%dlX\n", 2*data_size, 2*data_size);
-+ printf(fmt_str, (unsigned long)target, virt_addr,
-+ write_val, read_result);
- fflush(stdout);
- }
- =09
-@@ -119,3 +136,12 @@
- return 0;
- }
-=20
-+static inline void *fixup_addr(void *addr, size_t size)
-+{
-+#ifdef FORCE_STRICT_ALIGNMENT
-+ unsigned long aligned_addr =3D (unsigned long)addr;
-+ aligned_addr &=3D ~(size - 1);
-+ addr =3D (void *)aligned_addr;
-+#endif
-+ return addr;
-+}
diff --git a/meta-oe/recipes-support/devmem2/devmem2.bb b/meta-oe/recipes=
-support/devmem2/devmem2_2.0.bb
similarity index 40%
rename from meta-oe/recipes-support/devmem2/devmem2.bb
rename to meta-oe/recipes-support/devmem2/devmem2_2.0.bb
index 70d413521..aee6bfe3d 100644
--- a/meta-oe/recipes-support/devmem2/devmem2.bb
+++ b/meta-oe/recipes-support/devmem2/devmem2_2.0.bb
@@ -1,22 +1,14 @@
SUMMARY =3D "Simple program to read/write from/to any location in memory=
"
LICENSE =3D "GPL-2.0-or-later"
LIC_FILES_CHKSUM =3D "file://devmem2.c;endline=3D38;md5=3Da9eb9f38903845=
19f435aedf986297cf"
-PR =3D "r7"
=20
-SRC_URI =3D "https://bootlin.com/pub/mirror/devmem2.c;downloadfilename=3D=
devmem2-new.c \
- file://devmem2-fixups-2.patch;apply=3Dyes;striplevel=3D0 \
- file://0001-devmem.c-ensure-word-is-32-bit-and-add-support-fo=
r-6.patch \
- file://0001-devmem2-support-different-page-sizes-at-run-time.=
patch \
-"
+SRC_URI =3D "git://github.com/denix0/devmem2.git;protocol=3Dhttps;branch=
=3Dmain"
+SRCREV =3D "5b395a946894eb4f4ef5d07c80a50a88573a541e"
=20
-S =3D "${WORKDIR}"
+S =3D "${WORKDIR}/git"
=20
CFLAGS +=3D "-DFORCE_STRICT_ALIGNMENT"
=20
-python do_unpack:append() {
- os.rename("devmem2-new.c", "devmem2.c")
-}
-
do_compile() {
${CC} -o devmem2 devmem2.c ${CFLAGS} ${LDFLAGS}
}
@@ -25,6 +17,3 @@ do_install() {
install -d ${D}${bindir}
install devmem2 ${D}${bindir}
}
-
-SRC_URI[md5sum] =3D "e23f236e94be4c429aa1ceac0f01544b"
-SRC_URI[sha256sum] =3D "3b15515693bae1ebd14d914e46d388edfec2175829ea1576=
a7a0c8606ebbe639"
--=20
2.25.1