]> git.zerfleddert.de Git - proxmark3-svn/blobdiff - client/flasher.c
fix Makefile for new flasher
[proxmark3-svn] / client / flasher.c
index 418718dd0cf44767d400b8f2f24fbb60347c5676..85aae04970d59de1e2273998f849605a7edc823e 100644 (file)
@@ -1,58 +1,93 @@
+//-----------------------------------------------------------------------------
+// This code is licensed to you under the terms of the GNU GPL, version 2 or,
+// at your option, any later version. See the LICENSE.txt file for the text of
+// the license.
+//-----------------------------------------------------------------------------
+// Flasher frontend tool
+//-----------------------------------------------------------------------------
+
 #include <stdio.h>
 #include <stdlib.h>
+#include <string.h>
 #include "sleep.h"
 #include "proxusb.h"
 #include "flash.h"
 
-unsigned int current_command = CMD_UNKNOWN;
+static void usage(char *argv0)
+{
+       fprintf(stderr, "Usage:   %s [-b] image.elf [image.elf...]\n\n", argv0);
+       fprintf(stderr, "\t-b\tEnable flashing of bootloader area (DANGEROUS)\n\n");
+       fprintf(stderr, "Example: %s path/to/osimage.elf path/to/fpgaimage.elf\n", argv0);
+}
 
-extern struct partition partitions[];
+#define MAX_FILES 4
 
-static void usage(char **argv)
+int main(int argc, char **argv)
 {
-  fprintf(stderr, "Usage:   %s areas image [image [image]]\n", argv[0]);
-  fprintf(stderr, "         areas is a comma-separated list of areas to flash, with no spaces\n");
-  fprintf(stderr, "               Known areas are:");
+       int can_write_bl = 0;
+       int num_files = 0;
+       int res;
+       flash_file_t files[MAX_FILES];
 
-  for (int i = 0; partitions[i].name != NULL; ++i) {
-    fprintf(stderr, " %s", partitions[i].name);
-  }
+       memset(files, 0, sizeof(files));
 
-  fprintf(stderr, "\n");
-  fprintf(stderr, "         image is the path to the corresponding image\n\n");
-  fprintf(stderr, "Example: %s os,fpga path/to/osimage.elf path/to/fpgaimage.elf\n", argv[0]);
-}
+       if (argc < 2) {
+               usage(argv[0]);
+               return -1;
+       }
 
-int main(int argc, char **argv)
-{
-  if (argc < 2) {
-    usage(argv);
-    exit(-1);
-  }
+       for (int i = 1; i < argc; i++) {
+               if (argv[i][0] == '-') {
+                       if (!strcmp(argv[i], "-b")) {
+                               can_write_bl = 1;
+                       } else {
+                               usage(argv[0]);
+                               return -1;
+                       }
+               } else {
+                       res = flash_load(&files[num_files], argv[i], can_write_bl);
+                       if (res < 0) {
+                               fprintf(stderr, "Error while loading %s\n", argv[i]);
+                               return -1;
+                       }
+                       fprintf(stderr, "\n");
+                       num_files++;
+               }
+       }
+
+       usb_init();
 
-  /* Count area arguments */
-  int areas = 0, offset=-1, length=0;
-  while (find_next_area(argv[1], &offset, &length)) areas++;
+       fprintf(stderr, "Waiting for Proxmark to appear on USB...");
+       while (!OpenProxmark(0)) {
+               sleep(1);
+               fprintf(stderr, ".");
+       }
+       fprintf(stderr, " Found.\n");
 
-  if (areas != argc - 2) {
-    usage(argv);
-    exit(-1);
-  }
+       res = flash_start_flashing(can_write_bl);
+       if (res < 0)
+               return -1;
 
-  usb_init();
+       fprintf(stderr, "\nFlashing...\n");
 
-  fprintf(stderr,"Waiting for Proxmark to appear on USB... ");
-  while (!OpenProxmark(0)) { sleep(1); }
-  fprintf(stderr,"Found.\n");
+       for (int i = 0; i < num_files; i++) {
+               res = flash_write(&files[i]);
+               if (res < 0)
+                       return -1;
+               flash_free(&files[i]);
+               fprintf(stderr, "\n");
+       }
 
-  do_flash(argv);
+       fprintf(stderr, "Resetting hardware...\n");
 
-  UsbCommand c = {CMD_HARDWARE_RESET};
-  SendCommand(&c);
+       res = flash_stop_flashing();
+       if (res < 0)
+               return -1;
 
-  CloseProxmark();
+       CloseProxmark();
 
-  fprintf(stderr,"Have a nice day!\n");
+       fprintf(stderr, "All done.\n\n");
+       fprintf(stderr, "Have a nice day!\n");
 
-  return 0;
+       return 0;
 }
Impressum, Datenschutz