68HC08

Der 68HC08 ist ein 8-Bit-Mikrocontroller (MCU) der Firma Freescale Semiconductor. Freescale Semiconductor ist die Halbleitersparte von Motorola, sie wurde 2004 ausgegliedert. Neben dem ursprünglichen 68HC08 Mikrocontroller sind weitere Varianten entstanden, sodass man inzwischen von einer HC08-Familie spricht.[1]

Der Programmcode seiner Vorgänger der 68HC05-Familie ist aufwärtskompatibel zum HC08, was eine Migration erleichtert.

Evaluationboard mit einer 68HC908JK-MCU

Architektur

Der 68HC08 ist nach der Von-Neumann-Architektur aufgebaut. Bei der Von-Neumann-Architektur ist, anders als bei der Harvard-Architektur, der Speicherbereich nicht nach Programmcode und Daten getrennt. Es werden deshalb keine getrennten Busse benötigt, allerdings ist die Von-Neumann-Architektur langsamer im Vergleich zu Harvard-Architektur, da nicht gleichzeitig auf Programmcode und Daten zugegriffen werden kann.

Die CPU

Der HC08 hat als Kern den 6800-Mikroprozessor (CPU), nicht zu verwechseln mit der 68000-CPU, die den Kern für die 32 Bit-Mikrocontroller-Familie von Freescale bildet.

Arithmetikbefehle

  • Addition mit (ADC) und ohne Übertrag (ADD)
  • Subtraktion mit (SBC) und ohne Übertrag (SUB)
  • schnelle 16×8 unsigned Division (DIV)
  • schnelle 8×8 unsigned Multiplikation (MUL)

BCD-Arithmetik

Um Binary-Coded-Decimal Arithmetikanwendungen auszuführen, gibt es den Decimal Adjust Accumulator(DAA) und den Nibble Swap Accumulator (NSA) -Befehl.

Hochsprachenunterstützung

Das Index-Register, der Stack-Pointer, die 8-Bit Sprunganweisungen und die dazugehörenden Befehle ermöglichen die Benutzung von Hochsprachencompilern. Man ist nicht mehr gezwungen, den Mikrocontroller über Assemblersprache zu programmieren.

Low-Power Unterstützung

Um die Leistungsaufnahme der CPU zu verringern, können der WAIT- und der STOP-Befehl eingesetzt werden. Mit dem WAIT-Befehl wird der Taktgenerator der CPU angehalten, mit dem STOP-Befehl können zusätzliche periphere Taktgeneratoren gestoppt werden.

Die CPU-Register

Index-Register

Das Index-Register ist 16 Bit breit und erlaubt die Adressierung von bis zu 64 KByte Speicher, das zusammengesetzte Register trägt die Bezeichnung H:X, wobei das untere Byte die Bezeichnung X trägt und das obere Byte die Bezeichnung H. Das H:X ist nur dann identisch zum I:X-Register der M6805-Familie, wenn H=O ist und sich keine Befehle auf das obere Byte auswirken. Für die Adressierung können 16 verschiedene Methoden verwendet werden. Das Index-Register kann auch kurzfristig als Datenspeicher verwendet werden.

Statusregister CCR

Das 8 Bit Statusregister CCR. Im Statusregister sind die Zustände der Interrupt Maske und des Overflow-, Half-Carry-, Negative-, Zero- und des Carry-Borrow-Flags hinterlegt.

Weitere CPU-Register

Betriebsspannungen

Die HC08 Mikrocontroller können mit verschiedenen Betriebsspannungen betrieben werden, allerdings verringert sich mit der Spannung auch die Bustaktung. Bei einer Betriebsspannung von 5 V arbeitet der Bus mit einem Takt von 8 MHz, bei einer 3 V Betriebsspannung nur mit 4 MHz. Die Mikrocontroller der HCS08-Unterfamilie arbeiten mit einer Betriebsspannung von 1,8 V.

Varianten des 68HC08

Mikrocontroller der HC08-Familie sind in einer breiten Palette verfügbar. Bei den Gehäusen reicht die Auswahl von einem 8-Pin DIP-Gehäuse bis zu einem 64-Pin LQFP-Gehäuse, der Nutzer kann daneben zwischen verschiedenen Typen und Anzahl der Analog/Digital-Wandler oder unterschiedlichen Möglichkeiten der Peripheriekommunikation auswählen. Die untenstehende Tabelle zeigt einige Eigenschaften von aktuell verfügbaren HC08-Untergruppen (Stand: September 2010).

UntergruppeInternal Flash (kB)Internal RAM (kB)InterfacetypenA/D-BitbreiteA/D-Wandler-Kanäle
HC08AB321; 0,512SCI,SPI88
HC08AP32; 16; 82; 1IRSCI,SPI,I2C108
HC08BD481; 0,512USB 1.0,I2C86
HC08JB/JT/JW32; 16; 12; 81; 0,384; 0,256; 0,128USB 1.0, USB 2.0, SCI, SPI, IRSCI, SCI00
HC08JK/JL16; 8; 4; 1,50,512; 0,256; 0,128SCI00
HC08LD602; 1I2C,USB 1.086
HC08LV80,512IRSCI,SPI,I2C106

Daneben gibt es die RS08-Familie, die im Prinzip auf einem abgespeckten HC08 beruhen. Die RS08-MCU können keine Adressstapel verarbeiten und das Statusregister verfügt lediglich über Carry- und Zeroflagbits. Sein Speicherbereich ist auf 16 kB begrenzt. Die bereits erwähnte Weiterentwicklung HCS08 hat ihren Schwerpunkt in einer geringen Leistungsaufnahme, so verfügt er über verschiedene Modi zur Verbrauchseinsparung.

Verfügbarkeit

Von den Mikrocontrollern der HC08-Familie sind trotz ihres Alters immer noch viele Varianten verfügbar, da sie, vor allem, in industriellen Anwendungen kostengünstig eingesetzt werden können. Einige Varianten sind aber vonseiten des Herstellers bereits abgekündigt, und es wird davon abgeraten, diese Varianten in der Großserienproduktion zu verwenden.

Hitachi HD6301

Hitachi verfügte mit den HD6301 und HD6303 über Mikrocontroller, die auf dem Design der 6800 CPU beruhten und als Second-source-Produkte eingesetzt werden konnten. Der Befehlssatz der Hitachi-Mikrocontroller ist um einige Befehle erweitert worden, was die Funktionalität vergrößerte. Inzwischen sind diese Mikrocontroller aber weder bei Hitachi noch bei der inzwischen ausgegliederten Halbleitersparte Renesas Electronics verfügbar.

Nachfolger

Nachfolger ist der kompatible Freescale S08, der einen erweiterten Instruktionssatz, insbesondere die zur Implementierung von Hochsprachen wichtige Stapelzeiger-relative Adressierung aufweist. Daneben gibt es den stark vereinfachten Freescale RS08.

Softwareentwicklung

Für die Softwareentwicklung steht neben der proprietären CodeWarrior IDE auch der Small Device C Compiler mit dem SDCC-UCSIM-Simulator zur Verfügung. Inzwischen ist mit dem Helium-OS auch ein Echtzeit-Betriebssystem für den HCS08 im Einsatz.

Literatur

  • Harald Kreidl, Gerald Kupris, Peter Dilger: 68HC08 Mikrocontroller erfolgreich anwenden. Franzis’ Verlag, Poing 2000, ISBN 3-7723-5824-1.

Einzelnachweise

  1. HC08 Documentation, abgefragt am 17. Dezember 2010, (engl.)

Weblinks

Auf dieser Seite verwendete Medien

HC08 Eval.jpg
Autor/Urheber: Tomlux, Lizenz: CC BY-SA 3.0 de
Evaluations-Board mit 68HC08JL-MCU