Continue to Site

Welcome to EDAboard.com

Welcome to our site! EDAboard.com is an international Electronics Discussion Forum focused on EDA software, circuits, schematics, books, theory, papers, asic, pld, 8051, DSP, Network, RF, Analog Design, PCB, Service Manuals... and a whole lot more! To participate you need to register. Registration is free. Click here to register now.

Open Source Universal 48 pin programmer design

Status
Not open for further replies.

picman100

Junior Member level 2
Junior Member level 2
Joined
Oct 11, 2011
Messages
21
Helped
10
Reputation
20
Reaction score
10
Trophy points
1,283
Activity points
1,457
Hi, i have designed a 48 pin universal programmer but need help finishing it off, is anyone up for the challange?

Programmer info:
LPC2388 ARM7TDMI CPU with USB
2XDC/DC Converters
48 universal pin drivers which can be either GND/VCC/VPP/HI,LO/CLOCK/INPUT
Smart card interface
ISP socket which is used for JTag for FPGA's/CPLD/ARMs Anything JTag... /serial programming devices mounted on a board Pic's/AVR's etc/In car Dashboards/ECU's etc
USB Interface
Ethernet Interface
SD card
LCD
Serial interface
Buttons/switches lights etc
JTAG For ARM
JTAG for FPGA
Soft JTAG for FPGA

100_5193.JPG

This is really a massive project and has taken me a while to get this far, i think i need help to finish it.




The software is written in delphi:

programmer.PNG


testpin.PNG

USB Uses CDC So can be used on any PC.

So far i can read and write to all pins fine, program the FPGA, etc

There are three parts to the programmer.
Firmware:
Written in C using Keil compiler.
FPGA:
Designs are done in Altium.
PC Software:
Written in Delphi 7

I am very good with the firmware, and not bad with the FPGA, the PC software is not good for me...

I want the software, fpga designs and the firmware to be OPEN SOURCE, this was the idea behind it, as you cannot by a good true universal programmer for less than around £500 i thought it would be a good project to undertake, with the added benefit of a smart card programmer and ISP it should be a good device, and hoping to ship it for less than £100

So if you are up for a challange let me know......

Many Thanks....
Picman....;-)


Programmer Schematics....

The PSU for VCC and VPP need changing does not work too well, but i think it would be good to only need the 5V from the USB to power the programmer, so DC/DC converters are needed to get VPP.
 

Attachments

  • programmer.pdf
    3 MB · Views: 530
Last edited:

Great
I was also thinking of starting this type of project. but I think FPGA is not for diy if we can remove it is it possible to design the programmer may be for less chip support.
 

The FPGA is key to the programmers functionallity, even if you just use it to route pins to the micro so using it as a pin matrix. but you can do a lot more with it there, as it is, it will program most programmable devices on the market.
I am fine with coding the verilog for the fpga anyway..
 

hi,my friend
I am interested in your programmer. I am also a programmer for the project is open source, with the study
email:libyoufer@sina.com
qq:28000622
my site:**broken link removed**
But the language is in Chinese
welcome
 

What about replacing fpga with cpld? You can get those in packages like qfp44. This would somewhat reduce difficulty of assemblying it at home.
 

Unfortunately there are 48 IO's from the ziff so it needs a larger package than the 44 pin, i have assembled 2 of these at home an both work fine, just takes a little time. also the ARM is 144 pins and most pins are used.
Anyway the basic idea will be to sell the boards already made, but open source the software, but i do see where you are comming from for the development.
Having 200K gates also opens up a lot more potential for doing some clever things in the fpga, and freeing the CPU from a lot of tasks. For instance a logic analyzer.....
 

If idea is to sell the board already made than large footprint FPGA is fine.

A logic analyzer is also a nice idea, but for it to have good parameters you need an external RAM chip, because the bandwidth of USB is insufficient for analyzing high speed signals.

I think that it would be nice if your device was able to switch between different compatibility mode. I mean that you could set it up to work like pickit 2 and be able to use it from MPLAB. Or set it up to work like STK500 and be able to use it from AVR studio. That would increase functionality creatly, because most people find it far more convenient to be able to operate programmer/debugger straight from IDE.

I realize that it would need enormous amount of coding and reverse engineering, but having a universal programmer with IDE compatibility would be very nice.
 

What would you use the IDE for? If its programming the ARM then there is already an IDE which i use called KEIL.
 

No, I mean the IDE which u will be using to develop software that you will later download into some device using this programmer. Or maybe I got the purpose of this device wrong?
 

To achieve 48 pin drive all, the fpga haved more than 48 io's and Dynamic reconfiguration
Firmware must be prepared to understand the hardware architecture, and sometimes have to modify the hardware design to suit the software development
I do not know the hardware architecture in the case, there is no other thing that programmers can do
If you want to do open source, then this is a must. If you do the programmer development platform is to provide a schematic
my development :
windows 2003
keil 8.16a
visual c++ 6

---------- Post added at 07:55 ---------- Previous post was at 07:13 ----------

