by snm, November 3rd, 2017

The MultiTech Systems “Routefinder RF102” is a dual serial port router with a built-in 4-port 10/100 Ethernet switch. Slow by today’s standards (with Gigabit Ethernet or faster), this device could be useful in 2005 when it was manufactured. The two serial ports are for connecting to an ISDN or 56k modem uplink, both now obsolete technologies. So let’s crack it open:

The board is silkscreened “RF102S Ver 10 ISDN/56k Router+Switch”, an apt description.
Notable chips:
The serial circuitry on the right is more complex:
On the reverse side, there is not much but surface-mount passives:

Taking a closer look at the HT93LC46 1k 3-wire serial EEPROM, which appears to be connected to the PLD.

Desolder the chip and insert into a breadboard:

Powered the device up without the EEPROM and verified the 4-port 10/100 Mbps switch continued to operate normally:

This is what we would expect since the EEPROM and PLD appear to be used for the serial ports (ISDN/56k), not the Ethernet ports.
Now to dump it. Found this helpful thread on the Dangerous Prototypes forum: 93LC46 eeprom dump
Referring to the HT93LC46 Datasheet, operating voltage 2.0V to 5.5V read and 2.4V to 5.5V write, so used 5 V. Clock frequency at 5V±10% minimum 0 maximum 2000 kHz, so any of the Bus Pirate’s supported frequencies should work. Probing the ORG pin (#6) in circuit, reads 0.7 V = low, so the memory is organized as 128 groups of 8 bits: 128 bytes (as opposed to 64 groups of 16 bits).
Configuring the mode mode on a Bus Pirate 3.6:
m 7 (3WIRE) 1 (~5KHz) 1 (CS) 2 (normal)
Turn on the power supply with “W”. Wire up the AUX pin to ORG, then pull it low with “a” (128 groups of 8-bits = 128 bytes).
Send the “READ” instruction, opcode 0b10. Start bit 1.
3WIRE>[0b110 0 r:128]
CS ENABLED
WRITE: 0x06 
WRITE: 0x00 
READ: 0x11 0x82 0x47 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFE 0x11 0x82 0x45 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFE 0x00 0x00 0xB1 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFE 0x00 0x00 0xB1 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFE 
CS DISABLED
3WIRE>
Reformatting 16 bytes per line:
11 82 47 FF FF FF FF FF  FF FF FF FF FF FF FF FF
FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FF
FF FE 11 82 45 FF FF FF  FF FF FF FF FF FF FF FF
FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FE
00 00 B1 FF FF FF FF FF  FF FF FF FF FF FF FF FF
FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FF
FF FE 00 00 B1 FF FF FF  FF FF FF FF FF FF FF FF
FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FE
TODO: what is this? An ASCII hexdump -C with offset:
00000000  11 82 47 ff ff ff ff ff  ff ff ff ff ff ff ff ff  |..G.............|
00000010  ff ff ff ff ff ff ff ff  ff ff ff ff ff ff ff ff  |................|
00000020  ff fe 11 82 45 ff ff ff  ff ff ff ff ff ff ff ff  |....E...........|
00000030  ff ff ff ff ff ff ff ff  ff ff ff ff ff ff ff fe  |................|
00000040  00 00 b1 ff ff ff ff ff  ff ff ff ff ff ff ff ff  |................|
00000050  ff ff ff ff ff ff ff ff  ff ff ff ff ff ff ff ff  |................|
00000060  ff fe 00 00 b1 ff ff ff  ff ff ff ff ff ff ff ff  |................|
00000070  ff ff ff ff ff ff ff ff  ff ff ff ff ff ff ff fe  |................|
00000080
This router contains an Altera EPM3032ALC44, part of the MAX 3000A family. The family’s datasheet reveals the EPM3032A has 600 usable gates, with 32 macrocells, 2 logic array blocks, and 32 maximum user I/O pins. This makes it the smallest of the series:
| Feature | EPM3032A | EPM3064A | EPM3128A | EPM3256A | EPM3512A | 
|---|---|---|---|---|---|
| Usable gates | 600 | 1,250 | 2,500 | 5,000 | 10,000 | 
| Macrocells | 32 | 64 | 128 | 256 | 512 | 
| Logic array blocks | 2 | 4 | 8 | 16 | 32 | 
| Maximum user I/O pins | 34 | 66 | 98 | 161 | 208 | 
but it looks to be still used, especially in networking equipment. Another user salvaged the same EPM3032A (from “NetApp DS14 Filers”) and designed a breakout board, then programmed it successfully with Quartus II, writing a simple 4-bit counter in VHDL. This looks promising, the author concludes:
The EPM3032A is not a large CPLD, with only 32 macrocells it’s by no means a device for large scale logic implementations. The 4 bit counter ended up using 4 macrocells or 13% of the usable space in the CPLD, but it is perfect when you need a small custom logic device where many individual chips would be required.
While searching more information about this device, found a EPM3032 CPLD Breakout Board on OSHPark. This PCB measures 1.07x2.37” so it would cost about $10 to manufacture with their prototype service. It was made for an online course, PyroEDU Course 5: FPGA and CPLD, and the completed populated CPLD Breakout Board (EPM3032ATC44-10) can be ordered for $14.95, however, it is for the TQFP package not the PLCC which is the package used in this device. The 44-pin TQFP (thin quad flat package) and 44-pin PLCC (plastic leaded chip carrier) pinouts are completely different:

so unfortunately PyroEDU’s breakout board will not be useful for using this chip (although it could still be useful for educational purposes, the complete Introduction to FPGA and CPLD Kit is only $37.95 from The Gadgetory, for the 10-lesson course).
There are other comparable introductory kits, such as Adafruit’s Mojo FPGA Development Board for $79.95. Mojo uses a Xilinx Spartan 6 XC6SLX9 FPGA instead of an Altera EPM3032 CPLD, and their tutorial uses Verilog instead of VHDL. CPLDs come with built-in non-volatile memory to store the configuration, whereas FPGAs usually don’t.
TODO: is it possible to dump the programmed logic on this CPLD’s non-volatile memory?
TODO: learn how to desolder/solder PLCCs (hot air station?), and make a breakout board for the EPM3032ALC44 (not the EPM3032ATC44)
but further research into FPGAs and CPLDs will have to wait for later. Although they are very powerful, there are even powerful video game consoles built on FPGAs such as the Analogue Nt mini.
The 512 KByte (4 Megabit) EN29F040A flash memory is connected to the ARM7TDMI microcontroller, likely as operating system code. According to Wikipedia, ARM7TDMI stands for “ARM7 + 16 bit Thumb + JTAG Debug + fast Multiplier + enhanced ICE”, and was one of the most popular ARM cores in 2009. Reverse-engineering it is out of the scope of this post, but we can take a closer look at the flash:

Pinout for the PLCC package from page 4 of the data sheet (their blurry text, not mine):

The designer of this board seemed to really like PLCC packages. Probably good for production, but not for us to salvage and repurpose these components. Anyways, A0-A18 are the address lines, and DQ0-DQ8 are the data output bits. Vcc is 5.0V, /CE chip enable, /OE output enable, /WE write enable. With the right tools, dumping this chip should be relatively trivial, but the PLCC package and parallel interface makes it beyond my reach. Oh well.
There are several crystals on this board, of different frequencies and shapes. Desoldered the X4 crystal and confirmed the 4-port switch still functioned (as we would expect since it is for the serial function, not Ethernet). Measuring the X4 crystal with a frequency counter shows 7.3735 MHz, not far from the “T07.372” label:

The other crystals I would guess are more important to the function of the switch so I didn’t bother desoldering them, but at least I got a working 7.3735 MHz to add to my parts bin.
Since I’m not planning on using ISDN/56k (who uses that anymore?), I desoldered the serial ports:

The power connector could also be worthy of salvaging, to use along with the 5 V power brick (TTL logic levels), but I kept it so the device could be used as a switch without further modifications. After removing the serial ports, the Ethernet switch continues to operate normally as you would expect:
