]> cvs.zerfleddert.de Git - rsbs2/blobdiff - firmware.c
saving/restoring of settings implemented
[rsbs2] / firmware.c
index 16b86183431ebd89bdba766af34f4710b75fd708..80e12e54f9ff73aaaa15449524dde10055601a7d 100644 (file)
@@ -263,6 +263,7 @@ void syntax(char *name)
        fprintf(stderr,"\t-u\t\t\tupdate checksum of the image\n");
        fprintf(stderr,"\t-b\t\t\tmodify BOARD_DESCRIPTION for more power-switch options\n");
        fprintf(stderr,"\t-e\t\t\textract files in firmware\n");
+       fprintf(stderr,"\t-l\t\t\tlist files in firmware\n");
        fprintf(stderr,"\t-t property\t\tset 'property' to true\n");
        fprintf(stderr,"\t-f property\t\tset 'property' to false\n");
        fprintf(stderr,"\t-w property\t\tallow read-write access to 'property'\n");
@@ -375,11 +376,12 @@ int main(int argc, char **argv)
        int patch_bd = 0;
        int patch_fw = 0;
        int extract = 0;
+       int list = 0;
 
        if (argc < 2)
                syntax(argv[0]);
 
-       while ((opt = getopt(argc, argv, "dubet:f:w:r:x:")) != -1) {
+       while ((opt = getopt(argc, argv, "dubelt:f:w:r:x:")) != -1) {
                switch(opt) {
                        case 'd':
                                showall = 1;
@@ -393,6 +395,9 @@ int main(int argc, char **argv)
                        case 'e':
                                extract = 1;
                                break;
+                       case 'l':
+                               list = 1;
+                               break;
                        case 't':
                        case 'f':
                        case 'w':
@@ -487,6 +492,10 @@ int main(int argc, char **argv)
                handle_boarddescription(fw, statbuf.st_size - 4, 0);
        }
 
+       if (list) {
+               list_files(fw, statbuf.st_size - 4);
+       }
+
        if (extract) {
                extract_files(fw, statbuf.st_size - 4);
        }
Impressum, Datenschutz