Skip to content

Cypress FX2 based Logic Analyzers

David Banks edited this page Aug 17, 2023 · 22 revisions

Introduction

Development boards based on the Cypress (now Infineon) FX2 chipset (the CY7C68013A) are widely available for ~£10-£20. These boards can be used as cheap 8-bit/16 bit USB logic analyzers.

One use of such a logic analyer is in debugging 8-bit microprocessor based computer systems. The logic analyzer is setup to capture the microprocessor data bus, and optionally a small number of control signals. Open source software (the 6502/6809/Z80 Decoder) can then be used to post-process the binary data into a human readable form, showing the instructions executed and the machine state.

???? :          : RESET !!       : A=?? X=?? Y=?? SP=?? N=? V=? D=? I=1 Z=? C=?
Rd:   D9CD = A9
Rd:   D9CE = 40
D9CD : A9 40    : LDA #40        : A=40 X=?? Y=?? SP=?? N=0 V=? D=? I=1 Z=0 C=?
Rd:   D9CF = 8D
Rd:   D9D0 = 00
Rd:   D9D1 = 0D
Wr:   0D00 = 40
D9CF : 8D 00 0D : STA 0D00       : A=40 X=?? Y=?? SP=?? N=0 V=? D=? I=1 Z=0 C=?
Rd:   D9D2 = 78
D9D2 : 78       : SEI            : A=40 X=?? Y=?? SP=?? N=0 V=? D=? I=1 Z=0 C=?
Rd:   D9D3 = D8
D9D3 : D8       : CLD            : A=40 X=?? Y=?? SP=?? N=0 V=? D=0 I=1 Z=0 C=?
Rd:   D9D4 = A2
Rd:   D9D5 = FF
D9D4 : A2 FF    : LDX #FF        : A=40 X=FF Y=?? SP=?? N=1 V=? D=0 I=1 Z=0 C=?
Rd:   D9D6 = 9A
D9D6 : 9A       : TXS            : A=40 X=FF Y=?? SP=FF N=1 V=? D=0 I=1 Z=0 C=?
Rd:   D9D7 = AD
Rd:   D9D8 = 4E
Rd:   D9D9 = FE
Rd:   FE4E = 80
D9D7 : AD 4E FE : LDA FE4E       : A=80 X=FF Y=?? SP=FF N=1 V=? D=0 I=1 Z=0 C=?
Rd:   D9DA = 0A
D9DA : 0A       : ASL A          : A=00 X=FF Y=?? SP=FF N=0 V=? D=0 I=1 Z=1 C=1
Rd:   D9DB = 48
Wr:   01FF = 00
D9DB : 48       : PHA            : A=00 X=FF Y=?? SP=FE N=0 V=? D=0 I=1 Z=1 C=1
Rd:   D9DC = F0
Rd:   D9DD = 09
D9DC : F0 09    : BEQ D9E7       : A=00 X=FF Y=?? SP=FE N=0 V=? D=0 I=1 Z=1 C=1

Capturing data with Sigrok

The open source Sigrok software includes support for the FX2 analyzer.

Sigrok builds are available on Windows, Linux and MacOS.

Here'e an example sigrok-cli command:

sigrok-cli -d fx2lafw --config samplerate=12MHz -o data.bin -O binary --continuous 

To limit the number of channels, add:

--channels D0,D1,D2,D3,D4,D5,D6,D7

To capture a fixed number of samples, e.g. 10 million, replace --continuous with

--samples 10M

To trigger on one of the inputs, e.g. the rising edge of D14 (normally connected to nRST):

--trigger D14=r

When capturing with Sigrok, the FX2 analyzer always samples data using it's own internal clock. So data bus samples are asynchronous to the microprocessor data bus. Consequently, it's necessary to sample at a much higher frequency than the microprocessor clock (over-sampling).

There is no hard and fast rule as to what over-sampling factor is necessary for a reliable instruction trace. This is actually system dependent, and depends on how long the 6502 data bus is stable before the falling edge of Phi2. In a BBC micro, with a 2MHz 6502, it's typically necessary to sample at 12MHz to get an error-free trace.

Capturing data with fx2pipe

fx2pipe is an an open source project developed by Wolfgang Wieser. The original web page is here: http://www.triplespark.net/elec/periph/USB-FX2/software/fx2pipe.html

When capturing with fx2pipe there is more flexibility in how the FX2 analyzer is configured. It's possible to configure the FX2 analyzer to capture data using an external clock. Capturing on either the positive or negative edge is possible.

I would recommend using the version of fx2pipe in the 6502Decoder repository, as this has a couple of improvements on the original. https://github.com/hoglet67/6502Decoder/tree/master/fx2pipe

