Wednesday, 24 January 2018

programmable logic - What are my less expensive options for getting started with CPLDs



I would like to goof around with some CPLD stuff and I see I have a couple options out there. I don't have a particular application in mind; it just seems like there a lot of possibilities, some of which are easier to use than others.


The main manufactures have development boards, some more expensive than others. They also have programmer cables that generally seem... not cheap. Doing some digging, I've come across several options and I'm looking to understand the pros/cons of each.



  1. Is it fair to say that CPLDs with X Macrocells are more or less the same?

  2. Although the JTAG interface is standard, for the purposes of programming the part, there is no standard previous JTAG Question. Is this a matter of the vendor software talking to the programmer? Do things become more standard if I use some other utility to dump a binary file?


  3. Some of the platforms have cheaper alternatives. I'm wondering what the catches are with these in terms of USB/parallel port, Linux/Windows.

  4. Assuming I get comfortable with a development board, how difficult is the transition to just using one of the base parts directly? My impression is that in the major options, it's just a matter of some header pins and a couple diodes/resistors. Am I far off on this?

  5. How would I program the devices in my own designs? If I have a development board or starter kit, will I then have to go back and buy an expensive programmer? Why does a dev board sell for cheap but the programmer runs hundreds of dollars? Presumably the dev board comes with the ability to program.


Here are some of the options that stand out for me. I list the prices only to differentiate them from the multi-hundred-dollar options. All of them are in the ballpark for me. I'm looking for the hiden costs in terms of ease of use, software issues and so on.


Xilinx is a popular path. I could do:



The Digilent cable requires using their software which is currently windows only, so I'd need to go the $48 USB route.


Another Xilinx possibility is




Switching companies to Lattice:



I like the idea of using Lattice parts as Mouser.com carries them (I don't see much Xilinx there). I tend to order more from them. Once I get comfortable with their stuff, I'm guessing that I could hack up a programmer cable based on the schematics of this board. It looks really straight forward. Could I use the eval board as a programmer? The do expose the JTAG header?


The Lattice MachXO2 Pico kit ($29) also looks to be a great value, though the part that it's showcasing is more expensive.


Altera also has good offerings.



  • A programmer can be had from EBay for ($15)

  • A demo board can be had from EBay for ($28)


Alternately, Altera has




  • A starter kit for ($50)


Which of these is the better route for a beginner that is easier to get working (drivers and such), has some staying power, and perhaps offers the most flexibility?




No comments:

Post a Comment

arduino - Can I use TI's cc2541 BLE as micro controller to perform operations/ processing instead of ATmega328P AU to save cost?

I am using arduino pro mini (which contains Atmega328p AU ) along with cc2541(HM-10) to process and transfer data over BLE to smartphone. I...