Thursday, April 29, 2010

Spartan3 ja PicoBlaze programmimälu värskendamine üle JTAG liidese

Kogu vajatav atribuutika selleks on kaasas PicoBlaze protsessori assembleri KCPSM3 failidega XILINX PicoBlaze lehelt.
Tähelepanu tuleb pöörata lühijuhendile JTAG_loader_quick_guide.pdf, mis annab üsna ammendava ja pildirohke seletuse.
  1. Asendada mälu alusfailid ROM_form.vhd ja ROM_form.v, mis vaikimisi on koopiad failidest Normal_ROM_form.vhd ja Normal_ROM_form.v.
    Kopeeri nende asemele failid JTAG_Loader_ROM_form.vhd ja JTAG_Loader_ROM_form.v.
  2. Põhimoodulis, mis paigaldab KCPSM3 ja selle nüüdseks kahepordilise programmimälu, tuleb tagada JTAG-laaditava ROM-mooduli poolt genereeritava RESET-signaali jõudmine protsessorisse. Kui on soov protsessori RESET-i sõltumatult väljastpoolt juhtida, siis tuleb lihtsalt vastavad signaalid liita, nt.:
    reset <= CLEAR or proc_reset; -- siin CLEAR on minu kasutatud välise RESET-signaali nimi
  3. See pole veel kõik - tõenäoliselt tabab teid sünteesil teade, et prog_rom.vhdl failis on puudu komponent BSCAN_VIRTEX2. Tõepoolest, sellist pole Xilinx Unisim teegis olemaski, küll on seal aga BSCAN_SPARTAN3 - ja mis võiks olla parem! S.t. prog_rom.vhdl failis tuleb teha vastav asendus, ju on universaalsena mõeldud KCPSM3 paketis vaiikimisi üht teist Xilinx kiibisarja silmas peetud.
    Veelgi enam - kuna prog_rom.vhdl fail on genereeritud ROM_form.vhd aluspõhjast, siis tuleb see asi korda ajada hoopis aluspõhjas ROM_form.vhd, et uuel programmi kompileerimisel sama tüli ei tekiks!
  4. Kompileerida ja laadida Spartan3 arendusplaadile mistahes kanali/rakenduse kaudu.
Kui nüüd on disainis vaja muuta ainult PicoBlaze programmi, siis sedapuhku saab programmi maha laadida ilma pikka sünteesiprotsessi läbimata.
  1. Programm kompileeritakse nagu tavaliselt, kuid sorry, sobib ainult KCPSM3 kompilaator, mitte pBlazIDE. Viimane ei genereeri väljundiks vajalikku .hex formaadis failil.
  2. Järgneb rida hex faili teisendusi, milleks on KCPSM failide hulgas olemas sobiv käsufail jtag_loader.bat, mis esmalt kontrollib vastava Boundary_scan konfiguratsioonifaili (hex2svf.cnf) olemasolu töökaustas ja puudumisel loob selle dialoogis kasutajaga. Sisendiks tuleb anda Xilinx kiibi tüüp (Spartan3 on 4) ja kirjeldada ahelat, s.t. Spartan3-le eelnevaid ja järgnevaid kiipe ahelas. No Nexys2 arendusplaadil on üks järgnev mäluelement xcf04s, mille kood dialoogis on 8, tavaahel on näha joonisel:

  3. Pärast teisendusi laadib jtag_loader.bat plokk-ROM-i sisu (.xsvf faili) ka paralleelpordis oleva JTAG liidese kaudu Xilinx kiipi.
    USB-liidese kaudu laadimiseks on lihtsaim kasutada Xilinx IMPACT rakendust (alternatiiviks oleks modifitseeritud .bat faili, mis sama IMPACT-i käsurežiimis rakendab). IMPACT graafilises režiimis kasutamiseks tuleb kustutada jtag_loader.bat-failis viimane käsk playxsvf %1.xsvf.
    IMPACT käivitatakse puhta tööväljaga. Kui eelenvast tööst on Boundary-scan ahel tööväljal, siis tuleb see kustutada (klikkides hiire vasaku klahviga elementidel ja ükshaaval kustutades Del-klahviga).
    Seejärel tühjal tööväljal parem hiire klikk ja valida hüpikmenüüst Add Xilinx Device.
    Valida töökaustast vastav .xsvf fail (minul prog_rom.xsvf), mille järele ilmub tööväljale ahel XSVF elemendiga.


    Valida element parema hiire klahviga ja hüpikmenüüst valida Execute XSVF/SVF.
    Prototüüpplaadil võib olla jälgitav (kui programm jooksis ja midagi dünaamiliselt esitas) programmi seiskumine ja toimub PicoBlaze lähestamine. Voila!
