FPGA Based E/EPROM Programmer

Slides:



Advertisements
Similar presentations
Xilinx CPLDs and FPGAs Module F2-1. CPLDs and FPGAs XC9500 CPLD XC4000 FPGA Spartan FPGA Spartan II FPGA Virtex FPGA.
Advertisements

EXTERNAL COMMUNICATIONS DESIGNING AN EXTERNAL 3 BYTE INTERFACE Mark Neil - Microprocessor Course 1 External Memory & I/O.
Implementing Logic Gates and Circuits Discussion D5.1.
Implementing Logic Gates and Circuits Discussion D5.3 Section 11-2.
The Spartan 3e FPGA. CS/EE 3710 The Spartan 3e FPGA  What’s inside the chip? How does it implement random logic? What other features can you use?  What.
Registers  Flip-flops are available in a variety of configurations. A simple one with two independent D flip-flops with clear and preset signals is illustrated.
Programmable logic and FPGA
Introduction to Field Programmable Gate Arrays (FPGAs) COE 203 Digital Logic Laboratory Dr. Aiman El-Maleh College of Computer Sciences and Engineering.
Multiplexers, Decoders, and Programmable Logic Devices
Introduction to FPGA and DSPs Joe College, Chris Doyle, Ann Marie Rynning.
Introduction to Computing: Lecture 4
Section II Basic PLD Architecture. Section II Agenda  Basic PLD Architecture —XC9500 and XC4000 Hardware Architectures —Foundation and Alliance Series.
Computers Are Your Future Eleventh Edition Chapter 2: Inside the System Unit Copyright © 2011 Pearson Education, Inc. Publishing as Prentice Hall1.
GRECO - CIn - UFPE1 A Reconfigurable Architecture for Multi-context Application Remy Eskinazi Sant´Anna Federal University of Pernambuco – UFPE GRECO.
Programmable Logic Devices
Field Programmable Gate Arrays (FPGAs) An Enabling Technology.
Basic Sequential Components CT101 – Computing Systems Organization.
ESS | FPGA for Dummies | | Maurizio Donna FPGA for Dummies Basic FPGA architecture.
Programmable Logic Devices
Introduction to the FPGA and Labs
This chapter in the book includes: Objectives Study Guide
ETE Digital Electronics
Programmable Logic Devices
Sequential Programmable Devices
Sequential Logic Design
Atmega32 Architectural Overview
Topics SRAM-based FPGA fabrics: Xilinx. Altera..
Computer Hardware – System Unit
MEMORY DEVICES, CIRCUITS, AND SUBSYSTEM DESIGN
Random access memory Sequential circuits all depend upon the presence of memory. A flip-flop can store one bit of information. A register can store a single.
Complex Programmable Logic Device (CPLD) Architecture and Its Applications
Recap DRAM Read Cycle DRAM Write Cycle FAST Page Access Mode
Microprocessor Systems Design I
Microcontroller Based Digital Code Lock
XILINX FPGAs Xilinx lunched first commercial FPGA XC2000 in 1985
Random access memory Sequential circuits all depend upon the presence of memory. A flip-flop can store one bit of information. A register can store a single.
Memory Systems 7/21/2018.
DIGITAL CALCULATOR USING 8051
ECE 4110–5110 Digital System Design
Memory Units Memories store data in units from one to eight bits. The most common unit is the byte, which by definition is 8 bits. Computer memories are.
Electronics for Physicists
This chapter in the book includes: Objectives Study Guide
Maintaining Data Integrity in Programmable Logic in Atmospheric Environments through Error Detection Joel Seely Technical Marketing Manager Military &
Chapter 11 Sequential Circuits.
Introduction to Microprocessors and Microcontrollers
Interfacing Memory Interfacing.
History of Embedded Systems
Field Programmable Gate Array
Field Programmable Gate Array
Field Programmable Gate Array
We will be studying the architecture of XC3000.
Chapter 13 – Programmable Logic Device Architectures
The Xilinx Virtex Series FPGA
XC4000E Series Xilinx XC4000 Series Architecture 8/98
Semiconductor Memories
MICROPROCESSOR MEMORY ORGANIZATION
PLC Hardware Components.
MICROPROCESSOR MEMORY ORGANIZATION
Programmable Logic- How do they do that?
8051 Micro Controller.
part 2: implementation, analysis & design
The Xilinx Virtex Series FPGA
EECE.3170 Microprocessor Systems Design I
Random access memory Sequential circuits all depend upon the presence of memory. A flip-flop can store one bit of information. A register can store a single.
Electronics for Physicists
"Computer Design" by Sunggu Lee
Implementing Logic Gates and Circuits
FPGA’s 9/22/08.
♪ Embedded System Design: Synthesizing Music Using Programmable Logic
Programmable logic and FPGA
Presentation transcript:

