Topic permanente di programmazione newbie

BrainBooster: ma hai chiamato il 4313 con il nome giusto nella board?(t4313)

ho provato ora per scrupolo, ma anche l'attiny2313 viene scritto per intero, ecco perché dico che il nome deve essere altrove, come giustamente dice Astro.

@ QP: grazie, me lo dà come primo link ma mi era sembrato un po' sospetto :fearful: oltretutto mi dà in ftp una cartella zeppa di versioni, scarico l'ultima?

Si. Ossia questa http://sourceforge.net/projects/winavr/files/WinAVR/20100110/

Ciao QP

Fatto, ma ho lo stesso errore, forse non è sufficiente questa manovra di sostituzione della cartella avr e comunque nell'AVRDUDE.CONF nuovo il 4313 non c'è, ho visto che aprendo il makefile l'mcu appare, ma davvero non so come integrarlo, ed è un peccato non riuscirci perché ci sono altri micro che mi interessano come gli attyny 88 e 861; gli 861 sono molto simili ai 2313, abbastanza da poter tentare di partire da questi per aagiungere i dati nel core e creare la relativa board. Per il momento lascio installato il winavr e ripristino la vecchia versione della cartella, poi se mi suggerite idee o se fate qualche tentativo tenetemi aggiornato.

menniti: Fatto, ma ho lo stesso errore, forse non è sufficiente questa manovra di sostituzione della cartella avr e comunque nell'AVRDUDE.CONF nuovo il 4313 non c'è

Impossibile che ti da lo stesso errore perché la versione 4.3.3 di AVRGCC prevede il 4313, l'ho verificato.

Queste sono le prime righe del suo file .h di configurazione:

/* Copyright (c) 2009 Atmel Corporation
   All rights reserved.

/* $Id: iotn4313.h,v 1.1.2.2 2009/11/02 02:44:17 arcanum Exp $ */

/* avr/iotn4313.h - definitions for ATtiny4313 */

/* This file should only be included from , never directly. */

#ifndef _AVR_IO_H_
#  error "Include  instead of this file."
#endif

#ifndef _AVR_IOXXX_H_
#  define _AVR_IOXXX_H_ "iotn4313.h"
#else
#  error "Attempt to include more than one  file."
#endif 


#ifndef _AVR_ATtiny4313_H_
#define _AVR_ATtiny4313_H_ 1

edit: forse il problema è nel nome che usi per il micro che non è quello atteso dal compilatore.

sarebbe questo che hai postato tu? AVR_ATtiny4313_H oppure dove lo trovo?

menniti: sarebbe questo che hai postato tu? AVR_ATtiny4313_H oppure dove lo trovo?

No questo è il nome simbolico usato nel file di descrizione, non ha nulla a vedere con quanto atteso dal compilatore sulla riga di comando, mi pare che c'è una opzione che fornisce la lista dei micro supportati e il nome da utilizzare, devo dare un attimo una sbirciatina al manuale del gcc.

Ho fatto al volo una prova sostituendo AvrWin con l'ultima versione come ti avevo detto, nome cpu ".mcu=attiny4313" e il compilatore lo accetta, però poi viene fuori una serie di errori perché il core non è adatto per il micro, quindi la questione supporto del compilatore è risolta, ora tocca risolvere il problema core.

attima la scoperta della signature sbiellabile.
Menny scopri cose interessanti anche quando sbagli :slight_smile:

quind l’idea del menu’ Proteggi Micro e’ accettata ?

qualcuno sa niente del discorso di cancellare solo il bootloader ? giusto per didattica, lo sketch non partirebbe giusto ?
Non basterebbe cancellare solo il primo byte della flash ?

@ Astro: riprovo, ma sono ragionevolmente sicuro di aver usato proprio quella dicitura: mi confermi di aver sostituito solo la cartella della nuova versione (nel mio caso era in root non in programmi) al posto della vecchia? e poi come hai fatto la prova, hai creato una board qualsiasi con quella mcu?

@ Testato: è stata spettacolare questa cosa :D Guarda io non ho particolari problemi ora a implementare il lock_bit, ormai "possiedo" la tecnica, ci perderò un po' di tempo e sarà fatto; ma devo approfondire un paio di questioni sul datasheet per capire se davvero ne vale la pena; invece quella cosa del no_BL scusa ma "me pare propio na strunzata" ed io sto già litigando moltissimo col tempo quindi lascio l'onore a te, quando avrai il mio sketch sul PC ti potrai sbizzarrire ;) ti ricordo che quando programmiamo con l'ISP il BL non lo mettiamo ed lo sketch parte lo stesso, se devi solo sabotare la flash non ne capisco davvero la necessità :astonished:

menniti: @ Astro: riprovo, ma sono ragionevolmente sicuro di aver usato proprio quella dicitura: mi confermi di aver sostituito solo la cartella della nuova versione (nel mio caso era in root non in programmi) al posto della vecchia? e poi come hai fatto la prova, hai creato una board qualsiasi con quella mcu?

Si ho semplicemente sostituito il contenuto della cartella con quello della nuova versione di WinAvr, poi ho preso una board per Attiny e ho semplicemente cambiato il nome della mcu, giusto per vedere se veniva accettato dal compilatore, e infatti la compilazione parte, però poi vengono fuori vari errori dovuti al mancato supporto del core a questo modello.

menniti: @ Leo e BB: quindi ora vorrei poter aggiungere una board per programmare correttamente il 4313 (mi basta 1MHz); da quanto ho capito i file da modificare sono tre: – AVRDUDE.CONF: qui (come feci allora col 328noP) mi limito a fare un copincolla del 2313 ed a modificare nome, descrizione e signature; Vi ricordo che ieri, semplicemente modificando la signature ho programmato il 4313 con la board ed il finto boootloader del 2313, cambiando solo il valore del LFuse che, peraltro, non ha alcuna importanza per gli sketch; quindi la manovra su AVRDUDE in linea di massima va; poi non scordiamo tutto ciò che disse Astro a proposito di questo tipo di operazioni barbariche, ma visto che ieri ho fatto lampeggiare tre led senza questioni, a me basta. – pins_arduino.c e pins_arduino.h: anche qui posso fare un copincolla del 2313 modificando le sole info varianti, ho già verificato che la pinature è identica e le assegnazioni dei pin sono perfettamente compatibili -boards.txt: e anche qui una nuova board a partire dalla 2313 in cui modifico i vari attributi, l’LFuse (giusto per esattezza) e il nome dell’mcu, mentre lascio inalterato il bootloader che, a farla sporca, forse potrei copiare e rinominare opportunamente nella cartella specifica. La questione è: tutto ciò mi evita l’errore dell’IDE che ogni volta mi strapazza le vecchie che mi dice che non conosce il 4313 e mi mostra l’infinito elenco di quelli che dice di conoscere? A voi l’ardua sentenza.

Ripensando alla cosa, non è così come ti ho detto. Nel senso che quando ho modificato il core Sanguino per i 1284 ho visto che di file ce n'erano anche altri da cambiare, non solo i file pins_arduino: questi servono per la mappatura dei pin, ma poi c'era il discorso dei timer, degli interrupt, del PWM... Insomma, va preso il core Tiny, file per file, e controllato se e dove servono le modifiche.

@ Leo: l'IDE nel messaggio sembra chiaro: usare -F significa non controllare la signature, che altro dovrebbe fare/non fare?

Tu hai chiesto se bastava aggiungere quell'opzione, io ti ho detto che per alcuni compiti serve, per altri no. Esempio: se hai un chip briccato, signature o non signature, non lo programmerai mai con avrdude anche usando l'opzione -F. Non so se mi sono spiegato.

yep, attendo l'uscita sulla rivista e poi ci buttiamo nelle modifiche. sai se sara' possibile comprare la sola pcb ? o cmq tutto il kit, tanto in teoria dovrebbe essere un kit economicissimo, sempre perche' non mi va di mettere mano all'acido.

per il fatto del cancella bootloader (fai bene a non considerarlo per il progetto, e' solo una domanda al forum per capire cose nuove) non e' come il discorso del caricre lo sketch in isp. se il bootloader e' presente, e' lui che passa allo sketch, quindi rimuovendoplo lo sketch non parte, secondo me :)

Il bootloader risiede in un'area di Flash che viene protetta mediante i fuse ed a cui viene passata l'esecuzione del codice all'avvio del micro, se i fuse prevedono quest'area. Io credo che se riprogrammi i fuse per togliere l'area riservata al bootloader, non hai bisogno di cancellarlo materialmente perché l'esecuzione del codice parte, senza bootloader impostato nei fuse, dalla cella $0000 e non più dall'area riservata.

No questo è il nome simbolico usato nel file di descrizione, non ha nulla a vedere con quanto atteso dal compilatore sulla riga di comando, mi pare che c'è una opzione che fornisce la lista dei micro supportati e il nome da utilizzare, devo dare un attimo una sbirciatina al manuale del gcc.

Forse ti riferisci a questa?

avr-gcc -dumpspecs

Certo non è chiarissima, almeno a me girano gli oci.

Ciao.

qui c'è in elenco: http://www.nongnu.org/avr-libc/user-manual/ e gcc può compilare per integrati di quella famiglia (avr25): http://gcc.gnu.org/onlinedocs/gcc/AVR-Options.html