Originaaljuhis on SIIN. Samal lehel allpool on soovitusi jtag_loader.bat faili modifitseerimiseks IMPACT kasutamiseks käsurežiimis.
Kui see protseduur on korra juba läbi tehtud, siis järgmistel PicoBlaze koodi uuenduste kordadel piisab lahtihoitud käsu- ja IMPACT akendes väheste korralduste kordamisest, see läheb tõesti nobedalt.

Sunday, April 4, 2010

DMX 4-kanaliline kontroller PAR56-le

Riist- või tarkvara disaini näidisprojekt
Antud artiklis on juttu nö elektroonika hobiprojektist, mis siiski sai autorilt enam tähelepanu, kuna lahendust sai otsitud nii riist- kui tarkvaralisena, seda küll ilma koosdisaini metoodikat kasutamata. Sellest siis ka nihe pealkirjas – mitte riist- ja tarkvara koosdisain vaid riist- või tarkvara disain. Tulemus võib siiski väärida järeletegemist kuna valminud kontroller on küllalt universaalne seade.
Projekti algatas lihtne juhtum – tekkis vajadus lisada 3-värvilisele LED-prožektorile PAR56, mis on küll varustatud sisemise kontrolleriga ja mõningate DIP-lülitilt valitavate valmis värvusskeemide ning värvivahetusprogrammidega, täielikku häälestusulatust lubav lihtne juhtseade. Valgustusseadmete juhtimiseks on olemas ka valmispulte, kuid need olid ühe pro˛ektori kodukasutaja jaoks „liiga head“.
Nagu lähemal uurimisel selgus, on DMX (täpsemini DMX512 [1]) füüsikalisel tasandil sama, mis RS485 [2], s.t. diferentssignaali kasutav jadakoodi andmevahetusstandard. DMX protokoll on lihtne, lausa robustne – kõige lihtsamal juhul ühesuunaline andmepakett, milles iga bait tähendab infot ühe DMX kanali kohta. Konkreetne DMX-seade võib kasutada oma funktsioonide juhtimiseks mingit kanalite vahemikku paketist. Ühte paketti mahub kuni 512 kanalit, selle ulatuse ärakasutamine sõltub juba otstarbest, pakett võib olla palju lühem, olles määratud vajatavate kanalite arvuga. Pakettide vahel on paus (BREAK) loogilisel nivool „0“. Iga pakett algab minimaalselt 12µs märgisega MARK (nivool „1“), millele järgneb startkood (DMX seadmetel on üldjuhul koodiks 0x00) ja seejärel juba kanalid alates number 1-st. Jadakood saadetakse välja andmesõnadena (slot) kujul – startbitt (loogiline „0“), 8 andmebitti alates nooremast ja kaks stoppbitti (loogiline „1“). DMX standard defineerib veel pakettide vahelise pausi minimaalse kestvuse (92 µs ) ja ülekandekiiruse, milleks on üsna aukartustäratav 250kboodi – ühe bit kohta 4 µs aega. Maksimaalse paketipikkuse ja minimaalse pausi korral jõutakse sekundis saata 44 paketti, samas kui seadmed peaksid säilitama tööre˛iimi ka siis kui tuleb ainult üks pakett sekundis. Eri kanalid võivad olla mõeldud eri seadmetele kõik ühe ja sama RS485 signaaliahela (daicy-chain topoloogia) küljes. Iga seade loeb ühisest paketist välja just temale seatud kanalite andmed.


PAR56 prožektor on häälestatud reageerima paketi nelja esimese kanali andmetele, mis on siis vastavalt:
1. Punased LED-d         (koodid 0-255),
2. Rohelised LED-d     (koodid 0-255)
3. Sinised LED-d         (koodid 0-255)
4. Heledus (koodid 0-189), vilkumine (koodid 190-250) ja mittedefineeritud (koodid 251-255).

Niisiis, lähtudes otse standardist, tuleks saata sagedusel 250kHz vähemalt kord sekundis välja 58-bitiline pakett-vektor. Juhul kui PAR56 kõigi kanalite väärtuseks on 127, oleks pakett järgmine (algus paremal):

"1101111111011011111110110111111101101111111011000000000111"  ====>