FPGA Based E/EPROM Programmer By: Jeremy Cooke With Advisor: Dr. Izadi

Presentation Overview Definitions Project Goals Technologies Used Hardware Design Software Design Problems and Solutions Conclusions

Definitions E/EPROM Programmer FPGA A device that can read and write the contents of a variety of non-volatile memory chips FPGA Field Programmable Gate Array, a programmable logic device

Project Goals Design and develop an E/EPROM programmer Explore advanced digital logic techniques Learn modern FPGA design techniques Mix analog and digital circuitry Interface hardware with Windows based software Parallel port interfacing techniques Communications protocol development and implementation

Technologies Used Field Programmable Gate Array Analog Circuitry Digital core Analog Circuitry Power Subsystem Windows Based Software Programming in Visual C++ 6.0

Hardware Design Hardware broken into separate analog and digital sections Digital hardware Based around an FPGA core Handles control and coordination of all other components Controlled by Personal Computer over parallel port Analog Hardware (Internal Power Supply) Used for voltage regulation and control Based around DC-DC converter and adjustable voltage regulators Controlled by FPGA

Hardware Block Diagram Windows Application Software Memory Device Switching System Personal Computer FPGA Core Power Supply Volatile Circuit

XC4010XL Field Programmable Gate Array Xilinx FPGA Excellent for complex digital systems PROM required for non-volatile operation XC4010XL Field Programmable Gate Array Logic Cells 950 System Gates 7-20K Max RAM Bits 12,800

XC4000 Architecture Programmable Interconnect I/O Blocks (IOBs) Configurable Logic Blocks (CLBs)

XC4000 Configurable Logic Blocks D Q SD RD EC S/R Control 1 F' G' H' DIN H Func. Gen. G F G4 G3 G2 G1 F4 F3 F2 F1 C4 C1 C2 C3 K YQ Y XQ X H1 DIN S/R EC 2 Four-input function generators Look Up Tables 2 Registers Each can be configured as Flip Flop or Latch

Look Up Tables Combinatorial Logic is stored in 16x1 SRAM Look Up Tables (LUTs) in a CLB Example: Look Up Table 4-bit address A B C D Z 0 0 0 0 0 0 0 0 1 0 0 0 1 0 0 0 0 1 1 1 0 1 0 0 1 0 1 0 1 1 . . . 1 1 0 0 0 1 1 0 1 0 1 1 1 0 0 1 1 1 1 1 4 (2 ) Combinatorial Logic A B C D Z 2 = 64K ! Capacity is limited by number of inputs, not complexity

