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:
Joerg Wunsch 2006-08-29 21:39:26 +00:00
parent 8a833f921e
commit 9473243b2c
3 changed files with 46 additions and 46 deletions

View File

@ -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:

View File

@ -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);
} }

View File

@ -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],