Atari ST(E) Flash EPROMs instead normal (EP)ROMs with TOS version switch


  This is my old idea (and others), to have in-circuit reprogrammable ROM chips in Atari ST machine. Benefits are: easy TOS patching, making some OS additions, and changing TOS version without opening machine or loading TOS in RAM. Now (2008) is ideal time for such upgrade - the prices are very low, so 4 Mbit Flash EPROM costs much less than 1 Mbit (what is size of 1 chip by 2-chip TOS variant) EPROM. And we can have then 4 TOS versions at once, switchable.

  The principle: fortunatelly there are some standards (JEDEC), so new ROM chips have practically same pin layout as older ones, except of course new pins (higher addresses). It makes replacement and upgrade relatively simple. Looking standard pin layout by DIL ROM chips used in small computer systems we can notice that GND is always last pin in bottom row - pin 14 by 28-pin chips, pin 16 by 32-pin chips. Data lines are also on same (physical) place, and address lines A0-A14 too. So, we need to care only about pins 1, 2, 30, 31, 32 when replacing 28-pin chip with 32-pin one.

  In circuit programming inside Atari ST(E): Flash EPROMs are designed to be programmable inside regular microcomputer architectures, with standard CE, OE, WE signals.
By chips of series 29xxx, 39xxx, 49xxx no need for 12V (as by 28xxx). Reading of Flash EPROMs is exactly same as ordinary EPROMs - need to activate CE, OE while WE is inactive. Of course, all that lines are low-active. In Atari, we need to invert RW signal of CPU, and lead that to OE, RW directly to WE, and to CE connect OR-ed signals ROM0, ROM1, ROM2 - this is at output of 74LS11 (U12 in Mega ST) . Unfortunately it is not enough, because Glue chip will generate bus error by attempt to write in ROM address space. So, we need some additional logic, what will activate DTACK when writing in ROM address space. It is simplest to do with GAL, but may be done with couple logic 74xxx chips.

  Boolean equatations are:

/DTACK = /AS*A23*A22*A21*/A20

 Above is for TOS 1.6, 2.06... (STE) ,  address space is $E00000-$E3FFFF  .

/DTACK = /AS*A23*A22*A21*A20*A19*A18*/A17*A16 +  /AS*A23*A22*A21*A20*A19*A18*A17*/A16 + /AS*A23*A22*A21*A20*A19*A18*/A17*/A16 

 Later is for TOS 1.00 - 1.04 (ST, Mega ST) . Adress space is: $FC0000-$FEFFFF . Since it is complicated it is best to do with GAL, and then we can solve support for TOS 2.06 by adding address space for it...
 Note: DTACK needs OC output for drive. If it is not case, we may connect via schottky diode.

flainmst2.jpg

On pic above is how it is solved in Mega ST. 32-pin sockets are inserted in original ROM sockets, so that pins 1, 2, 31, 32 are in air. Pins 30 are cut down, and is best to put little insulator between them and sockets, to avoid contact.

Connectiing of Flash EPROMs:   pin 32:   +5V (Vcc) , add cer. capacitor between it and GND, with shortest possible legs.
                                                 pin 31:  (/WE)  /RW signal from CPU - via resistor and protection switch (explained later)
                                                 pin 30:  (A17 of Flash)    to selection switch
                                                 pin  2:   (A16 of Flash)    to A17 of CPU - it is
closest at W2, point 3 .
                                                 pin  1:  
(A18 of Flash)    to selection switch

Other connections in Mega ST:  W3 (remains) on pos for 1M ROMs (2-3 connected). W2: remove shortcut and connect point 3 to pins 2 of Flash EPROMs. To point 2 of W2 connect inverted RW signal of CPU (this leads to OE pins of ROMs) .
W4: remove shortcut (if there was 6 chip TOS), Lower point (ROM2 signal) goes to selection logic, upper point comes from selection logic - then need to cut (desolder) pin 12 of 74LS11 , to avoid conflict.


  From opposite side:
