## Memory Functions of the Poly 88 CPU

## 1.1 Introduction

Memory external to the CPU board is normally quite simple to use. Memory cards simply plug into the POLY 88 bus after you have selected an appropriate starting address. One exception is the block of memory between addresses ØØØØ hex and ØFFF hex; the CPU disregards any external memory at this address unless you have made the appropriate modification.

## 1.2 External lower memory.

The CPU hardware modifications necessary for use of a second block of memory at lower addresses is fairly simple, as it was considered when the board was designed. Some memory cards (including those manufactured by PolyMorphic Systems) have "phantom" capabilities on bus pin 67. These offer an advantage when making this modification but are not necessary in many cases. The POLY 88 monitor PROM will be disabled; so some software additions will be necessary. The software additions can be lengthy or short depending on your particular application.

1.3 Hardware changes for external lower memory.

As a general rule, make sure the normal functions of the system are operational before attempting any special alterations. Cut trace "HH" and remove a small section. This trace is near the upper left corner of the CPU board when viewing the bottom (noncomponent side). Install a jumper (on the non-component side of the board) between the pad at the right end of the trace "HH" (ungrounded pad) and pad "H" directly above capacitor C9. Pad "H" is labeled only on the component side. Two pads are provided so you can use a jumper to replace trace "HH" if it becomes necessary.

If the memory card you will use as a second block of lower memory has a "phantom" facility at bus pin 67, connect a jumper between bus pin 67 and pin 6 of IC12, on the non-component side of the CPU board. Bus pin 67 has a jumper pad attached, pin 6 of IC12 does not have a jumper pad.

Be sure to double check the connections you make before applying <u>p</u>ower; misplaced jumpers are a common source of serious damage to integrated circuits.

1.4 Theory behind hardware changes.

IC35 is a 74LS138 3-line to 8-line decoder. Address lines A13 through A15 are decoded by this chip to porduce a LO TTL level signal at one of its outputs. A12 is connected to an active-LO enable input of IC35, thus the chip can produce a LO output only when A12 is LO. When all four address lines are LO (indicating the first 4K of memory), the output at IC35 pin 15 is LO creating an active onboard signal (ONBD-). One function of ONBD- is to provide an enable to IC36, another 3-line to 8-line decoder. IC36 is completely enabled when ONBD- and INTA+ (interrupt acknowledge) are both LO. At this time, address lines A1Ø and A11 are decoded to select 1K of onboard memory (memory select signals = MSØ- through MS3-) or one of four onboard I/O signals (peripheral select signals = PSØ- through PS3-).

2

The output of IC37 pin 3 determines whether memory blocks or I/O signals are decoded. The output of IC37 pin 3 is HI if an input or output instruction is being executed.

Returning to the discussion of IC35, notice the enable at pin 5 (active LO) is normally grounded through trace "HH". If trace "HH" is broken and pin 5 is connected to pad "H", IC35 is enabled only when A12 and output pin 13 of IC11 are both LO. IC11 pin 13 goes LO when the output of IC37 to pin 3 is LO (indicating neither input nor output instructions are being performed) and IC30 pin 7 is HI.

IC30 is used as a latch to store baud rate, serial device select, and onboard disable status; it will be referred to by the name BRG (baud rate generator latch) for ease of discussion. The BRG output pins continually display the aforementioned status according to Figure 1.

To disable the onboard memory, set bit 5 (of bits Ø through 7) HI in the accumulator and output to port 4 (BRG).

3E 20 Example: MVI A,2ØH; SET BIT 5 HI D3 04 OUT 4 ; LATCH NEW STATUS IN BRG To re-enable the onboard memory set bit 5 of port 4 LO or press the front panel reset button. The latter resets the BRG and executes the monitor which places a given status in the BRG.

The other hardware change suggested for memory cards having a

"phantom" facility enables the memory card when pin 7 of BRG is HI (onboard memory disable) and disables the memory card when pin 7 is LO (assuming bus pin 67 disables the memory card when HI). The "phantom" facility is not absolutely necessary but without it, writing into onboard memory (including stack ops performed by the monitor) also writes into the corresponding offboard memory location.

