Introduction
Some time ago I needed to program an MCM68766 EPROM to upgrade the BIOS in an IBM PC 5150, and in the process discovered that hardware which can program these is rather difficult to come by. Despite having a collection EPROM programmers, including one fairly expensive model (which apparently could, but wouldn’t do it in practice) – in the end none were up to it.
So I set out to build my own. Knowing that the pin-out for 2708 EPROMs was quite similar to MCM68766 – I thought I’d tick that off while I was at it, as this is another type that is very difficult to find hardware to program.
Why is MCM68766 difficult to program?
There is nothing algorithmically complicated about programming one of these – the main difficulty centres on the high Vpp voltage (26V). Most cheap EPROM programms have a max Vpp of 13V. That having been said, there are some cheap programmers which support the 2716 EPROM, also needing a Vpp of 26V, so quite why MCM68766 is such a difficulty, may also depend on other things, such as pin arrangements, or perhaps just limited demand for it.
Why is 2708/2704 difficult to program?
This type of EPROM is genuinely more difficult to deal with. It also needs the same high Vpp voltage, as well as an additional cocktail of voltages. +26V, +12V, +5V and -5V being the full list. All of these are required during programming – quite a headache for the designers of universal programmers. Models that do support it, require a special adapter which doesn’t come cheap. This adapter typically supplies the extra voltages which aren’t practical to provide through the universal socket. Like the MCM68766 – they are algorithmically simple to program, so no complicated software stuff to worry about.
Design
The physical design is in the form of an Arduino Mega shield. I chose this because it was large enough to accommodate all of the components, and there would be enough I/O pins without needing I/O expanders or other complicated stuff.
The only supported Arduino is the Mega 2560 R3 or compatible.
When designing it I was aware that I was likely the only person that’d want something that did both, so have allowed for it to be constructed as a dual 270x/MCM6876x programmer, or 270x only / MCM6876x only.
When built in its dual type form, selection between devices is made by a 6PDT switch, which software can query before powering on the device, checking against the selected device in the user interface, limiting the chance of accidentally blowing an EPROM (which will certainly happen if the switch is in the wrong position).
When programming 270x EPROMs, the Arduino must be supplied with a regulated +12V supply as the shield does not generate its own +12V rail. There is a software check to ensure this voltage is correct before powering on the EPROM.
There is also a footprint for an RS-232 connection + MAX232 but this is not required for most applications as the Arduino can provide a serial interface through its USB port.
Constructing it as a dual type programmer
All components must be fitted except for the RS-232 section.
Constructing it as a MCM68764/MCM68766 programmer
I figured it would be easier to just show a picture of this. All fitted components are as specified on the schematic, unless omitted or replaced with a wire link.
SW1 is hard wired in the left hand position.
Constructing it as a 2704/2708 programmer
When constructing as a 2708 programmer, only the following components can be omitted: SW1, J1, U4, D2, C1, C8, C9, C10, C11, R9, R16.
SW1 must be hard wired in the right hand position.
Buying one pre-built
I don’t sell these things myself. Search for “2708 programmer” on eBay. I’ve seen a number of examples of people selling my design pre-built. There is now at least one “compatible” design out there – different hardware, but using my software.
Host software / firmware
Please see the main project page for more information.
Schematic
Can be downloaded here.
Gerbers
There are two versions of the gerbers. A “Long” version which has the exact dimensions of an Arduino Mega. Choose this if your PCB house doesn’t charge extra for exceeding 100x100mm dimensions. Total size is 101.5mm x 53.5mm.
The “Short” version has the tab at the end clipped to keep it under 100mm. Total size is 99.95mm x 53.5mm.
BOM
Can be downloaded from here (or here – CSV).
2708 Voltage range warning
When developing this shield I found that some 2708 devices are fussy about the voltage on the +12V rail – they won’t be damaged but they’ll not program successfully. The designers of the Arduino Mega have helpfully fitted a reverse protection diode (D1).
While this does prevent hapless newbies from blowing their Arduinos, unfortunately in our case it reduces the 12V supply down to 11.2V. For reliable 2708 programming either this diode must be replaced with a wire link, or the Arduino should be powered with a 13V supply.
Hello,
I hope you don’t mind, but I am going to have some of your shields made up by Oshpark for myself and a couple of friends who are involved in the repair of Vintage computers.
I have sourced some MCM68764/66 EPROMs and this will be great for replacing or upgrading old 24-pin DIP ROMs.
If it’s OK, I’m going to share the ability to have the boards ordered from Oshpark as needed.
No one, other than them, will make money off this and I will have the board design credited to you.
Thank you for your work in designing this shield.
Regards,
Richard
Go for it!
In case anyone wants to build this project, here is the link to the board.
https://oshpark.com/shared_projects/VToG8dY0
I built your programmer and everything worked on the first try!
I’m really excited about having programmed an EPROM 2708 for my old computer.
Thank you so much, you were incredible, very good … and sorry for my bad English ๐
Greetings from Italy
Hi there
Could you include a CRC display of the files in your software?
with kind regards
Achim
I’ll add it to the list
Hi there
Can’t get the 232 version to work.
I also tested with a “real” Com-Port
Kind regards
The error message now often appears:
Eod.pgm has stopped working.
How can the problem be solved?
Good morning
I have problems to write and veryfine the eprom TMS2708
What do i wrong
Can someonee help
Built today your 2708 programmer, worked from the first power on, great project, thank you for sharing. Was curious, because I used a 12V Zener instead of a 11V and 220uH inductors instead of a 180uH, but the voltage values were ok, and I was able to program a 2708 EPROM. Are I on a “dangerous” way with this componets?
The changes you’ve made wouldn’t make a lick of difference to operation. The zener is to keep Vgs below 20V but still allow fast gate charge time, so 12V will still be OK.
As for the inductor, also not going to be an issue. Going higher can result in higher losses (+overheating) and slower regulation response time, but at 220uH it’s still going to be well within operating margins.
Can I get the source code of the Windows software to insert the CRC option?
I have just released an updated version which has the checksum calculator
Thanks for the effort.
I wanted to display the checksum display automatically when loading the binary file or reading out the EPROM.
Couldn’t you get the source code after all?
Perhaps you could look at writing a specific programming tool which does exactly what you want? I’ll never be able to please everyone! I’d certainly be happy to share it here. Happy to provide any protocol information needed.
Would be nice if you shared the sources, so that you can customize the software according to your needs.
Kind regards
I wanted to make the software a little more comfortable.
For example, immediate CRC display in the user interface, use as a pure 2708 programmer and possibly an editor.
I did not want to expect all of this from you.
Kind regards
If you are looking to create a highly customised interface – I’d ask that you build it from scratch rather than customising mine. If you are in a position to integrate a binary editor – this should be no difficulty for you.
As I’ve previously said, I do not intend to release the source for the Windows UI as I don’t want bastardised versions of it all over the place, which I then have to support.
I have added the source for the command line version which should be a very good starting point:
https://github.com/inaxeon/hvepromcmd
I last programmed a 2708 with a borrowed burner for my Commodore 64 club. 1990 or so. Always wanted to play with them since.
I’ve been mostly wanting to burn spare chips for older test equipment and other stuff.
Ideally I would like to just read older chips and burn to some pin-compatible new stuff. I assume eeproms for 2708 and newer are available.
I have unused burners somewhere, but was going to order a modern burner like the TL866.
Also for my Heathkit HERO 1 robots and et-3400a microprocessor trainer and peripheral adapter roms.
Hello Matt,
I am maintaining old school arcade game pcb. As you know, it is difficult to use programmers who read and write old eproms now.
I’d like to use your 2708 eprom programmer. I know you don’t sell it yourself, but it’s very difficult because there’s no place to buy it. I know one seller on eBay, but I can’t make a purchase because of the delivery problem. He said that shipping from Germany to Korea is difficult due to costs and customs clearance.
I would appreciate it if you could sell the finished product or kit for me. Prefer finished products to minimize errors in production. I will pay for the cost and delivery charge by Paypal.
I live in South Korea. I look forward to your positive answer.
Thank you.
Just send the gerbers to a PCB house i.e. seeedstudio
It’s not hard to build yourself
Hi,
is anybody ordering/making these pcb’s?
i am interested to have one…
struggling with my 2708 here
thanks,
Wim
I am about to order and build some pcb’s. Are you interested in one?
Hi Patrick, if it’s not too late already, I am interested in one. Any idea how much the total cost comes to?
Hello,
I sent the email to you for getting the 2708 eprom programmer.
Look forward to your reply.
Hello
it is possible to program even on 2716
Hi Matt,
congratulations to your outstanding projekt.
I built a programmer for my Arcade repairs and it worked from the first try!
Thank you very much for sharing your project!!!
Hello
TMS2708 cannot be programmed.
Timing ?
They work good for me. Did you run through the hardware test?
All tensions are fine.
Problems only with TMS2708
I just re-tried my TMS2708’s. All working.
Had you bypassed the protection diode on the Mega board? Perhaps the 12V is too low and the TMS2708 does not like it?
Hi Matt,
I built the 2708 version of your programmer. I’m getting “Chip is not blank at 0x0000, Data 0x00” on what I believe is a blank chip. If I save to a .bin file and open in a hex editor, I’m seeing 00 in every position. All the voltages looked correct when I ran the self test.
Any guesses what could be wrong here?
thanks
Charlie
Did you run the read-data test?
Hmm, the test looked good last night, but now I’m seeing wrong voltages in the tests. I do have 12v coming from my power supply.
5v is reading 4.2v, -5v reading .3v, 12v reading 1v, 4.2v reading 1.8v. Sounds like I managed to burn something out!
Also, no more buzz sound on the 25v step. This looks to be pulsing between 0v and ~10v, but it is difficult to tell the exact high number
I had not tried the read test yet, (I’m assuming that is the final one with the resistors).
I’m going to go back to my bench to inspect my soldering job for any mistakes and also double check that I didn’t put something in the wrong spot.
Anything jump out at you as possible failed components that could do this?
PS – Everything appears to be in the right place. No bad solder joints. Maybe a bad MC34063?
My minipro programmer has a max VPP of 21V, this is not enough for some of the 2716 eprom I have. I have built this programmer (thanks for sharing you design by the way) and am thinking it should be able to support these eproms too. Is it possible to add support for the 2716?
I was looking at this recently. Unfortunately it’s not just a software tweak, significant change to the hardware would be required.
Yes, I was just looking at the pinouts and realised that VPP /CE and A10 would need to be switched around. Maybe it’s easier to design an adapter board that switches these pins to the right place? Still would need some adjustments to the software, or have a jumper tie A10 to gnd or vcc and program both halves separately.
Software changes not an issue, having an adapter would be a bit of a pain. It may make more sense to revise the board so that the switch changes between 2708/2716(32) and support MCM6876X with an adapter, given that few build it for this. But, considering that 2716 capable hardware can be had for $30 – I don’t think many would bother.
Interestingly the 2732 can be supported with a software change. Maybe it might be worth knocking up a small adapter for 2716’s…
If the 2732 can be done with only software, that would be great. Hoping you can add this feature and maybe even the 2717 with adapter board.
I may be wrong about that. The sticking point is that all 2732’s that I could see are 21v Vpp, so there’s be a small hardware change to allow software selection of the programming voltage.
Probably one for a future revision of the shield I think…
Actually I have many 2732’s here that are 25v Vpp so I am hoping for support for these. The 21V Vpp 2732’s I can program with my TL866.
Can you give me some part numbers? I can’t add support for it if I can’t obtain them ๐
There are many 2732’s with 25vpp I found a list here with different brands.
2732 2732 EPROM* normal algorithm, 50msVpp=25.0V, Vcc*=5.0V
AMD, Fujitsu, Intel,
Mitsubishi, NEC, NS, Oki,
UMC
2732 2732 EPROM* normal algorithm, 5ms Vpp*=25.0V, Vcc*=5.0V TI
2732 2732 4k*8 EPROM* 25VPP many
2732 2732A EPROM* normal algorithm, 10msVpp=21.0V, Vcc*=5.0V TI
2732 2732A EPROM* normal algorithm, 50msVpp=21.0V, Vcc*=5.0V
AMD, Fujitsu, Intel,
Mitsubishi, NEC, Oki, ST,
Toshiba
file:///C|/ํํ์ด์ง/new_021010site/public_html/body/PARTS/EPROM.htm (4 / 12) [2003-04-01 ๏ฝฟ๏พ๏พ๏พ 5:14:20]
EPROM
2732 2732B EPROM* intelligent algorithm Vpp*=12.5V, Vcc*=6.0V Intel
2732 2732D EPROM* normal algorithm, 50msVpp=25.0V, Vcc*=5.0V Toshiba
2732 27C32 EPROM* normal algorithm, 50msVpp=25.0V, Vcc*=5.0V NS
2732 27C32A EPROM* normal algorithm, 50msVpp=21.0V, Vcc*=5.0V Fujitsu
2732 27C32B EPROM* interactive algorithm Vpp*=13.0V, Vcc*=6.0V NS
2732 27C32H EPROM* normal algorithm, 10msVpp=25.0V, Vcc*=5.0V NS
2732 27P32A EPROM* normal algorithm, 10msVpp=21.0V, Vcc*=5.0V TI
2732 P2732A EPROM* normal algorithm, 10msVpp=21.0V, Vcc*=5.0V Intel
The one I have here are these HN462732G, you can find the datasheet here https://pdf1.alldatasheet.com/datasheet-pdf/view/116329/HITACHI/HN462732.html
Update on my issues above. It turned out the MC34063 was failed. I replaced it and now my voltages are correct.
Unfortunately I am still getting “Chip is not blank at 0x0000, Data 0x00โ. The resulting bin file is all 0s which I think means blank. The hardware tests all pass with the correct voltages and the read test with resistors works correctly for all the inputs.
Any suggestions on what else to check?
PS – Here’s a link to the bin file if that is of interest
https://1drv.ms/u/s!AqiyUGOT8PbNw-tEeGj1u-EIkMvWZQ?e=ODDmBn
How many EPROMs have you tried? If it’s just one, you might have fried it.
I just have one 2708. I will trying ordering some others in case this one is bad.
I figured I have nothing to lose with trying to program this 2708, so I just turned off the blank check option and tried programming it anyway. It made a few passes and U1 exploded in a puff of smoke and sparks! Below is a pic of the U1 aftermath…
I have U1 socketed and was able to replace it quickly. The next time I tried it was able to make all 100 passes but it doesn’t look like anything was written. I will try with a different 2708 and see if that helps
U1 explosion!
https://1drv.ms/u/s!AqiyUGOT8PbNw-tJrwbP2DYdOMMLjQ?e=XrR7YL
When burning a TMS2708JL Eprom, an error message occurs.
The comparison immediately after the burn process reports “Verify error”.
But if Verify is called individually after burning, it is correct.
Can you insert a pause before the automatic verify in the software?
Done: http://www.mattmillman.com/wp-content/files/HvEprom.zip
It’s defaulted to 1000ms however can be changed in HvEprom.Pgm.exe.config (VerifyDelayMilliseconds)
Hi Matt – You were right. I had a bad 2708. Replacement 2708s seem to work fine.
One issue I noticed is blank / unused memory areas of the programmed chip have “FF” in them. I see this if I write a .bin file that is smaller than the total size of the 2708. This leads to a different checksum when comparing the chip contents to the original bin.
For example, if I write this 2 line source file, (rom #9 from the arcade game, Magical Spot)
https://1drv.ms/u/s!AqiyUGOT8PbNw-tzHjdzqXG2hdPQHA?e=cNS9C9
it seems to write fine, but I then get this slightly different file when reading the 2708 and saving as a bin.
https://1drv.ms/u/s!AqiyUGOT8PbNw-t0PJZXLhlLBvZZfg?e=RmrjwU
If I view the original file in a hex editor, there are just 2 lines of code. The saved bin has those 2 lines, followed by many lines of “FF”.
Is there any way to eliminate all the “FF”s in this situation so the files are identical?
I’ll look into it
Fixed it. New release here: http://www.mattmillman.com/wp-content/files/HvEprom.zip
I just tried it, but unfortunately I’m still seeing lines of FF at the end of the file.
https://1drv.ms/u/s!AqiyUGOT8PbNw-wwltAzHXzSuPcFmQ?e=AwxdVf
Looks correct to me. 2708 hold 1024 bytes, so that’s what it should read back.
The write checksum now includes the 0xFF padding, so will now match the read checksum.
I’ve been struggling to modify a TL866II+ to program some of my vintage eeproms. Namely 2716 and 2532. I ended up making a circuit that looks a lot like your VPP drivers. Alas, not much repeatable success with the 2532. I’d be curious to hear a write up on your CE, OE and VPP circuit theory here. And a mod of your programmer for 2532. Vpp=25 btw (and drops to 5v for reads)
There isn’t much theory to it. There are quite a few different approaches out there. Most common is NPN+PNP combo, works for most. My design will work with PNP transistors in place of the FETs provided a base resistor is added (with the exception of Q6). In my case I’m using P-Ch FETs because Rds(on) is lower than comparable circuit using a small PNP transistor, which gives a faster and cleaner pulse, but it probably doesn’t matter. It may well be possible to achieve comparable performance with a NPN+PNP transistor combo. I’ve not looked into it in detail.
The 11v Zener diode isn’t needed, and I haven’t included this on subsequent designs. The idea was a circuit which charges the gate as quickly as possible, without exceeding Vgs(max). A simple divider circuit does the job just fine.
I’ve also seen people use opto-isolators to drive Vpp pins too. Not an approach I’d use, but it definitely does work.
Back in the heyday of these chips, engineers spent a lot of time fretting about this stuff because FETs were rare exotica and the performance of available PNP transistors was quite poor. These days just about anything will work.
Please help programmer 2708 what upload on windows fimware to arduino for programer 2708 file for upload and software for upload? Thanks usb version
Get send to email? Thanks
Get make arduino eprom programmer for eprom 2532 ?
Ooh, I really had trouble getting past “Operation timed out”.
I could not succeed to burn the bootloader on my Win10 either. Had to pull put an old Mac which worked without problem. Still had doubts that it would work with the Win-GUI, and guess what? It didn’t. I still got “Operation timed out”.
Hmm, tried to run the GUI as Administrator, and everything was butter smooth!
So, if you get the “Operation timed out”, try running the GUI as Administrator!
Cheers,
Ola
Wow never heard of having to run as admin to access serial hardware before! Glad you got there in the end.