- M68k
-
Die Motorola 68000er-Familie, auch als 680x0 oder m68k bzw. 68k bezeichnet, ist eine Serie von CISC-Mikroprozessoren der Firma Motorola.
Alle Prozessoren dieser Serie haben einen einfachen aber mächtigen Befehlssatz mit vielen Adressierungsarten und Operandengrößen von 8, 16 und 32-Bit. Es existiert beispielsweise der Datentransferbefehl "move", der als echter Zweiadressbefehl ein Datum von einer Speicherstelle zur anderen kopieren kann, ohne dabei den Umweg über ein CPU-Register zu gehen. Die Byte-Reihenfolge der 68k Familie ist Big-Endian.
Eingesetzt wurden Prozessoren dieser Familie in vielen Heimcomputern wie dem Atari ST, Amiga oder Apple Macintosh, in Servern beispielsweise von Apollo, Hewlett Packard oder Sun Microsystems, aber auch in Spielekonsolen wie dem Atari Jaguar oder Sega Mega Drive. Im Bereich eingebetteter Systeme sind Abkömmlinge dieser Familie (683xx) bis heute im Einsatz.
Mitglieder dieser Familie sind:
- Motorola 68000
- Motorola 68008
- Motorola 68010
- Motorola 68012
- Motorola 68020, Motorola 68EC020
- Motorola 68030, Motorola 68EC030
- Motorola 68040, Motorola 68EC040, Motorola 68LC040
- Motorola 68060
- Motorola CPU32 (Motorola 68330)
- Motorola Coldfire
- Motorola Dragonball
- Motorola 68440 - zweikanaliger DMA Controller für den 68000/10
- Motorola 68450 - vierkanaliger DMA Controller für den 68000/10
- Motorola 68451 - externe MMU für den 68000/10
- Motorola 68851 - externe MMU für den 68020
- Motorola 68881 - externe FPU für den 68020 und 68030
- Motorola 68882 - externe FPU für den 68020 und 68030
Die Serie beginnt 1979 mit dem Motorola 68000. Er besitzt intern 32-Bit-Register, einen mit 32-Bit adressierten linearen Adressraum, eine 16-Bit-ALU sowie einen 16-Bit-Datenbus. Nach außen hat er nur 24 Adressleitungen, real benutzbar sind also nicht 4 GB, sondern nur 16 MB Speicher.
Der Motorola 68008 ist eine Version des 68000 mit einem 8 Bit breiten Daten- und einem 20 Bit breiten Adressbus. Neben ihrer Verwendung als Hauptprozessor beispielsweise im Sinclair QL wurde diese CPU gerne als Controller in der Steuerungstechnik eingesetzt.
Wenig erfolgreich war der Motorola 68010, der einige Fehler des 68000 behob. Speziell wurde der Umgang mit Speicherzugriffsfehlern verbessert, was zur ordentlichen Unterstützung einer MMU notwendig war. Außerdem erhielt die Pipeline einen speziellen Modus, der kurze Schleifen aus zwei Befehlen deutlich beschleunigte, indem diese ohne wiederholtes Lesen der Befehle ausgeführt wurden.
Der "Motorola 68012" war eine Variante des 68010 bei dem zusätzliche Adressleitungen die Adressierung von bis zu 2 GB Speicher erlaubten.
Mit dem Motorola 68020 wurde der Prozessor komplett auf 32-Bit umgestellt, verfügte erstmals über einen Cache für Instruktionen (Größe: 256 Byte) und konnte problemlos mit der FPU 68881 bzw. 68882 oder der MMU 68851 eingesetzt werden.
Der Motorola 68030 erhielt eine integrierte programmierbare MMU, mit deren Hilfe Virtuelle Speicherverwaltung möglich wird, und getrennte Cachespeicher für Daten (256 Bytes) und Befehle (256 Bytes).
Die FPU wurde mit dem Motorola 68040 auf dem Chip integriert sowie der Level-1-Cache auf 4 KB vergrößert. Durch interne Taktverdoppelung bringt ein 68040 mit 25 MHz etwa die Integer-Rechenleistung eines mit 50 MHz getakteten 68030.
Der Motorola 68060 bot eine deutliche Leistungsverbesserung gegenüber dem 68040; er ließ ebenfalls Taktfrequenzen von 50 MHz zu, die jedoch intern verdreifacht wurde. Er wurde aber hauptsächlich für eingebettete Anwendungen eingesetzt, da die Prozessoren von Intel aufgrund der wesentlich größeren Stückzahlen sehr viel günstiger waren, bei Servern nun hauptsächlich RISC-Prozessoren Verwendung fanden und mit dem PowerPC bereits ein markttechnischer Nachfolger im PC- und Workstation-Bereich zur Verfügung stand. Außer in einigen erweiterten Amiga-Computern und als eingebettetes System fand der Motorola 68060 praktisch keine Anwendung.
Weiterentwicklungen mit erweitertem Befehlssatz stellen die Motorola Coldfire und Motorola Dragonball Prozessoren dar, letzterer kommt in den PDAs von Palm zum Einsatz.
Typische 68k-Betriebssysteme sind OS-9, AmigaOS, Atari-TOS, Mac OS, MiNT, Linux68k, NetBSD und OpenBSD.
Siehe auch
Wikimedia Foundation.