Individální projekty MPOA

Mikroprocesory s architekturou ARM

Uživatelské nástroje

Nástroje pro tento web


2014:gen2-decoder

Rozdíly

Zde můžete vidět rozdíly mezi vybranou verzí a aktuální verzí dané stránky.

Odkaz na výstup diff

Obě strany předchozí revize Předchozí verze
2014:gen2-decoder [2015/01/17 21:49]
Tomáš Janošík
2014:gen2-decoder [2015/01/18 20:26] (aktuální)
Tomáš Janošík
Řádek 5: Řádek 5:
  
 =====Hardware===== =====Hardware=====
-Dekodér signálu PIE je realizovaný na vývojovom kite KL25Z. ​K splneniu účelu postačuje ​využiť jeden vstupný pin a USB rozhranie. ​Digitálny signál ​PIE generuje iný vývojový kit osadený mikrokontrolérom ATmega16. Po stalčení tlačítka mikrokontrolér vyšle data kódované podľa protokolu Gen2.\\+Dekodér signálu PIE je realizovaný na vývojovom kite KL25Z. ​Z tohto kitu je využitý jeden vstupný pin a USB rozhranie. ​Testovaciu sekvenciu signálu ​PIE generuje iný vývojový kitosadený mikrokontrolérom ATmega16. Po stlačení tlačítka mikrokontrolér vyšle data kódované podľa protokolu Gen2.\\
 {{:​2014:​gen2-decoder:​evb4.3_2_1_.jpg?​direct&​300|}} {{:​2014:​gen2-decoder:​frdm-kl25z.jpg?​direct&​300|}} {{:​2014:​gen2-decoder:​evb4.3_2_1_.jpg?​direct&​300|}} {{:​2014:​gen2-decoder:​frdm-kl25z.jpg?​direct&​300|}}
  
 =====Protokol Gen2===== ​ =====Protokol Gen2===== ​
-Podľa protokolu zahajuje komunikáciu vždy čítačka a to odoslaním Preambuly ​a následne príkazu ​Query. Následne čítačka čaká na odpoveď tagu. Ďaľšie príkazy začína čítačka vždy sekvenciou Frame-Sync. {{ :​2014:​gen2-decoder:​snimka2.png?​direct&​500 |}}+Podľa protokolu zahajuje komunikáciu vždy čítačkaa to odoslaním Preambuly ​s príkazom ​Query. Následne čítačka čaká na odpoveď tagu. Ďaľšie príkazy začína čítačka ​odosielať ​vždy so sekvenciou Frame-Sync. {{ :​2014:​gen2-decoder:​snimka2.png?​direct&​500 |}}
  
-Obsah príkazov tvoria datové 1 a datové 0, kódované podľa nasledujúceho obrázku.+Obsah príkazov tvoria datové ​'1' ​a datové ​'0', kódované podľa nasledujúceho obrázku.
 {{ :​2014:​gen2-decoder:​snimka.png?​direct&​400 |}} {{ :​2014:​gen2-decoder:​snimka.png?​direct&​400 |}}
  
 =====Problém s meraním krátkych pulzov====== =====Problém s meraním krátkych pulzov======
-Maximálna bitová rýchlosť komunikácie v smere od čítačky k tagu je podľa protokolu 128 kbps. Spracovať tento signál procesorom Cortex M0 by na prvý pohľad nemal byť problém. Avšak po rozsiahlých ​pokusoch ​sa nepodarilo merať šírku impulzov, ktoré sú široké rádovo 10-ky us, s dostatočnou presnosťou. Program písaný v prostredí MBED vnášal do čítača chybu okolo 30us, čo znemožňuje merať presné hodnoty impulzov. To je spôsobené pravdepodobne vývojovým prostredím MBED na takúto aplikáciu nie je vhodné, alebo nevhodne napísaným kódom s nedostatočnou optimalizáciou. Riešením tohoto problému je zväčšenie ​šasových intervalov 1000 násobne. Tým vznikne datový signál s šírkou impulzov 10-ky ms, namisto ​us, ktoré sú v protokole. ​Princípy komunikácie sú však zachované+Maximálna bitová rýchlosť komunikácie v smere od čítačky k tagu je podľa protokolu 128 kbps. Spracovať tento signál procesorom ​ARM Cortex M0 by na prvý pohľad nemal byť problém. Avšak po rozsiahlych ​pokusoch sa nepodarilo merať ​s dostatočnou presnosťou ​šírku impulzov, ktoré sú široké rádovo 10-ky us.  Program písaný v prostredí MBED vnášal do čítača chybu okolo 30us, čo znemožňuje merať presné hodnoty impulzov. To je spôsobené pravdepodobne vývojovým prostredím MBED, ktoré ​na takúto aplikáciu nie je vhodné, alebo nevhodne napísaným kódom s nedostatočnou optimalizáciou. Riešením tohoto problému je zväčšenie ​časových intervalov 1000 násobne. Tým vznikne datový signál s šírkou impulzov 10-ky ms, namiesto ​us, ktoré sú v protokole. ​Síce to nevyrieši problém ako taký, ale umožní to otestovať dekodér signálu, ktorý dodržiava princípy komunikačného protokolu Gen2
  
 =====Software==== =====Software====
 ====Signál z čítačky==== ====Signál z čítačky====
 Mikroprocesor ATmega 16 osadený vo vývojovom kite bol naprogramovaný tak, aby po stlačení tlačítka odoslal sekvenciu Preambula + Query + 200ms pauza + Frame-Sync + ACK. Mikroprocesor ATmega 16 osadený vo vývojovom kite bol naprogramovaný tak, aby po stlačení tlačítka odoslal sekvenciu Preambula + Query + 200ms pauza + Frame-Sync + ACK.
