mirror of
git://projects.qi-hardware.com/ben-blinkenlights.git
synced 2024-11-27 19:11:54 +02:00
lpc111x-isp/lpc111x.c: new option -r to reset the target and let it run
This commit is contained in:
parent
66d091317a
commit
c7a7d358bb
@ -563,17 +563,45 @@ static void start_isp(int power)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* ----- Reset and run target ---------------------------------------------- */
|
||||||
|
|
||||||
|
|
||||||
|
static void run_target(int power)
|
||||||
|
{
|
||||||
|
if (ubb_open(0) < 0) {
|
||||||
|
perror("ubb_open");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (power)
|
||||||
|
ubb_power(1);
|
||||||
|
|
||||||
|
SET(TGT_nRESET);
|
||||||
|
OUT(TGT_nRESET);
|
||||||
|
|
||||||
|
IN(TGT_nISP);
|
||||||
|
|
||||||
|
CLR(TGT_nRESET);
|
||||||
|
usleep(10); /* DS Table 9 pg 29 says min 50 ns */
|
||||||
|
SET(TGT_nRESET);
|
||||||
|
|
||||||
|
ubb_close(UBB_nPWR | TGT_nRESET | TGT_nISP);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* ----- Command-line processing ------------------------------------------- */
|
/* ----- Command-line processing ------------------------------------------- */
|
||||||
|
|
||||||
|
|
||||||
static void usage(const char *name)
|
static void usage(const char *name)
|
||||||
{
|
{
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"usage: %s [-n] [-q] [-v ...] [file.bin]\n\n"
|
"usage: %s [-n] [-q] [-v ...] [file.bin]\n"
|
||||||
|
" %s [-n] -r\n\n"
|
||||||
" -n don't power the device\n"
|
" -n don't power the device\n"
|
||||||
" -q suppress basic progress messages\n"
|
" -q suppress basic progress messages\n"
|
||||||
|
" -r reset the target and let it run\n"
|
||||||
" -v increase verbosity level\n"
|
" -v increase verbosity level\n"
|
||||||
, name);
|
, name, name);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -582,9 +610,10 @@ int main(int argc, char **argv)
|
|||||||
{
|
{
|
||||||
FILE *file = NULL;
|
FILE *file = NULL;
|
||||||
int power = 1;
|
int power = 1;
|
||||||
|
int run = 0;
|
||||||
int c;
|
int c;
|
||||||
|
|
||||||
while ((c = getopt(argc, argv, "nqv")) != EOF)
|
while ((c = getopt(argc, argv, "nqrv")) != EOF)
|
||||||
switch (c) {
|
switch (c) {
|
||||||
case 'n':
|
case 'n':
|
||||||
power = 0;
|
power = 0;
|
||||||
@ -592,6 +621,9 @@ int main(int argc, char **argv)
|
|||||||
case 'q':
|
case 'q':
|
||||||
quiet = 1;
|
quiet = 1;
|
||||||
break;
|
break;
|
||||||
|
case 'r':
|
||||||
|
run = 1;
|
||||||
|
break;
|
||||||
case 'v':
|
case 'v':
|
||||||
verbose++;
|
verbose++;
|
||||||
break;
|
break;
|
||||||
@ -599,6 +631,13 @@ int main(int argc, char **argv)
|
|||||||
usage(*argv);
|
usage(*argv);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (run) {
|
||||||
|
if (quiet || verbose || argc != optind)
|
||||||
|
usage(*argv);
|
||||||
|
run_target(power);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
switch (argc-optind) {
|
switch (argc-optind) {
|
||||||
case 0:
|
case 0:
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user