BrainBooster: qui c'è in elenco: http://www.nongnu.org/avr-libc/user-manual/ e gcc può compilare per integrati di quella famiglia (avr25): http://gcc.gnu.org/onlinedocs/gcc/AVR-Options.html

Diciamo che per il momento la questione aggiornamento compilatore alla 4.3.3 è risolta. Ieri sera ho fatto molte prove con tutti programmi che ho per Arduino, sia UNO che MEGA2560, alcuni molto complessi come MultiWii (software per quadricotteri), e non ho riscontrato nessun problema, quindi direi che il trapianto è perfettamente riuscito e il paziente gode di ottima salute :) Per quanto riguarda gli ATtiny4313 rimane il problema del core perché sebbene ora viene riconosciuto dal compilatore poi saltano fuori errori dovuti alle differenze hardware tra questi micro e quelli normalmente impiegati su Arduino. Ho fatto una prova al volo con il core per ATtiny 45-85, sapendo già che non poteva funzionare, solo per verifica se cambiavano gli errori e così è stato confermando ulteriormente che ora è possibile compilare anche per i 4313. Ho fatto un ulteriore test con una versione sperimentale dell'IDE 1.0 con trapiantata la toolchain di ATmel al posto di WinAvr, ci sto lavorando sopra da diverso tempo per la famosa questione del limite di memoria del ATmega2560, e anche questa riconosce senza problemi i 4313, cosa di cui ero più che certo, e mi fornisce gli stessi errori, dovuti al core, del test con avrgcc 4.3.3.

Salvo imprevisti, ovvero impegni lavorativi, dovrei rilasciare a breve la procedura per sostituire WinAvr con la toolchain di Atmel, che è sempre aggiornatissima e con molti meno bug delle altre release di avrgcc, in modo da mettere la parola fine ai fastidiosi bug e limiti della versione 4.3.2, abbastanza vecchiotta (2009), di WinAvr che è ufficialmente abbinata all'IDE di Arduino, inclusa la 1.0, per Windows.

Comunque sia ho stabilito per oggi (quasi libero!) questa scaletta: 1 - metto in ordine il firmware (troppo incasinato) 2 - studio e decido se implementare il lock_bit 3 - rifaccio il test winavr, evidentemente ieri mi è sfuggito qualcosa; riguardo il core la prova va fatta con quello per il 2313, che nella libreria tiny c'è; rispondo con l'occasione a Leo: - penso che essendoci tra i due solo differenze di memoria e del low fuse, non ci dovrebbero essere problemi di timer ecc., infatti dicendo al compilatore che stavo usanto una variante del 2313 lui ha eseguito tutto alla perfezione, quindi qui si tratta solo di fargli riconoscere il nome, vedremo con questo test di Astro; l'unico dubbio mi viene dal fatto che io tengo tutti il materiale extra ide 0022 in una cartella separata rispetto alla hardware originale, quindi mi devo ricordare anche di fare questa prova.

Sempre come chiarimento a Leo: nel frangente del -F si parlava di un micro che ha perso la signature e che io volevo provare a programmarlo, i fuse ovviamente erano a posto, quindi no-bricked, altrimenti a che mi serve l'HV? ;)

@ Testato: Elettronica In regala tramite sito il firmware e i gerber per farsi i PCB; se poi dovessero decidere di farne un kit (ma ne dubito, dovrebbero avere un bordello di richieste) allora metteranno in vendita anche i soli PCB, di solito fanno così. Comunque ragazzi, a lavoro finito pubblico le caratteristiche, se mi fate sapere di essere interessati realmente alla costruzione, una volta che so quanti siete gli chiedo di farmi stampare "xx" copie dei vari PCB, mi faccio fare un preventivo e ve li giro; oppure (meglio ancora) gli dò i Vostri nominativi e ve li faccio spedire a casa in c/assegno, così ognuno potrà decidere di aggiungere qualche componente che non ha in casa. Ne riparliamo se vi fa piacere.

menniti: l'unico dubbio mi viene dal fatto che io tengo tutti il materiale extra ide 0022 in una cartella separata rispetto alla hardware originale, quindi mi devo ricordare anche di fare questa prova.

Io la prova l'ho fatta in questo modo, ho copiato in toto l'IDE 0023 in una nuova cartella denominata ide23_test, poi ho cancellato tutto il contenuto della cartella che contiene winavr e ho copiato al suo interno tutto il contenuto, meno avr32 che non serve, di quella del nuovo winavr. Più tardi provo con il core del 2313, non mi ricordavo che c'era pure questo, e vediamo se compila correttamente.

Ora guardo il core Tiny, se con poco è possibile implementare il 4313.

leo72: Ora guardo il core Tiny, se con poco è possibile implementare il 4313.

Ottimo, allora aspetto il tuo verdetto prima di rifare il test.