Fórum témák
» Több friss téma |
Cikkek » Launchpad: ismerkedés az MSP430 mikrovezérlőkkel III. Launchpad: ismerkedés az MSP430 mikrovezérlőkkel III.
Szerző: icserny, idő: Jún 19, 2012, Olvasva: 20566, Oldal olvasási idő: kb. 8 perc
Az MSP430G2553 mikrovezérlő bemutatásaA Texas Instruments az MSP430 Launchpad fejlesztői kártyája az MSP430 mikrovezérlők belépő szintű, ún. Value Line sorozatának (MSP430G2xx sorozat) tagjaihoz készült. Ezek közös jellemzője az ultra kis teljesítményfelvétel, s hogy igen kedvező áron (8-bites mikrovezérlők árszintjén) 16-bites, max 16 Mhz-es mikrovezérlőt nyújtanak, melyek korszerű perifériakészlettel vannak ellátva. E sorok írásának idejéig az MSP430G2xx mikrovezérlőknek három típuscsaládja jelent meg:
A Launchpad kártya újabb (Rev 1.5) kiadáshoz a G2xx2 és a G2xx3 típuscsaládok csúcsmodelljeit (MSP430G2452 és MSP430G2553) kapjuk. Ezek közül az alábbiakban az MSP43G2553 típust mutatjuk be részletesen. Az MSP430G2553 mikrovezérlő lábkiosztásaAz alábbi ábrán az MSP430G2553 mikrovezérlő lábkiosztását láthatjuk (ez az az IC, amelyet gyárilag előre programozottan (a hőmérő demó) és a kártya foglalatába dugva kapunk meg).
Amint a kivezetések mellé írt elnevezések tömkelegéből is látható, a mikrovezérlő jóval több funkció ellátására képes, mint amennyihez egyidejűleg kivezetést tudunk rendelni. A feliratok egy részét így is törölnünk kellett hogy az ábra elférjen az itt rendelkezésre álló hasáb keretei között. Ezért minden program elején az inicializálás során be kell állítanunk, hogy melyik lábat milyen funkció ellátására kívánunk használni. Az általános célú ki-/bemeneti portok kivezetéseit színezéssel jelöltük: a zöld jelzésű kivezetések a P1 porthoz, a piros jelzésűek a P2 porthoz tartoznak. Amint látjuk, a bitek számozása 0-val kezdődik. Mindegyik bit egyedileg beállítható, hogy kimenet, vagy bemenet legyen. A P1.0-P1.7, P2.0-P2.7 elnevezések jelentése tehát már tisztázott. Nézzük, mit fed a többi név! CA0...CA7 az analóg komparátor bemenetei. CAOUT az analóg komparátor kimenete. RXD (vétel) és TXD (adás) az USCI_A egység (univerzális soros kommunikációs egység) UART portjának kivezetései. Ezek az elnevezések a soros kommunikáció hardveres kezelése esetében vannak érvényben. (A szoftveres UART kezelésnél az RXD és TXD kivezetések felcserálődnek!) Megjegyzések:
Elektromos jellemzők
Az MSP430G2553 mikrovezérlő blokkvázlataAz előzőekben "kívülről nézve" vizsgáltuk az MSP430G2553 mikrovezérlőt. Most nézzük meg "belülről" is, lássuk, mi van benne! A narancssárga színezésű blokkok a korábbi cikkekben ismertetett MSP430G2231 mikrovezérlőben nincsenek, tehát ennyivel bővült a perifériakészlet, illetve a korábbi USI modul helyett itt a kombinált USCI_A és USCI_B modul található, amely hardveres UART támogatást is tartalmaz, s az I2C kommunikáció hardveres támogatása is fejlettebb. A Port 3 blokkja azért van lehúzva, mert az csak a 28 lábú tokozásban van kiépítve, az viszont a Launchpad kártyába nem illeszthető be. Piros színnel kiemeltem azokat a paramétereket, amelyekben az új kártya MSP430G2553 mikrovezérlője meghaladja a korábbi (MSP430G2231) mikrovezérlőt: nagyobb memória, több I/O kivezetés, és TIMER0 három Capture/Compare modult tartalmaz. 2_2. ábra: Az MSP430G2553 mikrovezérlő belső felépítésének blokkvázlataA kibővített perifériakészletben helyett kapott egy analóg komparátor is. A régebbi kiadású Launchpad kártyához kapott mikrovezérlőknél az egyikben analóg komparátor volt, a másikban ADC, itt most egyszerre van mindkettő. Újdonság az is, hogy az MSP430G2553 mikrovezérlőben két számláló/időzítő egység (Timer0_A3 és Timer1_A3) kapott helyet. Mindkettő "A típusú", tehát hasonló felépítésű mint a korábbi kiadású Launchpad kártya mikrovezérlőinél, de mindkét modulban 3-3 Capture/Compare regiszter található. A lábkiosztás ismertetésében szereplő TA0.0 ... TA2.2 jeleknél az első szám a számláló/időzítő egység sorszáma (0: Timer0, 1: Timer1), a második szám pedig a Capture/Compare regiszter sorszáma (0: TACCR0, 1: TACCR1, 2: TACCR2). Az USCI egység USCI_A0 modulja UART, LIN, IRDA, vagy SPI kommunikációhoz használható, melyek közül a Launchpad kártya az UART kapcsolatot preferálja, ennek segítségével kommunikálhatunk az emulátoron keresztül a PC-vel. Az USCI_B0 egység SPI vagy I2C kommunikációra használható. A blokkvázlaton nincs feltüntetve, de az adatlapból kiderül, hogy az MSP430G2XX3 mikrovezérlő család tagjai gyárilag beégetett betöltőprogramot (Bootstrap Loader, BSL) is tartalmaznak. A BSL segítségével a P1.1 és P1.5 lábak felhasználásával soros kapcsolaton keresztül tölthetünk be programokat. A Launchpad kártya emulátora azonban fölöslegessé teszi ennek használatát, tehát a következőkben figyelmen kívül hagyjuk a BSL lehetőségét. Az órajel generátor többféle órajelet szolgáltat: MCLK a központi egység (CPU) működtető órajele, ACLK és SMCLK pedig a perifériák működtetésére szolgálnak. A központi egység (Central Processing Unit, CPU), amely 16-bites felépítésű, és 0 - 16 MHz között tetszőleges frekvenciájú órajellel használható, feladata az utasítások elővétele, és végrehajtása. A CPU 16 db. regisztert is tartalmaz, amelyek közül négy speciális célt szolgál, a többi általános célra felhasználható, pl. átmeneti adattárolásra, operandusként, vagy memória címzéshez. Az emulációs egység hardveres nyomkövetésnél két töréspontot képes kezelni, s ide tartozik a JTAG, illetve a Spy-bi-Wire programozó/nyomkövető illesztőáramkör is. A Brownout Protection (BOR) a tápfeszültség esetleges leesését figyeli, s RESET állapotba kényszeríti a mikrovezérlőt, ha a tápfeszültség nem elegendő a mikrovezérlő működéséhez. Ez a védelem arra jó, hogy a mikrovezérlő "félálmában" (amikor az alacsony tápfeszültség miatt az utasítások felismerése és végrehajtása már bizonytalanná válik) nehogy valami nem kívánt dolgot tegyen (pl. felülírja vagy kitörli a memória egy részét). Az "őrkutya" (WDT+, Watchdog Timer) szerepe az, hogy bizonyos időközönként (beállítástól függően) megszakítsa, vagy újraindítsa a programot. Ez például arra használható, hogy a program elakadását (például egy perifériára való eredménytelen várakozást) észlelje és megszakítsa a program. Ehhez a normális futás közben rendszeresen nullázni kell a WDT számlálóját, s akkor nem csordul túl. Ha viszont egy kritikus részen elakad a program, akkor nem jut el a nullázó részhez, s akkor a számláló túlcsordulása RESET-eli a mikrovezérlőt, újraindítja a programot. Alapértelmezetten a CPU 1 MHz-en fut, így a WDT 15 bites számlálója kb. 32 ms elteltével csordul túl. Az analóg-digitális átalakító (ADC) 10-bites felbontású, szukcesszív megközelítést alkalmazó periféria, melynek bemenete előtt egy 8 csatornás analóg multiplexer is található. Az egyes csatornák jelét tehát egyenként lehet megmérni. Másodpercenként max. kb. 200 000 mérés végezhető. A memóriaAz MSP430G2553 mikrovezérlő 16 kB FLASH memóriában tárolja a beégetett programot, s 512 bájt RAM memória áll a változók rendelkezésére. A memória címzése és az adatforgalom is egy-egy 16 bites buszon történik. A memória címtartománya tehát 0x0000-tól 0xFFFF-ig terjed (tízes számrendszerben 0-tól 65535-ig). A címzési egység a bájt, az adatátvitel tehát bájtonként (8-bites egységekben) vagy szavanként (16-bites egységekben) történhet. A szavak címzésekor azonban a cím csak páros lehet. Így a memória 0x0200 és 0x0201 címén elhelyezkedő két bájt megcímezhető szavankénti eléréssel, mert a 0x0200 cím páros, azaz érvényes cím. A memória 0x0201 és 0x0202 címén elhelyezkedő két bájt viszont nem címezhető meg szavankénti eléréssel, mert a 0x0201 cím páratlan, azaz érvénytelen cím. Fontos megjegyeznünk, hogy az utasítások elővétele mindig szavankénti eléréssel történik, tehát az utasítások kötelezően páros címen kezdődnek. Ugró utasításnál sem adhatunk meg páratlan címet. Az MSP430 mikrovezérlőknél a több-bájtos adatok tárolása a "little endian" konvenció szerint történik, vagyis a kisebb memóriacímen az alacsonyabb helyiértékű bájt helyezkedik el. Például, ha a 0x0200 címre az 0x1234 számot írjuk, szó szélességű átvitellel, akkor a 0x0200 című bájt tartalma 0x34 lesz, a 0x0201 című bájtba pedig 0x12 kerül. Az MSP430G2553 mikrovezérlő memória címterületének beosztása az alábbi ábrán látható: 2_3. ábra: Az MSP430G2553 mikrovezérlő memóriatérképe Bekapcsoláskor vagy újraindításkor az első utasítás címét a legmagasabb szócímről (0xFFFE) veszi elő a mikrovezérlő, ez tehát az ún. RESET vektor. Alatta helyezkednek el a programmegszakítási vektorok, amelyek az egyes perifériák vagy "kivételek" esetén aktiválódnak. A programmemória fennmaradó területre (0xC000-0xFFBF címtartományban) helyezhetjük el a programkódot. A programmemória FLASH, nem felejtő memória, kb. 100 000 alkalommal írható újra. Az 0x1000-0x10FF címtartományban elhelyezkedő 256 bájtnyi FLASH információs memória olyan adatok tárolásra szolgál, amelyek a mikrovezérlő kikapcsolása után is megőrződnek (pl. kalibrációs vagy konfigurációs adatok, egyedi sorszám, vagy azonosító). A 256 bájt 4 lapra van osztva, s a legfelsőben gyári beállítások találhatók, mint pl. a gyárilag kalibrált frekvenciák beállításhoz szükséges paraméterek. A változók és a veremtár a RAM adatmemóriát használják (a változók alulról, a veremtár felülről lefelé bővül. A legalsó 16 bájton az ún. speciális funkciójú regisztereket találjuk, amelyek többek között a programmegszakítással kapcsolatos jelzőbiteket és engedélyező biteket tartalmazzák. A perifériák elérése is memóracímzéssel történik. A 0x0010-0x00FF közötti címtartományban a bájtként címezhető, a 0x0100-0x01FF címtartományban pedig a szavankénti elérésű periféria regiszterek találhatók. Bájt elérésűek például az általános célú digitális ki/bemeneti portok regiszterei. Szavanként elérésűek például a flash memória elérésével, az ADC-vel és a Timer0-val kapcsolatos regiszterek. A bájt- és szavak szerinti elérésű periféria regiszterek teljeskörű felsorolása (névvel, címmel) az MSP430G2553 adatlap 14. és 15. táblázataiban található meg. A cikk még nem ért véget, lapozz! Értékeléshez bejelentkezés szükséges! |
Bejelentkezés
Hirdetés |