Submitted by Juergen Weigert:

patch #7056: adding support for mikrokopter bootloader to butterfly
* butterfly.c: Add some specific logic to handle the
mikrokopter.de butterfly bootloader.
* butterfly.h: Add one related function declaration.
* config_gram.y: Add butterfly_mk keyword.
* lexer.l: (Ditto.)
* avrdude.conf.in: Add entry for butterfly_mk.




git-svn-id: svn://svn.savannah.nongnu.org/avrdude/trunk@991 81a1dc3b-b13d-400b-aceb-764788c761c2
This commit is contained in:
Joerg Wunsch 2011-08-26 20:50:32 +00:00
parent 61e52e318d
commit 9afb392045
7 changed files with 98 additions and 18 deletions

View File

@ -1,3 +1,14 @@
2011-08-26 Joerg Wunsch <j.gnu@uriah.heep.sax.de>
Submitted by Juergen Weigert:
patch #7056: adding support for mikrokopter bootloader to butterfly
* butterfly.c: Add some specific logic to handle the
mikrokopter.de butterfly bootloader.
* butterfly.h: Add one related function declaration.
* config_gram.y: Add butterfly_mk keyword.
* lexer.l: (Ditto.)
* avrdude.conf.in: Add entry for butterfly_mk.
2011-08-26 Joerg Wunsch <j.gnu@uriah.heep.sax.de> 2011-08-26 Joerg Wunsch <j.gnu@uriah.heep.sax.de>
Submitted by Stefan Tomanek: Submitted by Stefan Tomanek:

View File

