programmare il 644 ... ma come????

Il bootloader lo devi caricare in ogni caso come giá ti é stato suggerito. Poi, per caricare gli sketch, non devi dimenticarti di mettere una resistenza di pull-up di 10k tra i 5V ed il pin di Reset del 644 (credo debba essere il pin 9) oltre al condensatore, in serie, tra il pin di reset e quello del programmatore (Arduino, oppure convertiore usb/seriale). Per il valore del condensatore prova pure quello da 1uf

Nel pacchetto che ho preparato c'è anche uno schema di collegamento. Vale anche per il 644, l'unica cosa che forse a te non serve è il circuito sulle linee RX/TX se usi il 644 perché quel filtro RC è stato aggiunto per un bug hardware che affligge alcuni lotti di 1284).

Per poterlo programmare via seriale ti serve flashare il bootloader ma prima di fare questa operazione, accertati di riuscire a comunicare con il micro. Senza bootloader, col tuo convertitore è normale che tu non riesca a comunicare via seriale con il 644.

Quindi io preparerei intanto un 644 standalone su una breadboard e ci flasherei sopra il bootloader tramite ISP: connetti i pin 10/11/12/13 di un Arduino UNO (con lo sketch ArduinoISP) rispettivamente ai piedini fisici 9/6/7/8, poi aggiungi ovviamente 5V e GND.
Aprendo l'IDE devi avere la voce "Amtega644 @ 16 MHz w/bootloader". Selezioni questa e poi dai "scrivi bootloader".
Se tutto è andato per il meglio puoi adesso usare il tuo convertitore.

x iscrizione.

.. allora... innanzitutto grazie per i vostri suggerimenti ...

... prima ho caricato sull'arduino da usare come programmatore lo sketc arduinoISP...

... ho eseguito le istruzoini di leo... ho scaricato il suo file.zip .. questo: 644P/1284P core for Arduino 1.0.2
. l'ho installato nella cartella hardware\arduino.. dell'IDE .. come da istruzioni...
ho copiato il contenuto del file new_entrie_for_boards .. nel file boards ...
.. sull'IDE ho seloezionato la board giusta ... (644 a 16 mhz.. for bootloader)..

ho attivato il trasferimento del bootloader .. i led TX, RX ed il led 9 hanno lampeggiato per quasi un minuto... nessun messaggio d'errore, ma solo il messaggio di avvenuto trasferimento del bootloader ...
... quindi ne deduco che il bbotloader sia stato caricato ....

adesso provo a tresferire uno skech ...
carico nell'IDE l'esempio blink... per fare lampegguare il pin 13

seleziono nell'IDE strumenti/tipo di arduino/la board 644 ISP ... (non bootloader)
selezione nell'IDE strumenti/programmatore/arduinoISP
attivo il tarsferimento del file con il pulsante "carica" e mi da errore (non posso scrivere qui il messaggio di errore perchè non ho la pennina dove ho memorizzato il tutto)...

dal menu file do il comando "carica con un programmatore" ....
apparentemente non mi da errore... cè il lampeggio dei led tx rx e il messaggio positivo a fine trasferimento

ma non funziona nulla
il primo problema e che non so la corrispondenza dei pin nel 644 .. li ho provati tutti ... ma niente...

le domande sono queste:
.. in linea di principio vi pare che il procedimento che sto seguendo sia quello giusto??
.. siccome uso l'IDE 1.0.1 .. può essere questo il problema?
.. come faccio a identificare i PIN nel 644??? .. ho guardato il datasheet e non trovo la corrispondenza tra A0, A1, A7 etc.. o i PIN 1,2,.. 10, 13 .. etc.. ho solo capito come sono raggrupati come PORTA, PORTC, PORTD etc....

suggerimenti idee??...

chiedo scusa se sono stato poco preciso ma sono in una pausa lavoro e non ho con me pennina con i risultati delle prove fatte ieri sera.. grazie
ciao

La corrispondenza dei pin la trovi nel file PINS_ARDUINO.H che risiede nella cartella

POSIZIONE DOVE HAI ARDUINO IDE\hardware\CARTELLA DEL CORE CHE HAI SCARICATO DA LEO\variants\VARIANTE CHE STAI UTILIZZANDO

