Message ID | 20220512234307.1189721-1-denis@denix.org |
---|---|
State | Rejected, archived |
Delegated to: | Armin Kuster |
Headers | show |
Series | [kirkstone,1/3] devmem2: reinstate previous patches, removed by mistake | expand |
On 5/12/22 16:43, Denys Dmytriyenko wrote: > This reverts commit 5e8f4720aaa3da7350ead06959cae0492133cd61. > > Signed-off-by: Denys Dmytriyenko <denis@denix.org> > Signed-off-by: Khem Raj <raj.khem@gmail.com> > Signed-off-by: Denys Dmytriyenko <denis@denix.org> thanks, I already have this staged in stable/kirtkstone-nut -armin > --- > meta-oe/recipes-support/devmem2/devmem2.bb | 3 +- > ...word-is-32-bit-and-add-support-for-6.patch | 70 ++++++++++++++ > .../devmem2/devmem2/devmem2-fixups-2.patch | 91 +++++++++++++++++++ > 3 files changed, 163 insertions(+), 1 deletion(-) > create mode 100644 meta-oe/recipes-support/devmem2/devmem2/0001-devmem.c-ensure-word-is-32-bit-and-add-support-for-6.patch > create mode 100644 meta-oe/recipes-support/devmem2/devmem2/devmem2-fixups-2.patch > > diff --git a/meta-oe/recipes-support/devmem2/devmem2.bb b/meta-oe/recipes-support/devmem2/devmem2.bb > index 92c05fe06..c6b8df5e4 100644 > --- a/meta-oe/recipes-support/devmem2/devmem2.bb > +++ b/meta-oe/recipes-support/devmem2/devmem2.bb > @@ -4,7 +4,8 @@ LIC_FILES_CHKSUM = "file://devmem2.c;endline=38;md5=a9eb9f3890384519f435aedf9862 > PR = "r7" > > SRC_URI = "http://www.free-electrons.com/pub/mirror/devmem2.c;downloadfilename=devmem2-new.c \ > - " > + file://devmem2-fixups-2.patch;apply=yes;striplevel=0 \ > + file://0001-devmem.c-ensure-word-is-32-bit-and-add-support-for-6.patch" > > S = "${WORKDIR}" > > 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/devmem2/devmem2/0001-devmem.c-ensure-word-is-32-bit-and-add-support-for-6.patch > new file mode 100644 > index 000000000..2a57f2989 > --- /dev/null > +++ b/meta-oe/recipes-support/devmem2/devmem2/0001-devmem.c-ensure-word-is-32-bit-and-add-support-for-6.patch > @@ -0,0 +1,70 @@ > +From 1360a907879dd24041797a3b709d49aeac2ab444 Mon Sep 17 00:00:00 2001 > +From: Denys Dmytriyenko <denys@ti.com> > +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@ti.com> > +--- > + 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 @@ > + > + #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 = *((unsigned short *) virt_addr); > + break; > + case 'w': > +- data_size = sizeof(unsigned long); > ++ data_size = sizeof(uint32_t); > + virt_addr = fixup_addr(virt_addr, data_size); > +- read_result = *((unsigned long *) virt_addr); > ++ read_result = *((uint32_t *) virt_addr); > ++ break; > ++ case 'l': > ++ data_size = sizeof(uint64_t); > ++ virt_addr = fixup_addr(virt_addr, data_size); > ++ read_result = *((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 = *((unsigned short *) virt_addr); > + break; > + case 'w': > +- virt_addr = fixup_addr(virt_addr, sizeof(unsigned long)); > +- *((unsigned long *) virt_addr) = write_val; > +- read_result = *((unsigned long *) virt_addr); > ++ virt_addr = fixup_addr(virt_addr, sizeof(uint32_t)); > ++ *((uint32_t *) virt_addr) = write_val; > ++ read_result = *((uint32_t *) virt_addr); > ++ break; > ++ case 'l': > ++ virt_addr = fixup_addr(virt_addr, sizeof(uint64_t)); > ++ *((uint64_t *) virt_addr) = write_val; > ++ read_result = *((uint64_t *) virt_addr); > + break; > + } > + sprintf(fmt_str, "Write at address 0x%%08lX (%%p): 0x%%0%dlX, " > +-- > +2.7.4 > + > diff --git a/meta-oe/recipes-support/devmem2/devmem2/devmem2-fixups-2.patch b/meta-oe/recipes-support/devmem2/devmem2/devmem2-fixups-2.patch > new file mode 100644 > index 000000000..4517797fc > --- /dev/null > +++ b/meta-oe/recipes-support/devmem2/devmem2/devmem2-fixups-2.patch > @@ -0,0 +1,91 @@ > +--- 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) > + > ++static inline void *fixup_addr(void *addr, size_t size); > ++ > + int main(int argc, char **argv) { > + int fd; > + void *map_base, *virt_addr; > +- unsigned long read_result, writeval; > ++ unsigned long read_result, write_val; > + off_t target; > + int access_type = 'w'; > ++ char fmt_str[128]; > ++ size_t data_size; > + > + if(argc < 2) { > + fprintf(stderr, "\nUsage:\t%s { address } [ type [ data ] ]\n" > +@@ -79,38 +83,51 @@ > + virt_addr = map_base + (target & MAP_MASK); > + switch(access_type) { > + case 'b': > ++ data_size = sizeof(unsigned char); > ++ virt_addr = fixup_addr(virt_addr, data_size); > + read_result = *((unsigned char *) virt_addr); > + break; > + case 'h': > ++ data_size = sizeof(unsigned short); > ++ virt_addr = fixup_addr(virt_addr, data_size); > + read_result = *((unsigned short *) virt_addr); > + break; > + case 'w': > ++ data_size = sizeof(unsigned long); > ++ virt_addr = fixup_addr(virt_addr, data_size); > + read_result = *((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, read_result); > ++ sprintf(fmt_str, "Read at address 0x%%08lX (%%p): 0x%%0%dlX\n", 2*data_size); > ++ printf(fmt_str, (unsigned long)target, virt_addr, read_result); > + fflush(stdout); > + > + if(argc > 3) { > +- writeval = strtoul(argv[3], 0, 0); > ++ write_val = strtoul(argv[3], 0, 0); > + switch(access_type) { > + case 'b': > +- *((unsigned char *) virt_addr) = writeval; > ++ virt_addr = fixup_addr(virt_addr, sizeof(unsigned char)); > ++ *((unsigned char *) virt_addr) = write_val; > + read_result = *((unsigned char *) virt_addr); > + break; > + case 'h': > +- *((unsigned short *) virt_addr) = writeval; > ++ virt_addr = fixup_addr(virt_addr, sizeof(unsigned short)); > ++ *((unsigned short *) virt_addr) = write_val; > + read_result = *((unsigned short *) virt_addr); > + break; > + case 'w': > +- *((unsigned long *) virt_addr) = writeval; > ++ virt_addr = fixup_addr(virt_addr, sizeof(unsigned long)); > ++ *((unsigned long *) virt_addr) = write_val; > + read_result = *((unsigned long *) virt_addr); > + break; > + } > +- printf("Written 0x%X; readback 0x%X\n", writeval, read_result); > ++ 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); > + } > + > +@@ -119,3 +136,12 @@ > + return 0; > + } > + > ++static inline void *fixup_addr(void *addr, size_t size) > ++{ > ++#ifdef FORCE_STRICT_ALIGNMENT > ++ unsigned long aligned_addr = (unsigned long)addr; > ++ aligned_addr &= ~(size - 1); > ++ addr = (void *)aligned_addr; > ++#endif > ++ return addr; > ++} > > -=-=-=-=-=-=-=-=-=-=-=- > Links: You receive all messages sent to this group. > View/Reply Online (#97083): https://lists.openembedded.org/g/openembedded-devel/message/97083 > Mute This Topic: https://lists.openembedded.org/mt/91070558/3616698 > Group Owner: openembedded-devel+owner@lists.openembedded.org > Unsubscribe: https://lists.openembedded.org/g/openembedded-devel/unsub [akuster808@gmail.com] > -=-=-=-=-=-=-=-=-=-=-=- >
diff --git a/meta-oe/recipes-support/devmem2/devmem2.bb b/meta-oe/recipes-support/devmem2/devmem2.bb index 92c05fe06..c6b8df5e4 100644 --- a/meta-oe/recipes-support/devmem2/devmem2.bb +++ b/meta-oe/recipes-support/devmem2/devmem2.bb @@ -4,7 +4,8 @@ LIC_FILES_CHKSUM = "file://devmem2.c;endline=38;md5=a9eb9f3890384519f435aedf9862 PR = "r7" SRC_URI = "http://www.free-electrons.com/pub/mirror/devmem2.c;downloadfilename=devmem2-new.c \ - " + file://devmem2-fixups-2.patch;apply=yes;striplevel=0 \ + file://0001-devmem.c-ensure-word-is-32-bit-and-add-support-for-6.patch" S = "${WORKDIR}" 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/devmem2/devmem2/0001-devmem.c-ensure-word-is-32-bit-and-add-support-for-6.patch new file mode 100644 index 000000000..2a57f2989 --- /dev/null +++ b/meta-oe/recipes-support/devmem2/devmem2/0001-devmem.c-ensure-word-is-32-bit-and-add-support-for-6.patch @@ -0,0 +1,70 @@ +From 1360a907879dd24041797a3b709d49aeac2ab444 Mon Sep 17 00:00:00 2001 +From: Denys Dmytriyenko <denys@ti.com> +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@ti.com> +--- + 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 @@ + + #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 = *((unsigned short *) virt_addr); + break; + case 'w': +- data_size = sizeof(unsigned long); ++ data_size = sizeof(uint32_t); + virt_addr = fixup_addr(virt_addr, data_size); +- read_result = *((unsigned long *) virt_addr); ++ read_result = *((uint32_t *) virt_addr); ++ break; ++ case 'l': ++ data_size = sizeof(uint64_t); ++ virt_addr = fixup_addr(virt_addr, data_size); ++ read_result = *((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 = *((unsigned short *) virt_addr); + break; + case 'w': +- virt_addr = fixup_addr(virt_addr, sizeof(unsigned long)); +- *((unsigned long *) virt_addr) = write_val; +- read_result = *((unsigned long *) virt_addr); ++ virt_addr = fixup_addr(virt_addr, sizeof(uint32_t)); ++ *((uint32_t *) virt_addr) = write_val; ++ read_result = *((uint32_t *) virt_addr); ++ break; ++ case 'l': ++ virt_addr = fixup_addr(virt_addr, sizeof(uint64_t)); ++ *((uint64_t *) virt_addr) = write_val; ++ read_result = *((uint64_t *) virt_addr); + break; + } + sprintf(fmt_str, "Write at address 0x%%08lX (%%p): 0x%%0%dlX, " +-- +2.7.4 + diff --git a/meta-oe/recipes-support/devmem2/devmem2/devmem2-fixups-2.patch b/meta-oe/recipes-support/devmem2/devmem2/devmem2-fixups-2.patch new file mode 100644 index 000000000..4517797fc --- /dev/null +++ b/meta-oe/recipes-support/devmem2/devmem2/devmem2-fixups-2.patch @@ -0,0 +1,91 @@ +--- 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) + ++static inline void *fixup_addr(void *addr, size_t size); ++ + int main(int argc, char **argv) { + int fd; + void *map_base, *virt_addr; +- unsigned long read_result, writeval; ++ unsigned long read_result, write_val; + off_t target; + int access_type = 'w'; ++ char fmt_str[128]; ++ size_t data_size; + + if(argc < 2) { + fprintf(stderr, "\nUsage:\t%s { address } [ type [ data ] ]\n" +@@ -79,38 +83,51 @@ + virt_addr = map_base + (target & MAP_MASK); + switch(access_type) { + case 'b': ++ data_size = sizeof(unsigned char); ++ virt_addr = fixup_addr(virt_addr, data_size); + read_result = *((unsigned char *) virt_addr); + break; + case 'h': ++ data_size = sizeof(unsigned short); ++ virt_addr = fixup_addr(virt_addr, data_size); + read_result = *((unsigned short *) virt_addr); + break; + case 'w': ++ data_size = sizeof(unsigned long); ++ virt_addr = fixup_addr(virt_addr, data_size); + read_result = *((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, read_result); ++ sprintf(fmt_str, "Read at address 0x%%08lX (%%p): 0x%%0%dlX\n", 2*data_size); ++ printf(fmt_str, (unsigned long)target, virt_addr, read_result); + fflush(stdout); + + if(argc > 3) { +- writeval = strtoul(argv[3], 0, 0); ++ write_val = strtoul(argv[3], 0, 0); + switch(access_type) { + case 'b': +- *((unsigned char *) virt_addr) = writeval; ++ virt_addr = fixup_addr(virt_addr, sizeof(unsigned char)); ++ *((unsigned char *) virt_addr) = write_val; + read_result = *((unsigned char *) virt_addr); + break; + case 'h': +- *((unsigned short *) virt_addr) = writeval; ++ virt_addr = fixup_addr(virt_addr, sizeof(unsigned short)); ++ *((unsigned short *) virt_addr) = write_val; + read_result = *((unsigned short *) virt_addr); + break; + case 'w': +- *((unsigned long *) virt_addr) = writeval; ++ virt_addr = fixup_addr(virt_addr, sizeof(unsigned long)); ++ *((unsigned long *) virt_addr) = write_val; + read_result = *((unsigned long *) virt_addr); + break; + } +- printf("Written 0x%X; readback 0x%X\n", writeval, read_result); ++ 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); + } + +@@ -119,3 +136,12 @@ + return 0; + } + ++static inline void *fixup_addr(void *addr, size_t size) ++{ ++#ifdef FORCE_STRICT_ALIGNMENT ++ unsigned long aligned_addr = (unsigned long)addr; ++ aligned_addr &= ~(size - 1); ++ addr = (void *)aligned_addr; ++#endif ++ return addr; ++}