This patch has been contributed by an anonymous developer
via the patch tracking system. patch #5096: Allow VCC and BUFF to be any pin in parallel mode * config_gram.y: Release the restriction to PPIDATA pins. * par.c: Rework the code to introduce a function par_setmany() that builds on top of par_setpin(), and use that function for the PPI_AVR_VCC and PPI_AVR_BUFF pin collections. This also abstracts the polarity of these signals appropriately. git-svn-id: svn://svn.savannah.nongnu.org/avrdude/trunk@628 81a1dc3b-b13d-400b-aceb-764788c761c2
This commit is contained in:
parent
8a833f921e
commit
9473243b2c
|
@ -1,3 +1,14 @@
|
||||||
|
2006-08-29 Joerg Wunsch <j@uriah.heep.sax.de>
|
||||||
|
|
||||||
|
This patch has been contributed by an anonymous developer
|
||||||
|
via the patch tracking system.
|
||||||
|
patch #5096: Allow VCC and BUFF to be any pin in parallel mode
|
||||||
|
* config_gram.y: Release the restriction to PPIDATA pins.
|
||||||
|
* par.c: Rework the code to introduce a function par_setmany()
|
||||||
|
that builds on top of par_setpin(), and use that function for the
|
||||||
|
PPI_AVR_VCC and PPI_AVR_BUFF pin collections. This also abstracts
|
||||||
|
the polarity of these signals appropriately.
|
||||||
|
|
||||||
2006-08-28 Joerg Wunsch <j@uriah.heep.sax.de>
|
2006-08-28 Joerg Wunsch <j@uriah.heep.sax.de>
|
||||||
|
|
||||||
Contributed by Ned Konz:
|
Contributed by Ned Konz:
|
||||||
|
|
|
@ -430,15 +430,7 @@ prog_parm :
|
||||||
while (lsize(number_list)) {
|
while (lsize(number_list)) {
|
||||||
t = lrmv_n(number_list, 1);
|
t = lrmv_n(number_list, 1);
|
||||||
pin = t->value.number;
|
pin = t->value.number;
|
||||||
if ((pin < 2) || (pin > 9)) {
|
current_prog->pinno[PPI_AVR_VCC] |= (1 << pin);
|
||||||
fprintf(stderr,
|
|
||||||
"%s: error at line %d of %s: VCC must be one or more "
|
|
||||||
"pins from the range 2-9\n",
|
|
||||||
progname, lineno, infile);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
current_prog->pinno[PPI_AVR_VCC] |= (1 << (pin-2));
|
|
||||||
|
|
||||||
free_token(t);
|
free_token(t);
|
||||||
}
|
}
|
||||||
|
@ -455,15 +447,7 @@ prog_parm :
|
||||||
while (lsize(number_list)) {
|
while (lsize(number_list)) {
|
||||||
t = lrmv_n(number_list, 1);
|
t = lrmv_n(number_list, 1);
|
||||||
pin = t->value.number;
|
pin = t->value.number;
|
||||||
if ((pin < 2) || (pin > 9)) {
|
current_prog->pinno[PPI_AVR_BUFF] |= (1 << pin);
|
||||||
fprintf(stderr,
|
|
||||||
"%s: error at line %d of %s: BUFF must be one or more "
|
|
||||||
"pins from the range 2-9\n",
|
|
||||||
progname, lineno, infile);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
current_prog->pinno[PPI_AVR_BUFF] |= (1 << (pin-2));
|
|
||||||
|
|
||||||
free_token(t);
|
free_token(t);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/*
|
/*
|
||||||
* avrdude - A Downloader/Uploader for AVR device programmers
|
* avrdude - A Downloader/Uploader for AVR device programmers
|
||||||
* Copyright (C) 2000-2004 Brian S. Dean <bsd@bsdhome.com>
|
* Copyright (C) 2000-2006 Brian S. Dean <bsd@bsdhome.com>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
@ -55,7 +55,7 @@ struct ppipins_t {
|
||||||
int inverted;
|
int inverted;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct ppipins_t ppipins[] = {
|
static struct ppipins_t ppipins[] = {
|
||||||
{ 1, PPICTRL, 0x01, 1 },
|
{ 1, PPICTRL, 0x01, 1 },
|
||||||
{ 2, PPIDATA, 0x01, 0 },
|
{ 2, PPIDATA, 0x01, 0 },
|
||||||
{ 3, PPIDATA, 0x02, 0 },
|
{ 3, PPIDATA, 0x02, 0 },
|
||||||
|
@ -106,6 +106,15 @@ static int par_setpin(PROGRAMMER * pgm, int pin, int value)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void par_setmany(PROGRAMMER * pgm, unsigned int pinset, int value)
|
||||||
|
{
|
||||||
|
int pin;
|
||||||
|
|
||||||
|
for (pin = 1; pin <= 17; pin++) {
|
||||||
|
if (pinset & (1 << pin))
|
||||||
|
par_setpin(pgm, pin, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static int par_getpin(PROGRAMMER * pgm, int pin)
|
static int par_getpin(PROGRAMMER * pgm, int pin)
|
||||||
{
|
{
|
||||||
|
@ -171,7 +180,7 @@ static int par_highpulsepin(PROGRAMMER * pgm, int pin)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int par_getpinmask(int pin)
|
static int par_getpinmask(int pin)
|
||||||
{
|
{
|
||||||
pin &= PIN_MASK;
|
pin &= PIN_MASK;
|
||||||
|
|
||||||
|
@ -182,27 +191,23 @@ int par_getpinmask(int pin)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
char vccpins_buf[64];
|
static char * pins_to_str(unsigned int pmask)
|
||||||
static char * vccpins_str(unsigned int pmask)
|
|
||||||
{
|
{
|
||||||
unsigned int mask;
|
static char buf[64];
|
||||||
int pin;
|
int pin;
|
||||||
char b2[8];
|
char b2[8];
|
||||||
char * b;
|
|
||||||
|
|
||||||
b = vccpins_buf;
|
buf[0] = 0;
|
||||||
|
for (pin = 1; pin <= 17; pin++) {
|
||||||
b[0] = 0;
|
if (pmask & (1 << pin)) {
|
||||||
for (pin = 2, mask = 1; mask < 0x80; mask = mask << 1, pin++) {
|
|
||||||
if (pmask & mask) {
|
|
||||||
sprintf(b2, "%d", pin);
|
sprintf(b2, "%d", pin);
|
||||||
if (b[0] != 0)
|
if (buf[0] != 0)
|
||||||
strcat(b, ",");
|
strcat(buf, ",");
|
||||||
strcat(b, b2);
|
strcat(buf, b2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return b;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -210,7 +215,7 @@ static char * vccpins_str(unsigned int pmask)
|
||||||
*/
|
*/
|
||||||
static void par_powerup(PROGRAMMER * pgm)
|
static void par_powerup(PROGRAMMER * pgm)
|
||||||
{
|
{
|
||||||
ppi_set(pgm->fd, PPIDATA, pgm->pinno[PPI_AVR_VCC]); /* power up */
|
par_setmany(pgm, pgm->pinno[PPI_AVR_VCC], 1); /* power up */
|
||||||
usleep(100000);
|
usleep(100000);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -220,12 +225,12 @@ static void par_powerup(PROGRAMMER * pgm)
|
||||||
*/
|
*/
|
||||||
static void par_powerdown(PROGRAMMER * pgm)
|
static void par_powerdown(PROGRAMMER * pgm)
|
||||||
{
|
{
|
||||||
ppi_clr(pgm->fd, PPIDATA, pgm->pinno[PPI_AVR_VCC]); /* power down */
|
par_setmany(pgm, pgm->pinno[PPI_AVR_VCC], 0); /* power down */
|
||||||
}
|
}
|
||||||
|
|
||||||
static void par_disable(PROGRAMMER * pgm)
|
static void par_disable(PROGRAMMER * pgm)
|
||||||
{
|
{
|
||||||
ppi_set(pgm->fd, PPIDATA, pgm->pinno[PPI_AVR_BUFF]);
|
par_setmany(pgm, pgm->pinno[PPI_AVR_BUFF], 1); /* turn off */
|
||||||
}
|
}
|
||||||
|
|
||||||
static void par_enable(PROGRAMMER * pgm)
|
static void par_enable(PROGRAMMER * pgm)
|
||||||
|
@ -247,7 +252,7 @@ static void par_enable(PROGRAMMER * pgm)
|
||||||
/*
|
/*
|
||||||
* enable the 74367 buffer, if connected; this signal is active low
|
* enable the 74367 buffer, if connected; this signal is active low
|
||||||
*/
|
*/
|
||||||
ppi_clr(pgm->fd, PPIDATA, pgm->pinno[PPI_AVR_BUFF]);
|
par_setmany(pgm, pgm->pinno[PPI_AVR_BUFF], 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int par_open(PROGRAMMER * pgm, char * port)
|
static int par_open(PROGRAMMER * pgm, char * port)
|
||||||
|
@ -304,24 +309,24 @@ static void par_display(PROGRAMMER * pgm, char * p)
|
||||||
char buffpins[64];
|
char buffpins[64];
|
||||||
|
|
||||||
if (pgm->pinno[PPI_AVR_VCC]) {
|
if (pgm->pinno[PPI_AVR_VCC]) {
|
||||||
snprintf(vccpins, sizeof(vccpins), " = pins %s",
|
snprintf(vccpins, sizeof(vccpins), "%s",
|
||||||
vccpins_str(pgm->pinno[PPI_AVR_VCC]));
|
pins_to_str(pgm->pinno[PPI_AVR_VCC]));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
strcpy(vccpins, " (not used)");
|
strcpy(vccpins, " (not used)");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pgm->pinno[PPI_AVR_BUFF]) {
|
if (pgm->pinno[PPI_AVR_BUFF]) {
|
||||||
snprintf(buffpins, sizeof(buffpins), " = pins %s",
|
snprintf(buffpins, sizeof(buffpins), "%s",
|
||||||
vccpins_str(pgm->pinno[PPI_AVR_BUFF]));
|
pins_to_str(pgm->pinno[PPI_AVR_BUFF]));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
strcpy(buffpins, " (not used)");
|
strcpy(buffpins, " (not used)");
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"%s VCC = 0x%02x%s\n"
|
"%s VCC = %s\n"
|
||||||
"%s BUFF = 0x%02x%s\n"
|
"%s BUFF = %s\n"
|
||||||
"%s RESET = %d\n"
|
"%s RESET = %d\n"
|
||||||
"%s SCK = %d\n"
|
"%s SCK = %d\n"
|
||||||
"%s MOSI = %d\n"
|
"%s MOSI = %d\n"
|
||||||
|
@ -331,8 +336,8 @@ static void par_display(PROGRAMMER * pgm, char * p)
|
||||||
"%s PGM LED = %d\n"
|
"%s PGM LED = %d\n"
|
||||||
"%s VFY LED = %d\n",
|
"%s VFY LED = %d\n",
|
||||||
|
|
||||||
p, pgm->pinno[PPI_AVR_VCC], vccpins,
|
p, vccpins,
|
||||||
p, pgm->pinno[PPI_AVR_BUFF], buffpins,
|
p, buffpins,
|
||||||
p, pgm->pinno[PIN_AVR_RESET],
|
p, pgm->pinno[PIN_AVR_RESET],
|
||||||
p, pgm->pinno[PIN_AVR_SCK],
|
p, pgm->pinno[PIN_AVR_SCK],
|
||||||
p, pgm->pinno[PIN_AVR_MOSI],
|
p, pgm->pinno[PIN_AVR_MOSI],
|
||||||
|
|
Loading…
Reference in New Issue