' ********************************************************************** ' * File: Corso_BASCOMAVR_047.BAS * ' * Versione: 1.1 * ' * Data: 09.11.09 * ' * Ambiente sviluppo: Bascom-AVR Demo Ver. 1.11.9.1 + * ' * + AVR bootloader grifo(r) Ver. 1.2 * ' * Schede: GMM AM08 + GMM TST3 * ' * Sviluppato da: GRIFO(r) Italian Technology * ' * via Dell'Artigiano 8/6 * ' * 40016 S. Giorgio di Piano (BO) * ' * Tel. +39 051 892052 Fax. +39 051 893661 * ' * http://www.grifo.com http://www.grifo.it * ' * Autore: Gianluca Angelini * ' ********************************************************************** ' Programma di esempio 047 del corso BASCOM AVR. ' Programma di prova e gestione EEPROM Microwire Microchip 93LC46A. ' Esegue le operazioni fondamentali sul componente con un'interfaccia ' Microwire software ed interagendo con l'utente tramite una console ' seriale dotata di monitor e tastiera, con un protocollo fisico costante ' a 19200 Baud, 8 Bit x chr, 1 Stop bit, Nessuna parità. ' Questa console può coincidere con un sistema in grado di gestire una ' comunicazione seriale in RS 232. Al fine di semplificarne l'uso si può ' usare un PC dotato di una linea COMx, che esegue un programma di emulazione ' terminale come HYPERTERMINAL o l'omonima modalità offerta dal BASCOM AVR ' (vedere Configurazioni IDE). ' Il programma funziona solo se la GMM AM08 è montata sullo zoccolo Z2 della ' GMM TST3!! ' ' Aggiunte: Nessuna. ' ' 09/11/09: Corso_BASCOMAVR_047.BAS - Ver 1.1 - By G.A. ' Prima versione. ' ' '*************************** Configurazioni IDE ******************************** ' NOTE: per usare correttamente questo programma demo, eseguire i seguenti ' punti: ' 1) Controllare la presenza del file M8DEF.DAT nella directory di ' installazione del BASCOM-AVR e se non disponibile copiarlo e dopo ' rilanciare l'IDE. ' 2) Nella finestra "Options | Compiler | Chip" impostare: ' Chip: m8def.dat ' XRAM: None ' HW Stack: 64 ' Soft Stack: 32 ' Framesize: 64 ' XRAM waitstate: disattivo ' External Access Enable: disattivo ' 3) Nella finestra "Options | Communication" settare: ' COM port = la linea del PC collegata alla GMM AM08, tramite la GMM TST3 ' Baudrate = 19200 ' Parity = None ' Databits = 8 ' Stopbit = 1 ' Handshake = None ' Emulation = TTY ' Font = Terminal, Normale, 12 punti, colore bianco ' Backcolor = Navy ' 4) Al termine della compilazione, della programmazione del codice nella ' GMM AM08, aprire la finestra di emulazione terminale del BASCOM AVR con ' l'opzione: Tools | Terminal emulator (Ctrl+T) ed a questo punto resettare ' o riaccendere il Mini Modulo. '********************** Direttive del compilatore ****************************** $regfile "M8DEF.DAT" ' File di definizione microcontrollore usato $romstart = &H0 ' Indirizzo inizio codice in FLASH $crystal = 7372800 ' Frequenza quarzo del microcontrollore $hwstack = 64 ' Spazio per stack hardware $swstack = 32 ' Spazio per stack software $framesize = 64 ' Spazio per frame $map ' Genera informazioni di debug $baud = 19200 ' Velocità comunicazione seriale: 19200 Baud ' Altri parametri sono fissi a: 8 bit x chr ' 1 Stop bit ' No parity '******************************* Definizioni *********************************** ' Le risorse usate dal programma sono collegate come illustrato nella seguenti ' tabelle: ' !!! N.B. Sulla GMM TST3 i jumper devono essere posizionati come segue: ' J1 in 2-3 ; J2 in 1-2 ; J3 in 1-2 ; J5 in 2-3 ; J7 in 2-3 ; J8 in 2-3 ' J9 in 2-3 !!! ' ' Segnale Risorsa pin Z2 pin Segnale Segnale uP ' 93LC46A GMM TST3 GMM TST3 GMM AM08 GMM AM08 usato ' CS CN4.1 32 26 PCO ADC0 PC0 ' SK CN4.4 31 25 PC1 ADC1 PC1 ' DI CN4.3 30 24 PB1 OC1A PB1 ' DO CN4.6 29 23 PB0 ICP PB0 ' ' Segnale pin COMx pin CN5 pin Z2 pin Segnale Segnale uP ' PC DB9 GMM TST3 GMM TST3 GMM AM08 GMM AM08 usato ' TX 3 3 9 3 RxD RS232 PD0 ' RX 2 2 10 4 TxD RS232 PD1 ' GND 5 5 20 14 GND - ' Da questa tabella si ricava che il cavo di collegamento tra la COM del PC ed ' il CN5 della GMM TST3 è un normale cavo dritto o prolunga. Volendolo ' richiedere alla grifo(r) si deve specificare il codice CCR 9+9E. Pincs Alias Portc.0 ' Bit con segnale d'uscita collegato a CS della EE Pinsk Alias Portc.1 ' Bit con segnale d'uscita collegato a SK della EE Pindi Alias Portb.1 ' Bit con segnale d'uscita collegato a DI della EE Pindo Alias Pinb.0 ' Bit con segnale d'ingresso collegato a DO della EE Pinrx Alias Ddrd.0 ' Bit con direzione segnale collegato a RxD GMM AM08 Pintx Alias Ddrd.1 ' Bit con direzione segnale collegato a TxD GMM AM08 '************************ Dichiarazioni costanti ******************************* '************************ Dichiarazioni variabili ****************************** Dim Choice As Byte ' Operazione scelta Dim Mwnbit As Byte ' Numero bit da comunicare con interfaccia Microwire Dim Mwout As Word ' Dato da inviare con interfaccia Microwire Dim Mwin As Word ' Dato ricevuto con interfaccia Microwire Dim Addmw As Word ' Indirizzo da inviare con interfaccia Microwire Dim Datmw As Byte ' Dato da comunicare con interfaccia Microwire Dim Hlpb As Byte ' Variabile di aiuto ad uso generico '************************ Dichiarazioni procedure ****************************** Declare Sub Ask_key() ' Richiede ed attende la pressione di un tasto da console Declare Sub Ini_mw() ' Inizializza linee usate per l'interfaccia Microwire software Declare Sub Com_mw(byval Mwout As Word , Mwin As Word , Byval Mwnbit As Byte ) ' Comunica su interfaccia Microwire software Declare Sub Read_mwee() ' Legge un byte dalla EE Microwire Declare Sub Write_mwee() ' Scrive byte sulla EE Microwire Declare Sub Enaew_mwee() ' Attiva cancellazione e scrittura sulla EE Microwire Declare Sub Disew_mwee() ' Disattiva cancellazione e scrittura sulla EE Microwire '************************** Programma principale ******************************* Main: Pinrx = 0 ' Inizializza segnali per comunicazione seriale Pintx = 0 ' come ingressi digitali Call Ini_mw() ' Inizializza linee usate per l'interfaccia Microwire software Print ' Separa precedenti rappresentazioni su console Print Print " Gestione EE Microwire 93LC46A con GMM AM08 + GMM TST3" Print "Montare Mini Modulo su Z2 della GMM TST3, collegare EE a CN4 come da schema." ' Da notare che le variabili dedicate all'indirizzo ed alla comunicazione con ' il dispositivo Microwire sono stati volutamente dichiarati di tipo Word a 16 ' bits, in modo da poter facilmente gestire anche EE con capacità superiori Do ' Inizio ciclo infinito Print ' Presenta menù con le possibili operazioni Print "R -> Legge locazione" Print "W -> Scrive locazione" Print "A -> Attiva cancellazione e scrittura" Print "D -> Disattiva cancellazione e scrittura" Print "Effettuare la scelta premendo il tasto associato: "; Choice = Waitkey() ' Attende scelta operazione da eseguire Printbin Choice ' Rappresenta scelta effettuata Print If Choice >= "a" Then ' Se scelta minuscola Choice = Choice And &HDF ' La converte in in maiuscolo End If Print ' Distanzia menù da rappresentazioni seguenti Select Case Choice ' Controlla scelta convertita Case "R": ' Scelta operazione di scrittura locazione EE Input "Indirizzo locazione da leggere (0..128): " , Addmw Call Read_mwee() ' Legge byte dalla EE Microwire Print "Dato letto= " ; Datmw Call Ask_key() ' Richiede ed attende da console per consentire lettura risultati Case "W": ' Scelta operazione di impostazione velocità Input "Indirizzo locazione da scrivere (0..128): " , Addmw Input "Dato da scrivere (0..255): " , Datmw Call Write_mwee() ' Scrive byte sulla EE Microwire Print "Scrittura effettuata." Call Ask_key() ' Richiede ed attende da console per consentire lettura risultati Case "A": ' Scelta operazione di attivazione cancellazione e scrittura Call Enaew_mwee() ' Attiva cancellazione e scrittura sulla EE Microwire Print "Cancelazione e scrittura attivate." Call Ask_key() ' Richiede ed attende da console per consentire lettura risultati Case "D": ' Scelta operazione di disattivazione cancellazione e scrittura Call Disew_mwee() ' Disattiva cancellazione e scrittura sulla EE Microwire Print "Cancelazione e scrittura disattivate." Call Ask_key() ' Richiede ed attende da console per consentire lettura risultati Case Else: ' Scelta non valida Printbin &H07 ' Emette un BEL di avviso sulla console End Select Loop ' Fine ciclo infinito End '************************ Fine programma principale **************************** '****************** Inizio procedure usate dal programma *********************** ' Richiede ed attende la pressione di un tasto da console ' Ingresso: Nulla ' Uscita: Nulla Sub Ask_key() Print "Premere un tasto per continuare..."; Hlpb = Waitkey() Print End Sub ' Inizializza segnali e variabili usati per l'interfaccia Microwire gestita via ' software ' Ingresso: Nulla ' Uscita: Nulla Sub Ini_mw() Ddrb.0 = 0 ' Inizializza PB0=DO come ingresso digitale Pinsk = 0 ' Inizializza PC1=SK come uscita digitale bassa Ddrc.1 = 1 Pindi = 0 ' Inizializza PB1=DI come uscita digitale bassa Ddrb.1 = 1 Pincs = 0 ' Inizializza PC0=CS come uscita digitale bassa Ddrc.0 = 1 End Sub ' Comunica sull'interfaccia Microwire gestita via software provvedendo ad ' inviare e ricevere il numero passato di bits fino ad un massimo di 16. ' Ingresso: Mwout = Dato da inviare ' Mwnbit = numero bit da comunicare ' Uscita: Mwin = Dato ricevuto Sub Com_mw(byval Mwout As Word , Mwin As Word , Byval Mwnbit As Byte ) If Mwnbit < 16 Then ' Se non tutti i bits del dato sono da inviare Hlpb = 16 - Mwnbit ' Ottiene numero bits da non inviare Shift Mwout , Left , Hlpb ' Scarta bits da non inviare End If For Hlpb = 1 To Mwnbit ' Ciclo ripetuto per i bits da comunicare Shift Mwin , Left , 1 ' Aggiorna bit attuale del dato ricevuto Pindi = Mwout.15 ' Setta stato bit attuale del dato da inviare su segnale DI Pinsk = 1 ' Alza segnale SK Mwin.0 = Pindo ' Preleva e salva stato bit attuale da segnale DO nel dato ricevuto Pinsk = 0 ' Abassa segnale SK Shift Mwout , Left , 1 ' Aggiorna bit attuale del dato da inviare Next Hlpb End Sub ' Legge un byte dalla EE Microwire 93LC46A. ' Ingresso: Addmw = indirizzo locazione EE da leggere ' Uscita: Datmw = dato letto da EEPROM Sub Read_mwee() Pincs = 1 ' Alza segnale CS Call Com_mw(&H06 , Mwin , 3) ' Invia 3 bits del comando READ alla EE Microwire Call Com_mw(addmw , Mwin , 7) ' Invia 7 bits di indirizzo alla EE Microwire Call Com_mw(&H00 , Mwin , 8) ' Preleva 8 bits del dato da leggere da EE Microwire Datmw = Low(mwin) Pincs = 0 ' Abbassa segnale CS End Sub ' Scrive un byte sulla EE Microwire 93LC46A. ' Ingresso: Addmw = indirizzo locazione EE da scrivere ' Datmw = dato da scrivere ' Uscita: Nulla Sub Write_mwee() Pincs = 1 ' Alza segnale CS Call Com_mw(&H05 , Mwin , 3) ' Invia 3 bits del comando WRITE alla EE Microwire Call Com_mw(addmw , Mwin , 7) ' Invia 7 bits di indirizzo alla EE Microwire Mwout = Datmw ' Uniforma dato da scrivere (8 bits) a parametro (16 bits) Call Com_mw(mwout , Mwin , 8) ' Invia 8 bits del dato da scrivere alla EE Microwire Pincs = 0 ' Abbassa segnale CS Waitms 10 ' Attende tempo fine scrittura EE Microwire (6 msec da data sheet) End Sub ' Attiva cancellazione e scrittura sulla EE Microwire 93LC46A ' Ingresso: Nulla ' Uscita: Nulla Sub Enaew_mwee() Pincs = 1 ' Alza segnale CS Call Com_mw(&H04 , Mwin , 3) ' Invia 3 bits del comando EWEN alla EE Microwire Call Com_mw(&H60 , Mwin , 7) ' Completa comando inviando 7 bits di indirizzo alla EE Microwire Pincs = 0 ' Abbassa segnale CS End Sub ' Disattiva cancellazione e scrittura sulla EE Microwire 93LC46A ' Ingresso: Nulla ' Uscita: Nulla Sub Disew_mwee() Pincs = 1 ' Alza segnale CS Call Com_mw(&H04 , Mwin , 3) ' Invia 3 bits del comando EWEN alla EE Microwire Call Com_mw(&H00 , Mwin , 7) ' Completa comando inviando 7 bits di indirizzo alla EE Microwire Pincs = 0 ' Abbassa segnale CS End Sub '******************* Fine procedure usate dal programma ************************