BLIT2008-Board
Aus BraLUG-Wiki
(→Erweiterungsbaugruppen) |
(→Aktuelles) |
||
(23 dazwischenliegende Versionen von einem Benutzer werden nicht angezeigt) | |||
Zeile 3: | Zeile 3: | ||
=Aktuelles= | =Aktuelles= | ||
+ | * '''10.05.2012''': [[BLIT2008-Board ADC]] | ||
+ | * '''12.05.2009''': seit ein paar Tagen experimentiere ich mit [[BLIT-Board-SD-Card|SD-Karten plus BLIT-Board]] rum, hier mal ein Anfang zur Dokumentation... | ||
+ | * '''04.05.2009''': Baugruppe [[BLIT2008-Board-7-Segment-Anzeige|7-Segment-Anzeige]] realisiert | ||
+ | * '''24.04.2009''': um mal wieder etwas über meine Aktivitäten rund ums BLIT-Board zu berichten: ich bin gerade dabei zwei Dinge zu realisieren. Hier schon mal die Links zu den entsprechenden Unterseiten: | ||
+ | ** [[BLIT2008-Board kann sprechen|BLIT-Board plappert vor sich hin...]] | ||
+ | ** [[BLIT2008-Board spielt Schach|BLIT-Board kann Schach spielen...!]] | ||
+ | * '''30.01.2009''': [[BLIT2008-Board mit 1-Wire|BLIT-Board goes to 1-Wire...]] | ||
+ | * '''08.01.2009''': aus der Beispielapplikation ''rc5_usb_mouse'' für das BLIT-Board ist ein eigenständiges Projekt ([[Infrarot-USB-Maus_im_Eigenbau]]) geworden. | ||
+ | * '''12.12.2008''': [[BLIT2008-Board-DCF77|TWI(I²C)-DCF77]] ist fertig! | ||
+ | * '''01.12.2008''': Seite etwas umgebaut | ||
* '''27.11.2008''': Markus hat auf dem BLIT-Board erfolgreich ''i2c-tiny-usb'' ausprobiert und dazu eine [[BLIT2008-Board_mit_i2c-tiny-usb-Firmware|Wiki-Seite]] erstellt | * '''27.11.2008''': Markus hat auf dem BLIT-Board erfolgreich ''i2c-tiny-usb'' ausprobiert und dazu eine [[BLIT2008-Board_mit_i2c-tiny-usb-Firmware|Wiki-Seite]] erstellt | ||
− | * '''17.11.2008''': Schaltung für [[BLIT2008-Board | + | * '''17.11.2008''': Schaltung für [[BLIT2008-Board-DCF77|DCF77-Baugruppe]] |
* '''16.11.2008''': Programm [http://bralug.de/wiki-common/images/8/84/Tasten_matrix.tar.gz tasten_matrix] zur Ansteuerung einer [[BLIT2008-Board#I2C-Tastatur|4x4-Tasten-Matrix]] | * '''16.11.2008''': Programm [http://bralug.de/wiki-common/images/8/84/Tasten_matrix.tar.gz tasten_matrix] zur Ansteuerung einer [[BLIT2008-Board#I2C-Tastatur|4x4-Tasten-Matrix]] | ||
* '''16.11.2008''': Programm [http://bralug.de/wiki-common/images/3/39/Led_matrix.tar.gz led_matrix] zur Ansteuerung einer [[BLIT2008-Board#I2C-Tastatur |4x4-LED-Matrix]] | * '''16.11.2008''': Programm [http://bralug.de/wiki-common/images/3/39/Led_matrix.tar.gz led_matrix] zur Ansteuerung einer [[BLIT2008-Board#I2C-Tastatur |4x4-LED-Matrix]] | ||
Zeile 71: | Zeile 81: | ||
=Basis-Board= | =Basis-Board= | ||
==Hardware== | ==Hardware== | ||
+ | ===Schaltplan=== | ||
[[Bild:Blit2008-board-v6.png|320px|BLIT2008-Basisboard]] | [[Bild:Blit2008-board-v6.png|320px|BLIT2008-Basisboard]] | ||
[[Bild:Proto blitboard.jpg|320px|BLIT2008-Basisboard-Prototyp hier mit einer zusätzlichen LED und einem Reset-Taster]] | [[Bild:Proto blitboard.jpg|320px|BLIT2008-Basisboard-Prototyp hier mit einer zusätzlichen LED und einem Reset-Taster]] | ||
[[Bild:Fert blitboard.jpg|320px|BLIT2008-Basisboard; die erste fertig bestückte Leiterplatte]] | [[Bild:Fert blitboard.jpg|320px|BLIT2008-Basisboard; die erste fertig bestückte Leiterplatte]] | ||
+ | [http://bralug.de/wiki-common/images/a/a9/Blit_board_eagle.tar.gz Eagle-Dateien (Schaltplan und Leiterplatte)] | ||
+ | |||
+ | ===Beschreibung=== | ||
Diese Baugruppe stellt das "Herzstück" dar und besteht aus folgenden Komponenten: | Diese Baugruppe stellt das "Herzstück" dar und besteht aus folgenden Komponenten: | ||
* als Mikrocontroller ein [http://atmel.com/dyn/resources/prod_documents/doc2486.pdf ATmega8]; alternativ kann auch ein pinkompatibler [http://atmel.com/dyn/resources/prod_documents/doc2545.pdf ATmega168] eingesetzt werden, wenn man mehr Speicher benötigt (wobei dabei aber einige Anpassungen in den Beispielprogrammen notwendig sind, da sich diverse Registerbezeichnungen ändern) | * als Mikrocontroller ein [http://atmel.com/dyn/resources/prod_documents/doc2486.pdf ATmega8]; alternativ kann auch ein pinkompatibler [http://atmel.com/dyn/resources/prod_documents/doc2545.pdf ATmega168] eingesetzt werden, wenn man mehr Speicher benötigt (wobei dabei aber einige Anpassungen in den Beispielprogrammen notwendig sind, da sich diverse Registerbezeichnungen ändern) | ||
Zeile 93: | Zeile 107: | ||
− | + | ===Stückliste=== | |
{| border=1 | {| border=1 | ||
|- | |- | ||
Zeile 329: | Zeile 343: | ||
Nachteil der Variante mit einem installierten Bootloader ist, dass dadurch etwas Programmspeicher auf dem Mikrocontroller "verloren" gehen. Im Fall von avrusbboot sind es 2kByte. Aber es bleiben bei einem ATmega8 noch 6kByte übrig, was für die folgenden Beispiele mehr als genug ist... | Nachteil der Variante mit einem installierten Bootloader ist, dass dadurch etwas Programmspeicher auf dem Mikrocontroller "verloren" gehen. Im Fall von avrusbboot sind es 2kByte. Aber es bleiben bei einem ATmega8 noch 6kByte übrig, was für die folgenden Beispiele mehr als genug ist... | ||
+ | |||
+ | |||
+ | ===USBaspLoader=== | ||
+ | Möchte man einen ATmega168 auf dem BLIT-Board betreiben, der ja doppelt soviel Flash-Speicher zur Verfügung stellt und Pin-kompatibel zum ATmega8 ist, lässt sich AVRUSBBoot nicht übersetzen. Einige Registerbezeichnungen sind anders als beim kleinen Bruder und dies wurde im Quelltext der Firmware nicht entsprechend ausprogrammiert. Aus diesem Grund sah ich mich nach einem anderen Bootloader um, der ebenfalls via USB-Schnittstelle funktioniert und würde auch fündig: [http://www.obdev.at/products/vusb/usbasploader.html USBaspLoader] von [http://www.obdev.at objective development]. Nebenbei kauft man sich gleich noch einen weiteren Vorteil ein, der Bootloader benötigt kein eigenes spezielles Tool für den PC, sondern funktioniert auch mit avrdude. | ||
+ | |||
+ | Damit dieser Bootloader auf dem BLIT-Board funktioniert, sind ein paar kleiner Anpassungen am Orginal-Quelltext (den man sich von obigen Link besorgt) vorzunehmen: | ||
+ | |||
+ | '''firmware/Makefile''': | ||
+ | <br> | ||
+ | Die korrekte Quarzfrequenz (F_CPU) und Device (DEVICE) sind einzutragen. | ||
+ | <br><br> | ||
+ | '''firmware/bootloaderconfig.h''': | ||
+ | <br> | ||
+ | * die USB-Pins anpassen | ||
+ | <pre> | ||
+ | #define USB_CFG_DMINUS_BIT 0 | ||
+ | </pre> | ||
+ | * Pin des Bootloader-Enable-Jumpers anpassen | ||
+ | <pre> | ||
+ | static inline void bootLoaderInit(void) | ||
+ | { | ||
+ | PORTC |= (1 << JUMPER_BIT); /* activate pull-up */avrdude -c usbasp -p m8 -t -v | ||
+ | if(!(MCUCSR & (1 << EXTRF))) /* If this was not an external reset, ignore */ | ||
+ | leaveBootloader(); | ||
+ | MCUCSR = 0; /* clear all reset flags for next time */ | ||
+ | } | ||
+ | |||
+ | static inline void bootLoaderExit(void) | ||
+ | { | ||
+ | PORTC = 0; /* undo bootLoaderInit() changes */ | ||
+ | } | ||
+ | |||
+ | #define bootLoaderCondition() ((PINC & (1 << JUMPER_BIT)) == 0) | ||
+ | </pre> | ||
+ | * ein paar Optionen abwählen, da u.U. die Codegröße >2048 Bytes nach dem Übersetzen wird und das passt dann nicht mehr in den Bootloaderbereich des Mikrocontrollers. Dies wären z.B. die Kandidaten: | ||
+ | <pre> | ||
+ | #define HAVE_EEPROM_PAGED_ACCESS 0 | ||
+ | ... | ||
+ | #define HAVE_EEPROM_BYTE_ACCESS 0 | ||
+ | </pre> | ||
+ | |||
+ | |||
+ | Ist dies alles, getan sollte ein mutiges... | ||
+ | <pre> | ||
+ | make | ||
+ | make fuse | ||
+ | make flash | ||
+ | make lock | ||
+ | </pre> | ||
+ | ...alles weitere tun, um den Bootloader auf den Mikrocontroller zu bringen und den entsprechenden Speicherbereich vor weiterem Überschreiben zu schützen. | ||
+ | |||
+ | |||
+ | Um nun ein Programm auf den Controller zu übertragen, genügt es den Jumper auf dem Board zu schliessen, BLIT-Board und PC via USB zu verbinden und avrdude entsprechend aufzurufen, z.B.: | ||
+ | <pre> | ||
+ | avrdude -p m168 -c usbasp -U flash:w:main.hex | ||
+ | </pre> | ||
+ | |||
+ | Das Parameter ''-p m168'' bezeichnet einen ATmega168. Natürlich kann die beschriebene Vorgehensweise auch mit einem ATmega8 durchgeführt werden. | ||
+ | |||
+ | Desweiteren funktionieren (teilweise) auch einige andere avrdude-Komandos, wie z.B. der Aufruf des Terminalmodus: | ||
+ | <pre> | ||
+ | avrdude -c usbasp -p m168 -t -v | ||
+ | </pre> | ||
=Erweiterungsbaugruppen= | =Erweiterungsbaugruppen= | ||
Zeile 346: | Zeile 423: | ||
Für die Verbindung der Baugruppen untereinander reicht ein einfaches 10-poliges Flachbandkabel auf dem mehrere 10-polige Stecker montiert sind. | Für die Verbindung der Baugruppen untereinander reicht ein einfaches 10-poliges Flachbandkabel auf dem mehrere 10-polige Stecker montiert sind. | ||
+ | In Sachen TWI bzw. I²C sei auch auf diese [[BLIT2008-Board_mit_i2c-tiny-usb-Firmware|Seite]] verwiesen, auf der eine spezielle Firmware beschrieben wird, die die Nutzung des BLIT-Boards mit den I2C-Tools oder lm-sensors ermöglicht. | ||
==Baugruppen== | ==Baugruppen== | ||
Zeile 355: | Zeile 433: | ||
* [[BLIT2008-Board-Tastatur|Tastatur-/LED-Matrix]] | * [[BLIT2008-Board-Tastatur|Tastatur-/LED-Matrix]] | ||
* [[BLIT2008-Board-DCF77|DCF77]] | * [[BLIT2008-Board-DCF77|DCF77]] | ||
+ | * [[BLIT2008-Board_ADC|ADC (Analog-/Digital-Converter))]] | ||
+ | * [[BLIT-Board-SD-Card|SD-Karten-Modul]] | ||
+ | |||
+ | =Diverse Software zum BLIT-Board= | ||
+ | |||
+ | * [[BLIT2008-Board-Software_usb2blitboard|usb2blitboard]] | ||
+ | * [[BLIT2008-Board_mit_i2c-tiny-usb-Firmware|BLIT2008-Board mit i2c-tiny-usb-Firmware]] | ||
+ | * [[BLIT2008-Board mit 1-Wire]] | ||
+ | * [[BLIT2008-Board kann sprechen|BLIT-Board plappert vor sich hin...]] | ||
+ | * [[BLIT2008-Board spielt Schach|BLIT-Board kann Schach spielen...!]] | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
=weitere Ideen= | =weitere Ideen= | ||
*es gibt noch eine Reihe weiterer interessanter TWI-ICs; hier eine kleine [http://www.roboternetz.de/wissen/index.php/I2C_Chip-%C3%9Cbersicht Auswahl] | *es gibt noch eine Reihe weiterer interessanter TWI-ICs; hier eine kleine [http://www.roboternetz.de/wissen/index.php/I2C_Chip-%C3%9Cbersicht Auswahl] | ||
− | |||
*eine Funk- und/oder Ethernetschnittstelle als TWI-Zusatzmodul? | *eine Funk- und/oder Ethernetschnittstelle als TWI-Zusatzmodul? | ||
− | |||
− | |||
=weiterführende Literatur= | =weiterführende Literatur= | ||
Zeile 409: | Zeile 475: | ||
Weitere Mikrocontroller-Projekte von mir: | Weitere Mikrocontroller-Projekte von mir: | ||
− | * [ | + | * [[3D-LED-Display]] |
+ | * [[Infrarot-USB-Maus_im_Eigenbau|Infrarot-USB-Maus]] |
Aktuelle Version vom 10. Mai 2012, 22:40 Uhr
Inhaltsverzeichnis |
[Bearbeiten] Aktuelles
- 10.05.2012: BLIT2008-Board ADC
- 12.05.2009: seit ein paar Tagen experimentiere ich mit SD-Karten plus BLIT-Board rum, hier mal ein Anfang zur Dokumentation...
- 04.05.2009: Baugruppe 7-Segment-Anzeige realisiert
- 24.04.2009: um mal wieder etwas über meine Aktivitäten rund ums BLIT-Board zu berichten: ich bin gerade dabei zwei Dinge zu realisieren. Hier schon mal die Links zu den entsprechenden Unterseiten:
- 30.01.2009: BLIT-Board goes to 1-Wire...
- 08.01.2009: aus der Beispielapplikation rc5_usb_mouse für das BLIT-Board ist ein eigenständiges Projekt (Infrarot-USB-Maus_im_Eigenbau) geworden.
- 12.12.2008: TWI(I²C)-DCF77 ist fertig!
- 01.12.2008: Seite etwas umgebaut
- 27.11.2008: Markus hat auf dem BLIT-Board erfolgreich i2c-tiny-usb ausprobiert und dazu eine Wiki-Seite erstellt
- 17.11.2008: Schaltung für DCF77-Baugruppe
- 16.11.2008: Programm tasten_matrix zur Ansteuerung einer 4x4-Tasten-Matrix
- 16.11.2008: Programm led_matrix zur Ansteuerung einer 4x4-LED-Matrix
- 14.11.2008: Zusatzbaugruppe "I2C-Tastatur"; Programmbeispiele folgen demnächst...
- 02.11.2008: Den Leuten, die gestern auf dem BLIT meinen Workshop besucht haben, bin ich noch ein Programm schuldig, was ich leider im Vorfeld nicht vorbereitet hatte: rtc_usb steuert nur das Timer-Zusatzboard an. Mit dem Kommandozeilentool kann über die USB-Schnittstelle Datum/Uhrzeit gesetzt/gelesen werden sowie auch der Rest des SRAMs auf dem Uhrenbaustein beschrieben/ausgelesen werden. Als "Hausaufgabe" :-) könnte man jetzt beide einzelnen Programme (lm75_usb, rtc_usb) kombinieren, um mal alle Baugruppen zu vereinen. Viel Spaß!
[Bearbeiten] Konzept
Zum 5.Brandenburger Linux-Infotag entstand u.a. die Idee einen Mikrocontroller-Workshop anzubieten. An Hand einer einfachen universellen Mikrocontrollerbaugruppe, welche durch die Teilnehmer selbst aufzubauen ist, soll der Einstieg in die "Mikrocontrollerwelt" ermöglicht werden. Folgende Kriterien waren/sind dabei wünschenswert:
- einfache, leicht aufzubauende und "sichere" Schaltung (mit "sicher" ist gemeint, dass die Schaltung möglichst auf Anhieb und ohne komplizierte Einstellvorgänge/Messtechnik funktioniert)
- kostengünstig
- erweiterungsfähig
- möglichst viele Aspekte der Mikrokontrollertechnik sollen abgedeckt werden
- mittels beigelegter Software soll beispielhaft die Programmierung von Mikrocontroller aufgezeigt werden
- mittels "abgeschlossener" und sinnvoll einsetzbarer Softwarebeispiele sollen mögliche Anwendungsgebiete aufgezeigt werden
Ob das, in der Folge beschriebene, BLIT2008-Board mit seinen Zusatzbaugruppen diese Kriterien erfüllt, muss jeder für sich entscheiden.
Grundlage für die Hardware waren jeweils fast immer die überall zu findenen Grundschaltungen der eingesetzten Baugruppen/Schaltkreise, die nur noch an die speziellen Gegebenheiten angepaßt wurden. Die Zusatzbaugruppen sind so konzipiert, dass sie ohne weitere Modifikationen an das Basisboard anschliessbar sind. Die Mikrocontrollerbasis besteht aus einem ATmega der Firma Atmel. Die Kommunikation mit den Zusatzbaugruppen erfolgt grundsätzlich über TWI (I2C) und steht damit auch im Mittelpunkt der Betrachtungen. Die eventuelle Kommunikation mit einem PC erfolgt via USB.
Auch auf der Softwareseite wurde, wenn möglich, das Rad nicht neu erfunden. Es werden diverse, frei verfügbare Bibliotheken und Code-Schnipsel verwendet. Welche dies sind, ist bei den einzelnen Anwendungsbeispielen vermerkt. Grund dafür ist, dass dadurch die Beispiele leichter zu verstehen sind, da im Internet unzählige weitere Anwendungen auf der gleichen Basis zu finden sind.
Eine grundlegende Einführung in die Welt der Mikrocontroller (MC) im allgemeinen bzw. speziell zur AVR-Mikrocontroller-Reihe der Firma Atmel wird es auf dieser Projektseite nicht geben. Dazu wird auf die unzähligen Seiten im Internet verwiesen. Ein guter Einstieg in die Materie ist zum Beispiel die Webseite www.mikrocontroller.net und dort speziell das AVR-Tutorial sowie das AVR-GCC-Tutorial.
Sehr viele und wertvolle Informationen sind in den Datenblättern zu den jeweiligen Schaltkreisen zu finden. Aus diesem Grund wird hier nicht jede Einzelheit beschrieben, aber dafür immer ein Link zum entsprechenden Datenblatt angeben.
[Bearbeiten] Vorausgesetzte Kenntnisse/Fähigkeiten
Es soll davor gewarnt sein, vollkommen unbedarft in die Materie einzusteigen. Über gewisse Fertigkeiten und Kenntnisse sollte man schon verfügen. Folgende wären das ungefähr:
- man sollte einen Lötkolben, der zum Löten von elektronischen Schaltungen geeignet ist, besitzen und ihn auch bedienen können
- man sollte mindestens ein Multimeter besitzen und bedienen können
- man sollte schon wissen, was Strom und Spannung sind und wie man diese messen kann
- man sollte Schaltpläne lesen können und einige Grundkenntnisse der Elektronik und Digitaltechnik besitzen
- man sollte ungefähr wissen wie ein Computer aufgebaut ist und solche Begriffe wie Prozessor, Speicher, I/O-Ports usw. definieren können
- man sollte schon mal Programme geschrieben und auch verstanden haben, sowie wissen was ein Kompiler, Bibliotheken, Binder usw. sind
- die Beispiele sind in C geschrieben, also sollte man diese Programmiersprache kennen. Natürlich kann man Mikrocontroller auch mit anderen Sprachen programmieren.
- viele Datenblätter zu den verwendeten Schaltkreisen sind in Englisch geschrieben, man sollte also etwas damit anfangen können
Prinzipiell stehe ich natürlich für Fragen und Anregungen zur Verfügung. Ich werde aber nicht unbedingt immer Fragen zu obigen Punkten beantworten!
In diesem Zusammenhang wird auch darauf hingewiesen, dass jegliche Haftung, Gewährleistung u.ä. bei Hardwareschäden, Datenverlusten o.ä., die auf das BLIT-Board, dessen Zusatzbaugruppen oder Software zurückzuführen sind, nicht übernommen wird! Also bitte vorher Überlegen, was passieren könnte und entsprechende Vorkehrungen treffen!
[Bearbeiten] Toolchain (Werkzeugkasten)
Zur Softwareentwicklung für MCs der hier betrachteten AVR-Reihe der Firma Atmel sind natürlich einige Werkzeuge notwendig. Dabei kann durchgängig auf Freie Software zurückgegriffen werden. Folgende Programme benötigt man:
- für Linux (meist als Installationspakete innerhalb der jeweiligen Distribution verfügbar):
- gcc-avr
- avr-libc
- binutils-avr
- avrdude (zum Flashen des übersetzten Programms auf den MC)
- für Windows (für die, die den Sprung zu Linux noch nicht vollzogen haben ;-)):
- WinAVR (ein freies Komplettpaket, welche sämtliche notwendigen Komponenten beinhaltet)
Neben diesen freien Softwarepaketen existieren noch eine Reihe von Entwicklungsumgebungen kommerzieller Anbieter, die entweder auch kostenlos angeboten werden bzw. als Demoversion mit Beschränkungen kostenfrei beziehbar sind und in der Regel nur auf Windowsplattformen lauffähig sind. Z.B. sind dies:
Zum Übertragen (flashen) des fertig übersetzten Programmes auf den MC braucht man noch ein Stück Hardware, einen Programmer. Diese Baugruppe gibt es in den verschiedensten Ausführungen für die unterschiedlichsten PC-Schnittstellen. Eine Übersicht ist hier zu finden. Alternativ ist es natürlich auch möglich initial einen sogenannten Bootloader auf dem MC zu installieren, was eigentlich auch das Konzept dieses Projekt vorsieht.
Noch ein Wort zum Debugging und Simulationsumgebungen: Ja, die gibt es, aber unter Linux leider (noch) nicht ausgereift genug, um sie effektiv einsetzen zu können. Als Debugger kann die AVR-Variante von gdb eingesetzt werden. Aber spätestens wenn es gilt zeitkritische oder ereignisorientierte Dinge zu überprüfen, braucht man einen Mikrocontrollersimulator. Hier haben die oben erwähnten kommerziellen Produkte eindeutig einen Vorsprung. Eigentlich Schade, aber vielleicht ändert sich dies mit der Zeit noch!
Bis dahin muß man sich bei der Fehlersuche anders behelfen:
- sinnvolle Ausgaben zu bestimmten Ereignissen an die vorhandene Peripherie senden (und sei es nur an eine angeschlossene LED)
- mittels Logikanalysatoren oder Oszilloskop das erwartete Zeitverhalten an Ein-/Ausgängen des MC oder andere Baugruppen überprüfen
[Bearbeiten] Basis-Board
[Bearbeiten] Hardware
[Bearbeiten] Schaltplan
Eagle-Dateien (Schaltplan und Leiterplatte)
[Bearbeiten] Beschreibung
Diese Baugruppe stellt das "Herzstück" dar und besteht aus folgenden Komponenten:
- als Mikrocontroller ein ATmega8; alternativ kann auch ein pinkompatibler ATmega168 eingesetzt werden, wenn man mehr Speicher benötigt (wobei dabei aber einige Anpassungen in den Beispielprogrammen notwendig sind, da sich diverse Registerbezeichnungen ändern)
- der ATmega wird mit einem externen 12MHz-Quarz getaktet; 16MHz gehen auch, aber einige USB-Beispiele benötigen zwingend 12MHz
- ein Infrarot-Empfänger (TSOP1738)
- eine frei ansteuerbare LED an einem der I/O-Port des MC
Folgende Schnittstellen zur Außenwelt sind vorgesehen:
- USB; hierüber erfolgt auch die 5V-Stromversorgung des Boards und aller weiteren Zusatzbaugruppen; nominell können bis zu 500mA aus einem USB-Port gezogen werden
- TWI (I2C) zum Anschluß weiterer Baugruppen
- ISP-Anschluß zur Programmierung (flashen) des MC; es wurde die 10-polige Variante gewählt, die auch bei den meisten Programmern verwendet wird
Auf die Herausführung weiterer, nicht benutzter, I/O-Ports des MC wurde verzichtet, um ein einfaches und einseitiges Leiterplattenlayout zu gewährleisten.
Der Aufbau der Schaltung ist bewußt einfach gehalten und sollte auf Anhieb funktionieren. Einzige kritische Stelle könnten die beiden 27pF-Kondensatoren am Quarz sein, die man, bei Nichtanschwingen des selbigen, leicht variieren kann. Dies ist aber bei mehreren aufgebauten Board bisher nicht notwendig gewesen. Wenn keine Bestückungs- bzw. Verdrahtungsfehler gemacht wurden, sollte der MC sofort arbeiten (natürlich erst, nachdem man die Fuses des AVR auf externe Taktquelle eingestellt hat ;-)).
[Bearbeiten] Stückliste
Teil | Anzahl | Beschreibung | Hinweis | Preis insgesamt (Reichelt) |
---|---|---|---|---|
IC1 | 1 | Mikrocontroller ATmega8 | . | 1,25€ |
IR1 | 1 | Infrarot-Empfänger TSOP1738 | . | 0,66€ |
Q1 | 1 | Quarz 12MHz | . | 0,24€ |
LED1 | 1 | LED (<=20mA) | . | 0,12€ |
D1, D2 | 2 | Zener-Diode 3,6V | . | 0,062€ |
R1, R2 | 2 | Widerstand 68 Ohm | . | 0,164€ |
R3 | 1 | Widerstand 1,5 kOhm | . | 0,082€ |
R4 | 1 | Widerstand 100 Ohm | . | 0,082€ |
R5 | 1 | Widerstand 220 Ohm | . | 0,082€ |
R6, R7, R8, R9 | 4 | Widerstand 10 kOhm | . | 0,328€ |
R10 | 1 | Widerstand 1 MOhm | . | 0,082€ |
C1, C2 | 2 | Keramikkondensator 27pF | . | 0,082€ |
C3 | 1 | Elko 10uF | . | 0,041€ |
C4 | 1 | Elko 4,7uF | . | 0,041€ |
C5 | 1 | Kondensator 47nF | . | 0,07€ |
C6 | 1 | Kondensator 100nF | . | 0,072€ |
SV1, SV2 | 2 | Wannenstecker 10-polig | Reichelt: 1x WSL 10G; 1x WSL 10W | 0,172€ |
X1 | 2 | USB-Buchse (Serie B) | Reichelt: USB BW | 0,32€ |
JP1 | 2 | Jumperstift | . | 0,04€ |
. | 1 | IC-Fassung 28-polig; schmal | Reichelt: GS 28P-S | 0,36€ |
. | 1 | USB-Kabel (A auf B) | Reichelt: AK 672/2-1,0 | 0,50€ |
Leiterplatte | . | . | Eigenproduktion | 2,50€ |
Gesamtpreis | . | . | ohne Leiterplatte | 4,85€ |
[Bearbeiten] Inbetriebnahme & Fuse-Bits
Nach dem Aufbau der Leiterplatte kommt der spannende Augenblick: funktioniert die Geschichte, die man da zusammengelötet hat? Folgendes sollte man überprüfen, bevor man das erste Mal den USB-Stecker reinsteckt (ein Durchgangsprüfer ist ganz hilfreich):
- Sichtprüfung auf Kurzschlüsse
- Kurzschluss zwischen Vcc und GND?
- kommt Vcc und GND auch am IC an?
Nach Einschalten der Spannungsversorgung (USB-Stecker) sollte es keinen lauten Knall o.ä. geben. Den Mikrocontroller überprüft man am besten mit einem Programmieradapter und avrdude. Dabei ist zu beachten, dass der Mikrocontroller im Auslieferungszustand mit seiner internen Taktquelle arbeitet und der Programmieradapter auf eine niedrige Geschwindigkeit einzustellen ist (USBasp: Jumper SCK). Nach einem mutigen:
avrdude -c usbasp -p m8 -t -v
sollte eine längere Ausgabe kommen, in der der erkannte Mikrocontroller mit seinen momentanen Parametern etc. aufgelistet wird. (mit Taste "q" kommt man wieder aus dem Terminalmode von avrdude)
Eine gute Ausgangsbasis für weitere Experimente ist folgende Einstellung der Fuse-Bits:
avrdude -c usbasp -p m8 -U hfuse:w:0xc9:m -U lfuse:w:0x9f:m
Danach kann man auch im schnelleren Mode des Programmieradapters arbeiten.
Eine recht nützliche Webadresse zur Ermittlung der jeweils gewünschten Fuse-High- und -Low-Bytes ist der AVR Fuse Calculator.
[Bearbeiten] Software
Hier einige Programmbeispiele, die die einzelnen Komponenten und Schnittstellen des Basisboards beispielhaft ansteuern bzw. verwenden. Über die Sinnhaftigkeit der kleinen Programme kann gestritten werden. Sie sollen nur grundlegende Aspekte der MC-Programmierung aufzeigen und als Ausgangsbasis für eigene Programmideen dienen.
- blink_led und blink_int: sind beides eigentlich das "Hello World" für MCs. In beiden Programmen wird die, auf dem Board befindliche, LED zum Blinken gebracht. Unterschied zwischen beiden Programmen: blink_led steuert die LED innerhalb einer Hauptschleife an; blink_int verwendet einen zyklischen Timer-Interrupt zur Zustandsänderung der LED.
- rc5_led: innerhalb dieses Programmes wird der IR-Empfänger auf dem Board eingebunden. Dabei wird das empfangene Signal einer RC5-IR-Fersteuerung decodiert und die LED entsprechend des empfangenen Tasten-Codes geschaltet.
- pwm_led: ein kleines Beispiel wie man die PWM-Hardware des ATmega verwendet. Dabei wird die Helligkeit der LED zyklisch variiert.
- rc5_usb_mouse: eigentlich schon eine abgeschlossene und sinnvoll einsetzbare Anwendung, die den IR-Empfänger und die USB-Schnittstelle kombiniert. Dabei meldet sich das Basisboard am PC als USB-Maus an. Über eine RC5-IR-Fersteuerung ist es möglich den Mauszeiger in alle Richtungen zu bewegen und natürlich auch die Maustasten zu emulieren. PC-seitig sind keine speziellen USB-Gerätetreiber notwendig, es werden automatisch die normalen Standard-USB-Treiber verwendet.
[Bearbeiten] Bootloader
Prinzipiell ist für das BLIT-Board ein Bootloader vorgesehen, der über die vorhandene USB-Schnittstelle funktionieren soll. Idee ist, dass der Mikrocontroller im "Auslieferungszustand" bereits mit diesem Stück Software initialisiert ist und der Anwender erstmal keine spezielle Hardware zum Flashen der Programme auf den Controller braucht.
[Bearbeiten] AVRUSBBoot
Ein Teil des BLIT-Boards basiert auf der vorgeschlagenen Grundschaltung, die unter http://www.fischl.de zu finden ist. Also sollte dieser Bootloader ohne große Probleme sofort funktionieren... Hier die ungefähren Schritte:
- Das Softwarepaket kann und sollte auch von obiger Quelle bezogen werden. Prinzipiell kann nach der, im Paket vorhanden, Dokumention (README.txt) vorgegangen werden...
- Die Firmware ist ohne Änderungen sofort auf dem BLIT-Board einsetzbar. Im Makefile ist lediglich der Typ der (initialen) Flash-Hardware anzupassen, mit der der Bootloader einmalig in den Flash des Mikrocontrollers übertragen wird.
- Im Quelltext des PC-Tools (im Unterverzeichnis software/) ist ein kleiner Fehler in der Datei main.cpp enthalten. In der allerletzten Zeile ist das ";" zu eliminieren. Zum erfolgreichen Übersetzen sind der installierte g++-Compiler sowie die entsprechenden Header-Files von libc und libusb Voraussetzung. Das übersetzte Programm avrusbboot kopiert man als root nach /usr/local/bin. (Was zur erfolgreichen Übersetzung unter Windows notwendig ist, ... keine Ahnung, sollte aber wohl auch möglich sein!)
- Das Flashen der Firmware in den Mikrocontroller erfolgt so, wie in der Dokumentation beschrieben wird. Auf jeden Fall sind danach die Fuse-Bits nicht zu vergessen, damit der Mikrocontroller nach einem Reset zuerst mit dem Bootloader startet! Die folgende Konstellation der Fuse-Bits realisiert u.a., dass nach einem Reset des Controllers zuerst die Startadresse des Bootloaders im Programmspeicher angesprungen wird.
avrdude -c usbasp -p m8 -U hfuse:w:0xc0:m -U lfuse:w:0x9f:m
- Zum Abschluß ist der Bootloader-Bereich im Flash des Controllers vor Überschreiben zu schützen. Dazu setzt man die Lock-Bits (siehe auch Datenblatt des Controllers) entsprechend (die Entsperrung des Bootloader-Bereiches erfolgt mit 0x3f):
avrdude -c usbasp -p m8 -U lock:w:0x2f:m
- ... und das sollte es gewesen sein!
Wenn nun Jumper JP1 auf dem BLIT-Board geschlossen ist, verweilt der Mikrocontroller nach einem Reset (USB-Stecker raus/rein) im Bootloader-Modus. Mit dem Tool avrusbboot kann nun das Mikrocontroller-Programm, ohne spezielle Hardware, direkt über die USB-Schnittstelle des PC in den Flash-Speicher geladen werden.
avrusbboot xyz.hex
(Natürlich kann auch das jeweilige Makefile entsprechend um eine Sektion erweitert werden.)
Öffnet man den Jumper JP1 und resetet das Board, springt der Mikrocontroller zuerst in den Bootloader-Bereich, erkennt, dass der Jumper nicht geschlossen ist (PIN PC2 des Controllers nicht Low) und startet sofort das Anwendungsprogramm am Anfang des Programmspeichers.
Nachteil der Variante mit einem installierten Bootloader ist, dass dadurch etwas Programmspeicher auf dem Mikrocontroller "verloren" gehen. Im Fall von avrusbboot sind es 2kByte. Aber es bleiben bei einem ATmega8 noch 6kByte übrig, was für die folgenden Beispiele mehr als genug ist...
[Bearbeiten] USBaspLoader
Möchte man einen ATmega168 auf dem BLIT-Board betreiben, der ja doppelt soviel Flash-Speicher zur Verfügung stellt und Pin-kompatibel zum ATmega8 ist, lässt sich AVRUSBBoot nicht übersetzen. Einige Registerbezeichnungen sind anders als beim kleinen Bruder und dies wurde im Quelltext der Firmware nicht entsprechend ausprogrammiert. Aus diesem Grund sah ich mich nach einem anderen Bootloader um, der ebenfalls via USB-Schnittstelle funktioniert und würde auch fündig: USBaspLoader von objective development. Nebenbei kauft man sich gleich noch einen weiteren Vorteil ein, der Bootloader benötigt kein eigenes spezielles Tool für den PC, sondern funktioniert auch mit avrdude.
Damit dieser Bootloader auf dem BLIT-Board funktioniert, sind ein paar kleiner Anpassungen am Orginal-Quelltext (den man sich von obigen Link besorgt) vorzunehmen:
firmware/Makefile:
Die korrekte Quarzfrequenz (F_CPU) und Device (DEVICE) sind einzutragen.
firmware/bootloaderconfig.h:
- die USB-Pins anpassen
#define USB_CFG_DMINUS_BIT 0
- Pin des Bootloader-Enable-Jumpers anpassen
static inline void bootLoaderInit(void) { PORTC |= (1 << JUMPER_BIT); /* activate pull-up */avrdude -c usbasp -p m8 -t -v if(!(MCUCSR & (1 << EXTRF))) /* If this was not an external reset, ignore */ leaveBootloader(); MCUCSR = 0; /* clear all reset flags for next time */ } static inline void bootLoaderExit(void) { PORTC = 0; /* undo bootLoaderInit() changes */ } #define bootLoaderCondition() ((PINC & (1 << JUMPER_BIT)) == 0)
- ein paar Optionen abwählen, da u.U. die Codegröße >2048 Bytes nach dem Übersetzen wird und das passt dann nicht mehr in den Bootloaderbereich des Mikrocontrollers. Dies wären z.B. die Kandidaten:
#define HAVE_EEPROM_PAGED_ACCESS 0 ... #define HAVE_EEPROM_BYTE_ACCESS 0
Ist dies alles, getan sollte ein mutiges...
make make fuse make flash make lock
...alles weitere tun, um den Bootloader auf den Mikrocontroller zu bringen und den entsprechenden Speicherbereich vor weiterem Überschreiben zu schützen.
Um nun ein Programm auf den Controller zu übertragen, genügt es den Jumper auf dem Board zu schliessen, BLIT-Board und PC via USB zu verbinden und avrdude entsprechend aufzurufen, z.B.:
avrdude -p m168 -c usbasp -U flash:w:main.hex
Das Parameter -p m168 bezeichnet einen ATmega168. Natürlich kann die beschriebene Vorgehensweise auch mit einem ATmega8 durchgeführt werden.
Desweiteren funktionieren (teilweise) auch einige andere avrdude-Komandos, wie z.B. der Aufruf des Terminalmodus:
avrdude -c usbasp -p m168 -t -v
[Bearbeiten] Erweiterungsbaugruppen
[Bearbeiten] Allgemeines zu TWI
Wie schon einleitend erwähnt, kommunizieren die, in der Folge beschriebenen Zusatzbaugruppen via TWI (I2C) mit dem Basisboard. Großer Vorteil des TWI-Bus ist es, dass theoretisch bis zu 127 Teilnehmer einfach parallel an die TWI-Leitungen angeschlossen werden können. Praktisch sind da natürlich einige elektrische und performancebegründete Grenzen gesetzt.
Auf dem Basisboard ist eine 10-polige Wannenbuchse vorgesehen, auf der die notwendigen TWI-Leitungen des MC (SDA, SCL, GND) herausführt sind. Zusätzlich liegen an der Buchse noch VCC (zur einfachen Stromversorgung der Zusatzbaugruppen über das Basisboard) und ein Interrupteingang (INT1) des MC an. Viele TWI-ICs haben einen INT-Pin, auf dem bei bestimmten Ereignissen ein Impuls ausgegeben wird. Beispiele für solche Ereignisse innerhalb von TWI-ICs können sein:
- I/O-Port-Expander PCF8574: an einem der acht als Eingang konfigurierten I/O-Pins liegt eine Signal an
- RTC PCF8583: der interne Zeitzähler hat einen bestimmten Wert erreicht (z.B. Sekundentakt, Alarmzeit erreicht)
- TWI-ADCs (Analog-Digital-Wandler): die Umwandlung eines Messvorganges ist abgeschlossen und der Wert steht zur Abholung bereit.
Auf solche Ereignisse kann gezielt in einem vernünftig strukturierten MC-Programm innerhalb einer entsprechenden Interrupt-Service-Routine (ISR) reagiert werden, was unnötiges zyklisches Abfragen von Werten über den TWI-Bus minimiert. Innerhalb des Beispielprogrammes rtc_lcd zur I2C-RTC-Baugruppe ist ein solches Vorgehen exemplarisch implementiert. Hier löst der Sekundentakt des RTC verschiedene Auslesevorgänge über den TWI-Bus aus. Jede der hier beschrieben Zusatzbaugruppen besitzt einen entsprechenden Jumper, mit dem die Interruptleitung geschlossen bzw. aufgetrennt werden kann.
Das TWI-Protokoll sieht die gezielte Adressierung der einzelnen TWI-ICs über eine 7-Bit-Kennung vor (siehe auch TWI-Tutorial). Von diesen 7 Bit sind meistens die ersten 4 Bit bereits vom Hersteller auf dem IC fest "eingebrannt", für die verbleibenden Bits gibt es Adress-Eingänge, welche frei konfiguriert werden können. Deshalb sind auf jeder Zusatzbaugruppe entsprechende Jumper-Gruppen zu finden, die diese Adress-Eingänge auf 0 oder 1 ziehen. Damit ist dann auch möglich mehrere gleiche TWI-ICs über ihre individuelle Adresse gezielt anzusteuern. Bei 3 Bit frei konfigurierbaren Adressen (A0-A2) können also bis zu 8 gleiche TWI-ICs an einem Bus unterschieden werden. Ausnahme ist z.B. der weiter unten verwendete RTC-IC (PCF8583): hier ist nur eine Adressleitung (A0) herausgeführt und damit sind nur zwei ICs von diesem Typ am Bus unterscheidbar.
Das letzte verbleibende Bit der 8-Bit-TWI-Adresse kennzeichnet die Art des Zugriffes auf den IC, also Lesen (1) oder Schreiben (0). Weiterhin ist die Adresse 0x00 für TWI-Broadcast reserviert.
Für die Verbindung der Baugruppen untereinander reicht ein einfaches 10-poliges Flachbandkabel auf dem mehrere 10-polige Stecker montiert sind.
In Sachen TWI bzw. I²C sei auch auf diese Seite verwiesen, auf der eine spezielle Firmware beschrieben wird, die die Nutzung des BLIT-Boards mit den I2C-Tools oder lm-sensors ermöglicht.
[Bearbeiten] Baugruppen
- LCD
- Temperaturfühler
- RTC
- 7-Segment-Anzeige
- Tastatur-/LED-Matrix
- DCF77
- ADC (Analog-/Digital-Converter))
- SD-Karten-Modul
[Bearbeiten] Diverse Software zum BLIT-Board
- usb2blitboard
- BLIT2008-Board mit i2c-tiny-usb-Firmware
- BLIT2008-Board mit 1-Wire
- BLIT-Board plappert vor sich hin...
- BLIT-Board kann Schach spielen...!
[Bearbeiten] weitere Ideen
- es gibt noch eine Reihe weiterer interessanter TWI-ICs; hier eine kleine Auswahl
- eine Funk- und/oder Ethernetschnittstelle als TWI-Zusatzmodul?
[Bearbeiten] weiterführende Literatur
- "Linux Hardware Hackz"; Jürgen Plate; Hanser-Verlag; 2007 (ISBN 3-446-40783-1)
- "Mikrocomputertechnik mit Controllern der Atmel AVR-RISC-Familie"; Günter Schmitt; Oldenbourg Verlag; 2006 (ISBN 3-486-58016-7)
- "Messen, Steuern und Regeln mit AVR-Mikrocontrollern"; Wolfgang Trampert; Franzis-Verlag; 2004 (ISBN 3-7723-4298-1)
[Bearbeiten] Links
- IgorPlug
- avrusbboot
- TWI-Grundlagen
- I2C-Portexpander
- I2C-Chips
- I2C-LCD
- I2C-Grundlagen
- TWI-Master/Slave
- Beispiel mit LM75
- AVR USB
- RC5-Code (IR-Fernbedienung)
- genialer Code für einen RC5-Empfänger
- USB-Grundlagen
- USB-Debugging
[Bearbeiten] Kontakt
Ich, Uwe, bin an weiteren Ideen zum BLIT-Board interessiert!
Weitere Mikrocontroller-Projekte von mir: