TOP Contributors

  1. MIKROE (2642 codes)
  2. Alcides Ramos (348 codes)
  3. Shawon Shahryiar (307 codes)
  4. jm_palomino (112 codes)
  5. Chisanga Mumba (90 codes)
  6. S P (73 codes)
  7. dany (71 codes)
  8. MikroBUS.NET Team (35 codes)
  9. NART SCHINACKOW (34 codes)
  10. Armstrong Subero (27 codes)

Most Downloaded

  1. Timer Calculator (136227 times)
  2. FAT32 Library (69498 times)
  3. Network Ethernet Library (55712 times)
  4. USB Device Library (45997 times)
  5. Network WiFi Library (41640 times)
  6. FT800 Library (40804 times)
  7. GSM click (28789 times)
  8. PID Library (26333 times)
  9. mikroSDK (26061 times)
  10. microSD click (25148 times)
Libstock prefers package manager

Package Manager

We strongly encourage users to use Package manager for sharing their code on Libstock website, because it boosts your efficiency and leaves the end user with no room for error. [more info]

< Back
Project

USB FPGA programmer

Rating:

5

Author: VCC

Last Updated: 2016-02-19

Package Version: 1.3.0.0

Category: Bootloaders

Downloaded: 2643 times

Followed by: 4 users

License: MIT license  

The project is a Xilinx Spartan-3(E) and Spartan-6 FPGA programmer made with PIC18F4550 using USB. There are two host applications: a HID one and a CDC one, written in Delphi.
Added support for Delphi XE5.

No Abuse Reported

Do you want to subscribe in order to receive notifications regarding "USB FPGA programmer" changes.

Do you want to unsubscribe in order to stop receiving notifications regarding "USB FPGA programmer" changes.

Do you want to report abuse regarding "USB FPGA programmer".

  • Information
  • Comments (2)

Project Blog

Features:
- Xilinx Spartan-3(E) and Spartan-6 FPGA programmer
- PIC microcontroller for USB communication and FPGA configuration
- USB protocol: CDC or HID
- Uses PIC ports for JTAG communication (only 4 pins)
- Separate Delphi projects for CDC and HID communication
- Tested on XC3S100E and XC6SLX16 FPGAs
- Tested with PIC18F4550 and PIC18F46J50
Features in v1.3:
- Recompiled with mikroPascal v6.0.1
- The programmer ignores FPGA revision number
- FPGA constants are moved into FPGAConsts.mpas unit
- Added "Read ID code" feature
- Added "Blink LED" feature for debug purposes
Project - libraries requirements
- The mikroPascal and Delphi binaries are included
- USB_CDC_ProjectItems.mpas and USB_HID_ProjectItems.mpas are also included for VID and PID declarations
- 3rd party units and drivers (not included in archive):
- for mikroPascal: BitUtils.mcl, StrngUtils.mcl, USB_CDC_Library.mcl, USB_HID_Library.mcl.
- for Delphi: WinCom.pas
- for Windows: usbser.sys, usbser.inf
- 3rd party units source: http://www.rosseeld.be/DRO/PIC/ and http://www.libstock.com/
- The included binaries are generated by mikroPascal v6.0.1 for mpas files and Turbo Delphi 2006 for WinCom.pas.
JTAG cable
- 1 x SN74HC04 IC
- 3 x (220R to 2.2K) resistors
- If JTAG power supply voltage is less than 3.3V for a 5V PIC, a voltage translator is needed from last device to PIC microcontroller.
- A 3.3V PIC does not need any voltage translator if connected near the JTAG chain, e.g. the same board.
- If using a 5V PIC, the TDO (input) pin must be TTL to recognize the logic "1" state from 3.3V FPGAs.
Warnings
- There is no handling for USB connection interruptions, hardware failures or other kind of failures.
- Do not plug out the USB cable while the Windows host app is running! This can block the app.
- Do not use USB mice at the same time you use the FPGA programmer on HID version! (the provided Windows application is not compatible with USB mice on some computers)
- The user should manually modify USBprotocol library to include only one of the two HID or CDC libraries.
Miscellaneous
- The CDC version is 4 times faster than the HID one.
- The PIC microcontroller is powered from USB.
- The JTAG cable (with its HC04 chip) is powered from FPGA board. If the voltage for this power supply voltage is below 3.3V (e.g. 2.5V), a voltage translator (to 5V) is needed from last device in the JTAG chain to the microcontroller TDO line. Since a PIC18F4550 can drive only 25mA on a pin, the number of JTAG devices is limited (TMS and TCK lines are common to all JTAG devices).
- Two hex files are included (one for HID and the other for CDC).

FPGA programmer with PIC18F4550 on breadboard

FPGA programmer with PIC18F4550 on breadboard

Notice the HC04 chip near the FPGA.

View full image

 

The added Delphi part of the project is compatible with Delphi XE5.

ALSO FROM THIS AUTHOR

DynTFT Color Themes

0

DynTFT Color Themes are a collection of inc files with color constants, usable by DynTFT components.

[Learn More]

PIC32MZ EF Osc Calc

1

This is a calculator for PIC32MZ EF oscillator frequencies.

[Learn More]

Resolver connected to AD2S1200 decoder with CmodA7 board

0

ResolverAD2S1200DecA7 is a hardware + software project, which uses AD2S1200 chip, to interface with a resolver, for motor control applications. To talk to the AD2S1200 chip, the Digilent's CmodA7 board is used.

[Learn More]