TI/National Bipolar PROM Programmer
Update: Arduino sketch and programmer utility finished. The programmer is now completely functional.
The K-1013 Floppy Disk Controller uses an optional (and obsolete) 256x8 bit, 20 pin PROM to be able to boot the OS from disk. There were many variants that were pin-compatible for reading, but that required different and incompatible programming methods that, however, have something in common: They are not supported by modern, cheap programmers.
I was able to find a few 74s471 on e-bay, but my search for a suitable programmer only yielded options that cost many hundreds of euros.
So, based on this design of a PROM programmer for the ACORN by Chris Oddy, I designed a poor man’s TI/National Semiconductor Bipolar PROM programmer shield for the Arduino Mega and should as well burn other 256x8 and 512x8 bit PROMs from TI and Tesla.
According to the datasheet, the programming procedure is as follows:
- Apply a supply voltage (Vcc) of 5 V and address the word to be programmed.
- Verify that the bit location needs to be programmed. If not, proceed to the next bit.
- If the bit requires programming, disable the outputs by applying a high-logic-level voltage to the chip-select input(s).
- Only one bit location is programmed at a time. Connect each output not being programmed to 5V through a 3.9 kΩ resistor and connect the output to be programmed to ground. Maximum current out of the programming output supply during programming is 150 mA.
- Step Vcc to 10.5 V nominal. Maximum supply current required during programming is 750 mA.
- Apply a low-logic-level voltage to the chip·select input(s). This should occur between 10 μS and 1 ms after Vcc has reached its 10.5 V level.
- After the programming pulse time (1 to 10 ms) is reached, a high logic level is applied to the chip-select inputs to disable the outputs.
- Within 10 μs to 1 ms after the chip-select input(s) reach a high logic level, Vcc should be stepped down to 5 V, at which level veritication can be accomplished.
- The chip-select input(s) may be taken to a low logic level (to permit program verification) 10 μS or more after Vcc reaches its steady-state value of 5 V.
- At a programming pulse duty cycle of 35% or less, repeat steps 1 through 8 for each output where it is desired to program a bit.
The 74s471 is supplied with all bit locatlons containing low logic level (0) and programming a bit changes the output of that bit to high logic level.
So, the programmer’s hardware must be capable of:
- Powering on/off the prom.
- Addressing each of the prom’s locations.
- Reading each location contents.
- Connecting each bit line to ground or to a 3.9 kΩ pullup.
- Controlling the prom’s select line(s).
- Applying a 10.5V pulse to the prom’s Vcc.
Chris’ design is very clever. It uses a boost converter which output voltage is set based on a voltage divider formed by R2 and R3 when the transistor Q1 is off. According to the datasheet, \(V_{out} = (\frac{R_{3}}{R_{2}} + 1)\times1.23 = 5.01 V\). When the transistor is on, R4 is added in parallel to R2, which yields an equivalent value of \(R_{eq} = \frac{R_{2} \times R_{4}}{R_{2} + R_{4}} = 15.95 kΩ\), so the new output voltage is \(V_{out} = (\frac{R_{3}}{R_{eq}} + 1)\times1.23 = 10.48 V\). This way, we can generate the programming pulse just controlling Q1.
The rest of the circuit is very straightforward, with a mosfet controlling power on/off, eight transistors that connect each bit pin to ground or the 3.9 kΩ pullups, and a couple of open-collector buffers. I’ve opted for an SMD design, with sizes big enough so they can be soldered manually:
The sketch for the firmware has been developed from scratch, following the PROM’s datasheet. It implements basic one-letter commands through the serial inteface, which are controlled by the programmer’s command line utility (sorry, only for Unix-like OS. On Windows, use the Windows Subsystem for Linux).
You can find everything to build your own, including the programmer utility, in my GitHub repository.
Programmer’s usage
Warning: During programming, the power comsumption goes well over 5W. I had a lot of stability problems until I realised that the USB connection was not providing enough juice, so you need to supply at least 10W to the Arduino through the barrel connector. I’m using a 12V, 1A adapter that I had lying around.
On WSL, first make sure that you attach the USB device to the Linux susbsystem.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
Usage: prom [-h]
prom DEVICE [-c NUM] -b
prom DEVICE [-c NUM] -r [ADDRESS [-n COUNT] | -o FILE [-f FORMAT]]
prom DEVICE [-c NUM] {-w|-s|-v} {ADDRESS -d STRING | -i FILE [-f FORMAT]}
Arguments:
DEVICE Serial device.
Options:
-h[elp] Show this help message and exit.
-c[hip] NUM Chip to program: 0 == 74s471 (default), 1 == 74s472.
-b[lank] Do a whole chip blank test.
-r[ead] [ADDRESS] Read chip. If ADDRESS is specified, read just that
byte. If not, do a hexdump of the chip contents to
the screen or, if an output file name is provided,
dump the contents with the format specified by the
-format option.
-n[um-bytes] [COUNT] Number of bytes to read. Defaults to the whole chip
size.
-w[rite] [ADDRESS] Program chip. If ADDRESS is provided, program
beginning at that location with data specified with
the -data option. If not, an input filename must be
specified.
-s[imulate] [ADDRESS] Program simulation. Will success of fail as the write
command, but without actually burning the chip.
-v[erify] [ADDRESS] Verify data. Same options as for -write|-simulate.
-d[ata] STRING Binary string to program, simulate or verify. Can
contain hex and oct escaped binary chars.
-i[nput] FILE File to read the data from.
-o[utput] FILE File to save the data to.
-f[ormat] {bin,ihex} File format. Defaults to bin.
Note: Long and short options, with single or dual '-' are supported
Blank test command
Makes a quick blank test of the whole chip.
Example:
1
2
3
$ prom /dev/ttyUSB0 -b
Connected to programmer, firmware V01.00.00.
Chip is not blank. Found non-zero data at address 0x0.
Read command
prom DEVICE -r
, without any more arguments, does a hexadecimal dump to the screen:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
$ ./prom /dev/ttyUSB0 -r
Connected to programmer, firmware V01.00.00.
000 ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
010 ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
020 ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
030 ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
040 ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
050 ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff |................|
060 01 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
070 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
080 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
090 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
0A0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
0B0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
0C0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
0D0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
0E0 00 00 00 00 00 00 00 00 ff ff ff ff ff ff ff ff |................|
0F0 ff ff ff ff ff ff ff ff ff ff 1c 1c 00 ff 1f 1c |................|
100
If an address is provided, the content from that cell and onwards is printed to the screen:
1
2
3
4
$ ./prom /dev/ttyUSB0 -r 0xec
Connected to programmer, firmware V01.00.00.
0EC ff ff ff ff ff ff ff ff ff ff ff ff ff ff 1c 1c |................|
0FC 00 ff 1f 1c |.... |
Finally, it is also possible to make a dump in binary or Intel HEX format with the -o FILE
and -f {bin|ihex}
options, If not specified, bin
is the default:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
$ ./prom /dev/ttyUSB0 -r -f ihex -o test.hex
Connected to programmer, firmware V01.00.00.
Writing contents to file `test.hex` in ihex format.
$ cat test.hex
:20000000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF00
:20002000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE0
:20004000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFC0
:2000600001000000000000000000000000000000000000000000000000000000000000007F
:20008000000000000000000000000000000000000000000000000000000000000000000060
:2000A000000000000000000000000000000000000000000000000000000000000000000040
:2000C000000000000000000000000000000000000000000000000000000000000000000020
:2000E0000000000000000000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF1C1C00FF1F1CA0
:00000001FF
Write and Simulate Write commands
prom DEVICE -w ADDRESS -d DATA
programs the cells beginning at address ADDRESS
with the DATA
binary string:
1
2
3
4
5
6
7
$ ./prom /dev/ttyUSB0 -w 0x60 -d '\x01\x02'
Connected to programmer, firmware V01.00.00.
WARNING: Programming is irreversible. Are you sure? Type YES to confirm
YES
Writing
..
Success.
prom DEVICE -w -f {bin|ihex} -i FILE
programs the chip with the contents of the FILE
file. Working with bin
and ihex
have different implications:
- If a binary file is specified, the chip is programmed starting at address
0x000
up to the size of the file or the chip, whichever is smaller. - With an Intel HEX file, only the addresses specified in the file are programmed.
1
2
3
4
5
6
7
8
$ ./prom /dev/ttyUSB0 -w -i test.bin
Connected to programmer, firmware V01.00.00.
WARNING: Programming is irreversible. Are you sure? Type YES to confirm
YES
Writing
.........................................................................
.......................
Success.
Command -s
works exactly the same as -w
, but without burning the chip. It is strongly suggested to execute first a simulation as it helps to catch errors beforehand:
1
2
3
4
5
$ ./prom /dev/ttyUSB0 -s -f bin -i test2.bin
Connected to programmer, firmware V01.00.00.
Performing a write simulation
..........................................................
Error writing (simulated) to prom address 0x039: Read == 0xff, expected == 0x03
Verify command
The verify command just checks the contents of the PROM against the data provided. It has the same options as the Write and Simulate write commands:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
$ ./prom /dev/ttyUSB0 -v -f bin -i test2.bin
Connected to programmer, firmware V01.00.00.
Verifying
..........................................................
Error verifying prom address 0x039: Read == 0xff, expected == 0x03
$ ./prom /dev/ttyUSB0 -v -f ihex -i test.ihex
Connected to programmer, firmware V01.00.00.
Verifying
.........................................................................
.........................................................................
.........................................................................
.....................................
Success.