全部博文(116)
分类:
2011-04-29 16:25:28
This JTAG cable is for an interface between the parallel port of a PC and a socalled interface. This type of circuit was originally developed by a company called Altera, which referred to it as the ‘Byteblaster’.
The version described here is compatible with the Byteblaster (electrically it is almost identical). This has the advantage that programs written for use with the Byteblaster can also be used with this interface.
The circuit itself is very simple. K1 is connected to the parallel port of the PC, whereas signals D0, D1 and D6 are brought to the JTAG connector via IC1. The output of the JTAG connector (TDO) is in turn fed back to the PC’s BUSY signal via IC1. Pin 7 of the JTAG connector is used to provide an extra output. This signal is brought to the SELECT input of the parallel port via IC1. Some circuits make this signal active while they are in debug mode. This isn’t really a requirement, but in some cases this can be useful (assuming that the software supports this feature). This signal could of course also be used to pass different status information back to the PC. IC1 is driven by the AUTOFEED output (active low) of the parallel port. As long as this is high the outputs of IC1 will be in a high-impedance state. This isolates the interface from the JTAG connector, so the target board isn’t loaded by the JTAG cable.
The other signals are not specifically required by the JTAG cable. These signals are used by the software to check that the interface has been connected to the (correct) parallel port. Two tests have been made available for this. The first is formed by the direct connection between D5 and the ACK input (active low). The second is made by the connection of D7, via IC1, to the P.END input of the parallel port. This connection only exists when the signal AUTOFEED (active low) is active. These two detection methods are very easy to implement in software. Should a printer be connected to the port, it won’t react by printing several pages of gibberish, since the STROBE signal (also active low) has not been used.
JTAG SoftwareSince the interface is designed to test, debug and/or program chips, the used with it will be dependent on the chip that is connected. But we can still give you a few tips to help you get started quickly with this interface. You should first go to the website of and download the software for programming Altera chips via the JTAG interface. You should also be able to find what is called a JAM player. Apart from a Windows version, there is also a Linux version available. The JAM player is in fact an interpreter with its own programming language, which has been specifically designed for use with the JTAG interface. This allows you to control the JTAG interface in a simple manner, using special commands. Apart from the JAM player there are also conversion programs that change several types of file into a JAM format, so that the JAM player can then interpret these files.
Xilinx JTAG CableThe JTAG cable described above is compatible with the programming software from Altera. Unfortunately, the software from Xilinx doesn't work in combination with this interface. The JTAG cable shown below is compatible with the software from Xilinx, so you can use it to program their range of CPLDs and FPGAs.
The circuit is very simple and consists of just two ICs and a handful of discrete components.
Connector K1 is connected to the PC using a 1:1 printer cable with a 25-way sub-D connector at each end. Connector K2 is connected to the JTAG interface of the device being programmed. The for connector K2 can vary. You can make the JTAG cable according to the device you would like to program, check what type of programming connector device uses and modify K2 accordingly.
The circuit can be easily built on a piece of prototyping board. Since there isn’t any real standard for the JTAG connector, it is very likely that the connections to K2 have to be modified; in that case, a ready-made PCB isn’t very useful.
This cable can be used to de-brick Linksys and WRT54GS routers with the de-brick utility. HairyDairyMaid is a simple flash programmer utility that was originally written to debrick a Linksys WRT54G. This interface is an unbuffered JTAG cable equivalent to the (make sure that it is not too long, 75 cm should work fine), but you can also use a type parallel buffered JTAG cable.
You don't need the VCC and TRST pins on the interface for WRT54G routers. The TRST is already pulled high on the router so there is no need for a TRST pin on the board. But you might want to build a generic JTAG cable that works with other JTAG devices.
There are various projects described on the Internet by people who write software to be used with specific JTAG cable. There is little point in giving a summary of the websites here because they are free web pages and regularly move to different servers. Any list will quickly become out of date. In this case a good Internet search engine like is the best starting point for finding suitable JTAG software.