Kolm „111“ alguses annavad täpselt vajaliku 12µs MARK-sündmuse.
Kui nüüd juhtseadme projekteerimiseks läheb, siis selgub, et kõige lihtsama mikrokontrolleriga seda ära ei teegi, hädavajalik on riistvaralise jadaside mooduli olemasolu  (UART). Ilma selleta oleks paketi saatmine protsessorile üle jõu käiv - tavaline mikrokontrolleri töökiirus on suurusjärgus 1 µs käsutsükli kohta, mille korral jõuaks protsessor teha ühe biti väljasaatmise jooksul vaid 4 käsku – sellest ei piisa, et andmeid ette valmistada. UART moodul võtaks bitthaaval andmesõna formeerimise vaeva enda peale ja baithaaval andmeid ette sööta jõuab siis ka palju aeglasem protsessor (baidi saateaeg koos START ja kahe STOP-bitiga on 11 x 4 = 44 µs). Signaali pausiaeg on DMX korral piisavalt pikaks venitatav (kuni 1 sekund), et selle jooksul mistahes protsessor mistahes kasutajaliidese töötlemisega toime tulla.
Kuidas oleks aga riistvaraline lahend väliprogrammeeritaval kiibil? Tegelikult väga elementaarne – riistvaras võib kuitahes pikki bitivektoreid moodustada, vajalikud andmebaidid tuleb vaid vektorisse õigesse positsiooni omistada ja 250kHz taktiga väljundisse suunata. Kasutajaliidest võib riistvara töödelda paralleelselt jadakoodi väljastamisega, selleks jätkub ressursse ka kõige tagasihoidlikumas FPGA-kiibis.


-- Nexus 2 on takteeritud 50MHz signaaliga, millest teeme esmalt 25MHz signaali
kell: process(clock)
  begin
    if rising_edge(clock) then
      clk <= not clk;
    end if;
  end process kell;


-- DMX jaoks 250KHz signaali tegemine 25MHz taktisignaalist   
txkell: process(clk)   
  begin
    if rising_edge(clk) then
      if txclk_cnt /= 49 then
        txclk_cnt <= txclk_cnt + 1;
      else
        txclk_cnt <=(others =>'0');
        txclk <= not txclk;
      end if;
    end if;
  end process txkell;


-- Main procedure
counting : process(txclk,reset)
  begin
    if reset = '1' then
      DE  <= '1'; -- lubav signal RS485 kiibi väljundile
      txcnt <= (others =>'0'); -- tsükliloendur (pakett + paus)
      dmxvector <= "1101111111011011111110110111111101101111111011000000000111";
    else
      if rising_edge(txclk) then
        txcnt <= txcnt + 1;
        if txcnt <= 1279 then –-paketitsükli kestvus 1280 x 4 us = 5.12ms
          dmxvector <= '0' & dmxvector (57 downto 1);    -- nihe paremale
        else
          txcnt <=(others =>;'0');<           dmxvector <= "11" & dmxch4 & "011" & dmxblue & "011" & dmxgreen & "011" & dmxred & "011000000000111"; -- DMX pakett-vektori moodustamine
        end if;
      end if;
    end if;   
  end process counting;


TxDI <= dmxvector(0); -- vektori kõige parempoolne bitt väljundisse DMX-signaaliks

Tervikkirjeldusse kuulub veel  komponent, mis tagab signaalide dmxred,dmxgreen, dmxblue ja dmxch4 juhtimise kasutaja poolt. Võib öelda, et kood töötas esimesest katsest, lubades pro˛ektorit vabalt juhtida ning katsetamise käigus proovida läbi erinevaid kasutajaliideseid.

