(CP/M Control program and monitor, digital research) door Peter Huisken
VOORWOORD ( Voor de hardware beschrijving zie de hardware sectie. )
Wat heeft men naast het Z80 kaartje nog nodig om het ten volle te benutten?
BESCHRIJVING VAN DE HARDWARE VAN DE Z80-KAART
Naast de Z80 CPU (D27) is op de kaart o.a. het volgende aanwezig:
8000-FFFF Random Access Memory Als de EPROM is uitgeschakeld dan Is de map: 0000-FFFF RAM De EPROM kan worden ingeschakeld door naar IO-adres 20 een willekeurig byte te schrijven.
Door naar IO-adres 21 te schrijven wordt de EPROM vervangen door het RAM. DE INPUT/OUTPUT ADRESSENINDELING
De besturingslijnen BO-B7 van de PIO worden als volgt gebruikt:
WERKING BIDIRECTIONELE INTERFACE
DE BOOTROM VOOR DE Z80
Nu nog eventjes in een EPROM zetten. HET GEBRUIK VAN ATOM DOS
Ik noem o.a. :
Bij het simuleren van ATOM floppies ligt de zaak iets anders:
Er zijn drie versies beschikbaar:
VOORWOORD ( Voor de hardware beschrijving zie de hardware sectie. )
Deze documentatie is zeer kort in vergelijking tot de aangesneden koek. De hardware wordt slechts kort besproken, zonder een uitgebreide bouwaanwijzing te presenteren. Het lijkt me dat voor de bouw van het systeem nogal wat kennis, handigheid, koppigheid enz. vereist is. Ondanks dit moet er met de hulp van iemand die het systeem al werkend heeft wel uit te komen zijn.
Naast de hardwarekennis veronderstel ik ook kennis van CP/M (Control Program Monitor (Microcomputer)), ÓDigital Research) operating-system, ZCPR2, ATOM-DOS en GDOS. Indien niet voorradig, lees dan een CP/M boek en loop eens langs bij een DOS-bezitter.
Sommige stukken tekst heb ik niet vertaald in het Nederlands. Deze tekst was al beschikbaar voordat ik deze handleiding ben gaan schrijven.
Voor public domain CP/M software (waaronder ZCPR2 en P2DOS ! ) met handleidingen kan men bij de CP/M-gg terecht. De CP/M-gg is een onderdeel van de Hobby Computer Club (HCC). Zonder hulp van de leden van de afdeling Twente was dit project niet geworden tot wat het nu is. Met name ben ik de volgende mensen dank verschuldigd voor het ontwikkelen van de print:
Rien Stoop, voor het tekenen van het schema, bouw proefmodel, vele correcties op de print layout.
Fernando Monsanto, voor coördinatie print.
Paul Klomp, voor bouw proefmodellen, correcties, tips, testen software, programmeren van vele eproms.
Harm de Leeuw: opnieuw tekenen schema, komponenten opstelling en nummering.
Jos Huisken, voor het beschikbaar stellen van zijn BIOS. Deze heeft als basis gediend voor de ontwikkeling van mijn software.
BASISOPZET
Sommige stukken tekst heb ik niet vertaald in het Nederlands. Deze tekst was al beschikbaar voordat ik deze handleiding ben gaan schrijven.
Voor public domain CP/M software (waaronder ZCPR2 en P2DOS ! ) met handleidingen kan men bij de CP/M-gg terecht. De CP/M-gg is een onderdeel van de Hobby Computer Club (HCC). Zonder hulp van de leden van de afdeling Twente was dit project niet geworden tot wat het nu is. Met name ben ik de volgende mensen dank verschuldigd voor het ontwikkelen van de print:
Rien Stoop, voor het tekenen van het schema, bouw proefmodel, vele correcties op de print layout.
Fernando Monsanto, voor coördinatie print.
Paul Klomp, voor bouw proefmodellen, correcties, tips, testen software, programmeren van vele eproms.
Harm de Leeuw: opnieuw tekenen schema, komponenten opstelling en nummering.
Jos Huisken, voor het beschikbaar stellen van zijn BIOS. Deze heeft als basis gediend voor de ontwikkeling van mijn software.
Peter Huisken
Het Z80 kaartje is op de eerste plaats bedoeld om CP/M compatible software te kunnen draaien. Om dit zo goedkoop mogelijk, en toch goed, te realiseren kan men het beste gebruik maken van de interfaces die je al in je ACORN ATOM computer hebt ingebouwd. Ik noem een paar dingen als: 80 kolommen kaart, printerinterface en toetsenbord. Door nu de Z80 met een snelle interface aan te sluiten is het mogelijk om met een geschikt protocolletje alle informatie voor de verschillende interfaces heen en weer te sturen zonder dat dit ten koste gaat van de snelheid. Nu vraagt u zich misschien af waarom de disc controller niet in de ATOM is ingebouwd. Bij bijna alles wat er gebeurt onder CP/M wordt er disc-access gepleegd. Wanneer de disc interface in de ATOM wordt gebouwd wordt CP/M circa drie keer langzamer. Dit is niet acceptabel (vergelijk de Commodore).
Aangezien er nu, weliswaar met omweg, een disc aan de ATOM hangt moet het ook mogelijk zijn om ATOM files op te bergen op schijf. Hiertoe moet de standaard DOS van de ATOM enigszins gewijzigd worden. In de plaats van de besturing van de 8271 floppy disc controller komt een communicatie programmaatje die via de Z80 disk-sectoren kan lezen en schrijven. Vanwege de extra communicatie wordt de dos bijna twee keer langzamer dan de standaard ATOM-DOS. Door de gebruikte constructie zijn alle faciliteiten van de standaard DOS aanwezig. Dit houdt in dat alle programma’s gedraaid kunnen worden, m.u.v. die programma’s die de 8271 FDC rechtstreeks aanspreken.
Aangezien er nu, weliswaar met omweg, een disc aan de ATOM hangt moet het ook mogelijk zijn om ATOM files op te bergen op schijf. Hiertoe moet de standaard DOS van de ATOM enigszins gewijzigd worden. In de plaats van de besturing van de 8271 floppy disc controller komt een communicatie programmaatje die via de Z80 disk-sectoren kan lezen en schrijven. Vanwege de extra communicatie wordt de dos bijna twee keer langzamer dan de standaard ATOM-DOS. Door de gebruikte constructie zijn alle faciliteiten van de standaard DOS aanwezig. Dit houdt in dat alle programma’s gedraaid kunnen worden, m.u.v. die programma’s die de 8271 FDC rechtstreeks aanspreken.
Wat heeft men naast het Z80 kaartje nog nodig om het ten volle te benutten?
- De ACORN ATOM moet nog voorzien worden van een bidirectionele interface voor communicatie met het Z80 kaartje. Verderop wordt beschreven hoe je de benodigde 6522 VIA aan moet sluiten.
- Voor een fijn CP/M compatible systeem is een 80 kolommen kaart onontbeerlijk. Naast de club 80 kolommen kaart (VDU80) zijn ook de Elektuur en de Twente – kaart bruikbaar. De Elektuur kaart kent niet de ‘low’ en ‘high’ video zoals deze veel gebruikt wordt in de wat luxere tekstverwerkers. De club-kaart is het makkelijkst aan te sluiten. Bovendien heeft deze kaart geen last van beeldruis.
- Een CP/M systeem draait niet zonder disc drives. Wat betreft disk-capaciteit lijkt het me nuttig te vermelden dat met 1 diskdrive van 800 kilobyte redelijk te werken is. Twee drives voldoen natuurlijk beter. Denk trouwens niet dat 400 Kb per disk veel is. Heeft men nog geen drives, koop dan altijd 800Kb modellen. Het prijsverschil verdien je snel terug aangezien je minder diskettes nodig hebt. Let bij aanschaf op de zgn. steprate. Neem bij voorkeur 3 Ms (80 trk) of 6 Ms (40 trk). Voor langzamere drives moet de software gepatched worden.
- Voor de Z80 kaart is een EPROM met inhoud nodig.
- Voor het draaien van CP/M software is een zogenaamde BIOS (Basic Input Output system) noodzakelijk. Deze BIOS biedt het zogenaamde P2DOS bepaalde standaard routines aan voor Input en Output (voor disk, terminal, printer).
- ZCPR2 en P2DOs. Deze twee systeemdelen vervangen de zogenaamde CCP en BDOS. (Ó Digital Research). De ZCPR2 is geschreven door R. Conn, P2DOs is geschreven door H.A.J ten Brugge. Deze programma.s zijn voor niet commercieel gebruik in de ‘public domain’ geplaatst door de auteurs. Mede hierdoor kan dit projekt een succes worden.
- De systeem afhankelijke utilities SYSGEN en FORMAT.
- Terminal programma in de ATOM. Dit programma omvat o.a. nogal uitgebreide 80 kolommen VDU software, printer driver en buffer, toetsenbord buffer met functietoets afhandeling , en tenslotte de communicatiesoftware met de Z80 kaart.
- In de ATOM moet een 4 kilobyte EPROM gezet worden met een gepatched DOS (AtomDos of GDOS). De AtomDos is Ó Acornsoft. De GDOS is geschreven door Gerrit Hillebrand. De DOS is gemakkelijk voor het aanpassen van de terminal.
Naast bovengenoemde absoluut noodzakelijke systeem software worden de volgende programma’s (voor gebruik onder CP/M) ook verspreid:
PRKEY.COM | Hiermee zijn de functietoetsen van de terminal ( = ATOM ) instelbaar. |
ATOMDOS.COM | Dit programma maakt het mogelijk om maximaal 8 ACORN ATOM diskettes te simuleren op 1 CP/M schijf (Er is een speciale BIOS nodig). |
CREATE.COM | Aanmaken van files (merk op dat 1 CP/M file overeenkomt met een hele disk bij de ATOM) voor ACORN ATOM DOS. |
AACOPY.COM | Kopiëren van ACORN floppy’s naar CP/M files (en vice versa). |
DCONF.COM | Voor instellen van de BIOS voor allerlei disk- formaten. |
RSECT.COM | Gemakkelijk voor het inspecteren van vreemde floppies. |
- Geheugen: 8 * 4164 D-RAM chips (D14-21) en 27128 EPROM (D28).
- Floppy-controller MB8877 (D241.
- Parallelle interface Z80 PIO (D5).
De genoemde NMOS chips worden bij elkaar gehouden door 18 TTL IC.s, een stel weerstanden, onstoringscondensatoren en een kristal. Ik zal nu enkele punten van het schema wat gedetailleerder bespreken.
AANSTURING VAN DE RAM EN BANKSWITGHING
Na een hardware reset begint de Z80 microprocessor instructies uit te voeren vanaf adres #0000. Het is noodzakelijk dat hier ROM aanwezig is zodat na power-up de machine kan opstarten. Een FLIP- FLOP van het type ’74 (D11) zorgt ervoor dat na een reset de EPROM geselecteerd kan worden. De adresruimte 0000-7FFF Is dan voor de EPROM. Het gebied 8000-FFFF Is altijd bezet door RAM geheugen. Na opstarten van een programma kan de EPROM uitgeschakeld worden zodat de hele adresruimte bestaat uit RAM.
De flip-flop voor de bankswitching wordt bestuurd door een adres in de Input/Output Map aan te spreken. Door de Z80 een zogenaamde OUT- instructie te laten uitvoeren naar IO-adres 21 hex kan de EPROM uitgeschakeld worden. De vrijgekomen ruimte wordt dan ingenomen door RAM. Met een OUT- instructie naar adres 20 wordt de EPROM weer teruggeschakeld. Door deze constructie is het mogelijk om bepaalde standaard software op te slaan in de EPROM en toch de voordelen te hebben van 64K aaneengesloten RAM.
De dynamische RAM ic’s hebben gemultiplexte adresingangen. De 16 adreslijnen van de Z80 worden gemultiplext met twee ‘157 (D29,30) ic’s. Het een vertragingslijn opgebouwd uit 4 Inverters (D26) en een decoder (D23) (deze decoder wordt ook gebruikt voor het schakelen tussen Ram en EPROM) wordt op het juiste moment de Row Adress Strobe en Column Adress Strobe signalen aan het RAM gegeven. Een NAND-poort (D25) zorgt bij het schrijven in RAM voor verder vertragen van de CAS puls zodat er geen bus-conflicten optreden (lastig, bekijk dit maar eens in de Z80 documentatie).
De EPROM heeft twee enable signalen namelijk nOE en nCE. De nCE wordt gebruikt om de chip ‘weg’ te schakelen. De 27128 staat dan in ‘standby mode’. De nOE wordt als normale chip select gebruikt.
NOOT: Let op dat de adreslijnen van de dynamische RAM goed zijn aangesloten. De Z80 geeft op de adreslijnen A0-A6 na elke opcode- fetch een refresh adres af. Wanneer men bijvoorbeeld de aansluitingen A6 en A7 van de RAM verwisseld zal de refresh in bepaalde delen van de RAM uitblijven waardoor de meeste programma’s niet meer werken. Aangezien de Z80 maar 7 refreshbits afgeeft zal het meteen duidelijk zijn dat 8 bits refresh chips, zoals de Texas Instruments TMS4164 niet geschikt zijn.
Ook de 64k*4 chips (41464) hebben 8 bits refresh nodig. Met een schakeling van 2 TTL-IGs is dit te realiseren. Voor mensen die geen gebruik maken van de print is dit een compacte oplossing.
PARALLELLE INTERFACE
De flip-flop voor de bankswitching wordt bestuurd door een adres in de Input/Output Map aan te spreken. Door de Z80 een zogenaamde OUT- instructie te laten uitvoeren naar IO-adres 21 hex kan de EPROM uitgeschakeld worden. De vrijgekomen ruimte wordt dan ingenomen door RAM. Met een OUT- instructie naar adres 20 wordt de EPROM weer teruggeschakeld. Door deze constructie is het mogelijk om bepaalde standaard software op te slaan in de EPROM en toch de voordelen te hebben van 64K aaneengesloten RAM.
De dynamische RAM ic’s hebben gemultiplexte adresingangen. De 16 adreslijnen van de Z80 worden gemultiplext met twee ‘157 (D29,30) ic’s. Het een vertragingslijn opgebouwd uit 4 Inverters (D26) en een decoder (D23) (deze decoder wordt ook gebruikt voor het schakelen tussen Ram en EPROM) wordt op het juiste moment de Row Adress Strobe en Column Adress Strobe signalen aan het RAM gegeven. Een NAND-poort (D25) zorgt bij het schrijven in RAM voor verder vertragen van de CAS puls zodat er geen bus-conflicten optreden (lastig, bekijk dit maar eens in de Z80 documentatie).
De EPROM heeft twee enable signalen namelijk nOE en nCE. De nCE wordt gebruikt om de chip ‘weg’ te schakelen. De 27128 staat dan in ‘standby mode’. De nOE wordt als normale chip select gebruikt.
NOOT: Let op dat de adreslijnen van de dynamische RAM goed zijn aangesloten. De Z80 geeft op de adreslijnen A0-A6 na elke opcode- fetch een refresh adres af. Wanneer men bijvoorbeeld de aansluitingen A6 en A7 van de RAM verwisseld zal de refresh in bepaalde delen van de RAM uitblijven waardoor de meeste programma’s niet meer werken. Aangezien de Z80 maar 7 refreshbits afgeeft zal het meteen duidelijk zijn dat 8 bits refresh chips, zoals de Texas Instruments TMS4164 niet geschikt zijn.
Ook de 64k*4 chips (41464) hebben 8 bits refresh nodig. Met een schakeling van 2 TTL-IGs is dit te realiseren. Voor mensen die geen gebruik maken van de print is dit een compacte oplossing.
De Z80 PIO chip ligt in de IO-map op de adressen 10-13. Deze chip kent een speciale mode die het mogelijk maakt met 12 draden data te ontvangen en te versturen (bidirectionele interface). Deze mode wordt gebruikt voor communicatie met de ATOM.
De overige IO-lijnen worden gebruikt voor de disk interface.
De PIO kan niet gebruikt worden voor bank-switching, omdat deze geen reset ingang heeft. Na vastlopen van een eens werkend programma zou dan de voeding aan en uit gezet moet worden om de EPROM weer voor te schakelen. Dit voorschakelen van de EPROM is namelijk noodzakelijk om de machine weer op te starten.
FLOPPYDISK INTERFACE EN CLOCK CIRCUITS
De PIO kan niet gebruikt worden voor bank-switching, omdat deze geen reset ingang heeft. Na vastlopen van een eens werkend programma zou dan de voeding aan en uit gezet moet worden om de EPROM weer voor te schakelen. Dit voorschakelen van de EPROM is namelijk noodzakelijk om de machine weer op te starten.
De Floppy Disk Interface is opgebouwd met een MB8877A of 1793 Floppy Disk Controller (FDC). Een MB8877A heeft geen 12V nodig zodat deze spanning dan niet meer nodig is op de print.
De FDC ligt op adres 00, 01, 02 en 03 in de IO-map. De gebruikte FDC is geschikt voor single en double density op 5 of B inch disk drives. De hardware rond deze chip is zo ontworpen dat softwarematig omgeschakeld kan worden tussen alle vier mogelijkheden op elk van de vier drives.
De dataseparator is opgebouwd met een teller van het type ‘193 (D9). Met behulp van een ‘153 (DB) multiplexer worden de juiste klokfrequenties voorgeschakeld, noodzakelijk voorde dataseparator en de FDC. Deze verschillende frequenties zijn afkomstig van een ‘393 (D7) teller.
De write-precompensatlon (250 nS) is opgebouwd met een schuifregister van het type ‘195 (D10). Het een one-shot van het type ‘123 (D12) wordt een puls gegenereerd van een seconde om de motor van de diskdrive tijd te gunnen om op toeren te komen. De andere helft van dit IC wordt gebruikt in de dataseparator. De ‘145 (D2) wordt gebruikt om de drive select code op disc interface te zetten. Dit IC beschikt over de noodzakelijke open collector uitgangen.
De uitgang DRQ {Data ReQuest) van de FDC hangt aan PB7 van de PIO. De CPU kan dan via de PIO zien wanneer de Floppy Disc Controller weer een byte klaar heeft (of nodig heeft in het geval van schrijven).
De DDEN van de FDC wordt bestuurd met PB2 van de PIO. Met PB4 van de PIO wordt de side select van de disc drive gestuurd. Ook in geval van een 1797 disc controller moet PB4 gebruikt worden.
Helaas wijst de praktijk uit dat SCHRIJVEN op 8 inch double density niet functioneert omdat de CPU de bytes net niet snel genoeg af kan leveren bij de FDC (het is moeilijk uit te leggen maar het lezen gaat wel goed). Door de processor-snelheid te verhogen naar 8 MHz Is dit probleem opgelost.
Voor sommige 8″ drives is de wrlte-precompensatlon aan de hoge kant. Door de clock-ingang van de 74LS195 aan 8 MHz te hangen in plaats van aan 4 MHz wordt de write-pre-comp 125 nS. Voor moderne slim-sline drives zoals Teac, Mltsublshi mag de write-pre-comp helemaal uitgezet worden. Dit gaat als volgt verwijder de 74Ls195 en soldeer de WD uitgang van de 179X direct aan de 7406.
OMBOUWEN NAAR 8 MHz
De FDC ligt op adres 00, 01, 02 en 03 in de IO-map. De gebruikte FDC is geschikt voor single en double density op 5 of B inch disk drives. De hardware rond deze chip is zo ontworpen dat softwarematig omgeschakeld kan worden tussen alle vier mogelijkheden op elk van de vier drives.
De dataseparator is opgebouwd met een teller van het type ‘193 (D9). Met behulp van een ‘153 (DB) multiplexer worden de juiste klokfrequenties voorgeschakeld, noodzakelijk voorde dataseparator en de FDC. Deze verschillende frequenties zijn afkomstig van een ‘393 (D7) teller.
De write-precompensatlon (250 nS) is opgebouwd met een schuifregister van het type ‘195 (D10). Het een one-shot van het type ‘123 (D12) wordt een puls gegenereerd van een seconde om de motor van de diskdrive tijd te gunnen om op toeren te komen. De andere helft van dit IC wordt gebruikt in de dataseparator. De ‘145 (D2) wordt gebruikt om de drive select code op disc interface te zetten. Dit IC beschikt over de noodzakelijke open collector uitgangen.
De uitgang DRQ {Data ReQuest) van de FDC hangt aan PB7 van de PIO. De CPU kan dan via de PIO zien wanneer de Floppy Disc Controller weer een byte klaar heeft (of nodig heeft in het geval van schrijven).
De DDEN van de FDC wordt bestuurd met PB2 van de PIO. Met PB4 van de PIO wordt de side select van de disc drive gestuurd. Ook in geval van een 1797 disc controller moet PB4 gebruikt worden.
Helaas wijst de praktijk uit dat SCHRIJVEN op 8 inch double density niet functioneert omdat de CPU de bytes net niet snel genoeg af kan leveren bij de FDC (het is moeilijk uit te leggen maar het lezen gaat wel goed). Door de processor-snelheid te verhogen naar 8 MHz Is dit probleem opgelost.
Voor sommige 8″ drives is de wrlte-precompensatlon aan de hoge kant. Door de clock-ingang van de 74LS195 aan 8 MHz te hangen in plaats van aan 4 MHz wordt de write-pre-comp 125 nS. Voor moderne slim-sline drives zoals Teac, Mltsublshi mag de write-pre-comp helemaal uitgezet worden. Dit gaat als volgt verwijder de 74Ls195 en soldeer de WD uitgang van de 179X direct aan de 7406.
Aan de componenten zijde van de print loopt vanaf de zijkant een spoortje naar pin 4 van D7. U snijdt dit spoortje vlak bij het IC door en verbindt het met pin 3 van hetzelfde IC. Vervang, indien noodzakelijk, de volgende componenten:
- – Z80 PIO door een Z80 B PIO.
- – Z80 CPU door een Z80 H CPU.
- – 4164 RAMs door 120Ns types.
- – 27128 door een 250 Ns type.
In de praktijk blijkt dat 4164-150 van bekende merken goed functioneren. Z80 A PIO’s van verschillende merken blijken ook op 8 MHz goed te werken. Voor de CPU is een ‘B’-type vaak voldoende. Een uPD780-2 (6 MHz ) van fabrikaat NEC geeft echter zeer slechte resultaten.
De EPROM geeft over het algemeen helemaal geen probleem. Meestal zijn de standaard types al 250 Ns.
UITZETTEN MOTOR ON/OFF
De EPROM geeft over het algemeen helemaal geen probleem. Meestal zijn de standaard types al 250 Ns.
Als uw drives voorzien zijn van een direct drive motor en ‘head load’ inrichting, dan kunt u overwegen de motoren van de drives continu te laten lopen. Dit is als volgt te realiseren:
- Snijd het koperbaantje naar pin 16 van de floppy connector los en verbind pin 16 naar massa. De motoren van de drives zullen nu continu draaien.
- De ‘motor on’ tijd moet nu nog gewijzigd worden. Vervang C4 (was 100 mF) door 2m2. De wachttijd bij het activeren van een drive is dan ± 50 Ms. Dit is voldoende voor de zogenaamde ‘head load’
Zorg voor voldoende afscherming bij montage dicht bij de disk drive. Bij montage direct op een disk drive zonder afscherming zal de instraling van de Z80 kaart zo groot zijn dat de drive niet functioneert. Disk drives hebben ook vaak last van instraling door monitoren en schakelende voedingen.
DE MEMORY HAP
De memory map ziet er na een reset als volgt uit:
0000-7FFF EPROM (er wordt een 16K EPROM gebruikt8000-FFFF Random Access Memory Als de EPROM is uitgeschakeld dan Is de map: 0000-FFFF RAM De EPROM kan worden ingeschakeld door naar IO-adres 20 een willekeurig byte te schrijven.
Door naar IO-adres 21 te schrijven wordt de EPROM vervangen door het RAM. DE INPUT/OUTPUT ADRESSENINDELING
00 | FDC command en status register. |
01 | FDC track register. |
02 | FDC sector register. |
03 | FDC data register. |
10 | IO data register A |
11 | PIO control register A |
12 | PIO data register B |
13 | PIO control register B |
20 | EPROM inschakelen in gebied 0000-7FFF |
21 | RAM inschakelen in gebied 0000-7FFF |
30 – 3F | Vrij voor uitbreiding |
40 – FF | Kopieën van bovenstaande adressen. Met extra decodering is deze ruImte ook te gebruiken voor uitbreidingen. |
B0, B1 | Drive nummer |
B2 | nDD I SD (omschakelen density) |
B3 | n5 / 8 (omschakelen discgrootte) |
B4 | side select |
B5 | vrij (niet gebruiken voor bankswitching) |
B6 | draadbrug voor ‘double steps’ (zie ATOMDOS) |
B7 | ingang voor DRQ (Data ReQuest) |
De Z80-kaart wordt met behulp van een VIA (6522) aangesloten aan de ATOM. Het standaardadres van deze VIA is #BF90.
In het onderstaande tijdvolgorde-diagrammetje (bron: ZILOG) is te zien hoe de PIO en 6522 communiceren. De volgende punten wil ik even benadrukken:
- De interface is asymmetrisch (dus 2 PIO’s kunnen niet communiceren zonder extra hardware-aanpassing),
- De 6522 bepaalt of de PIO de datalijnen mag bezetten.
- De 6522 mag ten alle tijden de datalijnen bezetten indien de PIO niet geactiveerd wordt door het A-stb signaal.
- Er wordt NOOIT een byte kwijtgeraakt, Bij seriële interfaces is dit anders: indien men daar het dataregister van een chipje niet snel genoeg leegt wordt de data overschreven door nieuwe. De parallelle interface daarentegen geeft de handshake-lijn pas weer ‘vrij’ indien het afgeleverde byte door de CPU opgehaald is.
De bootrom voor het Z80-kaartje is van het type 27128 (16 Kb). In deze EPROM staat o.a. de software die na een reset geëxecuteerd wordt.
Na reset of power-up gebeurt er het volgende:
Na reset of power-up gebeurt er het volgende:
- Er wordt een stuk van de EPROM naar RAM gekopieerd. Dan wordt er een JUMP-instructie uitgevoerd naar het RAM-gebied. De software die naar RAM gekopieerd is schakelt de EPROM weg, zodat de memory map geheel uit RAM bestaat.
- Er wordt gecontroleerd of er een disc drive aanwezig is met een floppy. Indien er geen disc drive of floppyaanwezig is, wordt er een simpele monitor opgestart (dit is handig voor testdoeleinden). Deze monitor is geschreven door Rolf Dieter Klein voor de MC-CP/M computer (lijst commando’s zie pag. 17). Ik heb deze monitor gepatched voor gebruik met de Z80- kaart.
- Normaal gesproken is er altijd een disc aanwezig. Van deze disk wordt dan sector 1 op track 0 gelezen (track 0 is altijd single density). Indien de lengte van deze sector 128 bytes is dan is het een CP/M floppy. Deze 128 bytes vormen dan een programmaatje dat de BIOS van track 1 in zal laden. Deze BIOS zal dan de P2DOS en ZCPR2 uit EPROM kopiëren (in het bovenste stuk RAM zetten) zodat CP/M opgestart wordt.
- Een ACORN ATOM floppy heeft sectoren van Z56 bytes. Wanneer de lengte van de gelezen sector 256 bytes is dan wordt een communicatie programma (aanwezig in de EPROM) opgestart voor ondersteuning van de ATOM-dos. Dit stukje software leest en schrijft dan op bevel van de ATOM sectoren van/ naar schijf. Voor een juiste werking van de ATOM-dos is het noodzakelijk dat de draadbrug n40/80 op de kaart goed geselecteerd is. Het een 80-track disc-drive is namelijk ‘double-stepping’ nodig (indien men standaard 40-track floppies wil gebruiken). Zie verder ‘De Gewijzigde Atom Dos Rom’ .
- Als de eerste track niet single density is, dan is het een GDOS floppy (1/4 Kb sectoren) of een niet geformatteerde. De GDOS ondersteuning wordt dan opgestart.
Voor het draaien van CP/M software is een aan de hardware aangepaste Basic Input Output System (BIOS) noodzakelijk. Deze BIOS biedt het P2DOS gestandaardiseerde routines aan voor disk. terminal, printer etcetera.
De BIOS voor het Z8O-kaartje kent ook nog de mogelijkheid om ‘ vreemde ‘ diskformaten in te stellen. Met het programma ‘DCONF’ wordt de BIOS intern verbouwd zodat allerlei formaten gebruikt kunnen worden.
Nadat een drive voor een bepaald formaat is ingesteld kan met het ‘FORMAT’ programma een nieuwe schijf geformatteerd worden. Met het programma SYSGEN kan men op de systeemtracks van een geformatteerde floppy een BIOS zetten (alleen club-formaat! ).
De BIOS voor het Z8O-kaartje kent ook nog de mogelijkheid om ‘ vreemde ‘ diskformaten in te stellen. Met het programma ‘DCONF’ wordt de BIOS intern verbouwd zodat allerlei formaten gebruikt kunnen worden.
Nadat een drive voor een bepaald formaat is ingesteld kan met het ‘FORMAT’ programma een nieuwe schijf geformatteerd worden. Met het programma SYSGEN kan men op de systeemtracks van een geformatteerde floppy een BIOS zetten (alleen club-formaat! ).
HET AANMAKEN VAN EEN BOOT FLOPPY VOOR P2DOS
Om op de normale wijze ‘ koud ‘ te kunnen booten moet de eerste track van de boot-floppy single density geformatteerd zijn. Het FORMAT programma vraagt hierna (128 bytes per sector).
Na het formatteren kan er een BIOS opgezet worden. Dit gaat m.b.v. het programma SYSGEN.COM. Met dit programma moet eerst een BIOS van een andere schijf gehaald worden, waarna het op de nieuwe schijf gezet kan worden.
LET OP: Bij standaard CP/M staan ook de BDOS en CCP op de systeemsporen. Echter bij dit systeem worden deze delen uit EPROM gekopieerd en staan dus niet op disk! Zodoende kan toch ‘warm’ geboot worden op een floppy zonder systeem. Wil men wijzigingen aanbrengen in het OS dan moet de EPROM opnieuw gebrand worden.
CONSOLE, LIST, PUNCH, READER input/ output.
Na het formatteren kan er een BIOS opgezet worden. Dit gaat m.b.v. het programma SYSGEN.COM. Met dit programma moet eerst een BIOS van een andere schijf gehaald worden, waarna het op de nieuwe schijf gezet kan worden.
LET OP: Bij standaard CP/M staan ook de BDOS en CCP op de systeemsporen. Echter bij dit systeem worden deze delen uit EPROM gekopieerd en staan dus niet op disk! Zodoende kan toch ‘warm’ geboot worden op een floppy zonder systeem. Wil men wijzigingen aanbrengen in het OS dan moet de EPROM opnieuw gebrand worden.
De I/0 van deze devices geschiedt ‘op afstand’ via de ATOM. Aangezien er slechts sprake is van 1 ‘half-duplex’ verbinding tussen de Z8O-kaart en de ATOM moet er een eenvoudig protocolletje gebruikt worden om de boel uit elkaar te houden. Dit protocolletje werkt als volgt: Van Z8O-kaart naar ATOM:
- Een byte voor de video wordt vooraf gegaan door een byte FC.
- Een byte voor de punch wordt vooraf gegaan door een byte FD.
- Een byte voor de printer wordt vooraf gegaan door een byte FE.
- Alle andere bytes zijn voor de video (extra snel: geen extra ‘preamble’ FC nodig). Van ATOM naar Z8O-kaart:
- Een byte voor het keyboard wordt vooraf gegaan door een byte FC.
- Een byte voor de reader wordt vooraf gegaan door een byte FD.
- De printer-status wordt voorafgegaan door een byte FE.
- Alle andere bytes zijn voor het toetsenbord.
Dankzij een goede implementatie van de printerstatus kan met een bekend tekstverwerking programma tegelijk ge-edit en geprint worden. Wie heeft er nu nog een printer-buffer nodig?
DE GEWIJZIGDE ACORN ATOM DOS
Vanwege de eenvoudige directory structuur van de ATOM-dos is het zeer eenvoudig en slechts weinig langzamer om de disc input/ output op afstand te laten gebeuren. Een file op een ATOM disc is een aaneengesloten rij van sectoren. Wanneer er een file in de ATOM geladen moet worden hoeft de ATOM alleen maar het sectoradres en het aantal sectoren bekend te maken aan de Z80. De Z80 laadt dan eerst de gewenste sectoren in het eigen werkgeheugen, waarna de hele hap met een snelheld van circa 10.000 bytes per seconde naar de ATOM wordt gestuurd.
Op de plaatsen in de oude DOS-ROM waar een aantal sectoren gelezen of geschreven moet gaan worden, wordt een sprong gezet naar de vervangende software die de taak uitbesteedt aan de Z80. Aangezien er maar twee mogelijkheden zijn (lezen en schrijven) is het patchen eenvoudig (dankzij ATOMWARE deel 2). Uiteraard wordt ook het drivenummer opgegeven aan de Z80. Nu is het de ATOM om het even of er nu echt een ATOM schijf in de disc drive zit, of dat de Z80-kaart een ATOM schijf SIMULEERT. Men kan onder CP/M bijvoorbeeld een file van 100 kilobyte aanmaken. Alle lees en schrijf operaties kunnen dan worden gesimuleerd met deze file. Met een grote disc drive kan men 7 files van 100Kb aanmaken zodat 7 oude ATOM schijven passen op 1 CP/M schijf (er is nog ruimte voor een ‘floppy’ van 76 Kb).
Voor dit simuleren is een CP/M programma ‘ATOMDOS’ beschikbaar. Aan de hand van het ingestelde discnummer (in de ATOM) wordt de juiste file geselecteerd waarop de lees en schrijf operaties moeten worden uitgevoerd.
De files van 100Kb kunnen worden aangemaakt met 2 programma’s:
Op de plaatsen in de oude DOS-ROM waar een aantal sectoren gelezen of geschreven moet gaan worden, wordt een sprong gezet naar de vervangende software die de taak uitbesteedt aan de Z80. Aangezien er maar twee mogelijkheden zijn (lezen en schrijven) is het patchen eenvoudig (dankzij ATOMWARE deel 2). Uiteraard wordt ook het drivenummer opgegeven aan de Z80. Nu is het de ATOM om het even of er nu echt een ATOM schijf in de disc drive zit, of dat de Z80-kaart een ATOM schijf SIMULEERT. Men kan onder CP/M bijvoorbeeld een file van 100 kilobyte aanmaken. Alle lees en schrijf operaties kunnen dan worden gesimuleerd met deze file. Met een grote disc drive kan men 7 files van 100Kb aanmaken zodat 7 oude ATOM schijven passen op 1 CP/M schijf (er is nog ruimte voor een ‘floppy’ van 76 Kb).
Voor dit simuleren is een CP/M programma ‘ATOMDOS’ beschikbaar. Aan de hand van het ingestelde discnummer (in de ATOM) wordt de juiste file geselecteerd waarop de lees en schrijf operaties moeten worden uitgevoerd.
De files van 100Kb kunnen worden aangemaakt met 2 programma’s:
- AACOPY: Dit programma kan ACORN ATOM schijven kopiëren naar een file onder CP/M (en vice versa).
- CREATE: Dit programma creëert files van willekeurige lengte en initialiseert de directory.
Voor het aanmaken van een dos-rom is het volgende noodzakelijk:
- Patch programma (zie pag. 20).
- Decados of TelecDos of AtomDos.
- Salfaa V1.5 of hoger op #A000. (symbolische assembler programma van de FAC)
- Laad de originele DOS op adres #6000.
- Laad (of intikken) het patch programma.
- Pas indien nodig in het patch programma de equate VIA = #BF90 aan.
- Run het patch-programma.
Nu nog eventjes in een EPROM zetten. HET GEBRUIK VAN ATOM DOS
De nieuwe ATOM-DOS is compatible met de oude. Alle min meer normale entrys zijn gelijk gebleven. Incompatibiliteit treedt zeker op wanneer een programma rechtstreeks gebruik maakt van de 8271 FDC.
De volgende programma’s commando’s werken dus niet:
- FORMAT, SECTOR, TYPE, LIST uit de DBOX. (De TYPE uit de DECADOS werkt wel. ) (DBOX en DECADOS zijn programma’s van de FAC)
- Het FORMAT programma.
Bovendien worden sommige foutmeldingen niet gegeven. Indien een schijf write-protected is, wordt er bij het schrijven niet gereageerd met een foutmelding. Ook een BAD sector wordt niet gerapporteerd (vastloper). Op de redenen hiervan ga ik niet verder in.
Alle andere faciliteiten werken wel. Ik noem o.a. :
- Sequentiële en random files.
- Gewoon laden en saven.
- Bijna alle commando’s uit de DBOX.
DISK NUMMERING
Bij gebruik van standaard ATOM single density floppies Is DRIVE nummering als volgt:ATOM DRIVE 0, 4 | —> | DRIVE A, | side 0 |
ATOM DRIVE 1, 5 | —> | DRIVE B, | side 0 |
ATOM DRIVE 2, 6 | —> | DRIVE A, | side 1 |
ATOM DRIVE 3, 7 | —> | DRIVE B, | side 1 |
ATOM DRIVE 0 | —> | DRIVE A, | CP/M file ATOMDOS.000 |
ATOM DRIVE 1 | —> | DRIVE A, | CP/M file ATOMDOS.001 |
ATOM DRIVE 2 | —> | DRIVE A, | CP/M file ATOMDOS.002 |
ATOM DRIVE 3 | —> | DRIVE A, | CP/M file ATOMDOS.003 |
ATOM DRIVE 4 | —> | DRIVE A, | CP/M file ATOMDOS.004 |
ATOM DRIVE 5 | —> | DRIVE A, | CP/M file ATOMDOS.005 |
ATOM DRIVE 6 | —> | DRIVE A, | CP/M file ATOMDOS.006 |
ATOM DRIVE 7 | —> | DRIVE A, | CP/M file ATOMDOS.007 |
HET AANMAKEN VAN EEN ATOM FLOPPY
Het aanmaken van een ATOM floppy is niet eenvoudig. Voor aanmaken van een standaard single density floppy gaat men beste als volgt te werk:
- Start CP/M op (ATOM is terminal).
- Stop In drive A een floppy met de programma’s DCONF en FORMAT.
- Stel m.b.v. DCONF drive B in voor ATOM 40 tracks.
- Roep het format programma aan en formatteer de (lege) schijf met drive B
Met een truuk Is het bovenstaande ook uit te voeren met slechts 1 drive:
Sluit In drive A ook de jumper voor drive B select aan. De drive werkt nu als drive A en B. Met enkele keren verwisselen van schijven is het dan mogelijk vreemde formaten te formatteren.
De net geformatteerde schijf staat nu vol met bytes #E5.
De directory is dus nog niet geinitialiseerd.
Start de ATOM met ATOMDOS op. Gebruik nu het ATOM-programma INITDIR om de net geformatteerde schijf te voorzien van een lege directory.
De net geformatteerde schijf staat nu vol met bytes #E5.
De directory is dus nog niet geinitialiseerd.
Start de ATOM met ATOMDOS op. Gebruik nu het ATOM-programma INITDIR om de net geformatteerde schijf te voorzien van een lege directory.
Wil men het programma ATOMDOS gebruiken voor het verkrijgen van meer opslagcapaciteit dan is het aanmaken nog ingewikkelder. Allereerst moet een floppy geformatteerd worden voor CP/M (eerste track single density). Vervolgens moet er een speciale BIOS opgezet worden m.b.v. SYSGEN (een BIOS zonder protocollje voor een printer etc.). Deze BIOS zorgt voor het automatisch opstarten van het programma ATOMDOS {moet er ook opgezet worden). M.b.v. het programma CREATE of AACOPY moeten er nog ATOMDOS.00? files gemaakt worden. Gebruikt men het programma CREATE dan kan men een afwijkende grootte instellen. Neem bijvoorbeeld meer dan 100Kb als er grote files in moeten, neem minder dan 100Kb indien er bijv. 31 ‘one-liners’ op moeten. Men is dan wat betreft disc-cap. niet meer compatible. Met AACOPY kunnen dan geen floppies meer uitgewisseld worden.
PAS OP: Bij het gebruik van standaard ATOM-floppies hoeft de Z80- kaart slechts 1 keer gereset te worden {met de ATOM-floppy in de drive). Bij het verwisselen van ‘simulatie’-floppies is de kans groot dat een floppy de zogenaamde ‘Read Only’ status krijgt. Een schrijf-poging resulteert dan in het vastlopen van de ATOM-dos. Om dit te voorkomen moet men bij verwisselen van ‘simulatie’- floppies een reset geven aan de Z80-kaart. Door de ‘simulatie’- floppies ‘gestandaardiseerd’ aan te maken worden ook de ‘R/O’ errors vermeden.
Aan de volgende eisen moet voldaan zijn:
Aan de volgende eisen moet voldaan zijn:
- De files moeten steeds in dezelfde volgorde op de schijf gezet worden.
- De files moeten van dezelfde grootte zijn.
- Er mogen geen files gedelete zijn.
De directory van de CPIM floppies moet exact hetzelfde zijn om bij verwisseling geen ‘R/O’ status te veroorzaken.
HET OPSTARTEN VAN ATOMDOS
Stop een atomfloppy in de drive. Reset vervolgens de Z80 kaart. Tik dan op de ATOM in: *DOS. De DOS moet dan werken.
Gebruikt men standaard ATOM 100Kb schijven dan hoeft de Z80 kaart niet opnieuw gereset te worden bij het verwisselen van schijven. Bij gebruik van gestandaardiseerde simulatie floppies is de reset bij floppy-wissel ook overbodig.
Na elke reset van de Z80 kaart moet op de ATOM opnieuw *DOS ingetikt worden.
Na elke reset van de Z80 kaart moet op de ATOM opnieuw *DOS ingetikt worden.
GDOS MET DE Z80 KAART
De ‘namaak’ -GDOS is wat betreft commando’s en OS-calls geheel compatible met het origineel. De volgende veranderingen zijn merkbaar voor de gebruIker:
- De DOS werkt langzamer i.v.m. de extra communicatie.
- Het VERIFY commando verifieert de gehele disk.
- Sommige foutmeldingen kunnen niet voorkomen.
- De entrys in de ROM zijn verschillend. Programma’s die rechtstreeks in de ROM springen moeten worden aangepast.
- De commando’s *#40, *#80 werken zonder dat daarvoor een hardware uitbreiding nodig is. Een 80-track drive is dan wel noodzakelijk. Zorg dat de jumper op de Z80 kaart goed staat !
HET OPSTARTEN VAN GDOS
- Stop een double density GDOS floppy (een niet geformatteerde mag ook) in drive A.
- Reset dan de Z80 kaart.
- Op de ATOM moet nu de gewijzigde GDOS op worden gestart.
- Nu moeten alle commando’s werken.
- M.b.v. *ENABLE en *FORHAT kan men floppies formatteren.
- De Z80 kaart hoeft nu niet meer gereset te worden.
- Bij hernieuwd opstarten van de ATOM (break) hoeft men alleen maar
- *DOS te tikken en het systeem is al weer klaar voor gebruik.
TERMINAL SOFTWARE
Deze terminal software is noodzakelijk voor het draaien van CP/M,Er zijn drie versies beschikbaar:
- Voor gebruik met de club 80-kolommenkaart (EF9345) VDU80
- Elektuur-achtige (6845),
- Universeel, voor gebruik met een ATOM video driver.
Alle I/0 voor CP/M (behalve disk I/O ) wordt via de ATOM gedaan. De terminal bevat o.a. de volgende delen:
- 80 kolommen driver. Deze emuleert een ADM-31 (Televideo 950) terminal. Deze driver kan o,a, het volgende:
- regels inserten en deleten, (*)
- het invoegen en deleten van karakters in een regel, (*)
- instellen intensiteit karakters, (*)
- verplaatsen van de cursor.
- het instellen van het scrollgebied, (*)
- het definiëren van de functietoetsen,
- het definiëren van de cursortoetsen.
- (*) Deze zijn niet beschikbaar op de universele terminal. De universele terminal maakt gebruik van de al in de ATOM aanwezige video driver (16*32, 24*32, 24*40, 24*64). Voor een compleet overzicht van de mogelijkheden zie appendix C en D
-
Toetsenbord driver. Deze werkt geheel onder interrupt.
Elke 4 milliseconde wordt het toetsenbord gescand. Zodoende is typeahaed onder alle omstandigheden gewaarborgd. Deze driver heeft ’two-key rollover’ en auto-repeat, Zodoende is ‘REPT’ toets vrij. Deze wordt gebruikt als een ‘SUPER- SHIFT’ voor functietoetsen. Het de implementatie van deze functietoetsen is een truc uitgehaald om ervoor te zorgen dat er ‘line-editing’ mogelijk is net zoals bij de ATOM.
Indien het eerste karakter van de inhoud van een functietoets gelijk is aan Ctrl-@, dan wordt de rest van de tekst direct naar de interne video-driver gestuurd. Hen kan zo de cursor op het scherm verplaatsen. De video-driver heeft ook nog een escape-sequence waarmee het character onder de cursor verstuurd kan worden. Laat men de copy-toets deze code intern naar de video driver sturen, dan is het mechanisme compleet.
Bij een tekstverwerkingsprogramma moeten de cursor-toetsen en copy-toets anders gedefinieerd zijn. De terminal heeft een paar escape sequensen waarmee omgeschakeld kan worden tussen de twee modes. - Buffers. Alle ‘stromen’ (toetsenbord, beeldscherm, printer) zijn gebufferd. Zodoende wordend er geen karakters gemist.
HET AANPASSEN VAN DE TERMINAL
Bij het aanpassen van de terminal is kennis van de geheugenindeling van de betreffende ATOM noodzakelijk. De volgende adressen kunnen (moeten) aangepast worden:
- Het adres van de VIA. Dit is de VIA waarmee de Z80-kaart aangesloten is. Ik heb gekozen voor #BF90.
- Het adres van de PRTVIA. Dit is de standaard ATOM-VIA met centronics printerinterface. Standaard #B800.
- Het adres van de CODE en adres van de RAM. Aanpassen aan eigen geheugenideling.
- De klokfrequentie moet worden ingevuld. Meestal 1.000.000 Hz.
- Indien men de standaard VIA (#B800) gebruikt voor communicatie met de Z80 kaart moet het adres van de printer VIA verzet naar een stukje leeg geheugen. Stuurt men iets naar de printer (is er niet) dan …… dag.
- Indien 6845, adres video geheugen, en controller.
- Initialisatie tabel van de video controller (9345 en 6845)
- Bij de universele terminal moet de schermafmeting worden ingevuld. Bovendien moet goed opgelet worden dat de printer niet meer bestuurd wordt door de standaard video driver. De terminal kijkt of de video driver begint met JSR #FEFB. Indien zo, dan wordt de sprong naar de driver 3 bytes opgeschoven. Pas dus op met drivers die de printer besturen en die niet beginnen met JSR #FEFB.
- Bij de universele terminal is graphics mogelijk in combinatie met VDU.JH. Hiervoor moeten jump adressen ergens in de code worden aangepast. Bovendien moet met een ander programma (GRP- SRC) ergens graphics routines neergezet worden. Het behulp van het *SAVE commando kan dan de vertaalde termi.nal en graphics routines in 1 file worden weggeschreven.
MINIMALE TERMINAL
In het Acorntjedbrood nr. 5.2 is een zeer minimale terminal gepubliceerd door Paul Klomp. Deze laat zich snel intikken en is dus geschikt voor testdoeleinden.
APPENDIX A: STEPRATE PATCHES
Op de hieronder genoemde adressen mag men alleen de volgende waarden invullen:
00 | voor | 6 Ms steprate |
01 | voor | 12 Ms |
02 | voor | 20 Ms |
03 | voor | 30 Ms |
In de EPROM staan op de volgende adressen de steprates gedefinieerd: 0D1F en 381F. Op 0D1F staat de steprate die gebruikt wordt bij reset en ATOMDOS. Voor GDOS ondersteuning staat de steprate op adres 381F.
In de programma’s SYSGEN en RSECT moet men adres 0102 (na laden met ZSID) wijzigen. Na wijzigen met SAVE commando weer wegschrijven.
In het programma AACOPY moet adres 300C gewijzigd worden.
Alle bovengenoemde adressen bevatten 00. De steprate is dus 6 Ms.
APPENDIX B: HET PATCHEN VAN DE BIOS
Voor het veranderen van de drive-instellingen is nogal wat handigheid nodig. Ik volsta met het geven van een paar voorbeelden.
Voorbeeld 1) Drive A en B zijn dubbelzijdige 40 track drives.
Voor drive B: komt een dubbelzijdige 80 track drive in de plaats.
Hoe moet nu de BIOS gewijzigd worden zodat drive B: een capaciteit krijgt van 790 Kb? Ga als volgt te werk:
De verspreidde BlOSsen zijn al ingesteld op dit type drives (drive C en D). De opslagcapaciteit bedraagt 1440 Kb per schijf.
M.b.v. het drive-volgorde tabelletje kan men de drive ook als drive A laten werken zonder jumpers om te zetten in de drive. Wil men zonder gebruik van de drive tabel zo’n drive als drive A gebruiken, dan moet de source van de BIOS gewijzigd worden.
Verander bijv. de tabel naar 02 03 00 01. De al aanwezige 5″ drive werkt nu als drive C. Let wel op: de programma’s RSECT en SYSGEN kijken niet naar deze tabel.
Noot: Voor TEAC G modellen moet de write prec. uitgezet worden. Mijn YE-DATA drives, model YD38OT, vereisen wel precomp.
Voor drive B: komt een dubbelzijdige 80 track drive in de plaats.
Hoe moet nu de BIOS gewijzigd worden zodat drive B: een capaciteit krijgt van 790 Kb? Ga als volgt te werk:
- Start CP/M ‘koud’ op van drive A:
- Start het programma ZSID op en wijzig drive type B (zie patch tabel). Wijzig de inhoud van adres EEB4H van 21h naar 30h.
- Verlaat ZSID met ctrl-C. Stel m.b.v. DCONF drive B in voor BigBoard 790 Kb.
- Het moet nu mogelijk zijn floppies te formatteren met drive B, en er vervolgens files op te zetten mbv kopieerprogramma’s.
- Nu moet de BIOS nog op de systeemtracks van een floppy gezet worden. Dit gaat als volgt: Start het programma ZSID op en laad tegelijk het programma SYSGEN.COM mee. Start het programma SYSGEN met een breakpoint op adres 0 (G100,0). Laad met sysgen een bootsector in het geheugen (met oude BIOS). Door vervolgens return te tikken komt men terug in de debugger. Nu kan met het verplaats commando (MEE00,FE00,1F80) de BIOS gekopieerd worden naar adres 1F80. Start nu het programma sysgen weer op vanuit de debugger (G100). Nu moet men geen source drive opgeven, alleen de destination drive (moet A zijn).
- Van de (40 tracks) floppy waar zojuist de nieuwe BIOS opgezet is, moet koud opgestart kunnen worden met drive B ingesteld voor 790 Kb.
- Sluit een 80 track aan als drive B (i.p.v. de 40 tracks drive).
- Wijzig m.b.v. ZSID het drive type B (zie Vb1).
- Gebruik DCONF om drive B in te stellen voor BigBoard 790 Kb.
- Formatteer een schijf met drive B.
- Zet er vast een stel utilities op zoals FORMAT, ZSID, SYSGEN en DCONF.
- Blijf ingelogd op drive A. Verander met ZSID de drive volgorde tabel. Nieuwe inhoud: 01 00 02 03. Verlaat ZSID met ctrl-C. Schrik niet: drive A en B zijn nu verwisseld voor P2DOs. De 80 track drive is nu drive A voor P2DOS.
- Wijzig met ZSID nu ook drive type A (voor P2DOS drive B) naar 80 tracks (nieuwe inhoud adres EE6A wordt 30h). Met DCONF drive B instellen voor BigBoard 790 Kb. Nu met ZSID en SYSGEN een bootsector van drive A ophalen (voor SYSGEN is de volgorde van de drives niet veranderd). Verplaats de BIOS (MEE00, FE00, 1F80). Op adres 1FBE staat de drive volgorde tabel. Terugpatchen naar 00 01 02 03. Nu met SYSGEN de BIOS wegschijven naar drive B (de 80 tracks drive).
- Sluit de tweede 80 track drive aan als drive A.
- Met de net aangemaakte floppy moet nu opgestart kunnen worden.
De verspreidde BlOSsen zijn al ingesteld op dit type drives (drive C en D). De opslagcapaciteit bedraagt 1440 Kb per schijf.
M.b.v. het drive-volgorde tabelletje kan men de drive ook als drive A laten werken zonder jumpers om te zetten in de drive. Wil men zonder gebruik van de drive tabel zo’n drive als drive A gebruiken, dan moet de source van de BIOS gewijzigd worden.
Verander bijv. de tabel naar 02 03 00 01. De al aanwezige 5″ drive werkt nu als drive C. Let wel op: de programma’s RSECT en SYSGEN kijken niet naar deze tabel.
Noot: Voor TEAC G modellen moet de write prec. uitgezet worden. Mijn YE-DATA drives, model YD38OT, vereisen wel precomp.
PATCHTABEL VOOR DE BIOS
; head load time 50 ms EE3C 3C hl.time: db 60 ; head settIe time 25 ms EE3D 1E hs.time: db 30 ; drive redefinition table EE3E 00 01 02 03 dr.tab: db 0,1,2,3 ; see zcpr2 manual EE42 01 00 00 00 PATHINIT: db 1,0, 0,0 EE46 00 00 00 00 db 0,0, 0,0 EE4A 00 db 0 ; type of the selected drive ; bit 0,1 steprate 3, 6, 10, 15 Ms ; bit 2: doubles steprate ; bit 3: 0 ; bit 4: 0 40(77) 1 80 trk ; bit 5: 0 single 1 double side ; bit 6: 0 mini 1 maxi floppy ; bit 7: 0 EE6A 30 A.TY.DRV: DB 30H ; 5" DS 80-TRK EBB4 30 B.TY.DRV: DB 30H ; TEAC F EEFE 70 C.TY.DRV: DB 70H ; 8" DS 80-TRK EF48 70 D.TY.DRV: DB 70H ; TEAC G Enkele voorbeelden van drive types ; 07h voor 5" SS 40 trks, 30 Ms steptime (hele oude Shugarts) ; 21h voor 5" DS 40 trks, 6 Ms steptime (TEAC B) ; 40h voor 8" SS 77 trks, 3 Ms (standaard 8") ; 60h voor 8” DS 77 trks, 3 Ms (dubbelzijdig 8")
APPENDIX C: 6845 EN EF9345 TERMINAL
Bell ^G Right ^L Backsp/left ^H Carriage return ^H Tabulate ^I Clrscreen, home ^Z LF/down ^J Home ^^ Up ^K Delete #;F Normal video ESC ( Low Video ESC J Clear screen ESC * Char insert ESC Q Char delete ESC W Line insert ESC E Line delete ESC R Clear end of line ESC T Clear end of screen ESC Y Set cursor pos ESC *line+20H column+20H Terminal reset ESC 00H Auto LF on ESC 01H Program function key nr ESC 06H nn ss text ss Define scroll window ESC 0DH tt bb Auto LF off ESC 0EH Erase to eol with CR on ESC 0FH Erase to eol with CR off ESC 10H Set cursor display ESC 13H nn (6845) Poke ln CRTC or DP ESC 16H rr dd Ask for the contents of key nn ESC 17H nn terminal returns: ESC 17H nn FFH text FFH Set line-editing cursor keys ESC 18H Set ‘wordstar' cursor keys ESC 19h Set dim/ underline/ blink/ inverse ESC G 4/ 5/ 6/ 7 (EF9345) Reset attributes ESC G 0/ 1/ 2/ 3 (EF9345) Special keyboard functions: ^O terminal reset ^4 on-line ^1 clock off (6845 terminal) ^5 local ^2 clock on ( " ") ^6 CP/M cursor & function keys ^3 not used ^7 WS cursor & function keys Function key numbers: @ 0 RETURN 32 (Add 8 if shifted) A-Z 1-26 DELETE 33 (Add 8 if shiftedJ [ 27 COPY 34 (Add 8 if shifted) \ 28 curs R-L 35 (Add 8 if shifted) ] 29 curs U-D 36 (Add 8 if shifted) ^ 30 Note: When the first char of a programmed key is a ^@ (00H)
then the rest of the key contents is send to the internal video driver.
This is used for Atom-like cursor & copy keys.
APPENDIX D: STANDAARD TERMINAL
Bell ^G Backspacelleft ^H Tabulate ^I Linefeed/down ^J Up ^K Right ^L Carriage return ^M Clear screen, home ^Z Home ^^ Clear screen ESC * Set cursor pos ESC. * line+20H column+20H Terminal reset ESC 00H Auto LF on ESC 01H Auto LF off ESC 0EH Program function key nr nn ESC 06H nn ss text ss Ask for the contents of key nn ESC 17H nn terminal returns: ESC 17H nn FFH text FFH Set line-editing cursor keys ESC 18H Set 'wordstar' cursor keys ESC 19h Clear graphics screen ESC 1BH mode Plot (modes same as in atom) ESC 1CH mode xl xh yl yh Special keyboard functions: ^O terminal reset ^4 on-line ^1 clock off (6845 terminal! ^5 local ^2 clock on ( " ") ^6 CP/M cursor & function keys ^3 ot used ^7 WS cursor & function keys Function key numbers: @ 0 RETURN 32 (Add 8 if shifted) A-Z 1-26 DELETE 33 (Add 8 if shiftedJ [ 27 COPY 34 (Add 8 if shifted) \ 28 curs R-L 35 (Add 8 if shifted) ] 29 curs U-D 36 (Add 8 if shifted) ^ 30 Note: When the first char of a programmed key is a ^@ (00H) then
the rest of the key contents is send to the internal video driver.
This is used for Atom-like cursor & copy keys.
APPENDIX E: MONITOR
COMMANDO’sA Werkt niet. B Invoer blokkeren (nuttig ??). Opheffen met ctrl-^ C Werkt niet. D <beginadr>,<eindadres> Hexadecimale dump van het geheugen E Genereert INTEL-hexformaart EOF. F <beginadres>,<eindadres>,<waarde> Vult geheugen met konstante waarde G <adres>[ ,<breakl>[ ,<break2>]] Start programma. Er kunnen 2 breakpoints opgegeven worden. Voor gebruik eerst I - register mbv ‘X' op #FF zetten. H <x><y> Berekent som en verschil van x en y. I Kopieert standaard BIOS uit EPROM. J Eenvoudige geheugen-test. Inhoud wordt niet veranderd. M <beginadres>,<eindadres>,<dest.adres> Intelligent verplaats commando. N Werkt niet. P<adres> Invoer van text van keyboard naar adres. Met '-‘ kan laatste teken gewist worden. Afsluiten met ctrl-D. QI<poortadres> Uitlezen IO-poort. QO<prtadres>,<waarde> Schrijven naar IO-poort R[<bias>[ ,<reladres>]] Inlezen INTEL hex-files over keyboard. S<adr> Modificeren van geheugen.
Met spatie naar volgende geheugenplaats,
met ‘_’ naar vorig~. Met RETURN afsluiten. T<beginadres>,<eindadres> ASCII dump van het geheugen. U Werkt niet. V<beginadres>,<eindadres>,<adres2> Vergelijk 2 geheugenstukken. W<beginadres>,<eindadres> Intel hex uitvoer. X[<register>] Display register inhoud. Als er een register gespecificeerd is kan de inhoud veranderd worden. Y<waardel>[,<waarde2>,. ..] Zoek naar volgorde van bytes. Z Geeft hoogste vrije adres (#EFFF). De monitor staat op adres F000h. Aan het begin ervan staat een Jump-tabel: F000 JP BEGIN ; Koude start monitor (eerst floppy etc. ) F003 JP Cl ; Console input. Char in reg. A F006 JP RI ; Was Reader-In. Werkt niet F009 JP CO ; Console out. Char in reg. F00C JP POO ; ?? FOOF JP LO ; ?? F012 JP CSTS ; Status, A=FF ==> toets ingedrukt. F015 JP IOBYTE ; ?? F018 JP IOSET ; ?? F01B JP MEMCK ; ?? F01E JP RESTART ; Print registers en PC, warme start.
De restart kan goed gebruikt worden om uit een testprogramma weer in de monitor te komen.
Met het ‘X’ commando kan men dan de registers bekijken.
APPENDIX F: ZCPR2
COMMANDS:
DU: The DU form standing alone is used to log into a different directory. There are three basic forms of this command -- Change Disk D: Change User U: Change Disk and User DU: A file may be preceded by DU: to indicate the disk and user. DIR Display files. Display $DIR File Names DIR DU : afn Display $SYS File Names DIR DU : afn S Display All File Names DIR DU : afn A ERA Erase files. Erase Specified Files ERA DU : afn Erase with Verify ERA DU : afn V REN Rename file. Rename File REN DU : ufn1=ufn2 TYPE Type file on screen. Type File Without Paging TYPE DU : ufn P Type File With Paging TYPE DU : ufn LIST List file on Printer. List File With Paging TYPE DU : ufn SAVE Save the contents of the TPA. Save Hemory into File SAVE n DU:ufn Save Memory into File SAVE n DU:ufn s n may be decimal (default) or hexadecimal (followed by "H"). When the S option is specified, n refers to the number of 128 bytes blocks instead of 256 byte pages. GET Load a file into memory. Load File Into Memory GET adr DU:ufn Adr must be hexadecimal GO Reexecute the last program loaded. Reexecute Last Transient GO params JUMP Branch to anywhere in memory. Call Subroutine JUMP adr Adr must be hexadecimal. The following facilities are enabled: -searchpath for *.COM files at address 0040H -standard CP/M submit !$$S.sUB). -Multiple command line buffer at address FB40H
APPENDIX G: ATOMDOS commando’s
*CAT inhoud schijf *DELETE delete een file *DIR laden directory *DRIVE specificeren drive *EXEC vergelijk submit bij CP/M *GO ?? *INFO informatie van een file *LOAD van een file *LOCK beschermen tegen wissen of schrijven *MON enable meldingen *NOMON disable meldingen *RUN laden en runnen *SAVE saven file *SET setten qualifier *SHUT sluiten file(s) *SPOOL uitvoer op beeldscherm ook naar file *TITLE wijzigen titel van een disk *UNLOCK file wordt weer Read/Write *USE s etten qualifier ?
LISTING PATCH PROGRAMMA
100 PROGRAM D-PATCH-salfaa 110 120 REM DOS patchen voor bidirectionele 1/0 Z80-kaart 130 REM gebruikt salfaa V1.5 140 REM voor schema V1A-P10 d.d. maart 1986 150 REM verwacht ACDOS / DECADOS op #6000 160 170 PASS2;GOSUBa 180 PASS1;GOSUBa 190 END 200 210a ASM-B 220 .TABLE#9800,#9FF0 230 .LIST 240 .OPT #40 \ P-Charme uit 250 260:via=#B400 270 280 .CODE #E000;.RAM #6000; NOP \voorafje 290 300 .CODE #E000;.RAM #6000 310 LDA @#FF;STA via+12 320 LDA @#FF;STA via+12 , \opvullen ruimte 330 340 .CODE #E112;.RAM #6112 350:sect 360 LDA @#FF;CLC;ADC #AO;LDA #Al;ADC @0;STA #CB 370 LDA @#13;JSR put’byte 380 LDA #A3;JSR put’byte;LDA #A2;AND @#F;JSR put’byte 390 LDA @#0E;JSR put’byte;LDA #CB;JSR put’byte 400 LDA #9C;STA #F6;LDA #9D;STA #F7;RTS;RTS;RTS 410 420 .CODE #E220;.RAM #6220 430 JHP #FFED;JSR #E731 440 NOP;NOP;NOP;NOP;NOP;NOP;NOP;NOP;NOP;NOP 450 460 .CODE #E4A3;.RAM #64A3 470 NOP;NOP;NOP;LDA @#00 480 STA #AD;JSR sect 490:label 500 JSR dsk’nr;JSR read’wr;te;LDA #CB;BEQ done 510:rept 520 JSR get’put;INY;BNE rept;INC #F7;DEC #CB;BNE rept 530:done 540 RTS 550 560 .CODE #E6B0;.RAM #66B0 570 NOP;NOP;NOP 580 590 .CODE #E6FF;.RAM #66FF 600 RTS . 610 620:init 630 JSR vreet;LDA @#DD;STA via+12;LDA @#FF;STA via+12 640:vreet 650 BIT via+O;BVC klaar;JSR get’byte;JSR #FE66;JMP vreet 660:klaar RTS 670 680 .CODE #E731;.RAM #6731 690 LDA @#00;JMP motor 700 710 .CODE #E74A;.RAM #674A 720 LDA @#4B;JMP motor 730 740 .CODE #E75B;.RAM #675B 750 RTS , \start motor 760:motor 770 STA #AD 780 LDA @#13;JSR put'byte;LDA @o;STA #F6;JSR put’byte;JSR put’byte 790 LDA @14;JSR put'byte;LDA @2;STA #CB;JSR put’byte 800 LDY @#20;STY #F7;JMP label 810:get'put 820 BIT #AD;BVC get 830 LDA (#F6),Y;JMP put’byte 840:get JSR get'byte;STA (#F6),Y;RTS 850 860:get.byte 870 BIT via+O;BVC get.byte 880 LDA @#FD;STA via+12;LDA via+1;PHA 890 LDA @#FF;STA via+12;PLA;RTS 900 910:put'byte 920 BIT via+0;BPL put'byte;STA via+1;PHA 930 LDA @#FF;STA via+3 940 LDA @#DF;STA via+12;LDA @#FF;STA via+12 950 LDA @#00;STA via+3;PLA;RTS 960 970:dsk’nr \ stel disknummer in 980 LDA @#04j;JSR put’byte;LDA #EE;AND @#07 990 ORA @#30;JMP put’byte 1000 1010:read’write \ stuur read/write-commando 1020 JSR vreet;LDA @#17;BIT #AD;BVS put;LDA @#12 1030:put 1040 LDY @0;JMP put’byte 1050 1060 .CODE #EF13;.RAM #6F13 1070 JMP init 108O 1090 .END 1100 ?#643C=#38;?#6440=7;REM DISK 0. .7 1110 RETURN