flainmst3.jpg



TOS switching: it is very simple. We only change TOP 2 (in case of 4Mbit Flash) address lines states. A17 and A18 of Flash chips. 1 (micro) switch for 1 line. No need for alternate switches: Connect address lines to +5V via resistors of 1K (may vary), and that common point to GND via switch. So, when switch is off it will be on High, and when switch is on, it will be Low.

Protection against accidental writing: again simple solution with switch and resistor - lead RW signal from CPU via resistor of about 470 ohms to pins 31 of Flash EPROMs. Then connect it via third switch to +5V. So, when switch is on, /WE will always be inactive, and no writing happens. When switch is off, it allows write operations.

I did switching with DIP microswitch, where 3 switches are used.

Software for in-circuit programming: I made simple GUI programm for programming Flash inside Atari. There is version for Atmel 29C040  and AMD 29F040  chips. Atmel programs very fast: 256KB (1 TOS space) programs in aprox 5 secs.  AMD is little slower because of different (bytewise) programming + required preerasing, but is still very fast: total under 10 seconds for 256KB .
Because TOS and AES constantly accesses ROMs under regular work, we can not do programming with enabled CPU interrupts. Workaround is following: load TOS in RAM (with SELTOS for instance), and then may do programming with GUI SW, and enabled interrupts, since no ROM accessing at all. After successfull programming may click 'Cold boot', for get rid of TOS in RAM.  After it usually must press reset button once that machine boot with new content.

flaamd01.png

Download in-circuit programator for AMD 29F040 with source

1 min video klip of in/circuit programming (3MB, Xvid)


The logic:  it can be solved in many ways . Will start with simplest, using GAL chips(s)

Example 1:

   % Multi TOS, Supports ROM areas #E00000-#EFFFFF %
  % #FC0000-#FEFFFF    , writing to Flash EPROMs in area at #E0.... %
  % For machines with orig. ROM at #FC0000 %

*IDENTIFICATION
   TOSMU1;

*TYPE
  GAL16V8;
 
*PINS
 
    %INPUTS %
   
    A23 = 1,
    A22 = 2,
    A21 = 3,
    A20 = 4,
    A19 = 5,
    A18 = 6,
    A17 = 7,
    A16 = 8,  
    
    AS = 11,
    RW = 12,
    ROM2 = 19,

    %OUTPUTS %
                 
    CER = 18,  %E00000-EFFFFF, FC0000-FEFFFF , for TOS 1.xx and 2.06 in same chips%
   
    OE = 16,
    DTACK = 17;     %connect via Schottky diode to CPU DTACK % 


*BOOLEAN-EQUATIONS

   /DTACK = /AS*A23*A22*A21*/A20;
  
      /CER = /AS*A23*A22*A21*/A20+/ROM2+
    /AS*A23*A22*A21*A20*A19*A18*/A17*A16*RW+
    /AS*A23*A22*A21*A20*A19*A18*A17*/A16*RW;
  
   /OE = RW ;    

*END
    
                  
Example 2:

   % Multi TOS, IDE . Supports ROM areas #E00000-#EFFFFF %
  % #FC0000-#FEFFFF    , writing to Flash EPROMs in area at #E0.... %
  % For machines with orig. ROM at #FC0000 %

*IDENTIFICATION
   TOSMIDE1;

*TYPE
  GAL16V8;
 
*PINS
 
    %INPUTS %
   
    A23 = 1,
    A22 = 2,
    A21 = 3,
    A20 = 4,
    A19 = 5,
    A18 = 6,
    A17 = 7,
    A16 = 8, 

    A5 = 9,
    
    AS = 11,
    RW = 12,
    ROM2 = 19,

    %OUTPUTS %
                 
    CER = 18,  %E00000-EFFFFF, FC0000-FEFFFF , for TOS 1.xx and 2.06 in same chips%
   
    SELP = 13,
    SELS = 14,
    IORD = 15,
    IOWR = 16,
    DTACK = 17;     %Goes to inverter with Open Collector e.g. 74LS03 % 

