tools: patch-image: Added optional size option
authorVishnu Swaroop Duddu <duddu.swaroop@intel.com>
Thu, 12 May 2016 14:37:29 +0000 (20:07 +0530)
committerHauke Mehrtens <hauke@hauke-m.de>
Tue, 21 Jun 2016 19:58:07 +0000 (21:58 +0200)
Added optional command line option for patch-image tool
Default 16KB size is still maintained as this is an optional argument.
if one wants to specify or increase size they can provide this option.
sample usage: patch-dtb <file> <dtb> [dtb max size]

Signed-off-by: Vishnu Swaroop Duddu <duddu.swaroop@intel.com>
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
tools/patch-image/src/patch-cmdline.c
tools/patch-image/src/patch-dtb.c

index d3a5b119e446a542f3ac7bc09c755f8fe8e0d050..8d1fce9172c48de14643240e99315eb1da030b29 100644 (file)
@@ -35,10 +35,16 @@ int main(int argc, char **argv)
 {
        int fd, found = 0, len, ret = -1;
        char *ptr, *p;
+       unsigned int search_space;
 
-       if (argc != 3) {
-               fprintf(stderr, "Usage: %s <file> <cmdline>\n", argv[0]);
+       if (argc <= 2 || argc > 4) {
+               fprintf(stderr, "Usage: %s <file> <cmdline> [size]\n", argv[0]);
                goto err1;
+       } else if (argc == 3) {
+               fprintf(stdout, "search space used is default of 16KB\n");
+               search_space = SEARCH_SPACE;
+       } else {
+               search_space = atoi(argv[3]);
        }
        len = strlen(argv[2]);
        if (len + 9 > CMDLINE_MAX) {
@@ -47,12 +53,12 @@ int main(int argc, char **argv)
        }
        
        if (((fd = open(argv[1], O_RDWR)) < 0) ||
-               (ptr = (char *) mmap(0, SEARCH_SPACE + CMDLINE_MAX, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0)) == (void *) (-1)) {
+               (ptr = (char *) mmap(0, search_space + CMDLINE_MAX, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0)) == (void *) (-1)) {
                fprintf(stderr, "Could not open kernel image");
                goto err2;
        }
        
-       for (p = ptr; p < (ptr + SEARCH_SPACE); p += 4) {
+       for (p = ptr; p < (ptr + search_space); p += 4) {
                if (memcmp(p, "CMDLINE:", 8) == 0) {
                        found = 1;
                        p += 8;
index 7812eb9b39d205fd14facbe8ccd9c6033b1dc0c8..8d186236c14531fc9f7873984568200d61a48840 100644 (file)
@@ -30,7 +30,6 @@
 #include <sys/stat.h>
 #include <string.h>
 
-#define SEARCH_SPACE   (16 * 1024)
 #define DTB_MAX        (16 * 1024)
 
 int main(int argc, char **argv)
@@ -38,11 +37,18 @@ int main(int argc, char **argv)
        int fd, fddtb, found = 0, len, ret = -1;
        char *ptr, *ptrdtb, *p;
        struct stat s;
+       unsigned int search_space , dtb_max_size;
 
-       if (argc != 3) {
-               fprintf(stderr, "Usage: %s <file> <dtb>\n", argv[0]);
+       if (argc <= 2 || argc > 4) {
+               fprintf(stderr, "Usage: %s <file> <dtb> [size]\n", argv[0]);
                goto err1;
+       } else if (argc == 3) {
+               fprintf(stdout, "DT size used is default of 16KB\n");
+               search_space = dtb_max_size = DTB_MAX;
+       } else {
+               search_space = dtb_max_size = atoi(argv[3]);
        }
+
        fddtb = open(argv[1], O_RDONLY);
        if (!fddtb)
                goto err1;
@@ -53,24 +59,24 @@ int main(int argc, char **argv)
        }
 
        len = s.st_size;
-       if (len + 8 > DTB_MAX) {
+       if (len + 8 > dtb_max_size) {
                fprintf(stderr, "DTB too big\n");
                goto err1;
        }
 
         if (((fddtb = open(argv[2], O_RDONLY)) < 0) ||
-               (ptrdtb = (char *) mmap(0, DTB_MAX, PROT_READ, MAP_SHARED, fddtb, 0)) == (void *) (-1)) {
+               (ptrdtb = (char *) mmap(0, dtb_max_size, PROT_READ, MAP_SHARED, fddtb, 0)) == (void *) (-1)) {
                fprintf(stderr, "Could not open DTB");
                goto err2;
        }
 
        if (((fd = open(argv[1], O_RDWR)) < 0) ||
-               (ptr = (char *) mmap(0, SEARCH_SPACE + DTB_MAX, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0)) == (void *) (-1)) {
+               (ptr = (char *) mmap(0, search_space + dtb_max_size, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0)) == (void *) (-1)) {
                fprintf(stderr, "Could not open kernel image");
                goto err3;
        }
 
-       for (p = ptr; p < (ptr + SEARCH_SPACE); p += 4) {
+       for (p = ptr; p < (ptr + search_space); p += 4) {
                if (memcmp(p, "OWRTDTB:", 8) == 0) {
                        found = 1;
                        p += 8;
@@ -82,7 +88,7 @@ int main(int argc, char **argv)
                goto err4;
        }
 
-       memset(p, 0, DTB_MAX - 8);
+       memset(p, 0, dtb_max_size - 8);
        memcpy(p, ptrdtb, len);
        msync(p, len, MS_SYNC|MS_INVALIDATE);
        ret = 0;