@ -17,6 +17,7 @@ Current:
and parallel ones) and parallel ones)
- FT2232 (and relatives) based programmers (MPSSE bitbang mode) - FT2232 (and relatives) based programmers (MPSSE bitbang mode)
- Wiring environment (http://wiring.org.co/) - Wiring environment (http://wiring.org.co/)
- butterfly-style bootloader of the Mikrokopter.de device
* Bugfixes * Bugfixes

View File

@ -552,6 +552,19 @@ programmer
type = butterfly; type = butterfly;
; ;
# suggested in http://forum.mikrokopter.de/topic-post48317.html
programmer
id = "mkbutterfly";
desc = "Mikrokopter.de Butterfly";
type = butterfly_mk;
;
programmer
id = "butterfly_mk";
desc = "Mikrokopter.de Butterfly";
type = butterfly_mk;
;
programmer programmer
id = "jtagmkI"; id = "jtagmkI";
desc = "Atmel JTAG ICE (mkI)"; desc = "Atmel JTAG ICE (mkI)";

View File

@ -43,6 +43,7 @@
#include <string.h> #include <string.h>
#include <errno.h> #include <errno.h>
#include <ctype.h> #include <ctype.h>
#include <unistd.h>
#include "avrdude.h" #include "avrdude.h"
#include "avr.h" #include "avr.h"
@ -205,6 +206,7 @@ static void butterfly_powerdown(PROGRAMMER * pgm)
return; return;
} }
#define IS_BUTTERFLY_MK 0x0001
/* /*
* initialize the AVR device and prepare it to accept commands * initialize the AVR device and prepare it to accept commands
@ -223,6 +225,39 @@ static int butterfly_initialize(PROGRAMMER * pgm, AVRPART * p)
* for plain avr109 bootloaders but does not harm there either. * for plain avr109 bootloaders but does not harm there either.
*/ */
fprintf(stderr, "Connecting to programmer: "); fprintf(stderr, "Connecting to programmer: ");
if (pgm->flag & IS_BUTTERFLY_MK)
{
char mk_reset_cmd[6] = {"#aR@S\r"};
unsigned char mk_timeout = 0;
putc('.', stderr);
butterfly_send(pgm, mk_reset_cmd, sizeof(mk_reset_cmd));
usleep(20000);
do
{
c = 27;
butterfly_send(pgm, &c, 1);
usleep(20000);
c = 0xaa;
usleep(80000);
butterfly_send(pgm, &c, 1);
if (mk_timeout % 10 == 0) putc('.', stderr);
} while (mk_timeout++ < 10);
butterfly_recv(pgm, &c, 1);
if ( c != 'M' && c != '?')
{
fprintf(stderr, "\nConnection FAILED.");
exit(1);
}
else
{
id[0] = 'M'; id[1] = 'K'; id[2] = '2'; id[3] = 0;
}
}
else
{
do { do {
putc('.', stderr); putc('.', stderr);
butterfly_send(pgm, "\033", 1); butterfly_send(pgm, "\033", 1);
@ -241,8 +276,10 @@ static int butterfly_initialize(PROGRAMMER * pgm, AVRPART * p)
id[sizeof(id)-1] = '\0'; id[sizeof(id)-1] = '\0';
} }
} while (c == '?'); } while (c == '?');
}
/* Get the HW and SW versions to see if the programmer is present. */ /* Get the HW and SW versions to see if the programmer is present. */
butterfly_drain(pgm, 0);
butterfly_send(pgm, "V", 1); butterfly_send(pgm, "V", 1);
butterfly_recv(pgm, sw, sizeof(sw)); butterfly_recv(pgm, sw, sizeof(sw));
@ -327,6 +364,7 @@ static int butterfly_initialize(PROGRAMMER * pgm, AVRPART * p)
progname, (unsigned)buf[1]); progname, (unsigned)buf[1]);
butterfly_enter_prog_mode(pgm); butterfly_enter_prog_mode(pgm);
butterfly_drain(pgm, 0);
return 0; return 0;
} }
@ -665,7 +703,7 @@ static int butterfly_read_sig_bytes(PROGRAMMER * pgm, AVRPART * p, AVRMEM * m)
void butterfly_initpgm(PROGRAMMER * pgm) void butterfly_initpgm(PROGRAMMER * pgm)
{ {
strcpy(pgm->type, "avr910"); strcpy(pgm->type, "butterfly");
/* /*
* mandatory functions * mandatory functions
@ -698,4 +736,12 @@ void butterfly_initpgm(PROGRAMMER * pgm)
pgm->setup = butterfly_setup; pgm->setup = butterfly_setup;
pgm->teardown = butterfly_teardown; pgm->teardown = butterfly_teardown;
pgm->flag = 0;
}
void butterfly_mk_initpgm(PROGRAMMER * pgm)
{
butterfly_initpgm(pgm);
strcpy(pgm->type, "butterfly_mk");
pgm->flag = IS_BUTTERFLY_MK;
} }

View File

@ -27,6 +27,7 @@ extern "C" {
#endif #endif
void butterfly_initpgm (PROGRAMMER * pgm); void butterfly_initpgm (PROGRAMMER * pgm);
void butterfly_mk_initpgm (PROGRAMMER * pgm);
#ifdef __cplusplus #ifdef __cplusplus
} }

View File

@ -161,6 +161,7 @@ static int parse_cmdbits(OPCODE * op);
%token K_USBVENDOR %token K_USBVENDOR
%token K_USBVID %token K_USBVID
%token K_BUTTERFLY %token K_BUTTERFLY
%token K_BUTTERFLY_MK
%token K_TYPE %token K_TYPE
%token K_VCC %token K_VCC
%token K_VFYLED %token K_VFYLED
@ -508,6 +509,12 @@ prog_parm :
} }
} | } |
K_TYPE TKN_EQUAL K_BUTTERFLY_MK {
{
butterfly_mk_initpgm(current_prog);
}
} |
K_TYPE TKN_EQUAL K_JTAG_MKI { K_TYPE TKN_EQUAL K_JTAG_MKI {
{ {
jtagmkI_initpgm(current_prog); jtagmkI_initpgm(current_prog);

View File

@ -130,6 +130,7 @@ bs2 { yylval=NULL; return K_BS2; }
buff { yylval=NULL; return K_BUFF; } buff { yylval=NULL; return K_BUFF; }
buspirate { yylval=NULL; return K_BUSPIRATE; } buspirate { yylval=NULL; return K_BUSPIRATE; }
butterfly { yylval=NULL; return K_BUTTERFLY; } butterfly { yylval=NULL; return K_BUTTERFLY; }
butterfly_mk { yylval=NULL; return K_BUTTERFLY_MK; }
chip_erase_delay { yylval=NULL; return K_CHIP_ERASE_DELAY; } chip_erase_delay { yylval=NULL; return K_CHIP_ERASE_DELAY; }
desc { yylval=NULL; return K_DESC; } desc { yylval=NULL; return K_DESC; }
default_parallel { yylval=NULL; return K_DEFAULT_PARALLEL; } default_parallel { yylval=NULL; return K_DEFAULT_PARALLEL; }