Eksperiment: Tarkvaraline lahendus
Tarkvara kandjaks protsessor Microchip PIC16F88, arendustarkvaraks  Microchip IDE (vabavara) ja CCS C-kompilaator PCM (kommertsprodukt [4]).
Mikrokontroller PIC16F88 on lihtne 8-bitilise arhitektuuriga 18-väljaviiguline protsessor, mis on paljude lisade hulgas varustatud asünkroonse jadaliidesega (USART). Dokumentatsiooni järgi suudab USART protsessor 4MHz sisemise takti korral genereerida vabalt 250kboodist jadasignaali.
Koodi kirjutamisel tuli tõdeda mitmeid üllatusi, mis nõudsid paljusid katseid enne kui tulemus PAR56 pro˛ektorit allutama hakkas:
1. Selgus, et PIC16F88 PortA on vaikimisi analoogsisenditena häälestatud, s.t. digitaalsisenditena kasutamiseks tuli analoogmoodul välja lülitada. Muidugi oli see ka dokumentatsioonis kirjas.
2. PIC16F88 USART ei ole otseselt häälestatav kahe stop-bitiga jadaprotokollile. Siiski, kuna andmeüksuse suurus võib olla ka 9 bitti, siis oli võimalik sättida 9-s bitt täitma esimese stopp-biti rolli (konstantselt „1“). Seda tuli siis teha väljaspool CCS PCM kompilaatori standardfunktsioone (assembleris).
3. PIC16F88 USART ei toetanud otseselt DMX protokolli. Tõsi küll, USART oskab genereerida väidetavalt RS485-toetuseks mõeldud ENABLE-signaali, mis on aktiivne andmesõna saatmise ajal, kuid ei oleks taganud vajalikku MARK signaali kestvust ja pealegi muutub ENABLE korraks passiivseks ka andmesõnade vahel, mis rikuks DMX-paketi kuju.
4. USART väljund jääb andmesõnade saatmise vaheajal kõrgeks „1“ . Kuna DMX protokoll nõuab BREAK tingimuse moodustamist, mille ajal signaal on „0“, siis lõppkokkuvõttes tuli BREAK ja MARK tingimused samuti genereerida väljaspool kompilaatori standardfunktsioone.
Nimetatud erisused tegid iseenesest triviaalse ülesande lahendamise ajakulukas ja väljundsignaali tegeliku kuju tuvastamiseks ja häälestamiseks tuli kasutada digitaalostsillograafi.
Lõppjäreldused
Riistvara (Nexys 2 ja Xilinx FPGA)
  • Geomeetria: Halb, defineeritud arendusplaadi suurusega ~180cm2
  • Katseplatvorm: Hea, triviaalne kodeerimine lähtudes otseselt standardist
  • Arendusaeg: Tunde
  • Kompileerimise/sünteesi  ja mahalaadimise aeg: Minutites
  • Hind: Nexys arendusplaat -$99, RS485 ajur -$3
Tarkvara (PIC16F88)
  • Geomeetria: Hea, plaadi suurus määratud  protsessori ja ajurikiibi poolt ~18cm2
  • Katseplatvorm: Komplitseeritud tingituna USART otsesest mittesobivusest konkreetse (DMX) protokolliga
  • Arendusaeg: Päevi
  • Kompileerimise/sünteesi  ja mahalaadimise aeg: Sekundites
  • Protsessor - $5, RS485 ajur - $3, CCS PCM C-kompilaator - $150

Tuleb tunnistada, et mõlematel variantidel on plusse ja miinuseid.  Kiireks prototüüpimiseks on riistvaraline lahendus FPGA-l vägagi sobiv ja eriti ladusalt läheb standardikohase protokolli genereerimine. Samas iga arendusplaadi väline lisafunktsionaalsus nõuab väliste riistvaraliste moodulite lisamist (näiteks mikrokontrolleris on mugav sisemine EEPROM, mida võib kasutada oleku säilitamiseks seadme väljalülitatud olekus; Nexys 2 arendusplaadil tulnuks sellise funktsionaalsuse saamiseks lisada mälukaardi moodul).
Tarkvaraline lahendus sobib lõppteostuseks paremini, kuid nõuab protsessori ning kompilaatori dokumentatsiooni põhjalikku uurimist, et kõigi võimaluste ja tõkete rägastikus leida sobiv tee protokolli ja muu funktsionaalsuse teostuseks.
Lõpptulemus, nelja kanaliga ja nelja mäluga DMX kontroller koos PAR56 prožektoriga on näha järgmisel fotol:

Seadme kasutajaliidesel on neli nuppu värvide valikuks (ühtlasi ka mälupesade valikuks), nupud valitud värvi väärtuse kerimiseks ning värvuskombinatsiooni salvestus- ja taasesitusnupud.
Projektifailid on veebis [5]: PIC16F88-ga DMX-kontrolleri skeem ja trükkplaat CadSoft Eagle failidena, kontrolleri tarkvara CCS PSM C-ning kompileeritud HEX-koodis ning Nexys 2 arendusplaadile mõeldud kontrolleri tipptaseme komponendi kirjeldus VHDL keeles.

Viiteid
1. DMX512, http://en.wikipedia.org/wiki/DMX512
2. Jan Axelson, Designing RS-485 Circuits, http://lms.uni-mb.si/~meolic/students/mpk/designingRS485.pdf
3. Nexys 2 FPGA board, http://www.digilentinc.com/Products/Detail.cfm?NavPath=2,400,789&Prod=NEXYS2
4. CCS Compilers, http://www.ccsinfo.com/content.php?page=compilers
5. Kontrolleri projektifailid (tarkvara uusim versioon dets. 2011!!!):  http://mini.li.ttu.ee/~nalle/tmp/DMX_PAR56contoller

Followers