-Preambula obsahuje delimiter=12,​5ms,​ tari=6,​25ms,​ RTcal=18ms, TRcal=15ms. Obsah príkazov ​bol zvolený následovne:+Preambula obsahuje delimiter=12,​5ms,​ tari=6,​25ms,​ RTcal=18ms, TRcal=15ms. Obsah príkazov ​je v poli query[] a ack[]:
 <code c> <code c>
 //​...................delimiter, ​ tari , RTcal, TRcal, //​...................delimiter, ​ tari , RTcal, TRcal,
Řádek 57: Řádek 57:
  
 ====Dekodér==== ====Dekodér====
-Základom dekodéru je časovač v kombinácií s prerušeniami na nábežnú a dobežnú hranu. Prerušenie na dobežnú hranu je aktívne len ak dekodér očakáva delimiter(Preambula alebo Frame-Sync). Po prijatí delimiteru je aktívne ​už len prerušenie na nábežnú hranu, pričom ​časovač meria intervaly medzi nábežnými hranami.  ​+Základom dekodéru je časovač v kombinácií s prerušeniami na nábežn[ a dobežnú hranu. Prerušenie na dobežnú hranu je aktívnelen ak dekodér očakáva delimiter(Preambula alebo Frame-Sync). Po prijatí delimiteru je aktívne ​iba prerušenie na nábežnú hranu časovač meria intervaly medzi nábežnými hranami.  ​
 Obsluha prerušení pre nábežnú a dobežnú hranu: Obsluha prerušení pre nábežnú a dobežnú hranu:
 <code c> <code c>
Řádek 146: Řádek 146:
  
 =====Záver===== ​ =====Záver===== ​
-Podarilo sa naprogramovať dekodér základných príkazov vysielaných RFID čítačkou smerom k tagu. Dodržané boli princípy protokolu Gen2, avšak časové intervaly testovacej sekvencie museli byť zväčšené 1000x. Tam kde majú byť podľa protokolu ​mikrosekundami ​tak tento dekodér pracuje s milisekundami. To z dôvodu popísaného kapitole Problém s meraním krátkych pulzov. Výsledkom je dekodér, ktorý síce dodržiava princípy komunikácie podľa protokolu Gen2 ale reálne nepoužiteľný,​ keďže nedokáže merať impulzy so šírkov ​rádovo desiatok mikrosekúnd. Z testovacej sekvencie dekodér dekóduje obsah preambuly- delimiter, tari, RTcal, TRcal a nasledujúci príkaz Query. Ďalej dekóduje Frame-Sync- delimiter, tari, RTcal a ľubovoľný nasledujúci príkaz. ​     ​+Podarilo sa naprogramovať dekodér základných príkazov vysielaných RFID čítačkou smerom k tagu. Dodržané boli princípy protokolu Gen2, avšak časové intervaly testovacej sekvencie museli byť zväčšené 1000x. Tam kde majú byť podľa protokolu ​mikrosekundy ​tak tento dekodér pracuje s milisekundami. To z dôvodu popísaného ​kapitole Problém s meraním krátkych pulzov. Výsledkom je dekodér, ktorý síce dodržiava princípy komunikácie podľa protokolu Gen2ale reálne ​je nepoužiteľný,​ keďže nedokáže merať impulzy so šírku rádovo desiatok mikrosekúnd. Z testovacej sekvencie dekodér dekóduje obsah preambuly- delimiter, tari, RTcal, TRcal a nasledujúci príkaz Query. Ďalej dekóduje Frame-Sync- delimiter, tari, RTcal a ľubovoľný nasledujúci príkaz. ​     ​
   ​   ​
2014/gen2-decoder.1421527753.txt.gz · Poslední úprava: 2015/01/17 21:49 autor: Tomáš Janošík