S-Record

aus Wikipedia, der freien Enzyklopädie
Zur Navigation springen Zur Suche springen

Das Motorola-S-Record-Format ist ein ASCII-basiertes Datenformat zur Kodierung von Binärdateien. Es ist auch als SREC- oder S19-Format bekannt. Hauptsächlich wird es zum Abspeichern des Programmcodes von Mikrocontrollern in eingebetteten Systemen verwendet. Es wurde in den 1970er Jahren vom Hersteller Motorola für dessen 6800-Mikroprozessor entwickelt.

Ein ähnliches, wenn auch leicht unterschiedliches Format ist das Intel-HEX-Format, welches u. a. für Intel-Prozessoren verwendet wird.

Die ASCII-Kodierung erlaubt die Bearbeitung bzw. das Öffnen der Datei mit einem Texteditor. Da es Prüfsummen enthält, können bei einer Übertragung beschädigte Datensätze erkannt werden.[1]

Eine S-Record-Datei besteht aus einer Reihe von ASCII-Datensätzen (engl. Records). Alle Hexadezimalzahlen sind Big endian, d. h. das höchstwertige Byte wird als erstes, also auf der kleineren Adresse gespeichert. Die Datensätze haben folgende Struktur:

  1. Start code, ein Zeichen: S
  2. Record type (Datensatztyp), eine Ziffer, 0 bis 9, definiert den Typ des Datensatzes
  3. Byte count (die Anzahl der Bytes), zwei hexadezimale Ziffern, 0 bis F, beinhaltet die Anzahl der Bytes (also jeweils zwei hexadezimale Ziffern) die im restlichen Datensatz (Adresse, Daten und Prüfsumme) folgen.
  4. Adresse, vier, sechs oder acht hexadezimale Ziffern (abhängig vom Datensatztyp), die die Speicheradresse der darauf folgenden Daten festlegen.
  5. Datenfeld, eine Folge von 2n hexadezimalen Ziffern, also n Datenbytes
  6. Checksum (Prüfsumme), zwei hexadezimale Ziffern – das Einerkomplement des niederwertigen Bytes der Summe von byte count, Adresse (byteweise) und der Daten (ebenfalls byteweise)

Es gab einige Programme, die die Anzahl der Zeichen in einem S-Record aus Gründen der Kompatibilität mit Fernschreibern auf 56 druckbare Zeichen begrenzten[2]. Eine UNIX-Manpage schreibt von einer Begrenzung auf 78 druckbare Zeichen[3]. Da von Motorola kein Limit definiert wurde, sollte ein Programm auch mit einem Byte count von 255, also mit 514 druckbaren zuzüglich terminierender Zeichen, umgehen können[4].

Es existieren die acht unten aufgeführten Datensatztypen:

Record Beschreibung Adressbytes Datenfeld
S0 Block header (Block Vorspann) 2 Ja
S1 Datenreihe 2 Ja
S2 Datenreihe 3 Ja
S3 Datenreihe 4 Ja
S5 Record count (Datensatzanzahl) 2 Nein
S6 Record count (Datensatzanzahl) 3 Nein
S7 End of block (Blockende) 4 Nein
S8 End of block (Blockende) 3 Nein
S9 End of block (Blockende) 2 Nein
  • Der S0-Vorspann enthält keine Programmdaten, sondern herstellerspezifische Daten. Das Datenfeld ist folgendermaßen aufgebaut:
    • Modulname (20 Zeichen)
    • Version (2 Zeichen)
    • Revision (2 Zeichen)
    • Beschreibung (0–36 Zeichen)
  • Im S5-Datensatz ist die Anzahl der vorstehenden S1-, S2- und S3-Datensätze in dem zwei Byte großen Adressfeld gespeichert. Dieser Datensatz enthält kein Datenfeld. Der S6-Datensatz hat die gleiche Funktion wie der S5-Datensatz und hat auch, bis auf das drei Byte große Adressfeld, den gleichen Aufbau.
  • Die Adressfelder von S7, S8, oder S9 können die Startadresse des Programmes enthalten.[2]

Beispiel mit 16-bit Adressen

[Bearbeiten | Quelltext bearbeiten]
S00F000068656C6C6F212020202000003B
S11F00007C0802A6900100049421FFF07C6C1B787C8C23783C6000003863000026
S11F001C4BFFFFE5398000007D83637880010014382100107C0803A64E800020E9
S111003848656C6C6F20776F726C642E0A0042
S5030003F9
S9030000FC
  • Start code
  • Record type (Datensatztyp)
  • Byte count
  • Adresse
  • Daten
  • Checksum (Prüfsumme)
  • Die Prüfsumme für den ersten Beispiel-Datensatz berechnet sich wie folgt: .

    Beispiel mit 24-bit Adresse

    [Bearbeiten | Quelltext bearbeiten]
     S2140D0760FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF87
    

    Verwandte Dateiformate

    [Bearbeiten | Quelltext bearbeiten]

    Sehr ähnlich ist das Intel HEX-Format (auch kurz Intel HEX). Weitere Formate für diesen Anwendungsbereich sind z. B. der einfache Binärcode oder das Jedec-Format.

    1. srec - Linux man page
    2. a b MC68000 Family Programmer’s Reference Manual (PDF; 2,4 MB) Appendix C
    3. Archivierte Kopie (Memento des Originals vom 19. Juni 2015 im Internet Archive)  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/www.ee.nmt.edu
    4. http://www.macgui.com/usenet/?author=Ron+Widell&id=1600&group=45