Remember, when the onboard memory is disabled, the POLY 88 monitor ROM is disabled. Thus, you must have any necessary control software (such as keyboard input, video display, and cassette tape reader routines) located in memory external to the CPU board.

1.5 Relocation of CPU onboard memory.

The onboard memory address can be shifted up if you do not wish to use the POLY 88 monitor ROM. It is important to remember the POLY 88 monitor will work only if its starting address is ØØØØ.

There are three possible starting addresses that are easily implemented on the POLY 88 CPU,  $\emptyset \emptyset \emptyset \emptyset$  (which is preselected on the PC card),  $8\emptyset \emptyset \emptyset$  hex (32K), and  $\widehat{E \emptyset \emptyset \emptyset}$  (56K). If you wish to select a starting location other than  $\emptyset \emptyset \emptyset \emptyset$ , cut trace "J" and remove a small section. Trace "J" is between two closely spaced pads on the non-component side, immediately to the right of IC35. Install a jumper with sleeving between pad "J" (the one nearest the regulators) and pad "R" (which connects to IC35 pin 14 and is labeled "T" in the schematic) for a starting location of  $8\emptyset \emptyset \emptyset$  hex; install a jumper between pad "J" (nearest the regulators) and pad "S"(connects to IC35 pin 7) for a starting location of E000 hex.

4

These changes simply create the ONBD- signal when the new memory block address is decoded by IC35.

| D5/7 | D4/15             | D3/2 | D2/12 | D1/10            | DØ/5 | ONBD                                  | SERIAL<br>DEVICE | IC29<br>OUTPUT<br>KHZ | ÷16<br>BAUD RATE |  |
|------|-------------------|------|-------|------------------|------|---------------------------------------|------------------|-----------------------|------------------|--|
| L    | X                 | X    | x     | х                | X    | Ε                                     | X                | X                     | x                |  |
| Н    | Х                 | X    | X     | Х                | Х    | D                                     | Х                | X                     | X                |  |
| X    | L                 | X    | X     | X                | X    | X                                     | ø                | х                     | ×                |  |
| X    | н                 | X    | X     | X                | X    | X                                     | 1                | х                     | X                |  |
| X    | X                 | L    | L .   | L                | L    | X                                     | X                | 0                     | 0                |  |
| X    | Х                 | L    | L     | L                | Н    | X                                     | Х                | 0.800                 | 50               |  |
| X    | X                 | L    | L     | н                | L    | Х                                     | X                | 1.200                 | 75               |  |
| X    | X                 | L    | L     | н                | Н    | X                                     | X                | 1.760                 | 110              |  |
| X    | X                 | L    | н     | L                | L    | Х                                     | X                | 2.152                 | 134.5            |  |
| X    | Х                 | L    | н     | L                | Н    | X                                     | X                | 2.400                 | 150              |  |
| X    | Х                 | L.   | Н     | Н                | L    | X                                     | X                | 4.800                 | 300              |  |
| X    | Х                 | L    | н     | Н                | Н    | X                                     | Х                | 9.600                 | 600              |  |
| X    | X                 | Н    | L     | L                | L    | Х                                     | X                | 14.400                | 900              |  |
| X    | Х                 | Н    | L     | L                | Н    | X                                     | X                | 19.200                | 1200             |  |
| X    | Х                 | Н    | L     | Н                | L    | X                                     | X                | 28.800                | 1800             |  |
| Х    | Х                 | Н    | L     | Н                | Н    | X                                     | Х                | 38.400                | 2400             |  |
| Х    | Х                 | Н    | Н     | L                | L    | Х                                     | X                | 57.600                | 3600             |  |
| X    | Х                 | Н    | Н     | L                | Н    | Х                                     | Х                | 76.800                | 4800             |  |
| Х    | Х                 | Н    | Н     | Н                | Ĺ    | х                                     | X                | 115.20                | 7200             |  |
| X    | X                 | Н    | Н     | Н                | Н    | X                                     | X                | 153.60                | 9600             |  |
|      | TTL HI<br>Enabled | 1    |       | TTL LO<br>Disabl |      | · · · · · · · · · · · · · · · · · · · | ( = Irre         | elevant               |                  |  |

from BRG pin 7.