*BOOLEAN-EQUATIONS


   DTACK = /AS*A23*A22*A21*/A20+
   /AS*A23*A22*A21*A20*/A19*/A18*/A17*/A16;
  
      /CER = /AS*A23*A22*A21*/A20+/ROM2+
    /AS*A23*A22*A21*A20*A19*A18*/A17*A16*RW+
    /AS*A23*A22*A21*A20*A19*A18*A17*/A16*RW;
   /SELP = A23*A22*A21*A20*/A19*/A18*/A17*/A16*/A5;
   /SELS = A23*A22*A21*A20*/A19*/A18*/A17*/A16*A5;
   /IORD = /AS*A23*A22*A21*A20*/A19*/A18*/A17*/A16*RW;
   /IOWR = /AS*A23*A22*A21*A20*/A19*/A18*/A17*/A16*/RW;
    
*END

    
     Example 2 is practically same as 1, but with additional IDE hard disk port control.
But, as we don't have free pins on GAL, we need to invert RW with external inverter, to get /OE signal for Flash EPROMs.
On site is scheme for IDE interface.

MegaST_IDE_RomSw.jpg
 IDE IF on expansion slot and switchable TOS with Flash EPROMs in Mega ST.

          

No GAL programmer? There is a simple solution:
tosmur2.png
 ROM must be connected to GND with pin 14 and to +5V with pin 32 too (power connections) . And 74xxx chips too, of course (pins 7 and 14).
 Only 2 cheap IC , 2 diode and 1 resistor required.
muro1040.jpg
 
In 1040 ST . ROM type selection pads are little different. You need some ohm-meter and pin layout for (Flash) EPROMs to ensure correct pad setting and connections.
Pins 24 of Flash (what are pins 22 of original ROMs) must be connected to GND (short left side of pad marked with A17). From right side of that pad get A17 and connect to A16 pins of EPROMs (pins #2). Pad marked with A16 should be shorted on 1M pos. CE signal from 74LS10, after resistor must go to pins 22 of (Flash) EPROMs, or pins 20 of original sockets - it is connected with pad marked CE, right upper point - disconnect all shortcuts there.

 
On scheme is read-only version. TOS switch may be added as above - need to may set highest address lines (pins 1 and 30) with some switch to L/H .
For possibility to reprogramm Flash EPROMs just one inventer more is required (there is still 4 free inv. in 2 IC) .
             
  Just couple steps more, and we have reprogrammable TOS:

  TOSMURW.png
On scheme is version with place for 4 TOS versions. 2 switch is for TOS version select, third (connected to +5) is for write disabling - to prevent accidental damage of ROM contents. So, open that switch only while reprogramming.
By early 520 ST machines (REV H and earlier) no 74LS11 (and setting pads) - so need to make same 3 input AND logic. May be done with existing ICs, remaining gates: 74LS10 (connect ROM0-ROM2 to 3 inputs) + 74LS04 (as inverter). There are differences by ROM connections on MB too - USB and LSB is used at pins 22, so need to do some wire cuttings too...

nogalrw4sw.jpg
Little  different pad setting:  OE of Flash EPROMs does not connect to GND, but to inverter out. So, no shortcut on left side of pad A17.
Programming SW is same as for "GAL" version. It is not recommended to make reprogrammable version with single-TOS capacity Flash EPROMs. Because, if something goes wrong by programming we will have dead machine after cold boot. By multi TOS switchable we will have always other sections with which can boot machine.


 Before starting usage you must program (Flash) EPROMs somehow. Otherwise machine can not be made 'alive' . So, need some programmer device.
  TOS ROMs must be splitted into High/Low parts, and so burned with programmers .
ROM splitting program with source
It can recalculate and set CRC for TOS 2.06, not only by splitting, but for ordinary binary image files too.



P. Putnik,  May, June  2008

Menu Properties Quick Reference

hcnt: 51793