patch #7936 Patch to support BusPirate AVR Extended Commands mode
* buspirate.c: added support for BusPirate AVR Extended Commands mode * avrdude.1: added doc for nopagedread parameter * doc/avrdude.texi: added doc for nopagedread parameter git-svn-id: svn://svn.savannah.nongnu.org/avrdude/trunk/avrdude@1137 81a1dc3b-b13d-400b-aceb-764788c761c2
This commit is contained in:
parent
fa4ab4941f
commit
67b1492b46
|
@ -1,3 +1,10 @@
|
||||||
|
2013-01-30 Rene Liebscher <R.Liebscher@gmx.de>
|
||||||
|
|
||||||
|
patch #7936 Patch to support BusPirate AVR Extended Commands mode
|
||||||
|
* buspirate.c: added support for BusPirate AVR Extended Commands mode
|
||||||
|
* avrdude.1: added doc for nopagedread parameter
|
||||||
|
* doc/avrdude.texi: added doc for nopagedread parameter
|
||||||
|
|
||||||
2013-01-30 Rene Liebscher <R.Liebscher@gmx.de>
|
2013-01-30 Rene Liebscher <R.Liebscher@gmx.de>
|
||||||
|
|
||||||
patch #7723 Bus Pirate “raw-wire” mode which can run down to 5 kHz
|
patch #7723 Bus Pirate “raw-wire” mode which can run down to 5 kHz
|
||||||
|
|
|
@ -946,6 +946,11 @@ Firmware versions 5.10 and newer support a binary mode SPI command that enables
|
||||||
whole pages to be written to AVR flash memory at once, resulting in a
|
whole pages to be written to AVR flash memory at once, resulting in a
|
||||||
significant write speed increase. If use of this mode is not desirable for some
|
significant write speed increase. If use of this mode is not desirable for some
|
||||||
reason, this option disables it.
|
reason, this option disables it.
|
||||||
|
.It Ar nopagedread
|
||||||
|
Newer firmware versions support in binary mode SPI command some AVR Extended
|
||||||
|
Commands. Using the "Bulk Memory Read from Flash" results in a
|
||||||
|
significant read speed increase. If use of this mode is not desirable for some
|
||||||
|
reason, this option disables it.
|
||||||
.It Ar cpufreq=<125..4000>
|
.It Ar cpufreq=<125..4000>
|
||||||
This sets the AUX pin to output a frequency of
|
This sets the AUX pin to output a frequency of
|
||||||
.Ar n
|
.Ar n
|
||||||
|
|
95
buspirate.c
95
buspirate.c
|
@ -65,6 +65,7 @@
|
||||||
#define BP_FLAG_NOPAGEDWRITE (1<<4)
|
#define BP_FLAG_NOPAGEDWRITE (1<<4)
|
||||||
#define BP_FLAG_XPARM_CPUFREQ (1<<5)
|
#define BP_FLAG_XPARM_CPUFREQ (1<<5)
|
||||||
#define BP_FLAG_XPARM_RAWFREQ (1<<6)
|
#define BP_FLAG_XPARM_RAWFREQ (1<<6)
|
||||||
|
#define BP_FLAG_NOPAGEDREAD (1<<7)
|
||||||
|
|
||||||
struct pdata
|
struct pdata
|
||||||
{
|
{
|
||||||
|
@ -265,8 +266,14 @@ static int buspirate_expect(struct programmer_t *pgm, char *send,
|
||||||
while (1) {
|
while (1) {
|
||||||
rcvd = buspirate_readline(pgm, NULL, 0);
|
rcvd = buspirate_readline(pgm, NULL, 0);
|
||||||
|
|
||||||
if (strncmp(rcvd, expect, expect_len) == 0)
|
if (strncmp(rcvd, expect, expect_len) == 0) {
|
||||||
|
if (! wait_for_prompt) {
|
||||||
|
serial_drain(&pgm->fd, 0);
|
||||||
|
return 1;
|
||||||
|
} else {
|
||||||
got_it = 1;
|
got_it = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (buspirate_is_prompt(rcvd))
|
if (buspirate_is_prompt(rcvd))
|
||||||
break;
|
break;
|
||||||
|
@ -359,6 +366,10 @@ buspirate_parseextparms(struct programmer_t *pgm, LISTID extparms)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (strcmp(extended_param, "nopagedread") == 0) {
|
||||||
|
pgm->flag |= BP_FLAG_NOPAGEDREAD;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (sscanf(extended_param, "serial_recv_timeout=%d", &serial_recv_timeout) == 1) {
|
if (sscanf(extended_param, "serial_recv_timeout=%d", &serial_recv_timeout) == 1) {
|
||||||
if (serial_recv_timeout < 1) {
|
if (serial_recv_timeout < 1) {
|
||||||
fprintf(stderr, "BusPirate: serial_recv_timeout must be greater 0.\n");
|
fprintf(stderr, "BusPirate: serial_recv_timeout must be greater 0.\n");
|
||||||
|
@ -472,6 +483,7 @@ static int buspirate_start_mode_bin(struct programmer_t *pgm)
|
||||||
.config = 0x8C,
|
.config = 0x8C,
|
||||||
};
|
};
|
||||||
pgm->flag |= BP_FLAG_NOPAGEDWRITE;
|
pgm->flag |= BP_FLAG_NOPAGEDWRITE;
|
||||||
|
pgm->flag |= BP_FLAG_NOPAGEDREAD;
|
||||||
} else {
|
} else {
|
||||||
submode = &(const struct submode){
|
submode = &(const struct submode){
|
||||||
.name = "SPI",
|
.name = "SPI",
|
||||||
|
@ -488,6 +500,7 @@ static int buspirate_start_mode_bin(struct programmer_t *pgm)
|
||||||
}
|
}
|
||||||
|
|
||||||
char buf[20] = { '\0' };
|
char buf[20] = { '\0' };
|
||||||
|
unsigned int ver = 0;
|
||||||
|
|
||||||
/* == Switch to binmode - send 20x '\0' == */
|
/* == Switch to binmode - send 20x '\0' == */
|
||||||
buspirate_send_bin(pgm, buf, sizeof(buf));
|
buspirate_send_bin(pgm, buf, sizeof(buf));
|
||||||
|
@ -525,6 +538,7 @@ static int buspirate_start_mode_bin(struct programmer_t *pgm)
|
||||||
if (pgm->flag & BP_FLAG_NOPAGEDWRITE) {
|
if (pgm->flag & BP_FLAG_NOPAGEDWRITE) {
|
||||||
if (verbose)
|
if (verbose)
|
||||||
fprintf(stderr, "%s: Paged flash write disabled.\n", progname);
|
fprintf(stderr, "%s: Paged flash write disabled.\n", progname);
|
||||||
|
pgm->paged_write = NULL;
|
||||||
} else {
|
} else {
|
||||||
/* Check for write-then-read without !CS/CS and disable paged_write if absent: */
|
/* Check for write-then-read without !CS/CS and disable paged_write if absent: */
|
||||||
strncpy(buf, "\x5\x0\x0\x0\x0", 5);
|
strncpy(buf, "\x5\x0\x0\x0\x0", 5);
|
||||||
|
@ -534,6 +548,7 @@ static int buspirate_start_mode_bin(struct programmer_t *pgm)
|
||||||
|
|
||||||
/* Disable paged write: */
|
/* Disable paged write: */
|
||||||
pgm->flag |= BP_FLAG_NOPAGEDWRITE;
|
pgm->flag |= BP_FLAG_NOPAGEDWRITE;
|
||||||
|
pgm->paged_write = NULL;
|
||||||
|
|
||||||
/* Return to SPI mode (0x00s have landed us back in binary bitbang mode): */
|
/* Return to SPI mode (0x00s have landed us back in binary bitbang mode): */
|
||||||
buf[0] = 0x1;
|
buf[0] = 0x1;
|
||||||
|
@ -562,6 +577,25 @@ static int buspirate_start_mode_bin(struct programmer_t *pgm)
|
||||||
/* Submode config */
|
/* Submode config */
|
||||||
buspirate_expect_bin_byte(pgm, submode->config, 0x01);
|
buspirate_expect_bin_byte(pgm, submode->config, 0x01);
|
||||||
|
|
||||||
|
/* AVR Extended Commands - test for existence */
|
||||||
|
if (pgm->flag & BP_FLAG_NOPAGEDREAD) {
|
||||||
|
if (verbose)
|
||||||
|
fprintf(stderr, "%s: Paged flash read disabled.\n", progname);
|
||||||
|
pgm->paged_load = NULL;
|
||||||
|
} else {
|
||||||
|
if (buspirate_expect_bin_byte(pgm, 0x06, 0x01)) {
|
||||||
|
strncpy(buf, "\x1\x0\x0", 3);
|
||||||
|
buspirate_send_bin(pgm, buf, 1);
|
||||||
|
buspirate_recv_bin(pgm, buf, 3);
|
||||||
|
ver = buf[1] << 8 | buf[2];
|
||||||
|
if (verbose) fprintf(stderr, "AVR Extended Commands version %d\n", ver);
|
||||||
|
} else {
|
||||||
|
if (verbose) fprintf(stderr, "AVR Extended Commands not found.\n");
|
||||||
|
pgm->flag |= BP_FLAG_NOPAGEDREAD;
|
||||||
|
pgm->paged_load = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -603,7 +637,7 @@ static int buspirate_start_spi_mode_ascii(struct programmer_t *pgm)
|
||||||
}
|
}
|
||||||
if (buspirate_is_prompt(rcvd)) {
|
if (buspirate_is_prompt(rcvd)) {
|
||||||
if (strncmp(rcvd, "SPI>", 4) == 0) {
|
if (strncmp(rcvd, "SPI>", 4) == 0) {
|
||||||
fprintf(stderr, "BusPirate is now configured for SPI\n");
|
if (verbose) fprintf(stderr, "BusPirate is now configured for SPI\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
/* Not yet 'SPI>' prompt */
|
/* Not yet 'SPI>' prompt */
|
||||||
|
@ -809,6 +843,62 @@ static int buspirate_cmd(struct programmer_t *pgm,
|
||||||
return buspirate_cmd_ascii(pgm, cmd, res);
|
return buspirate_cmd_ascii(pgm, cmd, res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Paged load function which utilizes the AVR Extended Commands set */
|
||||||
|
static int buspirate_paged_load(
|
||||||
|
PROGRAMMER *pgm,
|
||||||
|
AVRPART *p,
|
||||||
|
AVRMEM *m,
|
||||||
|
unsigned int page_size,
|
||||||
|
unsigned int address,
|
||||||
|
unsigned int n_bytes)
|
||||||
|
{
|
||||||
|
unsigned char commandbuf[10];
|
||||||
|
unsigned char buf[275];
|
||||||
|
unsigned int addr = 0;
|
||||||
|
|
||||||
|
if (verbose > 1) fprintf(stderr, "BusPirate: buspirate_paged_load(..,%s,%d,%d,%d)\n",m->desc,m->page_size,address,n_bytes);
|
||||||
|
|
||||||
|
// This should never happen, but still...
|
||||||
|
if (pgm->flag & BP_FLAG_NOPAGEDREAD) {
|
||||||
|
fprintf(stderr, "BusPirate: buspirate_paged_load() called while in nopagedread mode!\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// determine what type of memory to read, only flash is supported
|
||||||
|
if (strcmp(m->desc, "flash") != 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// send command to read data
|
||||||
|
strncpy(commandbuf, "\x6\x2", 2);
|
||||||
|
|
||||||
|
// send start address (in WORDS, not bytes!)
|
||||||
|
commandbuf[2] = (address >> 1 >> 24) & 0xff;
|
||||||
|
commandbuf[3] = (address >> 1>> 16) & 0xff;
|
||||||
|
commandbuf[4] = (address >> 1 >> 8) & 0xff;
|
||||||
|
commandbuf[5] = (address >> 1) & 0xff;
|
||||||
|
|
||||||
|
// send number of bytes to fetch (in BYTES)
|
||||||
|
commandbuf[6] = (n_bytes >> 24) & 0xff;
|
||||||
|
commandbuf[7] = (n_bytes >> 16) & 0xff;
|
||||||
|
commandbuf[8] = (n_bytes >> 8) & 0xff;
|
||||||
|
commandbuf[9] = (n_bytes) & 0xff;
|
||||||
|
|
||||||
|
buspirate_send_bin(pgm, commandbuf, 10);
|
||||||
|
buspirate_recv_bin(pgm, buf, 1);
|
||||||
|
buspirate_recv_bin(pgm, buf, 1);
|
||||||
|
|
||||||
|
if (buf[0] != 0x01) {
|
||||||
|
fprintf(stderr, "BusPirate: Paged Read command returned zero.\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (addr = 0; addr < n_bytes; addr++) {
|
||||||
|
buspirate_recv_bin(pgm, &m->buf[addr+address], 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
return n_bytes;
|
||||||
|
}
|
||||||
/* Paged write function which utilizes the Bus Pirate's "Write then Read" binary SPI instruction */
|
/* Paged write function which utilizes the Bus Pirate's "Write then Read" binary SPI instruction */
|
||||||
static int buspirate_paged_write(struct programmer_t *pgm,
|
static int buspirate_paged_write(struct programmer_t *pgm,
|
||||||
AVRPART *p,
|
AVRPART *p,
|
||||||
|
@ -1027,6 +1117,7 @@ void buspirate_initpgm(struct programmer_t *pgm)
|
||||||
pgm->write_byte = avr_write_byte_default;
|
pgm->write_byte = avr_write_byte_default;
|
||||||
|
|
||||||
pgm->paged_write = buspirate_paged_write;
|
pgm->paged_write = buspirate_paged_write;
|
||||||
|
pgm->paged_load = buspirate_paged_load;
|
||||||
|
|
||||||
/* Support functions */
|
/* Support functions */
|
||||||
pgm->parseextparams = buspirate_parseextparms;
|
pgm->parseextparams = buspirate_parseextparms;
|
||||||
|
|
|
@ -838,6 +838,12 @@ whole pages to be written to AVR flash memory at once, resulting in a
|
||||||
significant write speed increase. If use of this mode is not desirable for some
|
significant write speed increase. If use of this mode is not desirable for some
|
||||||
reason, this option disables it.
|
reason, this option disables it.
|
||||||
|
|
||||||
|
@item @samp{nopagedread}
|
||||||
|
Newer firmware versions support in binary mode SPI command some AVR Extended
|
||||||
|
Commands. Using the ``Bulk Memory Read from Flash'' results in a
|
||||||
|
significant read speed increase. If use of this mode is not desirable for some
|
||||||
|
reason, this option disables it.
|
||||||
|
|
||||||
@item @samp{cpufreq=@var{125..4000}}
|
@item @samp{cpufreq=@var{125..4000}}
|
||||||
This sets the @emph{AUX} pin to output a frequency of @var{n} kHz. Connecting
|
This sets the @emph{AUX} pin to output a frequency of @var{n} kHz. Connecting
|
||||||
the @emph{AUX} pin to the XTAL1 pin of your MCU, you can provide it a clock,
|
the @emph{AUX} pin to the XTAL1 pin of your MCU, you can provide it a clock,
|
||||||
|
|
Loading…
Reference in New Issue