Atmel AVRDe AVR is een 8 bit-RISC-microcontroller (µC) ontwikkeld door Atmel in 1996. De AVR was een van de eerste microcontroller-families die standaard gebruik maakte van on-chip-flashgeheugen voor programmaopslag in plaats van een noodzakelijke externe PROM, EPROM of EEPROM. ApparaatoverzichtDe AVR is een modified Harvard-architectuurapparaat waarbij het programma en de data worden benaderd via aparte fysieke geheugensystemen. FamiliesAVR's worden algemeen ingedeeld in vier groepen:
Input en outputDe elektrische, elektronische en functionele eigenschappen van de verbindingen van de Atmel AVR met de buitenwereld zijn multifunctioneel. Het grote probleem bij elektrische schakelingen is de fysieke ruimte die nodig is voor de pinnen, connectoren en bedrading. Door de verregaande verkleining van de schakelingen bij integratie op een chip, kan daar intern in het IC een functionaliteit worden aangebracht die ten dienste staat om de externe verbindingen optimaal in te stellen. Dit vereist voor de programmeur inzicht in de vele mogelijkheden waaruit een keuze moet worden gemaakt voor het doel waarvoor de processor wordt gebruikt. Bij het opstarten moeten eerst de juiste input en output registers geïnitialiseerd worden. Zo kunnen de aansluitpennen qua elektrische eigenschappen ingesteld worden op bijvoorbeeld op hoge en lage impedantie (tri-state) of op open drain met "trekweerstand". Bij de oscillator kan vaak gekozen worden voor een interne oscillator of met een externe oscillator, met digitale ingang of met condensator of met kristal. De elektronische eigenschappen kunnen ingesteld worden op ingang of op uitgang. Bij de ingang kan gekozen worden voor digitale of analoge ingangen. In het geval van analoge ingangen een comparator of A-D-converter. Functioneel worden allerlei combinaties via interne multiplexing zowel analoog als digitaal mogelijk gemaakt: bijvoorbeeld UART of I2C of 1-wire of PWM enz. ArchitectuurData RAMFlash, EEPROM, en SRAM zijn allemaal geïntegreerd in één chip, waardoor de noodzaak voor extern geheugen verdwijnt. Sommige apparaten hebben een externe bus voor extra datageheugen. Programmageheugen (flash)Programma-instructies worden opgeslagen in niet-vluchtig geheugen. Hoewel het 8 bits-MCU's zijn, gebruikt elke instructie een of twee 16-bitswoorden. De grootte van het programmageheugen wordt meestal aangeduid in de naam van het apparaat (de ATmega64-lijn heeft bijvoorbeeld 64 kB flashgeheugen. Er is geen mogelijkheid voor extern programmageheugen; alle code uitgevoerd door de AVR-kern moet in het on-chip flashgeheugen zitten. Intern datageheugenDe data-adresruimte bestaat uit het registerbestand, I/O-registers en SRAM. Interne registersDe AVR's hebben 32 single-byteregisters en zijn geclassificeerd als 8 bits-RISC-apparaten. In de meeste varianten van de AVR-architectuur worden de werkregisters gemapt in de eerste 32 geheugenadressen (0x0000-0x001F) gevolgd door de 64 I/O-registers (0x0020-0x005F). Het daadwerkelijke SRAM begint na deze registers (adres 0x0060). (De I/O-registerruimte kan groter zijn bij sommige uitgebreidere apparaten waarbij dus een deel van het SRAM-gedeelte wordt gebruikt.) Hoewel het registerbestand en de I/O-registers apart kunnen worden aangesproken met speciale opcodes, kunnen ze ook worden aangesproken en gemanipuleerd alsof ze in het SRAM zitten). EEPROMBijna alle AVR-microcontrollers hebben intern "Electrically Erasable Programmable Read Only Memory" (EEPROM) voor semi-permanente dataopslag. Net als het flashgeheugen behoudt het EEPROM zijn data als de spanning wegvalt. In de meeste varianten van de AVR-architectuur wordt het interne EEPROM-geheugen niet gemapt in de adresseerbare geheugenruimte van de MCU. Het kan alleen worden aangesproken met speciale pointerregisters en lees-/schrijfinstructies. Hierdoor is het EEPROM-geheugen een stuk langzamer dan het interne SRAM. Doordat het aantal schrijfbewerkingen van EEPROM-geheugen beperkt is – Atmel specificeert 100 000 schrijfbewerkingen in zijn datasheets – zou een goed ontworpen EEPROM-schrijfroutine moeten controleren of de data afwijkt van de gewenste data alvorens deze wordt geschreven. Programma-uitvoeringAtmels AVR's hebben een tweestaps, enkel niveau pijplijn-ontwerp. Dit houdt in dat de volgende machine-instructie wordt opgehaald als de huidige wordt uitgevoerd. De meeste instructies duren slechts één of twee cycli, wat de AVR's relatief snel maakt onder de 8 bits-microcontrollers. De AVR-familie van processors werd ontworpen met de efficiënte uitvoering van gecompileerde C-code in gedachte en heeft diverse ingebouwde pointers voor de taak. InstructiesetDe AVR-instructieset is meer orthogonaal dan de meeste 8 bits-microcontrollers, met name de PIC-microcontrollers waarmee AVR concurreert. Hij is echter niet compleet regulier:
Verder beïnvloeden sommige chipspecifieke verschillen de codegeneratie. Codepointers bestaan uit twee bytes op chips met 128 kB of minder flashgeheugen, maar drie bytes op de grotere chips; niet alle chips hebben hardwarevermenigvuldigers; chips met meer dan 8 kB flashgeheugen hebben branch- en call-instructies met langere ranges etc. De grotendeels reguliere instructieset maakt het programmeren met C- (of zelf Ada-)compilers vrij eenvoudig. GCC heeft al enige tijd AVR-ondersteuning die veel gebruikt wordt. Atmel vroeg zelfs om input van grote compilerontwikkelaars voor kleine microcontrollers, om te bepalen welke instructieset het nuttigste is voor een compiler. SnelheidDe AVR-lijn ondersteunt snelheden van 0-20 MHz, waarbij sommige apparaten tot 32 MHz reiken. Werking op lager vermogen vereist meestal een gereduceerde kloksnelheid. Alle recente (Tiny en Mega, niet de 90S) AVR's hebben een on-chip oscillator, waardoor er geen externe klok of resonantiecircuit meer nodig is. Sommige AVR's hebben ook een systeemklokdeler, die de klok kan delen met tot 256. Deze prescaler kan worden geherconfigureerd tijdens run-time, wat een geoptimaliseerde kloksnelheid toestaat. Aangezien alle operaties op registers R0-R31 een enkele cyclus gebruiken, kan de AVR tot 1 MIPS (miljoen instructies per seconde) per MHz halen. Laden en opslaan van en naar het geheugen duurt 2 cycli, branching duurt 3 cycli. Branching in de laatste "3 byte-pc"-onderdelen zoals de ATmega2560 zijn 1 cyclus langzamer. OntwikkelingAVR's worden veel gebruikt doordat er gratis en goedkope ontwikkelhulpmiddelen beschikbaar zijn, inclusief redelijk geprijsde ontwikkelborden en gratis ontwikkelsoftware. De AVR's worden verkocht onder verschillende namen die dezelfde basiskern, maar verschillende peripherals en geheugencombinaties hebben. Compatibiliteit tussen chips van elke familie is vrij goed, hoewel I/O-controllermogelijkheden variëren. MogelijkhedenAVR's bieden een grote reeks mogelijkheden:
Ontwikkelhulpmiddelen en evaluatiekitsDe officiële Atmel AVR-ontwikkelhulpmiddelen en -evaluatiekits bestaan uit een aantal starterskits en debughulpmiddelen met ondersteuning voor de meeste AVR-apparaten: STK600 Starter KitDe STK600-starterskit en -ontwikkelsysteem is een update van de STK500.[1] De STK600 gebruikt een basisbord, een signaalroutingbord en een targetbord. Het basisbord is hetzelfde als de STK500 en heeft een spanningsbron, een clock, in-systeem programmeren, RS-232-poorten en -connectoren voor de GPIO-signalen van het doelapparaat. Het targetbord heeft ZIF-sockets voor DIP-, QFN- of QFP-behuizingen, afhankelijk van het bord. Het signaalroutingbord zit tussen het basisbord en het targetbord, en verbindt de signalen aan de juiste pinnen op het targetbord. Er zijn veel verschillende routingborden die gebruikt kunnen worden met een enkel targetbord, afhankelijk van het apparaat in de ZIF-socket. De STK600 wordt verbonden met de pc via een USB-aansluiting, waardoor beide RS-232-poorten beschikbaar zijn voor de microcontroller. STK500 Starter KitDe STK500-starterskit en -ontwikkelsysteem heeft een ISP en een HVP (High Voltage Programming) voor alle AVR-apparaten, ofwel direct of via een uitbreidingsbord. Het bord bevat DIP-sockets voor alle beschikbare AVR's in DIP-behuizingen. Er zijn verschillende uitbreidingsmodules beschikbaar voor de STK500:
AVR ISP en AVR ISP mkIIDe AVR ISP en AVR ISP mkII zijn goedkope hulpmiddelen om AVR's te programmeren via ICSP De AVR ISP wordt verbonden met de pc via een seriële poort en haalt zijn spanning uit het doelsysteem. De AVR ISP staat gebruik van beide "standaard" ICSP-pinouts toe, de 10 pins- of de 6 pins-connector. De AVR ISP wordt niet meer geproduceerd en is vervangen door de AVR ISP mkII. De AVR ISP mkII wordt verbonden met de pc via een USB-aansluiting en haalt zijn spanning van de USB-poort. Leds die zichtbaar zijn door de doorzichtige behuizing geven de status van spanning van het doelsysteem aan. AVR DragonDe Dragon is een goedkoop hulpmiddel dan wordt verbonden met de pc via een USB-aansluiting. De Dragon kan alle AVR's programmeren via JTAG, HVP of ICSP. De Dragon biedt ook ondersteuning voor het debuggen van AVR's met minder dan 32 kB aan programmageheugen, via JTAG of debugWIRE. De Dragon heeft een klein prototypegebied waar een 8, 28 of 40 pins-AVR kan worden aangesloten. JTAGICE mkI en mkIIHet Joint Test Action Group, In Circuit Emulator (JTAGICE) debug hulpmiddel biedt ondersteuning voor on-chip debugging (OCD) van AVR's met een JTAG-interface. De originele JTAGICE mkI gebruikt een RS-232-interface als verbinding met de pc. De JTAGICE mkI wordt niet meer geproduceerd en is vervangen door de JTAGICE mkII. Het JTAGICE mkII debug hulpmiddel ondersteunt on-chip debugging (OCD) van AVR's met de JTAG, PDI of debugWIRE-interface. De debugWIRE-interface gebruikt slecht één pin (de Resetpin), waardoor debuggen mogelijk is voor applicaties met een microcontroller met weinig pinnen. De JTAGICE mkII wordt verbonden met de pc via een USB-aansluiting, maar er is een alternatieve aansluiting via een seriële poort, die een losse voeding nodig heeft. Naast JTAG ondersteunt de mkII programmeren via ISP (via de 6 of 10 pins-adapters). Zowel de USB- als de seriële variant gebruikt een versie van het STK500-protocol. Butterfly Demo BordHet zeer populaire AVR Butterfly-demonstratiebord is een zelfvoorzienende computer met batterijvoeding die draait op de Atmel AVR ATmega169V-microcontroller. Het was gebouwd om te pronken met de AVR-familie, in het bijzonder de nieuwe ingebouwde lcd-interface. Het bord bevat een lcd-scherm, een joystick, een speaker, een seriële poort, realtime clock (RTC), flash-geheugenchip en zowel temperatuur- als spanningssensoren. Eerdere versie van de AVR Butterfly bevatten ook een CdS-fotoweerstand; deze is niet meer aanwezig op borden geproduceerd na juni 2006 om aan de RoHS-norm te voldoen. Het kleine bord heeft een shirt-pin aan de achterkant zodat het als naamplaatje kan worden gedragen. De AVR Butterfly komt met vooraf geladen software om de mogelijkheden van de microcontroller te demonstreren. De fabrieksfirmware kan je naam laten scrollen, de sensorwaarden weergeven en de tijd weergeven. De AVR Butterfly demonstreert lcd-aansturing door een 14 segments-, 6 alpha-numeriek karakterdisplay aan te sturen. De lcd-interface gebruikt echter wel veel van de I/O-pinnen. De ATmega169 CPU van de Buttferly kan snelheden tot 8 MHz aan, maar is door de fabrieksfirmware ingesteld op 2 MHz om de batterijduur te verlengen. Een vooraf geïnstalleerd bootloaderprogramma geeft de mogelijkheid het bord te herprogrammeren via een standaard seriële RS-232-aansluiting met nieuwe programma's die gebruikers kunnen schrijven met het gratis Atmel IDE-hulpmiddel. AT90USBKeyDit kleine bord, ongeveer de helft van een creditcard, is iets duurder dan de AVR Butterfly. Het bevat een AT90USB1287-microcontroller met USB-On-The-Go (OTG), 16 MB DataFlash, leds, een kleine joystick en een temperatuursensor. Via de bijgeleverde software kan het bord zich gedragen als een USB-opslagapparaat, een USB-joystick en meer. Om als USB-host te werken is een batterij nodig, maar als USB-randapparaat gebruikt het alleen de spanning van de USB-poort. Alleen de JTAG-aansluiting gebruikt de normale 2,54mm-pinafstand. Alle andere AVR I/O-poorten gebruiken compactere 1,27mm-headers. Doordat de AT90USBKey 128 kB aan flashgeheugen heeft kan een AVR Dragon hem alleen programmeren en niet debuggen. Een JTAGICE kan hem zowel programmeren als debuggen. De processor kan ook worden geprogrammeerd via USB vanaf een Windows- of Linux-host, met USB "Device Firmware Update"-protocollen. LUFA is een gratis USB-protocolstack voor de USBKey gemaakt door derden (MIT license). Raven Wireless KitDe RAVEN-kit ondersteunt draadloze ontwikkeling met Atmels IEEE 802.15.4-chipsets voor ZigBee en andere draadloze stacks. Het stelt één paar draadloze Buttefly-kaarten voor plus een draadloze USBKey en kost ongeveer hetzelfde als deze samen (onder $100). Alle borden ondersteunen ontwikkeling via JTAG. De kit bevat twee AVR Ravenborden, beide met een 2,4GHz-transceiver met ondersteuning voor IEEE 802.15.4 (en een ZigBee-stack met gratis licentie). De radio's worden aangestuurd met ATmega1284p-processoren, die ondersteund worden door een aangepast gesegmenteerd lcd-display aangestuurd door een ATmega3290p-processor. Raven-peripherals lijken op de Butterfly; piëzospeaker, DataFlash (groter), externe EEPROM, sensoren, 32kHz-kristal voor RTC etc. Deze zijn bedoeld voor het ontwerpen van op afstand aanstuurbare sensormodules, het aansturen van relais of wat maar nodig is. De USB-stick gebruikt een AT90USB1287 voor verbindingen met een USB-host en de draadloze 2,4GHz-verbindingen. Ze zijn bedoeld voor het uitlezen en aansturen van draadloze modules, gebruikmakend van spanning van de host in plaats van batterijen. Programmers door derdenEr zijn een groot aantal programmeer- en debughulpmiddelen beschikbaar van derden. Deze apparaten gebruiken verschillende interfaces, waaronder RS-232, parallelle poort en USB. AVR Freaks heeft een uitgebreide lijst. GebruikAVR's worden gebruikt in verschillende automotive toepassingen zoals beveiliging, veiligheid en entertainment systemen. Atmel heeft een publicatie gelanceerd genaamd "Atmel Automotive Compilation", om nieuwe ontwikkelaars te helpen met automotive toepassingen. Het Arduino computerplatform is gebaseerd op een ATmega328-microcontroller (ATmega168 of ATmega8 in oudere versies). De ATmega1280, met meer pinnen en geheugen beschikbaar, is ook gebruikt om het Arduino Megaplatform te ontwikkelen. Arduino borden kunnen worden gebruikt met zijn eigen taal en IDE, of met meer conventionele programmeeromgevingen (C/ASM/etc.) zoals de standaard AVR-platformen. Arduino borden kunnen op vele manieren geprogrammeerd worden. Dit gebeurt via een speciaal software programma. USB-gebaseerde AVR's zijn gebruikt in de Microsoft Xbox hand-controllers. De link tussen de controllers en de Xbox is USB. Verschillende bedrijven produceren AVR-gebaseerde microcontroller borden, bedoeld voor gebruik door hobbyisten, robotbouwers, experimenteurs en kleine systeemontwikkelaars. System Semiconductor, Inc. produceert de M3000 Motor en Motion Control, waarin een Atmel AVR-kern en een Advanced Motion Controller zijn opgenomen. Nieuwe 32 bits-AVR'sIn 2006 bracht Atmel-microcontrollers uit gebaseerd op een nieuwe, 32-bits AVR32-architectuur. Deze bevatten SIMD- en DSP-instructies, samen met andere audio- en videoverwerkingsmogelijkheden. Deze 32 bitsfamilie van apparaten is bedoeld om te concurreren met de op ARM gebaseerde processoren. De instructieset lijkt op andere RISC-kernen, maar is niet compatibel met de originele AVR of een van de ARM-kernen. Lego heeft firmwarebroncodebestanden uitgebracht voor de 32 bits-AVR's om te helpen in de ontwikkeling van de opensourcealternatieven van zijn populaire robotica-NXT-besturingssysteem. Externe links
Bronnen, noten en/of referenties
|