vcc and vpp is controled ,one is dac another pwm
but the pwm is well because the cpu is’nt busy
 

Yes a Schematic will be provided, also the interface from the ARM to the FPGA is fixed, so its always the same no matter what device you program.

---------- Post added at 04:25 ---------- Previous post was at 04:22 ----------

No, I mean the IDE which u will be using to develop software that you will later download into some device using this programmer. Or maybe I got the purpose of this device wrong?

The purpose of the Programmers is a IC device programmer, like Datamans Dataman 48UXP Universal Programmer
But it can do more because it has a smart card slot, and an ISP plug and also can use ethernet and usb and serial, plus loads more....
It can also be used as a JTAG programmer/debugger etc....
 

the Programmer‘s vccx and vpp do what needs to be improved
and head3 ,How to use it? do Hand?

---------- Post added at 20:40 ---------- Previous post was at 20:16 ----------

pullup's work? i do'nt known
 

the Programmer‘s vccx and vpp do what needs to be improved
and head3 ,How to use it? do Hand?

---------- Post added at 20:40 ---------- Previous post was at 20:16 ----------

pullup's work? i do'nt known

Pullups/pulldowns work ok, VCC and VPP need to be redesigned, im not happy with them at the moment.

Whats Head3?


The power supply for vcc and vpp will be controlled by the ARM so we need some digital 3v3 way of changing the voltages on vcc and vpp.

---------- Post added at 15:39 ---------- Previous post was at 15:38 ----------

the Programmer‘s vccx and vpp do what needs to be improved
and head3 ,How to use it? do Hand?

---------- Post added at 20:40 ---------- Previous post was at 20:16 ----------

pullup's work? i do'nt known

Pullups/pulldowns work ok, VCC and VPP need to be redesigned, im not happy with them at the moment.

Whats Head3?


The power supply for vcc and vpp will be controlled by the ARM so we need some digital 3v3 way of changing the voltages on vcc and vpp.
 

i'm wrong,is “header 3”
this pic
未命名.jpg
 

how is the Pullups / pulldowns to work
I do not understand
the pullup_hi /pullup_lo signal from the arm,but U_hi,U_lo to where?
未命名.jpg
 

This is my programmable power supply
**broken link removed**
 

This is my programmable power supply
**broken link removed**

Ok what voltages can you get on vcc and vpp, what sort of range.. 0..25V and 0..5V???
And what Current?

Do you think it would work fine from 5V from USB?
If so your idea is good...

On the LPC2388 the ARM CPU we only have one DAC, so we would need an external DAC IC for your PSU to work.


Also in you PSU design what about pin 4 on the MC34063? I thought pin 4 was GND and pin 6 was VCC?????



---------- Post added at 03:07 ---------- Previous post was at 03:03 ----------

how is the Pullups / pulldowns to work
I do not understand
the pullup_hi /pullup_lo signal from the arm,but U_hi,U_lo to where?
View attachment 62730

U_hi/U_lo are just test pads on the board.

And Header 3 is just a 2 way jumper block.
 
Last edited:

Ok what voltages can you get on vcc and vpp, what sort of range.. 0..25V and 0..5V???
And what Current?

Do you think it would work fine from 5V from USB?
If so your idea is good...

On the LPC2388 the ARM CPU we only have one DAC, so we would need an external DAC IC for your PSU to work.


Also in you PSU design what about pin 4 on the MC34063? I thought pin 4 was GND and pin 6 was VCC?????



---------- Post added at 03:07 ---------- Previous post was at 03:03 ----------



U_hi/U_lo are just test pads on the board.

And Header 3 is just a 2 way jumper block.
A:
1.
vcp‘s range 1.8~6.8v
vpp’s range 1.8~25V
one step 0.1v
2.By sampling the voltage difference across the resistor to convert current
Programmable reference source and a comparator for protection
Of course, access to and control of current through the operation
3.34063
Use the datasheet of the design
I use the package who have‘nt 6 pin and 4 pin
pin4 gnd
pin6 vcc

Q?Pullups / pulldowns
How it’s work
What is the function in the end


thanks

---------- Post added at 20:05 ---------- Previous post was at 19:33 ----------

Do you think it would work fine from 5V from USB?
If so your idea is good...

usb1.1 Provide current is 500ma
usb2.0 Provide current is 1000ma
Inserted in usb1.1 port programmer to write some chips may work unstable
But basically no problem in usb2.0
Of course, the programmer also has external power connector
 

Pullups are uses as a logic 1.
So to write a 1 to the device being programmed you set the IO pin on the FPGA as HIZ or input, this will allow the Weak pullups to pull the pin to VCCX so putting a logic 1 on the pin.

The point of this is that a logic 1 is always the same as VCCX so if you want to program for example a 2.5V device then as long as VCCX is at 2.5V then the logic 1 will be the same voltage.

If we used the FPGA pin to output a 1 then this would be 3.3v, not good for a 2.5V or 5V or 1.8V device...

Do you understand now?
 

Status
Not open for further replies.

Similar threads

Part and Inventory Search

Welcome to EDABoard.com

Sponsor

Back
Top