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/31 08:31] – [Anschluss] volkerp | homecomputer:ac1:picoac1 [2024/12/05 13:18] (aktuell) – [Hardware] volkerp | ||
---|---|---|---|
Zeile 1: | Zeile 1: | ||
- | |||
====== picoAC1 ====== | ====== picoAC1 ====== | ||
Zeile 22: | 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/ | ||
- | Die mittige LED kennzeichnet den AC1-Betriebsmodus. Im CP/ | ||
===== Bedienung ===== | ===== Bedienung ===== | ||
Zeile 30: | 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 90: | 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 118: | 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 /" | |
- | l * | + | |
- | l XX* | + | |
- | l *.bas --> alle Dateien anzeigen, die mit " | + | |
- | + | ||
- | Das " | + | |
- | + | ||
- | l + --> Sortierung nach Änderungsdatum aufsteigend | + | |
- | l - | + | |
- | + | ||
- | Dateilisten sind auf 256 Einträge eines Verzeichnisses begrenzt. | + | |
- | + | ||
- | Laden von Dateien an Hand der Indexnummer | + | |
- | + | ||
- | Mit dem l-Kommando können Inhalte des aktuell gewählten Verzeichnisses angezeigt | + | |
- | Beispiel 1: | + | |
- | + | ||
- | | + | |
- | + | ||
- | Beispiel 2: | + | |
- | + | ||
- | l - | + | |
- | l 1 --> lädt die zuletzt gespeicherte Datei | + | |
- | + | ||
- | Die Nummerierung richtet sich immer nach der zuletzt angezeigten Liste. | + | |
- | + | ||
- | Nebenwirkung: | + | |
- | + | ||
- | ==== a - addr - Laden von Dateien an Absolut-Adresse im RAM ==== | + | |
- | + | ||
- | + | ||
- | a AADR Dateiname | + | |
- | + | ||
- | AADR < 1000H werden zurückgewiesen. Es wird nur die Anfangsadresse geprüft. | + | |
- | Weiteres Verhalten wie beim " | + | |
- | + | ||
- | Beispiel: | + | |
- | + | ||
- | a C000 5 | + | |
- | + | ||
- | Lädt die 5.Datei der zuletzt ausgegebenen Liste nach 0C000H. | + | |
- | + | ||
- | ==== r - remove - Datei in Papierkorb verschieben ==== | + | |
- | + | ||
- | + | ||
- | r Dateiname | + | |
- | + | ||
- | Der Dateiname wird um einen TimestampSuffix der aktuellen Systemzeit (.YYMMDDhhmmss) ergänzt und die Datei in den Systemordner | + | |
- | + | ||
- | ==== d - directory - Verzeichnisse anzeigen | + | |
- | + | ||
- | d Verzeichnisname --> Setzen des aktuellen Arbeitsverzeichnisses | + | |
- | d* --> Auflisten aller Verzeichnisse, | + | |
- | d+ --> Liste nach Dateidatum sortiert, aufsteigend | + | |
- | d- --> Liste nach Dateidatum sortiert, absteigend | + | |
- | d *abc* --> auflisten aller Ordner, die die Zeichenfolge | + | |
- | d / --> wechseln | + | |
- | 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. | Es wird mit einer Verzeichnisebene unterhalb von Root gearbeitet. Weitere Unterverzeichnisse werden nicht unterstützt. | ||
Zeile 204: | Zeile 168: | ||
Es ist möglich, direkt von einem in ein anderes Verzeichnis zu wechseln. Ein Umweg über das Root-Verzeichnis ist nicht erforderlich. | Es ist möglich, direkt von einem in ein anderes Verzeichnis zu wechseln. Ein Umweg über das Root-Verzeichnis ist nicht erforderlich. | ||
- | ==== m - makedir | + | **m Verzeichnisname (makedir)** |
- | m Verzeichnisname | + | Es wird ein neues Verzeichnis unterhalb von Root angelegt. Es ist dabei unerheblich, |
- | Es wird ein neues Verzeichnis unterhalb von Root angelegt. Es ist dabei unerheblich, | + | **t YYYY-MM-DD*hh: |
- | Das Löschen von Verzeichnissen kann nur am PC erfolgen. | + | |
- | ==== t - time - Zeitfunktionen ==== | + | 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! |
- | t YYYY-MM-DD*hh:mm:ss | + | **c v:h:r (color)** |
- | 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. | + | Setzt die drei Bildschirmfarben für Vordergrund, Hintergrund und Rahmen. Ohne Parameter |
- | Die Systemzeit | + | Der dritte Parameter |
- | Beim Setzen der Systemzeit ist das Format einzuhalten. Entscheidend ist die Position der Ziffern in der Zeichenkette. Die Trennzeichen sind beliebig. | + | **H (help)** |
- | Die Eingabe erfolgt als Zeichenkette und unterliegt o.g. Einschränkungen, | + | **h (help)** |
- | ==== c - color - Bildschirmfarben ==== | + | Anzeige der Bedienung des Ur-Monitors |
- | + | ||
- | c 7:0:3 -> Zeichen-, Hintergrund- und Rahmenfarbe | + | |
- | c --> Farbliste ausgeben | + | |
- | + | ||
- | Der dritte Parameter ist optional. Bei weglassen wird ' | + | |
- | + | ||
- | ==== h/H - help - Hilfetexte ausgeben ==== | + | |
- | + | ||
- | H --> | + | |
- | | + | |
==== Drucken in Datei ==== | ==== Drucken in Datei ==== | ||
- | | + | |
Dabei handelt es sich um eine Hilfsfunktion, | Dabei handelt es sich um eine Hilfsfunktion, | ||
- | Gestartet wird die Funktion mit der Tastenkombination | + | Gestartet wird die Funktion mit der Tastenkombination |
- | Danach ist das Anwenderprogramm zum Drucken zu veranlassen und nach Abschluss des Vorgangs ist wiederholt | + | Danach ist das Anwenderprogramm zum Drucken zu veranlassen und nach Abschluss des Vorgangs ist wiederholt |
In der Statuszeile wird Dateiname und Fortschritt angezeigt. | In der Statuszeile wird Dateiname und Fortschritt angezeigt. | ||
Zeile 258: | Zeile 209: | ||
Die Funktionsweise der Hardware ist auf https:// | Die Funktionsweise der Hardware ist auf https:// | ||
- | ^ Merkmal ^ Beschreibung ^ | + | ^ Merkmal |
- | | CPU | U880 | | + | | CPU |
- | | ROM | 4K 0000-0FFF (Monitor) | | + | | ROM |
- | | RAM | 64K 1000-FFFF (ab 0000 im CP/M-Modus) | | + | | RAM |
- | | Takt | 1,2,4,8 MHz | | + | | Takt | 1,2,4,8 MHz | |
- | | Anzeige | 64x32 Zeichen, s/w, versch. Zeichensätze möglich | | + | | Anzeige |
- | | Tastatur | ASCII | | + | | Tastatur |
- | | Peripherie | 2 PIO, 1 CTC | | + | | Peripherie |
+ | | | Videoprozessor (raspberry pico ) | | ||
+ | | | I/ | ||
^ Port | Verwendung | | ^ Port | Verwendung | | ||
Zeile 276: | Zeile 229: | ||
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), | 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), | ||
- | Die Umschaltung in den CP/M-Modus erfolgt durch ein Latch auf Port 1Ch(..1Fh). OUT 1Ch, 0 schaltet den AC1-Modus ein (Monitor-ROM, | + | 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, |
+ | |||
+ | < | ||
+ | FFFF # | ||
+ | | | ||
+ | | | ||
+ | | RAM | | ||
+ | | | ||
+ | | | ||
+ | 2000 # | ||
+ | | Mon-RAM | ||
+ | | 2K | ||
+ | 1800 # | ||
+ | | BWS | | ||
+ | | 2K | ||
+ | 1000 # | ||
+ | | Monitor | ||
+ | | 4K | ||
+ | 0000 # | ||
+ | |||
+ | OUT 1Ch,0 OUT 1Ch,1 | ||
+ | </ | ||
+ | |||
+ | |||
+ | Zeichensätze: | ||
+ | |||
+ | {{: | ||
+ | |||
+ | {{: | ||
+ | |||
+ | |||
+ | ===== CP/M ===== | ||
+ | |||
+ | Aktuell gibt es eine CP/ | ||
+ | |||
+ | Für den Betrieb von CP/M sind auf der SD-Karte diverse Dateien abzulegen, am besten in einem eigenen Verzeichnis. | ||
+ | |||
+ | TODO | ||
+ | |||
+ | Es gibt 6 Laufwerke A-F, die als Disketten-Image auf der SD-Karte liegen. | ||
+ | C und D sind dabei 8 MByte große " | ||
+ | |||
+ | Der Bildschirmtreiber nutzt die Cursor-Positionierung nach SCP. Steuerzeichen: | ||
+ | < | ||
+ | ; 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 | ||
+ | </ | ||
+ | |||
+ | Hier die **diskdefs** für die [[cpm: | ||
+ | |||
+ | < | ||
+ | # 800K AC1PICO-Hausformat | ||
+ | diskdef ac1 | ||
+ | seclen 512 | ||
+ | tracks 10 | ||
+ | sectrk 160 | ||
+ | blocksize 2048 | ||
+ | maxdir 256 | ||
+ | skew 0 | ||
+ | boottrk 0 | ||
+ | os 2.2 | ||
+ | end | ||
+ | |||
+ | # 8MB AC1PICO-Hausformat | ||
+ | diskdef ac1_8mb | ||
+ | seclen 512 | ||
+ | tracks 32 | ||
+ | sectrk 512 | ||
+ | blocksize 4096 | ||
+ | maxdir 512 | ||
+ | skew 0 | ||
+ | boottrk 0 | ||
+ | os 2.2 | ||
+ | end | ||
+ | </ | ||
+ | |||
+ | Starten von CP/M aus dem Monitor: | ||
+ | |||
+ | {{: | ||
+ | Importieren und Starten von CP/ | ||
+ | {{: |