+ if (argc < 3) {
+ usage(argv[0]);
+ return -1;
+ }
+
+ for (int i = 2; 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++;
+ }
+ }
+
+ pthread_mutex_init(&conn.recv_lock, NULL);
+
+ char* serial_port_name = argv[1];
+
+ fprintf(stderr,"Waiting for Proxmark to appear on %s", serial_port_name);
+ do {
+ sleep(1);
+ fprintf(stderr, ".");
+ } while (!OpenProxmark(serial_port_name));
+ fprintf(stderr," Found.\n");
+
+ // Lets start up the communications thread
+ conn.run = true;
+ pthread_create(&reader_thread, NULL, &uart_receiver, &conn);
+
+ res = flash_start_flashing(&conn, can_write_bl, serial_port_name);
+ if (res < 0)
+ return -1;