Dove

POSIZIONE DOVE HAI ARDUINO IDE = percorso completo dove hai installato arduino (es. c:\arduino-1.0.1)
VARIANTE CHE STAI UTILIZZANDO = la reperisci aprendo il file BOARDS.TXT presente in POSIZIONE DOVE HAI ARDUINO IDE\hardware\CARTELLA DEL CORE CHE HAI SCARICATO DA LEO, leggendo l'impostazione .build.variant della scheda che hai selezionato)

ES. (nel mio caso uso una scheda che nel menù di arduino si trova con il nome di 'Mighty 1284p 16MHz using Optiboot')

mighty_opt.name=Mighty 1284p 16MHz using Optiboot
....
....
....
mighty_opt.build.core=standard
mighty_opt.build.variant=standard

In questo caso la board in oggetto avrà il suo file PINS_ARDUINO.H in

es.
c:\arduino-1.0.1\hardware\CARTELLA DEL CORE CHE STo UTILIZZANDO\variants\standard

All'interno di detto file ti troverai una parte di codice dove verranno mappati i pin del micro alle porte specifiche della mcu e il relativo bit .
In alcuni file vi è anche una tabella di corrispondenza,nel tuo dovrebbe esserci una cosa di questo tipo:

//                         ATMEL ATMEGA644P/1284P
//
//                               +---\/---+
//            PCINT8/(D0 ) PB0  1|        |40  PA0 (A0 / D24)/PCINT0
//            PCINT9/(D1 ) PB1  2|        |39  PA1 (A1 / D25)/PCINT1
//      PCINT10/INT2 (D2 ) PB2  3|        |38  PA2 (A2 / D26)/PCINT2
//      PCINT11/OC0A (D3 ) PB3  4|~       |37  PA3 (A3 / D27)/PCINT3
//   PCINT12/0C0B/SS (D4 ) PB4  5|~       |36  PA4 (A4 / D28)/PCINT4
//      PCINT13/MOSI (D5 ) PB5  6|        |35  PA5 (A5 / D29)/PCINT5
// PCINT14/OC3A/MISO (D6 ) PB6  7|~*      |34  PA6 (A6 / D30)/PCINT6
//  PCINT15/OC3B/SCK (D7 ) PB7  8|~*      |33  PA7 (A7 / D31)/PCINT7
//                         RST  9|        |32  AREF
//                         VCC 10|        |31  GND 
//                         GND 11|        |30  AVCC
//                       XTAL2 12|        |29  PC7 (D23) TOSC2/PCINT23
//                       XTAL1 13|        |28  PC6 (D22) TOSC1/PCINT22
//       PCINT24/RX0 (D8 ) PD0 14|        |27  PC5 (D21) TDI/PCINT21
//       PCINT25/TX0 (D9 ) PD1 15|        |26  PC4 (D20) TDO/PCINT20
//  PCINT26/INT0/RX1 (D10) PD2 16|        |25  PC3 (D19) TMS/PCINT19
//  PCINT27/INT1/TX1 (D11) PD3 17|        |24  PC2 (D18) TCK/PCINT18
//      PCINT28/OC1B (D12) PD4 18|~       |23  PC1 (D17) SDA/PCINT17
//      PCINT29/OC1A (D13) PD5 19|~       |22  PC0 (D16) SCL/PCINT16
//      PCINT30/OC2B (D14) PD6 20|~      ~|21  PD7 (D15) OC2A/PCINT31
//                               +--------+
//
// *: OC3A/OC3B (and corresponding PWMs) are only present on Atmega1284

Tra parentesi tonde come vedi c'è il pin numerazione arduino corrispondente (D13 = digital 13, A1 = analog1)

Buon lavoro.

grazie niki .. utilissimo ......

per le prime due domande??? .. suggerimenti?????

eppoi ho ancora un'altro dubbio: ... ma quindi con la tecnica ISP si può programmare qyualsiasi microcntrollore senza che ci sia il bootloader?.... dove trovo altre informazoni al riguardo?

