## Single-chip RAM expansion for the NASCOM 2

I made the idle assertion that it would be simple to build a single-chip 64kbyte extension for the NASCOM-2, so I decided to design and describe it.

The target chip is an ALLIANCE SEMICONDUCTOR AS6C1008. This is a static 128Kbyte  $\times$  8 device, of which half will be used and the other half totally wasted!

This part is available as a 32-pin DIL package for about £3 -- from component distributors or on EBAY. It can run on a supply rail of 2.7V - 5.5V and has a pinout that is "sympathetic" to a 2716.

I propose 2 alternative construction methods:

1/ Mounted directly on the NASCOM main board, in and around one of the 24-pin memory sockets. In this scheme there are some flying leads but no additional components are required.

2/ Connected to the NASBUS. For example, if you have a small veroboard backplane it would be easy to mount the memory there. In this scheme an additional component (an inverter) is required.

For construction method 1, a convenient location is the A1 socket. If necessary, replace the socket with a 24-pin turned-pin socket, and use 2 more sockets to build up the height then finish with a 32-pin socket with its pin 16 aligned to the underlying pin 12 (GND in both cases).

In the wiring diagram below:

- pins marked A1/<number> connect directly down to the corresponding pin of the A1 socket.
- pins 30 and 32 can be wired to VCC (pin 24) of the A1 socket.
- Pins A10, A11, A12, A14, A15, A16 need short flying leads to NASBUS address lines A10, A11, A12, A13, A14, A15. These can be picked up from a combination of the BASIC ROM and IC2 or IC47.
- /WE can be wired to NASBUS /WRB eg on LKB1
- /OE wiring is described in "theory of operation", below.
- /CS can be wired to NASBUS /MREQB eg on IC47/15
- The LINK BLOCK for A1 (LKB1) should be configured with all the links "UP", like a 4118 SRAM.
- The LKS1 jumper block should be configured with NO CONNECTIONS to pins 3 or 5 or 7 (/RAM\_G1, /RAM\_G2, /XROM).

| AS6C1008 |              |             |                             |
|----------|--------------|-------------|-----------------------------|
|          | +<br>1  0    | 32          |                             |
| NC       | + NC         | VCC +       | **** Wire to A1/24          |
|          | 2            | 31          | WIT 0 00 7(I/ I )           |
| * * * *  | + A16        | A15 +       | ***                         |
|          | 3            | 30          |                             |
| * * * *  | + A14        | CE2 +       | **** Wire to A1/24          |
|          | 4            | 29          |                             |
| * * * *  | + A12        | /WE +       | ***                         |
| A4 /4    | 5            | 28          | A1/24 (                     |
| A1/1     | + A7<br>6    | A13 +       | A1/24 (unused address line) |
| A1/2     | + A6         | 27<br>A8 +  | A1/23                       |
| N1/ Z    | 7            | 26          | N1/ 25                      |
| A1/3     | + A5         | A9 +        | A1/22                       |
|          | 8            | 25          |                             |
| A1/4     | + A4         | A11 +       | * * * *                     |
|          | 9            | 24          |                             |
| A1/5     | + A3         | /0E +       | ***                         |
| 11/0     | 10           | 23          | ***                         |
| A1/6     | + A2         | A10 +       | ^ ^ ^ ^                     |
| A1/7     | 11 <br>+ A1  | 22<br>/CE + | ***                         |
| A1/ /    | 12           | 21          |                             |
| A1/8     | + A0         | D7 +        | A1/17                       |
|          | 13           | 20          |                             |
| A1/9     | + D0         | D6 ÷        | A1/16                       |
|          | 14           | 19          |                             |
| A1/10    | + D1         | D5 +        | A1/15                       |
|          | 15           | 18          |                             |
| A1/11    | + D2         | D4 +        | A1/14                       |
| A1/12    | 16 <br>+ GND | 17<br>D3 +  | A1/13                       |
| 71/17    | I OND        |             | VT/ T0                      |
|          | <br>+        | +           |                             |

## Theory of operation (piggy-back construction)

The NASCOM has ROM (NAS-SYS) in the low 2Kbytes, then 2Kbytes of RAM (workspace and video), then a hole, then 8Kbytes ROM at the top of the address space (BASIC). The hole is 52Kbytes and the idea is to fill the whole of that region with RAM.

Connecting MREQ to the expansion RAM's chip-select means that it will be selected for any memory access (but not I/O accesses). Connecting WE to the expansion RAM's write-enable means that it will be written to for any write. For example, it shadows the workspace RAM and any write to the workspace RAM will also write to the expansion RAM.

The two remaining areas of difficulty are:

- How to control the expansion RAM's output enable. This needs to be asserted for any read access to the 52Kbyte "hole" but must not be asserted for any other addresses becasue that would cause a bus clash (the fact that both devices might drive the same data value will not help us!!).
- How to control the enable on buffer IC45 so that the RAM's data is driven (via the NASBUS) to the CPU.
- -> the expansion RAM's /OE can be connected to IC44/12 (schematic sheet 3). That signal is high when another device (NAS-SYS, BASIC) is enabled on the same

segment of the data bus. Using this as /OE means that the expansion RAM is the default driver of this part of the data bus.

-> the /RAM\_G1 signal is connected to gnd. This means that the /RAM\_DISABLE signal is always asserted, disabling any NASBUS RAM resources, because all RAM is being provided via buffer IC45. IC45 is enabled for all reads except video RAM reads and during refresh cycles.

## Theory of operation (connected to the NASBUS)

The only difference (apart from more wires to connect) is that now the expansion RAM's data bus will be connected directly to the NASBUS -- the connections will be to the B side of buffer IC45 rather than to the A side. As a result, the enable on buffer IC45 must be controlled differently.

- -> the expansion RAM's /OE can be connected to NASBUS signal /RAM\_DISABLE through an inverter. This will enable the RAM when no main-board resource is driving the data bus.
- -> the /RAM\_G1 signal is disconnected (the on-board pullup will take it high). This means that buffer IC45 is enabled for NAS-SYS and BASIC ROM reads and disabled for video RAM reads, for refresh and for any other reads, leaving the 52Kbyte "hole" for the expansion RAM.

Questions or comments to the author

Neal Crook, foofoobedoo@gmail.com

22Jun2019 V1.0 25Jun2019 Correction to /OE connection for piggy-back construction.