Scancode
Ein Scancode ist in der Computertechnik eine Nummer, die von der Tastatur eines Rechners an diesen gesendet wird, wenn eine Taste gedrückt oder losgelassen wird.
PC/XT-Tastatur
Im Jahr 1981 hat IBM zusammen mit dem ersten IBM-PC eine Tastatur mit 83 Tasten eingeführt. Da diese auch beim 1983 erschienenen IBM PC/XT unverändert beibehalten wurde, ist sie heute als XT-Tastatur bekannt.
Frühere Computertastaturen sendeten oft direkt ASCII oder Codes einer anderen Zeichensatznorm an den Rechner. Um aber beim für den Vertrieb in vielen Ländern geplanten IBM PC nicht in jeder länderspezifischen Tastaturvariante andere Codes generieren zu müssen, wurde jeder Taste eine Nummer zugeordnet, der sog. Scancode. Dem Scancode wurde dann erst im Rechner vom Tastaturtreiber ein ASCII-Code zugeordnet. Für den Scancode wurden die Tasten einfach nach ihrer Lage auf der Tastatur reihenweise von links nach rechts durchnummeriert, im Gegensatz zum ASCII-Code, der der alphabetischen Anordnung folgt.
Ein Standard-Tastaturtreiber für die US-amerikanische Belegung war bei jedem PC im BIOS integriert, länderspezifische Zuordnungen erledigte ein Software-Tastaturtreiber, der als TSR-Programm beim Systemstart nachgeladen wurde. Unter MS-DOS heißt dieses Programm „KEYB.COM“, andere Betriebssysteme verwendeten oft den gleichen Namen.
Somit musste IBM bei den PC-Tastaturen für den Vertrieb in verschiedenen Ländern nur unterschiedlich bedruckte Tastenkappen einbauen, während die Elektronik der Tastatur gleich bleiben konnte und sich am Rechner selbst überhaupt nichts ändern musste.
Bei der XT-Tastatur gab es links einen Block von 10 Funktionstasten und rechts die alphanumerischen Tasten mit angegliedertem Zahlenblock. LEDs zur Signalisierung der aktuellen Zustände und einen separaten Pfeiltastenblock gab es noch nicht. Die Kommunikation geschah ausschließlich von der Tastatur zum PC, der PC konnte seinerseits also noch keine Befehle an die Tastatur schicken. Der prinzipielle Aufbau der seriellen Schnittstelle ist unter PS/2-Schnittstelle beschrieben; der typische Steckverbinder für PC- und AT-Tastaturen war allerdings über lange Jahre ein 5-poliger DIN-Steckverbinder, den man in Deutschland als Stecker für NF-Signale kannte („Überspielkabel“).
PC/AT-Tastatur
Die logische Weiterentwicklung war die 1984 mit dem IBM PC/AT eingeführte AT-Tastatur mit 84 Tasten (abgesetzten Funktionstasten und 10er Block). Hier wurde die physikalische Schnittstelle beibehalten, jedoch wurde die Signalisierung komplett neu gestaltet. Die Kommunikation zwischen Rechner und Tastatur war nun bidirektional, erkennbar beispielsweise daran, dass der Rechner die Status-LEDs programmgesteuert schalten konnte. Die übertragenen Codes waren völlig andere als beim XT. Ein kleiner Ein-Chip-Rechner (Intel 8042) auf der Hauptplatine des Computers, etwas missverständlich „Keyboard-BIOS“ genannt, setzte die tatsächlich übertragenen Codes auf kompatible Werte um. Für die Software sah eine AT-Tastatur (mit ihrem vorgeschalteten „Keyboard-BIOS“) einer XT-Tastatur sehr ähnlich; so konnte die so wichtige Kompatibilität der Rechner erhalten bleiben. Die Umsetzung der Codes war abschaltbar, und IBM rechnete wohl damit, dass sie normalerweise abgeschaltet sein würde, sobald ein moderneres Betriebssystem verfügbar wurde; in der Praxis wurde aber weiterhin fast überall MS-DOS bzw. PC-DOS verwendet und die Umsetzung war praktisch immer eingeschaltet.
Der Umbau eines XT auf AT erforderte meist den Austausch der Tastatur; es gab aber auch Tastaturen, die einen Umschalter auf der Unterseite hatten oder sich automatisch passend umschalten konnten.
MF2-Tastatur
Der nächste Generationswechsel vollzog sich 1986, als IBM die 101 Tasten große MF2-Tastatur (multi-functional) für den US-Markt herausbrachte. Analog wurde die länderspezifische 102 Tasten große MF2-Tastatur definiert. Letztlich basieren auf diesen beiden Tastaturbelegungen alle heute üblichen Erweiterungen, wie beispielsweise die 104/105-Tasten-Windows-Tastatur.
Die MF2-Tastatur verwendete die gleiche Schnittstelle und Signalisierung wie die vorherige PC/AT-Tastatur. Ab 1987 wurde der Stecker für die IBM PS/2-Computer durch eine kleinere Variante ersetzt, die elektrischen Signale blieben aber die gleichen.
Die Anordnung der Tasten wurde dahingehend geändert, dass nun die Funktionstasten, deren Anzahl zugleich um zwei erhöht wurde, oberhalb der alphanumerischen Tasten liegen. Der Zehnerblock und spezielle Tasten zur Cursorbewegung wurden optisch getrennt.
Grundsätzlich wird beim Drücken einer Taste der entsprechende Scancode der Taste gesendet. Bei längerem Drücken wird der gleiche Scancode wiederholt gesendet und beim Loslassen wird ein sog. Break-Code $F0 dem Scancode vorangesetzt.
Das „keyboard BIOS“ setzt diese Werte allerdings weiterhin um. Nach dieser Umsetzung ist in der Regel beim make code das oberste Bit 0, beim break code aber 1.
Beispiel: Die Leertaste hat nach der Umsetzung den make code $39 und den break code $B9.
Um mit einer MF2-Tastatur kompatibel zur XT-Tastatur zu sein, bekamen die Tasten des neuen Cursorblocks (nach der Umsetzung) den gleichen Code mit einem speziellen Code $E0 oder $E1 zur Unterscheidung davorgesetzt. Alte Software ignorierte gewöhnlich den ihr unbekannten Code $E0 bzw. $E1 und verarbeitete nur den folgenden Code, der der gleiche war wie bei der jeweils entsprechenden Taste des alten kombinierten Ziffern/Cursorblocks. Neue Software konnte dagegen den Code $E0 bzw. $E1 bei Bedarf erkennen und wusste dann, dass eine Taste des neuen Cursorblocks und nicht eine des kombinierten Ziffern/Cursorblocks gedrückt worden war.
Die amerikanische MF2-Tastatur hat 101 Tasten; die länderspezifische 102 Tasten. Die zusätzliche Taste trägt auf deutschen Tastaturen die drei Zeichen „<“, „>“ und „|“, die linke Umschalttaste ist dafür verkleinert.
Tastaturbefehle
- Wird die Tastatur zurückgesetzt (PC schickt Reset = $FF), antwortet sie bei erfolgreichem Basic Assurance Test mit Bat = $AA
- Wird die Tastatur zurückgesetzt und es gibt einen Fehlerfall, klemmt beispielsweise eine Taste, reagiert sie mit BatE1 = $FC oder BatE2 = $FD.
- Der Test der Kommunikation erfolgt vom PC mit Echo = $EE und die Tastatur antwortet ebenfalls mit Echo = $EE.
- Allgemein werden alle Kommandos zur Tastatur mit Acknowledge Ack = $FA von der Tastatur bestätigt. Stimmt etwas nicht mit den Daten, kommt ein Misunderstand Misu = $FE.
- Wird die Tastatur mit Read ID = $F2 nach ihrem Typ gefragt, antwortet eine MF2-Tastatur mit 2 Bytes ID1 = $AB und ID2 = $83. Aus Kompatibilitätsgründen wurde dies auch bei späteren Tastaturen nie geändert, so dass in der Praxis der Typ nicht softwaremäßig abgefragt werden kann (außer bei USB-Tastaturen, siehe unten).
- Ist der Tastaturpuffer voll, reagiert die Tastatur mit Full = $FF.
- Der vom PC kommende Befehl Set LED = $ED gefolgt von einem Byte steuert die Leuchtdioden (Bit 0..2 = ScrlLock, NumLock, CapsLock; Bit 3..7 = 0).
- Vom PC kommendes Set Codeset = $F0 gefolgt von einem Byte wählt das Code-Set 1..3 aus.
- Vom PC kommendes Set Codeset = $F0 gefolgt von 0 fragt ab, welches Code Set aktiv ist.
- Vom PC kommender Befehl Set Speed = $F3 gefolgt von einem Byte steuert die Verzögerungszeit zwischen dem Tastendruck und dem Anspringen der automatischen Tastenwiederholung (Bit 5, 6) und die Wiederholungsrate (Bit 0..4).
- Vom PC kommendes Enable = $F4 aktiviert den Scanvorgang und Disable = $F5 deaktiviert den Scanvorgang, so dass keine Tastendrücke mehr erkannt werden.
- Vom PC kommendes Set Default = $F6 setzt alles auf Standardwerte.
- Vom PC kommendes Resend = $FE fordert die Tastatur auf, den letzten Antwortcode zu wiederholen. Von der Tastatur kommendes Resend = $FE fordert umgekehrt den Rechner zur Wiederholung auf. Diese Codes werden gesendet, wenn durch eine Leitungsstörung Paritätsfehler oder unvollständige Bytes empfangen werden.
Code-Sets
Die Codetabelle der PC-Tastatur ist komplex, innerhalb der MFM-Tastatur selbst existieren drei Tabellen mit Scancodes, welche durch das Senden von Befehlscodes an die Tastatur ausgewählt werden können.
- Scancode-Set 1 (entspricht im Wesentlichen der XT-Tastatur)
- Scancode-Set 2 (entspricht im Wesentlichen der AT-Tastatur, heutiger Standard)
- Scancode-Set 3 (neues, logischer aufgebautes Codeset der MF2-Tastatur, das sich aber nie durchsetzen konnte)
Zusätzlich kann die Umwandlung von Tastaturcodes durch das im Rechnergehäuse befindliche „Keyboard BIOS“ ein- und ausgeschaltet werden (heutiger Standard: eingeschaltet); damit ergeben sich aus Sicht der Firmware und Software, die die Codes letztlich empfangen, insgesamt sechs mögliche Codevarianten.
Tastaturen anderer Hersteller als IBM haben teilweise die Scancode-Sets 1 und 3 nicht oder fehlerhaft umgesetzt. Ebenso funktioniert die Abschaltung der Scancodeumwandlung auf manchen Mainboards nicht korrekt. Auch die existierenden PC-Emulatoren implementieren diese Varianten nicht. Daher verwenden alle heutigen PC-Betriebssysteme ausschließlich das Scancode-Set 2 mit eingeschalteter Umwandlung. Der Controller im Keyboard überträgt die Codes zum „Keyboard-BIOS“ im PC mit Scancode-Set 2, und dieses setzt sie dann um auf Scancode-Set 1. Die Software bekommt daher auf allen PCs gewöhnlich nur die älteste Variante, Set 1, zu Gesicht – auf dem Ur-PC und auf XTs direkt, auf ATs und allen neueren PCs per Umsetzung.
USB-Tastaturen
USB-Tastaturen verwenden einen neuen Satz von Scancodes ohne Beziehung zu den verschiedenen älteren Systemen; die entsprechenden Treiber neuer Betriebssysteme können diese Codes verarbeiten. Für die Verwendung mit Bootloadern und älteren Betriebssystemen werden deren Scancodes vom BIOS des Rechners softwaremäßig auf die alten Scancodes abgebildet. Dabei wird ebenfalls nur das Scancode-Set 2 mit eingeschalteter Umwandlung emuliert. Manche BIOSe führen diese Umwandlung unvollständig durch, so wird z. B. teilweise die AltGr-Taste nicht von der Alt-Taste unterschieden, was für deutsche Tastaturen problematisch ist.
Die Scancodes für USB-Tastaturen sind architekturübergreifend einheitlich. USB-Tastaturen für die Apple-Macintosh-Serie verwenden also die gleichen Scancodes wie PC-USB-Tastaturen.