Dalla guida di Michele --> http://www.michelemenniti.it/vhd/Elettronica/GPAT_v4.pdf :grin:
D'altronde si chiama "Guida alle tecniche di programmazione dei microcontrollori ATMEL" e non "Guida alla programmazione di ARDUINO". ]:slight_smile:

@Paolo:
il procedimento è giusto, varia comunque in base a come vuoi usare il microcontrollore. Se metti un chip in standalone normalmente il bootloader non si usa, perché con la tecnica ISP puoi programmarlo direttamente, senza bootloader. Info le trovi nella guida del Menniti, è stata scritta inizialmente per programmare un Atmega328 ma i principi valgono per tutti i micro. L'idea di base è quella di usare lo sketch Arduino ISP come emulatore di un programmatore e collegare i pin D10/D11/D12/D13 dell'Arduino programmatore alle linee RESET/MOSI/MISO/SCK del chip di destinazione. MOSI/MISO/SCK sono le 3 linee della comunicazione SPI e le trovi nel datasheet, variano come corrispondenza da micro a micro.

Attenzione ad una cosa: se stai usando l'IDE 1.0.1 devi usare il pacchetto 644_1284 in versione 1.0.1! La versione 1.0.2 è per l'IDE 1.0.2 (e 1.0.3). Sono diversi perché nell'IDE 1.0.1 il supporto per il 644/1284 era incompleto e dovevano essere sostituiti 3 file del core dell'IDE.

Grazie PaoloP e Leo...

.... forse sbaglio, anzi probabilmente sbaglio... ma on mi piace l'idea di avere empre affianco un altro arduino da usare come programmatore...anche perchè il 644 deve lavorare in comunicazione con un altro 328 fa da web server,..... nella mia idea io volevo riservare nella breadboard i pin per la programmazione tramite l'emulatore USB Seriale che ho linkato nel primo post..

.. invece mi interessa la programmazione senza il boot loader direttamemnte dalla porta seriale del pc (o dall'emulatore USB-Seriale) ... ma nella guida di menniti (che ho guardato, anche se superficialmente) nonc'è nessun riferimento all'utilizzo della porta seriale direttamete dal pc e la connessione al microcontrollore ......

comunque adesso me la stampo a colori e stasera me la leggo bene....

Grazie ...

altri suggerimenti???? ... qualche link dove si tratta di questo argomento?

Non è possibile.
Il bootloader è un programma che permette di riprogrammare il microcontrollore dalla porta seriale. Senza bootloader niente programmazione seriale.
A questo punto ti conviene lascialo.

Ti consiglio comunque di prevedere il collegamento ai pin SPI per una programmazione di emergenza.
Se non vuoi usare un Arduino puoi usare un programmatore esterno ISP. C'è ne sono diversi in giro.

Non puoi programmare via serial un chip senza bootloader.
Il bootloader è un particolare programma scritto dal team di Arduino che all'avvio del microcontrollore controlla appunto se sulla seriale sta arrivando un nuovo sketch. Se arriva, lo legge e contemporaneamente lo scrive sulla Flash. Se non c'è nulla, avvia il programma già presente. In questo caso ti serve un convertitore USB/seriale.

Senza bootloader l'unico modo per scrivere il nuovo sketch è appunto la programmazione ISP, che usa la comunicazione SPI del micro. Quindi ti serve o un programmatore o un Arduino che lo emuli.

ok..
allora per la programmazione via seriale, con il mio emulatore USB, devo metterci il bootloadr..e credo che farò così....
.. le indicazioni le trovo nella guida di menniti? ... la tecnica seriale.. mi pare che sia stata chiamata così..!!! .. questa è valida anche per il 644??? come si utilizza?? ... perchè menniti parla del 328 ... mi pare ....

invece la programmazoine ISP è anch'essa trattata da menniti ma per il 328.. dove prende i collegamenti dal connettore ISP... ma come faccio sul 644 standalone????

[quote author=Paolo S link=topic=136740.msg1029964#msg1029964 date=1355316762]
invece la programmazoine ISP è anch'essa trattata da menniti ma per il 328.. dove prende i collegamenti dal connettore ISP... ma come faccio sul 644 standalone????[/quote]

leo72:
@Paolo:
il procedimento è giusto, varia comunque in base a come vuoi usare il microcontrollore. Se metti un chip in standalone normalmente il bootloader non si usa, perché con la tecnica ISP puoi programmarlo direttamente, senza bootloader. Info le trovi nella guida del Menniti, è stata scritta inizialmente per programmare un Atmega328 ma i principi valgono per tutti i micro. L'idea di base è quella di usare lo sketch Arduino ISP come emulatore di un programmatore e collegare i pin D10/D11/D12/D13 dell'Arduino programmatore alle linee RESET/MOSI/MISO/SCK del chip di destinazione. MOSI/MISO/SCK sono le 3 linee della comunicazione SPI e le trovi nel datasheet, variano come corrispondenza da micro a micro.

Attenzione ad una cosa: se stai usando l'IDE 1.0.1 devi usare il pacchetto 644_1284 in versione 1.0.1! La versione 1.0.2 è per l'IDE 1.0.2 (e 1.0.3). Sono diversi perché nell'IDE 1.0.1 il supporto per il 644/1284 era incompleto e dovevano essere sostituiti 3 file del core dell'IDE.

Il ragazzo non legge con attenzione e non si applica. ]:smiley: ]:smiley: ]:smiley:

Datasheet
644A e 644PA --> http://www.atmel.com/Images/doc8272.pdf
644P/V --> http://www.atmel.com/Images/8011S.pdf
644/V --> http://www.atmel.com/Images/doc2593.pdf
Quale hai?

hai ragione ... omonimo!!!!
.. chiedo scusa.

Ho capito che per la programmazione ISP devo usare RESET/MOSI/MISO/SCK del microcontrollare e fin qui ci siamo. Ma se non voglio usare arduino per emulare la seriale ,se volessi usare una seriale vera e propria, la corrisopndenza dei pin della seriale DB9 che mi occorrono li trovo nella guida di menniti?

Stasera riproverò... per i 644 credo di avere i PA.... ma dovrei verificare stasera ...
ciao

Tra 644, 644V, 644P e 644PA a livello di piedinatura non cambia quasi nulla.
I modelli "non P" non hanno il core PicoPower per cui non gestiscono il risparmio energetico in maniera ottimale. Sono da sconsigliare per progetti standalone dove vuoi mettere in sleep il micro.
Il modello "V" è una vecchia serie che reggeva una tensione di alimentazione minima di 1,8V: per contro il clock era max di 10 MHz.
Il modello "A" è una revisione del core che permette di lavorare a 1,8V minimi mantenendo un core capace di lavorare max a 20 MHz. Nell'acquisto, quindi, scegliere sempre il modello "644PA" possibilmente, che oltretutto costa anche meno dei precedenti 644V e 644P integrando le cose buone di entrambi.

@ Paolo S: come ti hanno spiegato io ho scritto la Guida basandomi sul 328P, i principi sono identici, quindi per la programmazione ISP devi "localizzare" sul modello di 644 che usi i segnali MISO, MOSI, SCK, RESET e poi collegare in parallelo le alimentazioni, nel senso che 5V e GND il 644 li deve prendere (per comodità, ma il GND sarebbe comunque obbligatorio) dall'Arduino. Per la programmazione seriale, una volta che hai caricato il bootloader sul 644, puoi continuare ad usare Arduino, sempre in base a come scritto nella Guida, senza necessariamente comprare un Convertitore, se non lo hai già. Anche in questo caso devi localizzare i pin TX/RX/RESET, ma il 644 ha più seriali, immagino che il core si riferisca alla prima, al massimo vai a tentativi.

@ Leo: non ho controllato ma penso che il 644 possa lavorare a 1,8V e 20MHz, ma NON contemporaneamente, se lo alimenti a 1,8V hai comunque una limitazione del clock massimo.

Do per scontato che quando scrivo che può lavorare a 1,8V lo intendo non certamente a 20 MHz. Sono da rispettare le tabelle nel datasheet.
Poi, come detto, il "644" è una cosa, questo chip effettivamente esiste. Ma è a 2,7V e 20 MHz. Poi c'è il 644V, a 1,8V di tensione minima ma solo 10 MHz di tensione massima (ovviamente innalzando la tensione).
In questa pagina:
http://atmel.com/devices/ATMEGA644.aspx
ci sono tensione minima e clock massimo per i 644 e 644V. Il 644 è dato per 2,7V/20 MHz mentre il 644V per 1,8V/10 MHz.

Qui il 644A:
http://atmel.com/devices/ATMEGA644A.aspx
come vedi, 20 MHz e 1,8V

Qui invece il 644P/V
http://atmel.com/devices/ATMEGA644P.aspx
Il 644P va a 2,7V/20 MHz mentre il 644PV va a 1,8V/10 MHz. Entrambi con core PicoPower

E qui il 644PA:
http://atmel.com/devices/ATMEGA644PA.aspx
1,8V/20 MHz con core PicoPower

cari leo e menniti...

ok... credo di avere capito come procedere con la programmazione ISP...

... in effetti ieri ci sono risucito a riprogrammare il 644 usando questa configurazione

che dovrebbe essere questa tecnica ISP. Ok.. funziona e sto gia "migrando" il codice dal 328 al 644 ....

Ho provato anche la programmazione seriale (sui primi tx e rx), presa dal manuale Menniti .... ma non sono riuscito.... puo darsi che magari non fosse andata a buon fine la scrittura del bootloader e quindi non abbia funzionato per questo.... stasera riproverò....

Per quanto riguarda la programmazine seriale non posso (e non voglio) usare un altro arduino ma preferisco lasciare sulla board i pin su cui inserire il convertitore USB - seriale che ho comprato.

... quindi se la programmazione seriale non ha funzionato i motivi potrebbere due:

  • o il bootloader non è stato caricato bene .. (anche se il messaggio di fine trasferimento confermava il buon esito!!!)
  • non ho usato la giusta copia di rx - tx sul 644

quindi la domande sono:

  • è giusto quanto sopra, sulle possibili cause del malfunzionamento?
  • esiste un metodo certo per verificare la presenza del bootloader nel micro?

ed ancora

  • i pin utilizzati per l'ISP (MISO, MOSI, SCK) .. opsso comunque utilizzarli, durante il normale funzionamento , come pin di OUT/IN ???

... comunque confermo che il 644 sta funzionando regolarmente programmato con l'ISP, con il 30 % di script già "tradotto" per il 644 .. e sono già soddisfatto ....
saluti

Bene, bene, partiamo dalla programmazione seriale, i collegamenti da fare sono: (premesso che il 644 deve essere configurato con quarzo e condensatori e R da 10K tra reset [pin 9] e 5V, per la frequenza a cui l'hai programmato)
TX convertitore al pin 14 del 644
RX convertitore al pin 15 del 644
5V covertitore ai pin 10 e 30 del 644
GND del convertitore ai pin 11 e 31 del 644
RESET/DTR/RST/RTS del convertitore (è sempre lo stesso pin, non so come si chiama sul tuo) ad un C da 100nF, l'altro capo del C da 100nF al pin 9 del 644
In caso di insuccesso puoi bypassare il C da 100nF, ma in genere serve

  • è giusto quanto sopra, sulle possibili cause del malfunzionamento?
  • esiste un metodo certo per verificare la presenza del bootloader nel micro?

sì alla prima domanda, segui le mie istruzioni per la prova; no alla seconda domanda, o meglio temo che la cosa sia abbastanza complessa, però se la procedura di caricamento è andata a buon fine stai tranquillo che il bl c'è :wink:

  • i pin utilizzati per l'ISP (MISO, MOSI, SCK) .. opsso comunque utilizzarli, durante il normale funzionamento , come pin di OUT/IN ???

sì, senza alcuna limitazione, invece devi stare attento a che siano completamente liberi quando decidi di riprogrammare il micro; ma se l'ISP lo usi solo per il bl in seguito non ti serviranno più.

... comunque confermo che il 644 sta funzionando regolarmente programmato con l'ISP, con il 30 % di script già "tradotto" per il 644 .. e sono già soddisfatto ....

certamente mi sono perso qualcosa, perché non capisco questa frase :cold_sweat: