Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
Beide Seiten der vorigen Revision Vorhergehende Überarbeitung Nächste Überarbeitung | Vorhergehende Überarbeitung | ||
homecomputer:ac1:picoac1 [2024/03/29 14:39] – [Bedienung] volkerp | homecomputer:ac1:picoac1 [2024/12/05 13:18] (aktuell) – [Hardware] volkerp | ||
---|---|---|---|
Zeile 21: | Zeile 21: | ||
Nach dem Anschließen der Stromversorgung sollte der picoAC1 ein Bild ähnlich wie folgt anzeigen: | Nach dem Anschließen der Stromversorgung sollte der picoAC1 ein Bild ähnlich wie folgt anzeigen: | ||
- | TODO | + | {{: |
+ | |||
+ | |||
+ | Die mittig auf der Leiterplatte sitzende LED kennzeichnet den AC1-Betriebsmodus. Im CP/ | ||
===== Bedienung ===== | ===== Bedienung ===== | ||
Zeile 28: | Zeile 31: | ||
Das Standard-System des picoAC1 ist eine Erweiterung des originalen Monitors 3.1 [[homecomputer: | Das Standard-System des picoAC1 ist eine Erweiterung des originalen Monitors 3.1 [[homecomputer: | ||
+ | |||
+ | {{: | ||
+ | |||
+ | {{: | ||
+ | |||
+ | |||
+ | |||
+ | |||
==== Tastatur ==== | ==== Tastatur ==== | ||
Zeile 88: | Zeile 99: | ||
===== Beispiel ===== | ===== Beispiel ===== | ||
- | TODO | + | * {{ : |
+ | |||
+ | Auf der SD-Karte ist folgende Verzeichnisstruktur angelegt: | ||
+ | |||
+ | < | ||
+ | E: (PICOAC1) | ||
+ | ├───.ac1bin | ||
+ | ├───basic8k | ||
+ | ├───cpm | ||
+ | │ | ||
+ | │ | ||
+ | ├───edas | ||
+ | ├───forth | ||
+ | ├───minibas | ||
+ | └───spiele | ||
+ | </ | ||
==== Systemdateien ==== | ==== Systemdateien ==== | ||
Zeile 106: | Zeile 132: | ||
im System " | im System " | ||
- | Die zusätzlichen Monitorkommandos sind **Kleinbuchstaben**, | + | Die zusätzlichen Monitorkommandos sind **Kleinbuchstaben**, |
Monitorkommandos bestehen aus einem Buchstaben/ | Monitorkommandos bestehen aus einem Buchstaben/ | ||
Zeile 116: | Zeile 142: | ||
Die Zeichenkette wird durch ein Leerzeichen abgeschlossen. Nachfolgende Zeichen werden ignoriert. D.h. Zeichenketten können keine Leerzeichen beinhalten. | Die Zeichenkette wird durch ein Leerzeichen abgeschlossen. Nachfolgende Zeichen werden ignoriert. D.h. Zeichenketten können keine Leerzeichen beinhalten. | ||
+ | **s aaaa eeee ssss Dateiname/ | ||
+ | Hiermit kann man eine File ab der Adresse aaaa bis zur Adresse eeee mit der Startadresse ssss unter dem Namen Dateiname (Länge max 16 Zeichen) auf SD-Karte abspeichern. Dem Dateinamen kann ein Infotext angefügt werden. Beide Teile werden durch '/' | ||
- | ==== s - save - Daten auf SD-Karte schreiben ==== | + | **l Dateiname/ |
- | s AAAA EEEE SSSS Dateiname/Infotext | + | l (kleines " |
+ | Wird ein Dateiname oder eine Nummer angegeben, wird die Datei wird im aktuell gewählten Verzeichnis gesucht und ab der im Header angegebenen Anfangsadresse in den RAM geladen. Danach wird die Startadresse im Header nach ARG1 geladen, sodass das Programm mit " | ||
- | AAAA Anfangsadresse | + | **a AADR Dateiname (absolute)** |
- | EEEE Endadresse | + | |
- | SSSS Startadresse | + | |
- | | + | |
- | Infotext | + | |
- | Dem Dateinamen kann ein Infotext angefügt werden. Beide Teile werden | + | Lädt die Datei an Absolut-Adresse AADR. AADR < 1000H werden |
- | ==== l - list/load - Daten von SD-Karte laden/ | + | **r Dateiname (remove)** |
- | l Dateiname (kleines | + | Verschiebt Datei in den Papierkorb-Systemordner |
- | Die Datei wird im aktuell gewählten Verzeichnis gesucht und ab der im Header angegebenen Anfangsadresse in den RAM geladen. | + | **d Verzeichnisname/ |
- | Danach wird die Startadresse im Header nach ARG1 geladen, sodass das Programm mit " | + | |
- | Die restlichen Headerparameter werden nur angezeigt. | + | |
- | Dateiinhalt des aktuellen Verzeichnisses auflisten | + | Ohne Parameter werden alle Verzeichnisse aufgelistet. Enthält Verzeichnisname das Wildcardzeichen " |
+ | Wird ein Verzeichnisname oder eine Nummer angegeben, wird in das entsprechende Verzeichnis gewechselt. Mit "d /" wird ins Root-Verzeichnis gewechselt. | ||
- | l * | + | Es wird mit einer Verzeichnisebene unterhalb von Root gearbeitet. Weitere Unterverzeichnisse werden nicht unterstützt. |
- | l XX* | + | Beim Auflisten wird das aktuell gewählte Verzeichnis |
- | l *.bas --> alle Dateien anzeigen, die mit ".bas" enden | + | Es ist möglich, direkt von einem in ein anderes Verzeichnis zu wechseln. Ein Umweg über das Root-Verzeichnis ist nicht erforderlich. |
- | Das " | + | **m Verzeichnisname (makedir)** |
- | l + --> Sortierung nach Änderungsdatum aufsteigend | + | Es wird ein neues Verzeichnis unterhalb von Root angelegt. Es ist dabei unerheblich, |
- | l - | + | |
- | Dateilisten sind auf 256 Einträge eines Verzeichnisses begrenzt. | + | **t YYYY-MM-DD*hh: |
- | Laden von Dateien an Hand der Indexnummer | + | Ohne Parameter wird die aktuelle Uhrzeit angezeigt, mit Parameter wird die Uhr gestellt. Die Systemzeit ist dabei in UTC (MEZ-1h | MESZ-2h) zu setzen. Diese Zeitbasis wird zum Speichern auf SD-Karte benötigt. Andernfalls wird am PC ein falscher Zeitstempel angezeigt! |
- | Mit dem l-Kommando können Inhalte des aktuell gewählten Verzeichnisses angezeigt werden. Vorangestellt ist jedem Dateinamen eine lfd Nummer | + | **c v:h:r (color)** |
- | Beispiel 1: | + | |
- | l 5 --> lädt die Datei mit der lfd Nummer 05. | + | Setzt die drei Bildschirmfarben für Vordergrund, |
+ | Der dritte Parameter ist optional. Bei weglassen wird ' | ||
- | Beispiel 2: | + | **H (help)** |
+ | **h (help)** | ||
- | l - --> Anzeigen der Dateinamen, aktuellste Datei zuerst | + | Anzeige der Bedienung des Ur-Monitors 3.1 mit H, die Bedienung der Monitorerweiterungen mit " |
- | l 1 --> lädt die zuletzt gespeicherte Datei | + | |
- | Die Nummerierung richtet sich immer nach der zuletzt angezeigten Liste. | + | ==== Drucken in Datei ==== |
- | Nebenwirkung: | + | Left-Strg + Alt + p |
- | ==== a - addr - Laden von Dateien | + | Dabei handelt es sich um eine Hilfsfunktion, |
+ | Gestartet wird die Funktion mit der Tastenkombination Left-Strg + Alt + P. Dabei wird automatisch ein Dateiname PXXXX.txt erzeugt, wobei XXXX eine fortlaufende Nummer ist, die in der .config gespeichert wird. | ||
+ | Danach ist das Anwenderprogramm zum Drucken zu veranlassen und nach Abschluss des Vorgangs ist wiederholt Left-Strg + Alt + P zu betätigen. Erst dann wird die Datei auf der SD-Karte gespeichert. | ||
+ | In der Statuszeile wird Dateiname und Fortschritt angezeigt. | ||
+ | ==== Externe Funktionen ==== | ||
- | a AADR Dateiname | + | Funktionen / Kommandos, die nicht im EPROM Platz gefunden haben oder weichen mussten, lassen sich im Flash des picoIO einbinden und per Kommandozeichen über die ZCOM-Schnittstelle in den RAM laden und starten. |
- | AADR < 1000H werden zurückgewiesen. Es wird nur die Anfangsadresse geprüft. | + | Aktuell eingebundene Kommandos: |
- | Weiteres Verhalten wie beim " | + | |
- | Beispiel: | + | Z --> MiniBasic-Interpreter nach 0F000h laden und dort starten. |
- | a C000 5 | + | Beim Verlassen wird angeboten, das Basic-Programm per Kommandozeile zu speichern. Hierzu ist das Prompt-Symbol '#' |
- | Lädt die 5.Datei der zuletzt ausgegebenen Liste nach 0C000H. | + | ===== Hardware ===== |
- | ==== r - remove - Datei in Papierkorb verschieben ==== | + | Die Funktionsweise der Hardware ist auf https:// |
+ | ^ Merkmal | ||
+ | | CPU | U880 | | ||
+ | | ROM | 4K 0000-0FFF (Monitor) | ||
+ | | RAM | 64K 1000-FFFF (ab 0000 im CP/ | ||
+ | | Takt | 1,2,4,8 MHz | | ||
+ | | Anzeige | ||
+ | | Tastatur | ||
+ | | Peripherie | ||
+ | | | Videoprozessor (raspberry pico ) | | ||
+ | | | I/ | ||
- | r Dateiname | + | ^ Port | Verwendung | |
+ | | 00-03 | CTC | | ||
+ | | 04-07 | PIO | | ||
+ | | 1C(-1F) | CP/ | ||
- | Der Dateiname wird um einen TimestampSuffix der aktuellen Systemzeit (.YYMMDDhhmmss) ergänzt und die Datei in den Systemordner " | ||
- | ==== d - directory | + | Der picoAC1 entspricht einem AC1 mit 64K RAM und CP/ |
+ | Auf der Platine sitzt ein 128K-SRAM. Dessen Kapazität kann allerdings nicht komplett genutzt werden. Die beiden 64K-Bänke werden parallel genutzt. Die untere Bank (A16=L) wird als Bildwiederholspeicher und Arbeitszellenspeicher genutzt (1000h-17FFh), | ||
- | d Verzeichnisname | + | Die Umschaltung in den CP/M-Modus erfolgt durch ein Latch auf Port 1Ch(..1Fh). OUT 1Ch, Bit0=0 schaltet den AC1-Modus ein (Monitor-ROM, BWS aktiv), OUT 1Ch, Bit0=1 schaltet den CP/M-Modus ein (durchgehend RAM). |
- | d* --> Auflisten aller Verzeichnisse, alphabetisch sortiert, ' | + | |
- | d+ --> Liste nach Dateidatum sortiert, aufsteigend | + | |
- | d- --> Liste nach Dateidatum sortiert, absteigend | + | |
- | d *abc* --> auflisten aller Ordner, die die Zeichenfolge " | + | |
- | d / --> wechseln ins Root-Verzeichnis | + | |
- | d1 --> wechseln ins Verzeichnis mit ldf Nummer(1), entspr. der zuletzt ausgegebenen Liste | + | |
- | Es wird mit einer Verzeichnisebene unterhalb von Root gearbeitet. Weitere Unterverzeichnisse werden nicht unterstützt. | + | <a2s> |
- | Beim Auflisten wird das aktuell gewählte Verzeichnis mit einem ' | + | |
- | Es ist möglich, direkt von einem in ein anderes Verzeichnis zu wechseln. Ein Umweg über das Root-Verzeichnis ist nicht erforderlich. | + | |
+ | | | ||
+ | | RAM | | ||
+ | | | ||
+ | | | ||
+ | 2000 # | ||
+ | | Mon-RAM | ||
+ | | 2K | ||
+ | 1800 # | ||
+ | | BWS | | ||
+ | | 2K | ||
+ | 1000 # | ||
+ | | Monitor | ||
+ | | 4K | ||
+ | 0000 # | ||
- | ==== m - makedir - Verzeichnis anlegen ==== | + | OUT 1Ch,0 OUT 1Ch,1 |
+ | </ | ||
- | m Verzeichnisname | ||
- | Es wird ein neues Verzeichnis unterhalb von Root angelegt. Es ist dabei unerheblich, | + | Zeichensätze: |
- | Das Löschen von Verzeichnissen kann nur am PC erfolgen. | + | |
- | ==== t - time - Zeitfunktionen ==== | + | {{: |
- | t YYYY-MM-DD*hh:mm:ss | + | {{:homecomputer:ac1:picoac1_zs_scch.jpg? |
- | t 2023-09-03*18:05:45 --> Systemzeit setzen | + | |
- | t --> Anzeige der aktuellen Systemzeit | + | |
- | Falls ein RTC-Modul installiert ist, wird die Zeit beim picoIO-Start übernommen. | ||
- | Die Systemzeit ist in UTC (MEZ-1h | MESZ-2h) zu setzen. Diese Zeitbasis wird zum Speichern auf SD-Karte benötigt. Andernfalls wird am PC ein falscher Zeitstempel angezeigt. | ||
- | Beim Setzen der Systemzeit ist das Format einzuhalten. Entscheidend ist die Position der Ziffern in der Zeichenkette. Die Trennzeichen sind beliebig. | + | ===== CP/M ===== |
- | Die Eingabe erfolgt als Zeichenkette und unterliegt o.g. Einschränkungen, | + | |
- | ==== c - color - Bildschirmfarben ==== | + | Aktuell gibt es eine CP/M-2.2-kompatible Implementierung. |
- | c 7:0:3 -> Zeichen-, Hintergrund- und Rahmenfarbe | + | Für den Betrieb von CP/M sind auf der SD-Karte diverse Dateien abzulegen, am besten in einem eigenen Verzeichnis. |
- | c --> Farbliste ausgeben | + | |
- | Der dritte Parameter ist optional. Bei weglassen wird ' | + | TODO |
- | ==== h/H - help - Hilfetexte ausgeben ==== | + | Es gibt 6 Laufwerke A-F, die als Disketten-Image auf der SD-Karte liegen. |
+ | C und D sind dabei 8 MByte große " | ||
- | H --> Bedienung "Ur-" | + | Der Bildschirmtreiber nutzt die Cursor-Positionierung nach SCP. Steuerzeichen: |
- | | + | <code> |
+ | ; Bildschirm-Steuerzeichen, | ||
+ | ; 00h NOP (keine Wirkung) | ||
+ | ; 01h Cursor links oben (home) | ||
+ | ; 07h akustisches | ||
+ | ; 08h Cursor zurueck | ||
+ | ; 0ah Linefeed (neue Zeile) | ||
+ | ; 0ch Bildschirm | ||
+ | ; zuletzt ausgegebenen Bildschirmzeilen), | ||
+ | ; links oben | ||
+ | ; 0dh Carriage Return (an Zeilenanfang) | ||
+ | ; 14h Rest des Bildschirms löschen | ||
+ | ; 15h Cursor nach rechts | ||
+ | ; 16h Rest der Zeile löschen | ||
+ | ; 18h Zeile löschen, Cursor an Zeilenanfang | ||
+ | ; 1ah Cursor eine Zeile hoch | ||
+ | ; 1bh Einleitung | ||
+ | ; sten beiden Bytes beinhalten Zeile und Spalte | ||
+ | ; Offset 00h oder 80h | ||
+ | ; 7fh Delete (streichen Zeichen links vom Kursor) | ||
+ | ; 20H..7EH | ||
+ | </code> | ||
- | ==== Drucken in Datei ==== | + | Hier die **diskdefs** für die [[cpm: |
- | LStrg + Alt + p | + | < |
+ | # 800K AC1PICO-Hausformat | ||
+ | diskdef ac1 | ||
+ | seclen 512 | ||
+ | tracks 10 | ||
+ | sectrk 160 | ||
+ | blocksize 2048 | ||
+ | maxdir 256 | ||
+ | skew 0 | ||
+ | boottrk 0 | ||
+ | os 2.2 | ||
+ | end | ||
- | Dabei handelt es sich um eine Hilfsfunktion, | + | # 8MB AC1PICO-Hausformat |
- | Gestartet wird die Funktion mit der Tastenkombination LStrg + Alt + P. Dabei wird automatisch ein Dateiname PXXXX.txt erzeugt, wobei XXXX eine fortlaufende Nummer ist, die in der .config gespeichert wird. | + | diskdef ac1_8mb |
- | Danach ist das Anwenderprogramm zum Drucken zu veranlassen und nach Abschluss des Vorgangs ist wiederholt LStrg + Alt + P zu betätigen. Erst dann wird die Datei auf der SD-Karte gespeichert. | + | |
- | In der Statuszeile wird Dateiname und Fortschritt angezeigt. | + | |
+ | sectrk 512 | ||
+ | blocksize 4096 | ||
+ | maxdir 512 | ||
+ | skew 0 | ||
+ | boottrk 0 | ||
+ | os 2.2 | ||
+ | end | ||
+ | </ | ||
- | ==== Externe Funktionen ==== | + | Starten von CP/M aus dem Monitor: |
- | Funktionen / Kommandos, die nicht im EPROM Platz gefunden haben oder weichen mussten, lassen sich im Flash des picoIO einbinden und per Kommandozeichen über die ZCOM-Schnittstelle in den RAM laden und starten. | + | {{: |
- | Aktuell eingebundene Kommandos: | + | Importieren |
- | + | ||
- | Z --> MiniBasic-Interpreter nach 0F000h laden und dort starten. | + | |
- | + | ||
- | Beim Verlassen wird angeboten, das Basic-Programm per Kommandozeile zu speichern. Hierzu ist das Prompt-Symbol '#' | + | |
+ | {{: |