XC4000 I/O Block Diagram T/OE O OK (Output Clock) I 1 I 2 CE IK (Input Vcc Slew Passive Rate Pull-Up, Control Pull-Down T/OE O D Q Output Pad Buffer OK (Output Clock) I 1 Input I 2 Buffer Q D Delay CE IK (Input Clock)

Xilinx FPGA Routing Fast Direct Interconnect – CLB to CLB General Purpose Interconnect – Uses switch matrix CLB Switch Matrix

What's in the chip? Programmable Interconnect Points, PIPs (White) Routed Wires (Blue) Switch Matrix Direct Interconnect (Green) CLB (Red) Long Lines (Purple)

How did I use the FPGA? Used to implement my core digital logic design As opposed to manually wiring discrete components Use made design more modular and easy to understand Memory Switching PC FPGA Power

Internal FPGA Circuitry

FPGA External Connections Memory Data Lines Parallel Port Address Lines Control Lines Voltage Lines

E/EPROM Considerations For most EPROM types there are corresponding EEPROMs of the same size, density, and compatible chip configuration Allows for easier support for both technologies

E/EPROM Considerations Usually require 2 voltage levels : Vcc and Vpp Vpp usually 12 volts or higher Special erasing procedures UV Light for example EEPROM Usually require only 1 voltage level : Vcc Erase/Write procedure often as simple as a static RAM device

Digital Level Shifting Power Supply DC-DC Converter 5V to 28V Vpp Level Selector Vcc Level Vpp Out 5V In 28V Control Lines Vcc Out

Power Supply Board Layout

Power Supply Programmer’s Model

Memory Device Voltage Requirements Chip Type Size Vcc (v) Vpp (v) 2716 EPROM 2k*8 5 25 2764 8k*8 6 21 27128 16k*8 21/12.5 27256 32k*8 12.5 27512 64k*8 2816 EEPROM NA 2864 28256 28512 28010 128k*8 28040 512k*8

Power Supply Calculations Simple 2 Resistor Configuration: R1 = R*(Vout/Vref-1) * In my design R is the parallel combination of resistors Power Supply Calculations

EPROM Comparison -- Pinout

EEPROM Comparison -- Pinout

ZIF Socket – Connection to Memory Zero Insertion Force Socket for memory device to be accessed Pinout designed to accommodate large variety of chip types Most pins connected directly to FPGA Special pins connected to switch interface

Switch Interface For Special Pins 7 Pins in ZIF socket must be handled specially They can be a specific analog signal or a specific digital signal depending on the memory device DIP switches used rather than automated circuitry to reduce complexity

Software Design Software was created using Visual C++ Program structure in terms of objects, not just C under C++ This development environment allowed me to create: software in an object oriented manner an easy to use user interface a professional looking final product in minimal time

Software Design Bottom up design process Encapsulate hardware interface routines lowest level Create software API Middle level of abstraction Create Application Software Top level

Software Design This design process enabled me to test and debug the hardware on its lowest level first. Then I built upon working routines while creating the application software. Hardware interfacing was less of a concern at this point because all routines have already been created and debugged.

Software Design – Objects ChipProg Object – Low Level Initialize/maintain communication with hardware Configure hardware for specific memory devices Set/Clear IDB Send and receive data Send address and control signal information Set all voltage levels ChipAPI Object – Software API Inherits functionality from ChipProg Read Byte(s) from specific addresses and ranges Write Byte(s) to specific addresses and ranges

Software Design – Objects Application ChipAPI Object Read Bytes individually or in blocks from specific memory locations Write Bytes individually ChipProg Object Initialize Hardware Modify Internal Data Bus (FPGA) Set Vpp and Vcc to specific levels Turn Vpp and Vcc on and off Set Address Information Set/Get Data Information Set Control Lines

Software Design – Hardware Testing Using the ChipProg object as interface to the hardware, I created a simple application to test features of the hardware: Then I wrote the final application software after all of the basic hardware functions seemed to work properly under software control

Application Software Memory chip reading and writing utility Read data into an internal buffer from: Memory device Or binary file Write to memory

Application Software First a user must select the appropriate memory device Then reading and writing options are enabled There are currently 2 memory types supported: Microchip 28C64A Generic 27128 Dialog box indicates technical information

Application Software The read memory function allows the user to read a specific address range from the memory device After reading is complete, the information is stored in an internal buffer, displayed in ASCII and hexadecimal, and the user may save it as a binary file The write memory function writes what is currently in the internal buffer to the memory device.

Application Software The memory buffer can be exported or imported to and from a memory file The current format is raw binary I plan to support the Motorola S-Record format in the future Simple buffer operations supported Fill with value Clear

Problems Insufficient pins on FPGA for all functions Forced manual solution for switching section Interference from FPGA evaluation board Timing to ms resolution difficult on PC Hard to coordinate control signal timing correctly Control related feedback not available Sometimes results in errors during block writes

Possible Improvements Use FPGA without evaluation board and more pins Design FPGA logic solely with VHDL Abandon limiting idea to use discrete logic chips Utilize a microcontroller Accurate timing Better communication with PC USB More information Intelligent device Remove DIP switches and use automated analog switching solution Analog MUX

Possible Improvements PC mC Power FPGA Memory Switching

Conclusions This project utilized advanced digital logic techniques Design and debug of FPGA based systems Current industry practice Implementation of a mixed voltage level system Common requirement in transition to low power systems As well as a mixed analog/digital system

Idea System Conclusions Design process for the hardware was a top-down approach Began with vague requirements and an idea of an end product Gradually broke ideas down into manageable components Implemented/debugged each component separately Combined to create the final hardware system

Conclusions System Application Hardware Driver Routines System Requirements For Control Conclusions Application Design process for the software was a bottom-up approach Hardware already developed so I knew what routines it required for control Wrote those, encapsulating hardware with a low-level object Wrote a higher level software object wrapper hiding all low- level hardware interfacing details from application level software Wrote hardware testing software as well as general application software based on hardware interface routines

Special Thanks Dr. Izadi - Senior Project Advisor Professor Otis Information and help regarding all aspects of FPGA based system design General hardware/software design advice Continued support through all phases of my project Professor Otis Support and advice on microprocessor and microcontroller based system design and interfacing details As well as gave general advice throughout the life of my project