💾 Archived View for mirrors.apple2.org.za › archive › apple.cabi.net › FAQs.and.INFO › Accelerators … captured on 2023-01-29 at 07:40:51.

View Raw

More Information

-=-=-=-=-=-=-

Path: ns-mx!uunet!wupost!waikato.ac.nz!comp.vuw.ac.nz!actrix!David.Empson
From: David.Empson@actrix.gen.nz (David Empson)
Newsgroups: comp.sys.apple2
Subject: Re: Speaking of the Zip...
Message-ID: <1991Nov12.135052.365@actrix.gen.nz>
Date: 12 Nov 91 13:50:52 GMT
References: <1991Nov11.185126.28247@usenet.ins.cwru.edu>
Organization: Actrix Information Exchange, Wellington, New Zealand
Lines: 148
Comment-To: bb252@cleveland.Freenet.Edu

In article <1991Nov11.185126.28247@usenet.ins.cwru.edu> bb252@cleveland.Freenet.Edu (James L. Brookes) writes:
> 
> The only drawback I find to the Zip is that the CDA is not in the 
> firmware, so you have to boot up GS/OS to access it.  While the speed of
> bootup now makes that less of a problem, I do remember hearing of some
> p8 util that would load CDAs.  If there is such a beast, I would
> *really* love to have it.  There are some games that are just *too*
> fast with the Zip in, it would be nice to play those at say 7 mhz or
> something. 
> 
> [High Speed at last, and loving every second of it:^]

Agreed!!!

The program you want is called P8CDA, and it is published by:

Roger Wagner Publishing, Inc.
1050 Pioneer Way, Suite P
El Cajon, California 92020

619/442-0522

P8CDA is a ProDOS-8 system file that installs all CDAs it finds in the
SYSTEM/DESK.ACCS directory, then runs the second .SYSTEM file.
The package includes a CDA screen blanker.  I don't know the price,
but it should be no more than US$25.


An alternative would be to write a ProDOS-8 SYS file that can set the
speed of the ZIP and perform the other operations that the CDA
supports.  It is very easy to write a program to 'enable' and
'disable' the ZIP - I have written a couple called FAST and SLOW.

All you need is details of the I/O addresses used by the ZIP.

Here is SLOW:

2000: A9 50	LDA	#$50
2002: 8D 5A C0	STA	$C05A	; write $50 to $C05A four times to
2005: 8D 5A C0	STA	$C05A	; enable access to the ZIP registers
2008: 8D 5A C0	STA	$C05A
200B: 8D 5A C0	STA	$C05A
200E: 8E 5A C0	STZ	$C05A	; write $00 to $C05A to disable the ZIP
2011: 0A	ASL
2012: 8D 5A C0	STA	$C05A	; write $A0 to stop accessing the ZIP
2015: 20 00 BF	JSR	$BF00	; Do a ProDOS QUIT call
2018: 65		$65
2019: 1D 20		$201D
201B: 00 00	BRK	$00
201D: 04 00 00 00 00

Just type in the hex codes on the left, and use the following commands
to save it:

CREATE SLOW,TSYS
BSAVE SLOW,TSYS,A$2000,L$22


To write FAST, simply change one byte:

200F:5B

(this changes the STZ $C05A to STZ $C05B)

CREATE FAST,TSYS
BSAVE FAST,TSYS,A$2000,L$22


Now, before you run your game, you boot ProDOS-8 and run SLOW.  After
you've finished with the game, boot ProDOS-8 and run FAST to resume
full speed operations (or boot GS/OS and use the CDA).


Here is the full set of ZIP registers, for those who are interested
(others can skip the rest of this article):


ZipChip GS Special Registers       Ex ZIP Technology, 12 October 1990

Registers must be unlocked before they can be accessed (see $C05A).
Locking them will re-enable the annunciators.

Writing to any I/O location $C058-$C05F (whether registers are locked or
unlocked) will reset delay in progress.

$C058 R   No operation

$C058 W   Write any value to force poweron/reset bit to COLD (forces next
reset to restore ZIP registers to defaults/switch settings).

$C059 R/W 76543210
          *.......  Bank Switch Language Card cache disable=1/enable=0?
          .*......  Paddle delay (5 ms) disable=0/enable=1  $C070/$C020
          ..*.....  External delay (5 ms) disable=0/enable=1
          ...*....  Counter delay (5 ms) disable=0/enable=1 $C02E/$C07E
          ....*...  CPS follow disable=0/enable=1
          .....*..  Last Reset warm?              READ ONLY
          ......*.  Hardware DMA                  READ ONLY
          .......*  non-GS (0)/GS (1)             READ ONLY

$C05A R   76543210
          ****....  Current ZIP Speed, 0=100%, F=6.25%, in 6.25% increments
          ....1111

$C05A W   Write values as follows:
          $5x       Unlock ZIP registers (must write 4 times)
          $Ax       Lock ZIP registers
          other     Force ZIP to follow system clock (i.e. disable card)

$C05B R   76543210
          *.......  1msclk - clock with 1 ms period
          .*......  cshupd - Tag data at $C05F updated (read $C05F to reset)
          ..*.....  Bank Switch Language Card cache (0), don't (1)
          ...*....  Board disable - 0=enabled, 1=disabled
          ....*...  delay in effect (0=ZIP, 1=Slow)
          .....*..  rombank (0/1) - not in development version
          ......**  Cache RAM size (00=8k, 01=16k, 10=32k, 11=64k)

$C05B W   Write any value to force ZIP to current speed (i.e. enable card)

$C05C R/W 76543210
          *******.  Slot 7-1 delay enable (all slots 52-54 ms)
          .......*  Speaker delay enable (5 ms)

$C05D R   Current 65816 bank

$C05D W   76543210
          ****....  Set ZIP speed, 0=100%, F=6.25%, in 6.25% increments
          ....****  Don't care

$C05E R   Read last Tag data written and force the next write to
create a trash tag value.

$C05E W   No operation

$C05F R   Read last Tag data written and reset cshupd.  Note: apparently
any write to a ZIP register (unlocked) will clear cshupd, but cshupd says
that this location must be read.

$C05F W   No operation


I got this information from ZIP Technology (with many thanks).
-- 
David Empson

EMPSON_D@kosmos.wcc.govt.nz
David.Empson@bbs.actrix.gen.nz