Note: fx2pipe relies on an older version of libusb: libusb-0.1 - it will NOT work with libusb-1.0, nor with libusb-compat-0.1.

To build fx2pipe:

cd 6502Decoder/fx2pipe
./configure
make
sudo make install

This will install fx2pipe to /usr/local/bin

There are two modes supported by fx2pipe that allow the use of an external clock:

Slave FIFO asynchronous write

The external clock is connected to the RDY1 input of the FX2 (please note, on the Geeetech board the RDY0 and RDY1 labels are swapped).

The following command line is used:

fx2pipe -a > data.bin

With the (modified) version of fx2pipe in this repository, this will capture on the falling edge of the clock. To capture on the rising edge, you need to add --ifclk=i to invert the sense of the clock.

To use this mode, the inputs of the FX2 analyzer should be connected as follows:

  • PB7..0 are the lower 8 bits of data input
  • PD7..0 are the upper 8 bits of data input (16 bit wide mode only)
  • IFCLK z
  • RDY0 (SLRD) tie to 3V3 with a 1K resistor
  • RDY1 (SLWR) is the external clock, which should be less than 7MHz
  • PA2 (SLOE) tie to 3V3 with a 1K resistor
  • PA4 (FIFOADR0) tie to GND a 1K resistor
  • PA5 (FIFOADR0) tie to 3V3 with a 1K resistor

It's best to explicitely tie these pins to GND/3V3 via resistors, as many of the pins are bidirectional. That said, I generally omit the pullups (as unconnected inputs seem to float high), and make the connections to GND directly.

Slave FIFO synchronous write

The external clock is connected to the IFCLK input of the FX2.

The following command line is used:

fx2pipe -s -ifclk=xi > data.bin

This will capture on the falling edge of the clock. To capture on the rising edge, you need to use --ifclk=x to invert the sense of the clock.

To use this mode, the inputs of the FX2 analyzer should be connected as follows:

  • PB7..0 are the lower 8 bits of data input
  • PD7..0 are the upper 8 bits of data input (16 bit wide mode only)
  • IFCLK is the external clock, which must be between 5MHz and 48MHz
  • RDY0 (SLRD) tie to 3V3 with a 1K resistor
  • RDY1 (SLWR) tie to GND (if -ifclk=xi) or 3V3 (if -ifclk=x) with a 1K resistor
  • PA2 (SLOE) tie to 3V3 with a 1K resistor
  • PA4 (FIFOADR0) tie to GND a 1K resistor
  • PA5 (FIFOADR0) tie to 3V3 with a 1K resistor

It's best to explicitely tie these pins to GND/3V3 via resistors, as many of the pins are bidirectional. That said, I generally omit the pullups (as unconnected inputs seem to float high), and make the connections to GND directly.

In practice the maxiumum clock speed is limited by the USB-2 transfer rate, and the data width. In 16-bit mode the limit appears to be 20MHz. In 8-bit mode the limit is 40MHz. This value is also likely to depend on the speed of the host.

LCSoft Mini board details

References:

The jumper J1 connects the A0 input of the EEPROM to VCC:

  • when the jumper is fitted, the USB Vendor/Product ID is read from the EEPROM
  • when the jumper is missing, the USB Vendor/Product ID defaults to 04b4:8613.

I prefer to remove this jumper, as the contents of the EEPROM are supplier specific, and can affect the operation of the board. However, the default ID 04b4:8613 is often claimed by a diagnostic module called usbtest, which prevents fx2pipe working. So you need to make sure the usbtest module is blacklisted by your kernel. On Ubuntu, you add the following line to /etc/modprobe.d/blacklist.conf

# The USBtest module, interferes with fx2pipe
blacklist usbtest

Geeetech board details

References:

There are a number of differences between the Geeetech and LCSoft boards:

Connector Differences:

  • There is one connector pin that is 3V3 on the LCSoft board, and GND on the Geeetech board. If you are designing an adapter for the FX2 board, it's best to leave tis pin unconnected.
  • There is an error on the silk-screen: the labels RDY0 and RDY1 are swapped. So the external clock needs to be connected to the pin labelled RDY0, not RDY1. This pin is in the same physical position on both board.

Jumper J1 on the Geetech board connects the anodes of LEDs D1/D2 to 3.3. These LEDs are connected to PA0 and PA1. The setting og this jumper should not matter.

Jumper J2 connects the A0 input of the EEPROM to GND:

  • when the jumper is missing, the USB Vendor/Product ID is read from the EEPROM
  • when the jumper is fitted, the USB Vendor/Product ID defaults to 04b4:8613.

This jumper must be fitted, otherwise captures from fx2pipe will not work. We don't currently understand what configuration data in the EEPROM is interfering with fx2pipe. But user gfoot on 6502.org found this was indeed the case. See [here](

References

Clone this wiki locally