walterword Posted June 29, 2004 Report Share Posted June 29, 2004 (edited) dunque sto preparando una scheda dove acquisisco dati cosi composta :PIC16F876 , 4 uscite a rele' e 4 ingressi (piu avanti optoisolati .finche e' una ok , ma il mio scopo sarebbe quello di creare una rete su standard RS485e protocollo modbus che sto gia studuando .visto che il pic dispone di 64 byte , ed in questo caso la scheda tratta solo bit , che essi siano uscite piuttosto che ingressi , pensavo di snellire il protocollo gestendo solo la lettura e la scrittura che il modbus definisce come registri con prefisso 3xxxx.quindi copierei o scorporerei tutti i bit della scheda in diversi bytes che saranno poi trasmessi al master che puo essere un PC oppre un modulo Rabbit che e' molto piu potente e dispone di piu ram per gestire diversi nodi (schede I/O)il modbus su rs485 e' formato da 1 byte indirizzo , 1 byte funzione , 1 byte quantita dati ,n° bytes per contenere i bit , e 2 byte (piu significativo e meno della word che gestisce il CRC )quindi se penso al massimo a 32 ingressi piuttosto che 32 uscite sono 4 bytes di dati ,che devo preservare per il buffer + 1 +1 +1 +2 = 9 bytes di ram del PIC16F876 da destinare alla gestione della comunicazione .considerando l'algoritmo per il calcolo del CRC , forse a livello di memoria flash dovrei riuscire a gestire il tutto mentre a livello di ram ditemelo voi ??? dovrei riuscire mi rimangono ancora 55 bytes liberi visto che poi il micro non fara un gran lavoro dovra solo copiare i registri ,dichiarati alle porte ingresso piuttosto che uscite ,nei byte del dati della comunicazione .domanda : per gestire questo protocollo devo avere la possibilita di spedire dei pacchetti , quindi un buffer di 9 bytes , solo che pero il PIC gestisce lo standard Rs232 che tramite i driver MAX232 vengono "buttati " in rete il pacchetto Rs232 e' diverso da come vorrei fare io , secondo voi come potrei fare ?sto provando con 2 PC la comunicazione modbus su tcp\ip e qui non ho problemi perche il tcp mi da la possibilita' di spedire e ricevere un pacchetto composto da n° bytes ed una volta ricevuto o prima di spedirlo posso riempirlo come voglio a seconda delle specifiche modbus e dai controlli che faccio .la comodita tra 2 pc e' che spedendo un buffer che e' un array di bytes posso tranquillamente spedire senza trasformazione in ascii anche numeri intero a 16 bit come faccio? prendo un intero , con 2 interi di appoggio , lo maschero con gli 8 bit meno significati e copio il risultato nell'intero di appoggio1 , e poi li maschero con quelli piu significati e dopo aver shiftato a dx di 8 li copio nell'intero di appoggio2 .da qui sono sicuro che il mio byte non supera mai 255 poi converto i 2 interi in byte e li metto nel pacchetto dalla parte dove leggo faccio l'algoritmo opposto , e li metto in OR sull'intero finale e sono apposto quindi come di solito uso nei plc schneider spedisco anche i bit di ingressi piuttosto che uscite e merkertutti in word , e cosi evito di scrivere le funzioni sui bit .Solo che pero con la trasmissione rs232 mi sembra di aver capito che funziona diversamente cioe spedisce un pacchetto di al massimo 8 bit di dati , quindi come potrei interpretare la cosa???quindi IFACHLIVIODLGCOMper cortesia illuminatemi ciao waltergrazie Edited June 29, 2004 by walterword Link to comment Share on other sites More sharing options...
dlgcom Posted June 29, 2004 Report Share Posted June 29, 2004 visto che il pic dispone di 64 byteDi cosa 64byte? Link to comment Share on other sites More sharing options...
walterword Posted June 29, 2004 Report Share Posted June 29, 2004 ram , mi sembra dalle specifiche memoria del pic Link to comment Share on other sites More sharing options...
dlgcom Posted June 29, 2004 Report Share Posted June 29, 2004 No , di memoria ram hai ben 368 byte , divisi in quattro banchi .hai 96 byte nel banco 0 80 byte nei banchi 1 2 e 3 gli ultimi 16 byte dei banchi 1,2 e 3 sono la copia degli indirizzi da 070h a 07Fh Link to comment Share on other sites More sharing options...
walterword Posted June 29, 2004 Report Share Posted June 29, 2004 i primi sono tassativamente riservati ai registri di "sistema" per esempio tmr , status ectvero?c'e' una tabella sul manuale del 16F876 , che ho appena finito di stampare comunque la mia lacuna sta nella comunicazione RS232 .se invece questo pic supporta lo standard RS485 allora sono a cavallo ciao walter Link to comment Share on other sites More sharing options...
dlgcom Posted June 29, 2004 Report Share Posted June 29, 2004 Devi farti la gestione della 485 , ovvero dovrai gestire l'uscita per commutare RXeTX .Per il resto il pic a una USART che fa tutto il lavoro di trasmissione .. devo solo depositare in un registro il byte che vuoi trasmettere .quelli riservati sono :banco 0 da 000h a 01Fhbanco 1 da 080h a 09Fhbanco 2 da 100h a 11Fhbanco 3 da 180h a 18Fh Link to comment Share on other sites More sharing options...
walterword Posted June 29, 2004 Report Share Posted June 29, 2004 ok il CRC lo lascio per ultimo tanto sono prove on devo consegnare qualcosa che poi si impianta.allora devo gestire il protocollo in RS232 cosi .preparo una tabella o meglio dire una colonna ,che e' il buffer di trasmissione , quindi spedisco il primo byte ,qualcosa mi dira che 'e stato spedito e quindi tramite puntatore o indicizzatore spedisco il secondo ect .dal lato ricevitore se la funziona ritorna senza codce di errore ricevo il buffer (sempre di 1 byte alla volta )e ad ogni byte che arriva incremento un contatore per sapere quanti byte ho ricevuto , ogni byte che ricevo lo copio su di un'area di meoria per memorizzarlo , e svuoto il buffer .Via cosi fintanto che non ho ricevuto tutti i byte del quale so precendemtente quanti sono perche li ho richiesti (nel master)prima id riceverli .devo trovare documentazione per capire come fare pero cioe come , dove e perche e come ca**o faccio a settare a 1 il bit di start per esempio , e ttui gli altri bit del pacchetto .mah .....bisogna sincronizzare bene tutte le operazioni domanda : prima di rispondere alle richieste del master , uno slave ,cosa fa ? come fa a sapere se la linea e' libera e cioe che nessuno stia mandando pacchetti , compresi gli altri slaves ?sai col pc e TCP\ip la cosa e' piu difficile sotto altri aspetti nei plc pure , qua invece siamo a basso livello , alle radici di dove succede tutto ,e sinceramente se devo dorti la verita i miei studi sulla comunicazione seriale e i pic li ho iniziati domenica ciao lucae scusa per la rotturaciao walter Link to comment Share on other sites More sharing options...
walterword Posted June 29, 2004 Report Share Posted June 29, 2004 (edited) ok quindi a prescindere dal protocollo sempre un byte alla volta sia in ricezione che trasmissione a livello hw di rete ci pensa poi il max485 a convertire il segnale .dico bene? cioe ma se devo spedire un intero ?devo settare il bit di start , prepare il primo byte scorporando l'intero in 2 bytes , spedirlo poi spedire il secondo e poi settare il bit di stop ? Edited June 29, 2004 by walterword Link to comment Share on other sites More sharing options...
dlgcom Posted June 29, 2004 Report Share Posted June 29, 2004 domanda : prima di rispondere alle richieste del master , uno slave ,cosa fa ? come fa a sapere se la linea e' libera e cioe che nessuno stia mandando pacchetti , compresi gli altri slaves ?saprannno dal numero di byte della trasmissione , e sono uno slave sara' abilitato a trasmettere . Alla fine della trasmissione dello slave , il master fara un altra domanda per un altro slave o per lo stesso in caso di errori di ricezione. Link to comment Share on other sites More sharing options...
walterword Posted June 30, 2004 Report Share Posted June 30, 2004 (edited) ho visto qualche istruzione o meglio dire funzione visto che si passano dei parametri in assemblersulla guida del MPlabla funzione btfsc potrebbe essere usata per valutare se sulla porta della seriale c'e' lo zero logico per vedere se ' arrivato il bit di start da parte del trasmittente eseguendo un ciclo tipo while-do in assembleresempio loopbtsfc valore logico sulla seriale,1goto .....subroutine per leggere il byte arrivato loop dovrebbe comunque esistere una word , pardon , un REGISTRO !!! , dove vengano salvati i bit in arrivo o no ?va be dai devo trovare un esempio pratico dove c'e' un esempio di comunicazione in assembler che come linguaggio assomiglia un PO' all AWL be e' molto veloce ho visto come linguaggio , certo quando si devon fare cicli con puntatori o indici su indici allora e' meglio usare il C , oppure fare dei switch-case per controllare dei valori per esempio di valori in arrivo va be ancora qualche giorno che mi mandano quel ca**o di programmatore e poi mi smazzo la seriale e poi inizio a divertirmi ciao waltera parte che anche in S7-200 on awl si posson fare dei bei cicli lavorando su tabelle composte da piu colonne basta sincronizzare bene tra loro i puntatori le istruzioni sono "&" per caricare indirizzi di variabili in puntatori (formato doppiaword)e * per deindirizzare il puntatore , e cioe fare operazioni sulla variabile da esso puntata oppure per salvare o leggere il valore della variabile puntata .senza * per esempio una somma viene incrementato il valore del puntatore (in sostanza viene incrementato l'indice) quindi punta ad un'altra variabile)poi si puo caricare l'indirizzo di un puntatore in un altro ectse anche coi microprocessori si posson fare queste cose penso proprio riusciro ad impararli discretamente Edited June 30, 2004 by walterword Link to comment Share on other sites More sharing options...
walterword Posted June 30, 2004 Report Share Posted June 30, 2004 (edited) dalle specifiche RS232 bisogna campionare il segnale a meta della sua durataquindi quando sono nel loop "vizioso"e leggo uno 0 sulla porta che non so come ma che settaro come rx chiamo la routine che gestisce l'arrivo dei bit .per non sapere leggere ne scrivere azzero subito il registro che dedichero alla ricezione quindi ul mio bufferdi 1 byte.poi devo aspettare con un ritardo , che sapro come fare nel futuro , per una durata di 1 volta e mezza la durata di un bit (visto la diversita di durate tra bit di start e gli altri di dati )quindi si presume che sia arrivato il momento di andare a controllare il livello logico sulla porta serialeanche perche a questo punto il bit di start dovrebbe essere finito leggo lo stato e lo memorizzo nel bit CARRY di STATUS che mi permette di shiftare o meglio ruotare i bit nel byte (registro-buffer) aspetto la durata di 1 bit questa volta e faccio le stesse operazioni in sostanza ruotando sempre di un bit a dx dovrei trovarmi giusto visto che la seriale trasmette partendo dal bit meno significativo , o sbaglio ? tutto questo movimento lo devo memorizzare in un'altra variabile che contera le operazioni , per sapere quando ca**o sono arrivati tutti gli 8 sfigati bit del dato .poi con qualche astuzia me ne rivado nel loop vizioso ad aspettare se arriva un altro bit di start questa secondo me dovrebbe essere la dinamica a basso livello , che potrebbe essere annidata all'interno di un'altra routine che gestira il mega pacchettone magari di 256 byte ( il massimo in modbus) cioe s enon funziona cosi mi metto li io col tester , la biro e un foglio e lo scrivo io il buffer azzzzzzzzzzzzzzzz.......................ditemi se ho capito qualcosa anch'io e' da domenica che ho iniziato i micro e le comunicazioni seriali , abbiate un po di pieta' per favore ciao walter Edited June 30, 2004 by walterword Link to comment Share on other sites More sharing options...
dlgcom Posted June 30, 2004 Report Share Posted June 30, 2004 Non hai bosogno di fare tutto questo con i pic 16F87x.Hanno gia' internamente un modulo per la ricezione seriale.Devi solo configurare la velocita' e appena arriva un carattere , il pic alzera' un flag per comunicarti che e' disponibile un byte nel buffer di ricezone, questo flag puo' anche scatenare un interrupt , cosi' non sei obbligato a leggere in continuazione lo stato del flag .oggi non ho tempo , ma domani ti mando una piccola routine di ricezioe e strasmissione seriale Link to comment Share on other sites More sharing options...
walterword Posted June 30, 2004 Report Share Posted June 30, 2004 fantastico !!!scusa un domanda : cioe la conversione del byte me la da in carattere o posso anche prenderla in byte proprio come valore decimale ???cosi mi sarebbe piu comodo ricevere i byte , cosi nel protocollo in base alla loro posizione vado ad unirli in OR + shift a sx e ricavo il mio intero che avevo precedentemente scisso in 2 byte come ho spiegato nei posto sopra ciao e graziewalter Link to comment Share on other sites More sharing options...
ifachsoftware Posted June 30, 2004 Report Share Posted June 30, 2004 Walter , premetto che mi hai fatto venire il mal di testa , ma vedo di riassumerti :1) Il PIC16F876 contiene un modulo che gestisce la seriale che viene riportata su due PIN a livello logico CMOS 0/5V 2) Per collegarti ad un dispositivo RS232 devi usare un convertitore da 5V a RS232 che e' un MAX232 o equivalenti3) La RS485 e' come la RS232 per la parte di trasmissione e ricezione (ossia la colleghi agli stessi pin della 232) solo che ti serve un MAX485 o equivalente per adattare il livello del segnale (in questo caso i cavi vanno Twistati e dotati di resistenze terminatrici da 120 Ohm a entrambi i capi) , piu' un pin aggiuntivo a cui collegherai i due segnali del MAX 485 che definiscono se sei in trasmissione o in ricezione , tali segnali vanno abilitati prima di partire a trasmettere e disabilitati subito dopo)4) Il 16F876 e' dotato di 2 Buffer da 1 Byte (8 Bit) cadauno che sono i buffer di trasmissione e di ricezioneIn pratica metti il dato nel buffer e dei bit che devi alzare o leggere ti dicono se il dato e' da spedire , se e' stato spedito , se e' arrivato un byte ecc.5) Il metodo migliore per gestire la seriale e' usare gli interrupt che chiamano una funzione quando e' stato ricevuo qualche carattere o quando e' stato trasmesso qualche dato.6) Ti ho dato degli esempi in C della CCS con esempio di gestione della seriale , considerando che conosci il C ti consiglio di partire da li , l'assembler piano piano lo impari.Ciao Link to comment Share on other sites More sharing options...
walterword Posted June 30, 2004 Report Share Posted June 30, 2004 okti spedisco un pacchettino di dati per il mal di testa (moment) grazie ciao walter Link to comment Share on other sites More sharing options...
walterword Posted July 4, 2004 Report Share Posted July 4, 2004 sto studiando l'assembler che non mi dispiace neanche poi tanto , e' dinamico e veloce quando avro capito i concetti ed il significato di ogni singola istruzione , provato emodificato un po di codice , e quando sentiro la necessita di fare programmi piu avanzati e complessi allora iniziero a studiarmi il potente compilatore in C, in modo tale da poter integrare sempre alcune parti di codice in asm per ottimizzare .i microprocessori mi danno veramente una capacita di voler fare non indifferente sembra quasi di essere dentro nel core e gestire le parti a basso livello , dal program counter , ai registri alla gesione di reti e protocolli .mi rendo conto di quante cose si possan fare , ma tante tante , e con una liberta e flessibilita non indifferente .basta pensare che un micro dal costo di pochi euro puo veramente fare quasi tutto e puo interfacciarsi con diversi mondi quali pc , plc , altri micro , server web ect ect .sono rimasto veramente affascinato ciao walter Link to comment Share on other sites More sharing options...
dlgcom Posted July 5, 2004 Report Share Posted July 5, 2004 Caro Walter ,Io invece sono alle prese con il C# , ho comprato un libro e mi sto atrezzando per lo studio .Ti ho trovato anche sul forum del C# .it ...Interessante come piattaforma , sopratutto per la portabilita'Voglio provare a fare qualche applicazione per pocket PC visto che esiste SDK free.Esiste qualche demo di OPC server che si possa isare in ambiente .NET? Link to comment Share on other sites More sharing options...
walterword Posted July 5, 2004 Report Share Posted July 5, 2004 io per i plc siemens uso Opc Server della siemens paghi una sola licenza per il protocollo (S7-Profibus ho io fa MPI e PROFI)da li c'e' una dll che ti permette di leggere ,scrivere , gestire eventi e quant'altro su plc siemens S7-300\400Premetto che ci ho messo 2 settimane per far funzionare il discorso con c#sai non del C# non siamo PARACULI come quelli del VISUAL BASIC , siamo un livello piu sotto e dobbiamo saper gestire le conversioni dei dati e i tipi . :ph34r: Oggi non ho avuto tempo , ero a piacenza , ma ieri sono riuscito ad implementare una funzione del modbus su TCP\IP con VC# . simultaneamente sto scrivendo sia la parte client che server in base alle specifiche che ti ho mandato .Direi che il doscroso funziona , ho bestemmiato un po con gli oggetti socket e sull'impacchettamento dei dati in byte.Nel pc server ho inizializzato un array di 1000 interi come se fossero i registir del modbus conindirizzo 3xxx.domani voglio col fantastico plc premium tsx con scheda ethernet , chi meglio di lui puo rispondermi come server ?cosi vedo un po cosa mi rimanda , voglio implementare anche altre 2 funzioni : scrivi molti registri e leggi una word .Fratello mi sto rpeparando per il brasile , non ti dimenticare se eventualmente ti serve una mano col c# fai un fischio , e' solo da gennaio che lo uso ma qualcosina la so fare anch'io nel frattempo procedo col fantastico mondo dei micro , mi sembra quasi di esser dentro quel pezzetto di silicio Guardati bene alcuni post del forum visualcsharp , potresti trovare molti spunti ciao bro'walter Link to comment Share on other sites More sharing options...
walterword Posted July 5, 2004 Report Share Posted July 5, 2004 col visual studio 2003.net puoi fare progetti crystal report , vb.net,java.net ( che non la caga nessuno )progetti web asp.net , servizi web , progetti di libreria controlli , custm ect, e anche pocket pc e windows cepensa un bel micro sotto , un bel pannellino o computerino con wince , e chi ci ferma piu .Il tutto ovviamente in rete Link to comment Share on other sites More sharing options...
walterword Posted July 5, 2004 Report Share Posted July 5, 2004 (edited) FRATELLI!!!!!!!!!!!!!!!!!!!!!!!!il discorso client-server modbus tcp\ip funziona che e' una meraviglia !!! ho implementato per ora un asola funzione : leggi tanti registri.nel server ho simulato un array di 1000 registri , che ogni 100 ms incrementano di 1 (reg++quando sono >32000 =0 ;Il client l'ho messo sotto timer , ed ogni 200ms fa una chiamata alla mia dll , legge i dati sempre refreshati crea gli oggetti dalacolumn , datatable e dataset e visualizza in una griglia dati i dati che cambiano continuamente .Posso scegliere al volo di andare a leggere da dove voglio e quanto voglio con gli opportuni controlli nel serversta andando da qualche ora e non si e' ancora impiantato che meraviglia !!!!!!!!!!111 lo faccio andare tutta notte e domani mattina quando mi sveglio se sta ancora andando prendo e butto tutto fuori nel giardino FACCIO UN MACELLOOOOOOOOOOOOOOOOO!!!!!!!!!!!!!!!!!!!!!!!!!!1111AHAHAHAHAHAHCIAO WALTER Edited July 5, 2004 by walterword Link to comment Share on other sites More sharing options...
dlgcom Posted July 6, 2004 Report Share Posted July 6, 2004 io per i plc siemens uso Opc Server della siemens paghi una sola licenza per il protocollo (S7-Profibus ho io fa MPI e PROFI)Paghi solo una licenza ? interessante ...Se mi puoi dare il codice , provo a trovarlo qui ...il discorso client-server modbus tcp\ip funziona che e' una meraviglia !!!Complimenti !!Io ho appena iniziato a leggere le specifiche.Devo solo trovare il C# Dovro' iniziare a smanettare con il rabbit per implementare il modbus... Link to comment Share on other sites More sharing options...
dlgcom Posted July 6, 2004 Report Share Posted July 6, 2004 Forse sarebbe meglio aprire un altro 3d ... stiamo andando un po OT... Link to comment Share on other sites More sharing options...
ifachsoftware Posted July 6, 2004 Report Share Posted July 6, 2004 Bel colpo WalterCiao Link to comment Share on other sites More sharing options...
walterword Posted July 6, 2004 Report Share Posted July 6, 2004 e' tutta la notte e la mattina che funziona senza perdere un colpo adesso vedo di metter giu anche la funzione Scrivi tanti registri usufruendo del codice che ho usato per impacchettare i dati di ritorno della Leggi multi registri poi voglio provare il tutto col fantastico plc premium e shceda ethernet , se anche lui mi risponde siamo a buon punto Codice Opc Server :-dunque devi ordinare il simatic net cd che contiene l'NCM net (uguale a quello dello step 7) ma in versione ridotta , in sostanza solo per configurare la rete e la stazione pc che si appoggia sull'OPC poi devi prendere un alicenza tra le tante , io ho preso quella del protocollo S7-profibus oggi vado a cremona e vedo di prendere i dati (costa sulle 380-400 euro).poi devi creare un'applicazione client facendo riferimento ad un assembly ( dll in .NET ) tra le tante , ti diro io quale ed il percorso .da qui creare oggetto opc server ,oggetti gruppo , oggetti items crei tutte le strutture array e i tipi di dati che passerai poi alle funzioni di scrittura o lettura sincrone e asincrone puoi gestire anche eventi tipo si scatena un metodo quando cambia un dato entro un certo range all'interno di di un gruppo precedentemente configurato .nel pc metti anche una CP5611 (MPI) e configurando col configuratore scegli profibus nel pc , mentre scegli mpi con relativi indirizzi nel plc .nel plc devi anche aggiungere nuova stazione pc simatic che contiene un rack virtuale dove piazzaerai al primo posto l'op server , al 3 o 4 a seconda dellla scheda la tua cp io nel notebook ho la cp5512 e con un cavo solo mi collego al plc in mpi ,con le dovute parametrizzazioni posso debuggare il pc on line e contemporaneamente lanciare la mi apllicazione per testarla , quindi scrivo da una parte e leggo dall'altra in tempo zero,tutto con un pc ed un cavo mpi .per il C# se non trovi il visual c#.Net 2003 standard che ti consente di realizzare applicazioni windows e web puoi scaricarti l'SDK gratuito , dopo aver installato il file DOTNETFX.msi che ti installa il framework altrimenti non gira un ca**o dunque oaragona C# al java , e il framework .NET alla virtual java machine ma molto piu potente con un 0infinita di classi , la gestione anche qua del Garbage Collettor , il codice sicuro senza punttori se vuoie tante al tre belle cose .con l'sdk devi pero , non avendo il RAD , aggiungere tutti i componenti ed inizializzarli da codice proprieta comrpese .ciao walter Link to comment Share on other sites More sharing options...
walterword Posted July 6, 2004 Report Share Posted July 6, 2004 molti di voi si chiederanno , cosa vorra fare sto pazzo ?semplice :Plc Premium tsx (server ) prot. Modbus su tcp\ip PC client (client) prot. Modbus su tcp\ip oppure Micro Rabbit (client) prot. Modbus su tcp\ip schede acquisizione analog\digital con micro PICdevices vari in SPI o I2C con PIC PIC -RABBIT prot. Modbus RS232-RS485oppure PIC -PC prot. Modbus RS232-RS485oppure RAbbit-PC prot. Modbus RS232-RS485 -oppure Modbus TCP\IPect ect Pls S7-300\400 opc server PC clientPC-Rabbit prot. Modbus RS232-RS485 -oppure Modbus TCP\IPoppure PC-PIC prot. Modbus RS232-RS485schede acquisizione analog\digital con micro PICdevices vari in SPI o I2C con PIC sono aperte le scommesse , riusciro a compiere il mio progetto anzi ns .progettimi sembra di aver capito che siamo in 3-4 io dico di si , di solito quando mi inpunto , costo di morire , ma porto semre a termine quello che voglio bisogna studiare e provare tanto , ma si puo fare sig. nel futuro potrete disporre di una linea nuova che rivoluzionera il mondo dell'automazione industriale ciao walter Link to comment Share on other sites More sharing options...
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now