Development of an integrated fuel management system with the aid of CPLDs by Swanepoel, S.
Development of an Integrated
Fuel Management System
with the aid of CPLDs
By
SSWANEPOEL
Study Leader: Prof Pf Bakkes
This thesis is submitted as the requirement for a Masters Degree
in Engineering at the
University of Stellenbosch
Electric and Electronic Engineering Department
UNIVERSITEIT VAN STELLENBOSCH
UNIVERSITY OF STELLENBOSCH
November 2000
Declaration
I, the undersigned, hereby declare that the work contained in this thesis is my own original
work and that I have not previously in its entirety or in part submitted it at any university for a
degree.
Signature: Date:
Stellenbosch University http://scholar.sun.ac.za
11
Abstract
The need for a locally manufactured, cost-effective, fuel management system led to the design and
development of a functional prototype.
This thesis presents the design, development and full implementation of two functional prototypes.
While field tests performed on the first prototype assisted in identifying necessary modifications, a
need for greater complexity in support hardware was also identified. In order to comply with the
cost-effective nature of the project, it was realized that this complexity could only be achieved via
the implementation of a CPLD based system. Using Altera's Maxplus II design software, the
CPLD code was synthesized according to the required specifications then simulated and analyzed
On completion of the new CPLD based system, the second prototype, one of Altera's megacore
functions is implemented and used as a substitute to an external hardware. All necessary
modifications were successfully completed and the system was installed.
Stellenbosch University http://scholar.sun.ac.za
Uittreksel
Die benodiging van 'n lokale vervaardigde, koste effektiewe brandstofbeheerstelsel het gelei tot
die ontwerp en ontwikkeling van 'n funksionele prototipe.
Hierdie tesis dek die ontwerp, ontwikkeling en volle implementasie van twee funksionele
prototipes. Terwyl toetse op die eerste prototipe gebruik is om die nodige aanpassings te
identifiseer, is daar ook besef dat daar meer komplekse hardeware onderstuening benodig word.
Om die koste effektiewe aard van die projek te handhaaf, is daar gesien dat die nodige
kompleksieteit alleenlik deur middel van die implementering van 'n 'CPLD' gebaseerde sisteem
bereik kan word.
Deur gebruik te maak van Altera se Maxplus II ontwerp sagteware, is die 'CPLD' kode met die
nodige spesifiekasies gesintiseer, gesimuleer en geanaliseer.
Na voltooing van die tweede prototiepe, die 'CPLD' gebaseerde sisteem, is een van Altera se
megacore funksies geimplementeer en gebruik as 'n plaasvervanger vir eksteme hardware. AIle
nodige aanpassings is suksesvol voltooi en die sisteem is geinstalleer.
Stellenbosch University http://scholar.sun.ac.za
: 1
Acknowledgments
Thanks be to God for providing me with the opportunity and strength required for the completion
of this thesis. I would also like to thank Prof PI Bakkes for his guidance throughout the duration
of this thesis.
A special acknowledgment to Altera for establishing the University program which allowed me the
opportunity of using their most current technology in this thesis.
Stellenbosch University http://scholar.sun.ac.za
Table of Contents
Page
LIST OF FIGURES .
LIST OF TABLES IV
IMPORTANT DEFINITIONS ................................................ V
CHAPTER I Introduction
1.1
1.2
1.3
CPLDs and Rapid Prototyping _..
Scope of the Thesis
......................... _ 2
Thesis Organization
.......................... 3
__ _.4
CHAPTER 2 Background
2.1 The Support Hardware
2.1.1 Microcontrollers
2.1.1.1
2.1.1.2
2.1.1.3
Processing Power _ 5
Peripheral Support.. . 6
Memory Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
Stellenbosch University http://scholar.sun.ac.za
2.1.2 Non-volatile ram/real-time Clock
2.1.2.1 Phantom Clock II
2.1.2.2 Battery back-up Support II
2.1.3 Dallas Touch Memory
2.1.3.1 Mobility 12
2.1.3.2 Durability 12
2.1.3.3 Reliability 12
2.1.3.4
2.1.3.5
2.1.3.6
2.1.3.7
Operation ofDS 1996 . 13
Storage Capacity . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
Parasitic Power . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
Ease of Implementation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
2.1.4 Intel 82510 Universal Asynchronous Receiver and Transmitter (UART)
2.1.4.1 Register Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
2.1.4.2 Reduced Power Consumption
2.1.5 Programmable Logic Devices (PLDs)
2.1.5.1 Configurability .
19
. 20
2.1.5.2 Programming Support. . . . . . . . . . . . . 21
2.1.5.3 Reliability. . . . . . . . . . . . . . . . . . . . . . . . 22
2.1.5.4 Cost-effectiveness. . . . . . . . . . . . . . . . . . 22
2.1.6 Optic Fibre Communication. . . . . . . . . . . . . . . . . . . . . . . . . . . 22
2.1.6.1 Reliability . . . . . . . . . . . . .. . . . . . . . . . . . .. .. 23
2.1.6.2 Safety. . . . . . . . . . . . . . . . . . . . . . . . . .. . 23
2.1.6.3 Cost-effectiveness 23
2.1.7 Radio Communication . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
2.1.7.1 Reliability. . . . . . . . . . . . . . . . . . . . . . . . . . . 24
2.1.7.2 Ease ofImplementation .
2.1.8 Microcontroller Supervisory Support
2.1.8.1 Power Monitoring Systems
2.1.9 CPLDs and FPGAs .
. . 25
.. 26
. 27
Stellenbosch University http://scholar.sun.ac.za
2.1. 10 FLEX Series CPLD Range of Altera
2.1.10.1 Performance. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
2.1.10.2 High Density Logic Integration . 30
2.1.10.3 Cost-effectiveness 31
2. 1.10.4 Development Cycle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 1
2.1.10.5 Mega-function Support 32
2.1.10.6 Jam Programming and Test Language 33
2.1.10.7 In-circuit Configurability 36
Configuration Methods
2.1.10.8 Flex 10KArchitecture 41
Logic Implementation Structure
Multivolt I/O Support
Internal tri-state Implementation
Flexible Package Options
Selection Criteria 452.1.10.9
2.2 The Support Software
2.2.1 80C 196X A96 Compiler
2.2.2 80C 196X C 196 Compiler .
..................... 45
. . 47
. 47
........... 48
2.2.3 PLD Programming Support .
2.2.4 Altera's MAX+PLUS II .
2.2.5 Microsoft Visual Basic .
2.2.6 Microsoft Visual C++ .
2.2.7 Tango Design Package .
. . . . . . 49
........ 50
50
2.2.8 Protei Design Package . 50
Stellenbosch University http://scholar.sun.ac.za
CHAPTER 3 Design of a Phase 1Micrcontroller Based System using Gate-level Logic
Components
3.1 Hardware Design
3.1.1 Intel 80C 196KC Microcontroller
3.1.1.1 Design Considerations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
3.1.1.2 Standard I/O Ports 56
3.1.1.3
3.1.1.4
3.1.1.5
Serial VO Port . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
Interrupts 63
Operating Modes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
3. 1.1.6 Timing Considerations and Calculations . . . . . . . . . . . . . . . . . . . 67
3. 1.2 Programmable Logic Devices (PLDs)
3.1.2.1 Control Signals 68
3.1.2.2 Wait State Implementation . 69
3.1.2.3 PLD Programming . . . . . . . . . . . . . . . . . . . 71
3.1.3 Intel 82510 UART
3.1.3.1 Control Signals . 72
3.1.3.2 Timing Considerations 74
3.14 Non-volatile Memory/Real-time Clock
3.1.4. 1 Phantom Clock Operation . . . . . . . . . . . . . . 76
3.1.5 Peripheral Interfaces
3. 1.5. 1 Keypad. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
3.1.5.2 Liquid Crystal Display 79
3.1.5.3 Pump Status Indicators . . . . . . . . . . . . . . . . . . . . . .. 79
3.1.54 Input/Output Signals for Pump Control 80
3.1.5.5
3.1.5.6
System Diagnostics .
Dallas Tag Communication Interface .
. 80
... 81
Stellenbosch University http://scholar.sun.ac.za
3.1.5.7 RS232 Communication Support Hardware 83
Radio Link
Optic Fiber Link
3.1.6 Supervisory Control Circuitry 86
3.1.7 Electromagnetic Interference Reduction Techniques , 87
3.1.8 Cost-effective Design Methodology 89
3.2 Software Design
3.2.1 Microcontroller Program 90
3.2.2 Generic Array Logic Program 90
3.2.2.1
3.2.2.2
3.2.2.3
3.2.2.4
Synthesis
Simulation
Software Analysis
Hardware Analysis with Logic Analyzer
3.2.3 PC Based Program for Serial Communication Link . . .... 92
3.3 Manufacture and Implementation of PHASE 1 System
3.3.1 Printed Circuit Board Design .
3.3.2 Power Supply .
. . 93
93
. 933.3.3 System Installation .
4 Commissioning and Field Tests of PHASE 1 System
3.4.1 Problems and Solutions 94
Recommendations for Improvements to PHASE 1 System 95
Stellenbosch University http://scholar.sun.ac.za
CHAPTER 4 Design of a PHASE 2 Microcontroller Based System using Complex
Programmable Logic Device Technology
4.1 PHASE 2 Hardware Design
4.2 Alterations to PHASE 1 Hardware Design
4.2.1 Memory Map 97
4.2.2 Supervisory Control Circuitry 97
4.2.3 Improved Configurability 101
4.2.4 CPLD Inclusion 101
4.2.5 JTAG with BST Implementation 102
4.2.6 Peripheral Upgrades .- 102
4.2.7 Flexible Timing Design 103
4.2.8 Electromagnetic Interference Reduction Techniques 103
4.2.9 Power Analysis and Optimization 103
4.2.10 Cost-effective Design Methodology 106
4 3 The CPLD Implementation into PHASE 2 Design
4.3. 1 Design Methodology using the Hierarchal Interface
4.3. 1.1 Graphical User Interface .
4.3.1.2 Text Definition Files
106
107
107
4.4
4.3. 1.3 Symbol Files .
Design Methodology using the EPFI0K10TC(144)
4.5 Bi-directional Tri-state Bus Implementation into the EPFIOKIOTC(144) 109
4.6 The a16450 MegaCore Function 110
4.7 Synthesis and Routing of the EPF 1OKTC(144)' s Internal Design . 1 1 1
4.8 Simulation of the EPFI0KI0TC(144) and EPFI OK20TC(144),s Internal Design. III
Stellenbosch University http://scholar.sun.ac.za
4.9
4.10
System analysis of the EPFI0KI0TC(144) and EPFI0K20TC(144) CPLDs
Cascaded PHASE 2 CPLD Configuration on Power Up .
4. 11 Manufacture and Implementation of PHASE 2 System
4. 11. 1 Printed Circuit Board Design .
4.11.2 System Installation .
CHAPTERS Conclusions, Recommendations and Future Work
111
III
112
112
5.1 Conclusions .... , . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. 113
. 5.2
5.3
Recommendations .
Future Work .
114
114
BffiLIOGRAPHY . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115
Stellenbosch University http://scholar.sun.ac.za
APPENDIX A-I:
APPENDIX A-2 :
APPENDIXB
APPENDIX C-I :
APPENDIX C-2 :
APPENDIXD
APPENDIXE
APPENDIXF
APPENDIXG
APPENDIXH
APPENDIX I
APPENDIX J-I
APPENDIX J-2
APPENDIXK
APPENDIXL
APPENDIXM
APPENDIXN
APPENDIX 0
APPENDIXP
APPENDIXQ
APPENDIXR
APPENDIXS
APPENDIXT
APPENDIX U
APPENDIXV
APPENDIX X
System Bus Timing .
Timing Analysis of the 80C 196KC System Board .
80C196KC 68 Pin PLCC Package .
Memory Map for Peripheral Outputs .
Memory Map of PHASE 1 and PHASE 2 Control Signals .
Intel 82510 UART Register Map .
Phantom Clock Control Sheet .
LCD Control Data .
Schematic of Dallas Tag Communication Interface .
Schematic and PCB of Optic Fiber Communication Board .
80C 196KC Microcontroller Source Code .
VHDL Code for PHASE 1 GAL 1 Design .
VHDL Code for PHASE 1 GAL 2 Design
Host Machine Communication Software .
PHASE 1 Design Schematics .
PHASE 1 Design PCBs .
PHASE 2 Design's Graphical User Interface Files .
PHASE 2 Design's Text Definition Files .
Synthesis of the FLEX 10Ks Internal Design .
Routing of the FLEX 10Ks Internal Design .
Simulation of the FLEX 10Ks Internal Design .
Software Timing Analysis Results using MAX +PLUS II .
Hardware Timing Analysis using the Logic Analyzer .
PHASE 2 Design Schematic and PCBs .
Complete Memory Map of DS 1991 Touch Memory Device
Complete Memory Map of DS 1994 Touch Memory Device
Stellenbosch University http://scholar.sun.ac.za
t :
List of Figures
Figure 2.1
Figure 2.2
Figure 2.3a
Figure 2.3b
Figure 2.4
Figure 2.5a
Figure 2.5b
Figure 2.6a
Figure 2.7a
Figure 2.7b
Figure 2.8
Figure 2.9
Figure 2.10
Figure 2.11
Figure 2.12
Figure 2.13
Figure 2.14
Figure 2.15
Figure 2.16
Figure 2.17a
Figure 2.17b
Figure 2.18
Page
A Block Diagram of the 80C 196KC Microcontroller 6
Major Memory Partitions 8
Reserved Memory Locations . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
Register Files of the 80C196KC 10
Dallas Touch Memory Module 12
64-Bit Lasered ROM . . . . . . . . . . . . . . . . . . . .. . . . . . . . 13
l-Wire CRC Generator .
Memory Function Flow Chart .
DS 1996 Memory Map .
DS 1996 Address Registers .
Internal Structure of the Dallas Touch Memory .
Moore Machine Design .
Moore Machine with Clocked Output 21
13
15
16
16
18
.. 20
Optic Fiber Communication Hardware ..
Radio Communication Hardware ...
Altera's CMOS Logic Product Range
22
............. 24
. . . . . . . . . . . . . . . . . 28
Architectural Structures of CPLDs and FPGAs ............. 29
Figure 2.19
MAX +PLUS II Development Cycle .... . . . . . . 31
Flow Diagram of Altera's JAM System . . . . . . . . . . . . . . . . 33
IEEE Std. 1149.1 Boundary Scan Testing 34
Boundary Scan Testing Layout 35
JTAG Programming and Configuration with the Byte
Blaster 36
Timing Diagram for Configuration of FLEX 10K Device 38
Stellenbosch University http://scholar.sun.ac.za
! I
Page
Figure 2.20 Pin Connections for Configuration of FLEX 10K
Device/s using an EPROM 39
Pin Connections for Configuration of FLEX lOK
Device/s using the Byte Blaster 40
Diagram ofInternal Structure of FLEX 10K Device 43
BSO Tasking's Application Development Process 46
Warp's Application Development Process 47
MaxPlus II Development Cycle 48
Block Diagram of the PHASE 1Microcontroller-based
System 51
Photograph of the PHASE 1Microcontroller-based
System 52
Chip Configuration Register 53
80C 196KCs Horizontal Windows 54,55
80C 196KC Input/Output Control Registers . . . . . . . . . . . . . 56
80C196KC Port Registers 57,58
PHASE 1 Design Port Connections . . . . . . . . . . . . . . 59
Control Registers for Serial Communications Port 6 I
Interrupt Control Registers . 65
Simulation Waveforms displaying Implemented Wait-states. 70
State Diagram of Moore Machine for Wait-states 71
VHDL Constructs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
Block Diagram of82510 UART 73
Intel 82510 Package Outline . . . . . . . . . . . . . . . . . . 74
DS1244Y Phantom Clock Package Outline. . . . . . 76
Figure 2.21a,b
Figure 2.22
Figure 2.23
Figure 2.24
Figure 2.25
Figure 3.1
Figure 3.2
Figure 3.3
Figure 3.4
Figure 3.5
Figure 3.6
Figure 3.7
Figure 3.8
Figure 3.9
Figure 3.10,11
Figure 3.12
Figure 3.13
Figure 3.14
Figure 3.15
Figure 3.16
Figure 3.17
Figure 3.18
Phantom Clock Register Definition
OS 1996 Open-drain Configuration
78
81
II
Stellenbosch University http://scholar.sun.ac.za
1 j
Page
Figure 3.19 Schematic ofRS232 to l-Wire Communication
Converter 82
Figure 3.20
Figure 3.21
Figure 3.22
Figure 3.23
Photograph ofRS232 to l-Wire Converter 85
PHASE 1 Supervisory Control Circuit. . . . . . . . . . . . . . . . . .. 86
Switching Circuit with Transients 87
Decoupling Capacitors in Switching Circuits 88
Figure 4.1
Figure 4.2
Figure 4.3
Figure 4.4
Figure 4.5
Figure 4.6
Figure 4.7
Photograph of PHASE 2 CPLD Incorporated Design 95
PHASE 2 Supervisory Control Circuit . . . . . . . . . . . . . . . . . . . . 96
Benefits of high level power optimization 102
Tri-state bi-directional bus communication. . . . . . . . . . . . . . . . 107
Tri-state bi-directional bus internal communication
Tri-state bi-directional bus externally routed communication
Tri-state bi-directional bus internally multiplexed
communication . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 109
108
108
III
Stellenbosch University http://scholar.sun.ac.za
, .
, i
: I
List of Tables
Table 2.1
Table 2.2
Table 2.3
Table 2.4
Table 2.5a, b
Table 3.1
Table 3.2
Page
Touch Memory Family 17
FLEX 10K Configuration Schemes .. . . . . . . . . . . . . . . . . . . . . 37
FLEX lOK Configuration Uses 37
MSEL Pin Options 37
FLEX 10K Device Features 41,42
80C 196KC Port Pin Functions '. 56
80C 196KC Interrupt Vector Sources, Locations and
Priorities ' . . . . . 63
Table 3.3
Table 3.4
PHASE 1 Design GAL# 1 Description 68
PHASE 1 Design GAL#2 Description 69
IV
Stellenbosch University http://scholar.sun.ac.za
Important Definitions
AHDL Altera Hardware Description Language. A design entry
language which supports Boolean equation, state
machine, conditional and decode logic. It also provides
access to all Altera and user-defined macro-functions.
Architecture Describes the behavior, data flow, and/or structure of a
VHDL entity. An architecture is created with an
architecture body. A single entity can have more than
one architecture. Configuration declarations are used to
specify which architectures to use for each entity.
ASIC Application Specific Integrated Circuit. It usually
includes gate array, standard cell and full custom
designs.
ASSP Application Specific Standard Product. An off-the-shelf
device which implements a specific function.
Behavioral Synthesis Where one hardware component can be re-used for more
than one parallel sequential language construction.
Bit A binary digit.
BST Boundary Scan Testing. An architecture which offers
the capability to efficiently test components on PCBs
with tight leg spacing.
Byte Any 8-bit unit of data.
CCB Chip Configuration Byte, which is loaded onto the Chip
Configuration Register (CCR) unless the device is
entering programming modes, in which case the PCCB
is used.
Cell A logic function.
CLB Configuration building blocks.
Clocked Process A synchronous process where several processes are
joined with the same clock.
v
Stellenbosch University http://scholar.sun.ac.za
, J
Combinational Process
CPLD
Design Hierarchies
Design Library
Design File
Device Command Mode
Device Configuration
Device Initialization
Device User Mode
DSP
EAB
EDIF
Electromagnetic Interferences :
Electromigration
EPLD
A process where all the input signals must be contained as a
sensitivity list.
Complex Programmable Logic Device.
Consist of components which contain other components,
VHDL code alone, or a mixture of both.
A library which stores VHDL units that have already been
compiled.
A file that contains descriptions of the logic and is compiled
by the compiler.
The combination of FLEX device configuration and
initialization.
The process of physically loading the SRAM programming
data into the FLEX device.
The operation in which the FLEX device resets its registers,
enables its I/O pins, and begins operation as a logic device.
Normal in-circuit device operation with the FLEX device
functioning as programmed.
Digital Signal Processor.
Embedded Array Blocks. Blocks which can be used to
implement various memory and complex logic functions.
Electronic Design Interchange Format. An industry
standard format for the transmission of design files
The electrical noises other than those inherent in the circuit
components.
A mass transport of metal atoms leading to electrical cuts or
shorts between metal lines.
EPROM Programmable Logic Devices. A PLD that uses
EPROM cells to internally configure the logic function.
Also called Erasable Programmable Logic Device.
VI
Stellenbosch University http://scholar.sun.ac.za
Fan-in The number of input signals that feed all the input equations
of a logic cell.
Fast Track Interconnect Dedicated connection paths that span the entire width and
height of a FLEX 10K device. These connection paths
allow the signals to travel between all LABs in a device.
FLEX Flexible Logic Element Matrix. A FPLD offering a fast
track interconnect architecture.
Floor Plan The physical arrangement of functions within a design
relative to the other.
FPGA Field Programmable Gate Array. An array of cells that is
either functionally complete or universal within a connection
framework of signal rooting channels.
FPLD Field Programmable logic Device. It is an integrated circuit
used for implementing digital hardware that allows the end-
user to configure the chip to realize different designs.
Configuring such a device is done using either a special
programming unit or by programming "in system".
Fuse A metallic interconnect point that can be electrically
changed from a short circuit to an open circuit by applying
an electrical current.
GAL Gate Array Logic (see description of PAL).
Gated Clock A clock configuration in which the output of an AND or OR
gate drives a clock.
Glitch A signal value pulse that occurs when a logic level changes
two or more times over a short period.
GND A low-level input voltage represented as low (0) logic level
in binary group values.
Input/Output Cell Register A register on the periphery of a FLEX 10K device or a fast
input-type logic cell that is associated with an 110 pin in
some FLEX devices.
Vll
Stellenbosch University http://scholar.sun.ac.za
Input/Output Feedback Feedback from the output pin on an Altera device that
allows an output pin to be used as an input pin.
Interrupt Controller The module responsible for handling interrupts that are to be
serviced by user-written interrupt service routines. Also
called the Programmable Interrupt Controller (PIC).
Interrupt Service Register The software routine that services a standard interrupt.
IOEs Input Output Element. An I/O register with flexible control
signals, programmable slew-rate control and an output
enable per pin.
Jam Programming It is vendor and platform independent interpreted language
optimized for programming devices via the standard IEEE
std.1149.l JTAG interface.
JTAG Joint Testing Action Group. A specification for boundary-
scan testing (BST) standardized as the IEEE 1149.1.
LAB Logic Array Block. A LAB is the basic building block of
the Altera MAX family. Each LAB contains at least one
macrocell, an 110 block and an expander product term array.
Latch A level-sensitive clocked storage unit that stores a single bit
of data.
Logic Analyzer Hardware equipment used to analyze digital waveforms
Logic Element A basic building block of an Altera FLEX 10K. It consists
of a look-up table and a programmable flip-flop to support
sequential functions.
LUT Look Up Table. A function generator that quickly
computes any function of four variables.
Logic Synthesis The way in which Boolean functions are translated and
minimized into gates.
Macrocell The portion of the FPGA that is smallest indivisible building
block. In the Altera MAX CPLD devices, it consists of two
parts: combinational logic and configurable registers
VIII
Stellenbosch University http://scholar.sun.ac.za
MAX Multiple Array Matrix, which is an Altera product family It
is considered to be a CPLD.
MAX + PLUS II Multiple Array Matrix Programmable Logic User System II.
A set of tools that allow design and implementation of
custom logic circuits with Altera's MAX and FLEX devices.
Mealy Machine A machine with it's outputs being a function of the present
state and all the inputs.
Mega Core Function Functions that are pre-verified hardware description
language (HDL) design files for complex system-level
functions.
Mega-function Mega-functions are off-the-shelf building blocks that
implement useful functions such as processors, digital signal
processing (DSP) functions, bus controllers and interfaces.
Moore Machine A machine with it's outputs being a function of it's present
state only.
MPLD Mask Programmable Logic Device.
Netlist An ASCII file that describes a design. It contains the
identification of function elements, inputs and outputs and
connections.
Netlist Synthesis A process where a netlist is derived from an abstract
presentation. This abstract presentation is usually a VHDL
file
One Hot Encoding A design technique used with FPGAs and CPLDs. A single
flip-flop is assigned to hold a logical one representing a
state, with the rest of flip-flops being held at zeros.
OPTROM One- Time-Programmable Read-Only-Memory, a version of
EPROM.
PAL Programmable Array Logic. A relatively small FPLD
containing a programmable AND plane followed by a fixed
OR plane.
PCB Printed Circuit Board.
IX
Stellenbosch University http://scholar.sun.ac.za
PLA
PLD
Primitive
Propagation Delay
QFP
Radio Frequency Interference:
Reconfigurability
Routing
RTL
RTL Synthesis
SFR
Simulation
Switched Capacitance
Synthesis
UART
Programmable Logic Array. A relatively small FPLD
that contains two levels of programmable logic. The
one is an AND plane and the other an OR plane.
Programmable Logic Device. The typical device class
consists of PALs, PLAs, FPGAs and CPLDs.
One of the basic functional blocks used to design
circuits with MAX +PLUS II software. Primitives
include buffers, flip-flops, latches, logical operators,
ports etc.
The time required for any signal transition to travel
between pins and/or nodes of a device.
Quad Flat Plack. A device package which is physically
square in nature, flat in height and surface mount.
Interference in the form of electromagnetic radiation.
The ability of FPLD devices to be reprogrammed for
different applications.
A process where previously placed logic functions are
interconnected.
Register Transfer Logic. This consists of a language
which describes behavior in asynchronous and
synchronous state machines, data paths, operators and
registers etc.
The same as Logic Synthesis, but also translates
sequential language constructions into gate and flip-
flops.
Special Function Register.
The process of modeling a logical design and it's stimuli
in which the simulation calculates output signal models.
The product of switching activity and physical
capacitance.
The way to translate VHDL, AHDL source code into
hardware.
Universal Asynchronous Receiver and Transmitter. A
part of the serial I/O port.
x
Stellenbosch University http://scholar.sun.ac.za
VCC A high-level input voltage represented as high (I) logic level
in binary group values. It is the default active node value in
AHDL.
VHDL The VHSIC Hardware Description Language. VHDL is
used to describe function, interconnect and modeling.
VHSIC Very High Speed Integrated Circuit.
WDT Watchdog Timer, an internal timer that resets the device if
the software fails to operate properly.
Word Any 16-bit unit of data.
XI
Stellenbosch University http://scholar.sun.ac.za
Chapter 1
Introduction
With all the available processing power currently obtainable in the form of microprocessors, it is
still advantageous to develop a microcontroller based system where required peripheral
components are included in the package. The trade-off between the two has been one of cost
verses performance. In the design undertaken in this dissertation, the micro controller proved the
more practical option with more than sufficient hardware support being provided by the inclusion
of the Flex IOK CPLDs.
The use of CPLDs in new hardware designs allows the electronic designers to develop custom
support processors to implement complex algorithms in hardware. Many designers previously
used ASICs or discrete logic components to implement custom hardware for dedicated
applications, but with the availability of the CPLD, the designer now has the ability to speedily
update, modify or emulate the new design which facilitates rapid prototyping.
Rapid prototyping provides great cost saving and allows the design to remain ahead of product
obsolescence. Projecting the consumer electronic market trend implies that in the future fully
customized products will need to be fabricated on demand. This indicates a definite need for the
inclusion of the CPLD into most dynamic new hardware designs.
In this design the CPLDs are used to provide special purpose input/output functionality required
for product customization. The new design process draws upon the expertise and multiple
disciplines in order to generate an effective solution
Stellenbosch University http://scholar.sun.ac.za
The choice of CPLDs verses FPGAs is due to the continuous interconnect structure of CPLDs
that uses continuous metal lines to provide logic-cell to logic-cell connectivity, which ultimately
leads to higher speeds and smaller die sizes than other comparable FPGAs. This continuous
interconnect structure eliminates the unpredictable timing associated with a segmented
interconnect structure providing fast fixed delay paths between logic cells.
Altera's range ofCPLDs were chosen for the following reasons:
The Altera PLDs are, to date, the fastest and largest in the industry, offering speeds
approaching those of mainstream gate arrays.
Altera offers the most cost-effective, highest-performance programmable logic available.
Altera works closely with EDA manufacturers to integrate the MAX +PLUS II .Software
with other industry-standard design entry, synthesis, and verification tools such as those
provided by Cadence, Exemplar, Logic, Mentor Graphics, Synopsis, Synplicity and View
logic.
Altera devices and development tools support both Altera-supplied megacore functions
and functions created by the Altera Megafunction Partners Program (AMPpSM)
Altera devices support in-system programming which makes prototyping easy during
design development. [7]
1.1 CPLDs and Rapid Prototyping
A current issue presented to most microelectronic designers today is one of integrating a field-
programmable logic device with an embedded microprocessor or microcontroller. The inclusion
of a microcontroller is to exploit the on-chip services which help to reduce the chip count and
board area of the overall design. The use of PLDs allows the developer to deal with a high level
description of a sub-system's behavior rather than with cumbersome low-level details. It is an
exciting new technology which provides for a solid platform to rapid prototyping since without
this technology design time would increase dramatically.
2
Stellenbosch University http://scholar.sun.ac.za
A further advantage of the CPLD is the reconfigurability of the device making it possible to re-use
the hardware and once again reduce development time, while maintaining application specific
performance.
The migration feature supported by Altera's FLEX IOK CPLD series allows for upgrades and
application specific designs using a single printed circuit board design. Altera's FLEX IOK CPLD
offers migration through logic densities ranging from 10 000 gates to 250 000 gates on pin
compatible devices.
S
The integration of the CPLD and the micro controller see~to be an effective solution to the
problem of developing a system that could rapidly be prototyped or reconfigured to suite the
immediate needs of the market.
1.2 Scope of the Thesis
This thesis presents two different approaches to an integrated hardware design utilizing firstly a
microcontoller with gate-level logic technology (PHASE 1) and secondly a microcontroller
integrated with two of Altera's FLEX IOK CPLDs (PHASE 2). The complete design,
implementation and commissioning of both systems is presented with conclusions and
recommendations following each approach.
The objectives in the development and analysis of the two systems based on their different
technologies are as follows:
Present comprehensive design techniques and methodologies as required by each design.
Analyze the flexibility of the timing constraints to be met by both systems
Investigate the development times associated with each design.
To consider the effect ofPLD technology on component count and the possible reduction
in the fault rate associated with this newer technology
3
Stellenbosch University http://scholar.sun.ac.za
Investigate the ease with which each system can be customized to suite the needs of the
application.
Utilize the hardware and software tools associated with each design technology in order to
synthesize, simulate and analyze the systems where possible.
Identify shortfalls in both designs and provide recommendations to overcome shortfalls.
1.3 Thesis Organization
This thesis is divided into 5 Chapters. Chapter 2 provides the reader with background into the
electronic components utilized in the phase one and two designs. The hardware selection criteria
and related hardware features used in the designs are also presented to provide the reader with
insight required when developing the systems. The architecture of Altera's CPLDs and the
process used to implement and design the CPLD circuits are also examined in this chapter.
Chapter 3 describes the design and analysis of the PHASE Imicrocontroller based system
including the gate-level components. The conclusions and recommendations on the PHASE I
system are then presented.
Chapter 4 presents the design and analysis of the PHASE 2 system where the microcontroller is
integrated with CPLD technology. Altera's megacore functions are implemented where possible.
The conclusions and recommendations are then presented for PHASE 2.
Chapter 5 concludes this thesis and presents recommendations for future work.
4
Stellenbosch University http://scholar.sun.ac.za
II
Chapter 2
Background
2.1 The Support Hardware
2. 1. 1 Microcontrollers
Through investigation it was determined that at least 70 percent of current microcontroller-based
applications are still using 8-bit microcontrollers. For this reason it was felt that use of a cost-
effective 16-bit microcontroller would provide the competitive edge desired in the market.
After a comprehensive study was performed on the available 16-bit microcontrollers, it was
decided to select a microcontroller supplied by a manufacturer offering a history of sound
hardware support. The microcontroller which best complied with the selection criteria was Intel's
80C196KC.
2.1. 1.1 Processing Power
The 80C 196KC is a 16-bit CHMOS micro controller designed to handle high-speed calculations
and fast input/output operations. The device has a 16-bit wide Central Processing Unit (CPU)
that connects to both an interrupt controller and a memory controller via a 16-bit CPU bus. An 8-
bit CPU bus transfers instruction bytes from the memory controller to the instruction register in
the Register Arithmetic-Logic Unit (RALU). Figure 2.1 presents a block diagram of the internal
structure of the 80C 196KC.
5
Stellenbosch University http://scholar.sun.ac.za
16
,-" - - - - - - - - - - - - - - - - - - - --
I : Memory Controller I
I I
I I
I I
I I
I I
I I
I I
I I
1'1
I I
I I
I ,
I ,
I ,
I , r-.~~_'_., r--L_--L--,
I ,
I I
, , O""=~....._T- ......L.~L...I..""':":;;:.L..J
I I
I I
I I
I&. _
__J)
I Register ::
File ::
Register
RAM
Interrupt
Controller
CPU
SFAs
I
1'-
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ CPU Control and
, , __ ~I~~_ ~iI!.~~_"
CPU BUSES 8
FIGURE 2.1 : A BLOCK DIAGRAM OF THE 80C196KC MICROCONTROLLER
The RALU performs most of the calculations for the microcontroller, but it does not use an
accumulator. Instead, it operates directly on the lower register file, which essentially provides
256 accumulators. Because the data does not flow through a single accumulator, the 80C 196KCs
code executes faster and more efficiently.
For example, the 80C196KC code multiplies two l o-bit variables and stores the 32-bit result in a
third variable. The 80C 196KC performs this operation in one instruction because it combines a
large set of general purpose registers with a 3-operand instruction format. This format allows a
single instruction to specify two source registers and a separate destination register.
6
Stellenbosch University http://scholar.sun.ac.za
2 1.1.2 Peripheral Support
The 80C 196KC' s internal peripheral modules provide special functions for a variety of
applications.
The required peripheral modules which led to the selection of this microcontroller are:
Four standard input/output ports.
A serial asynchronous/synchronous input/output port.
Two configurable 16-bit timers.
A watchdog timer.
Idle mode support.
ONCE mode support which electrically isolates the microcontroller form the external
system.
High-speed input/output (HSIO) unit.
The design implementation of these modules are presented in Chapters 3 and 4.
2 1.1.3 Memory Support
The addressable memory space of the 80C196KC extends to 64 kilo bytes. An INST pin on the
microcontroller can be used to facilitate the overlap of ROM and RAM. This allows for an
increase in the addressable memory space. Figure 2.2 shows the major memory partitions.
7
Stellenbosch University http://scholar.sun.ac.za
8XC196KC 8XC196KD
Addresses Addresses
OFFFFH 1OFFFFH External 1Memory
or
6000H OAOOOH 1/0
5FFFH 9FFFH
Program
Memory Either
20S0H I I Internal2080H OTPROM207FH or207FH Special- External
Purpose Memory
2000H 2000H Memory
1FFFH 1FFFH ·Port 4
1FFEH 1FFEH "Port 3
1FFDH 1FFDH
External
200H 400H ,. Memory
,.
1FFH 3FFH
Register
OH OH File
FIGURE 2.2 : MAJOR MEMORY PARTITIONS
The microcontroller can address either internal or external Read-Only Memory (ROM). The one-
time-programmable-read-only-memory (OTPROM) located on the microcontroller stretches from
2000 Hex to 5FFF Hex. The 80C196KC is thus internally limited to an OTPROM of 16 k byte.
The microcontroller allows for the selection of internal or external memory mapping. An external
access pin (EA#) on the 80C 196KC governs the selection of the internal or external memory
access. Program memory is located upwards from address 2080H. Special purpose memory is
located at addresses 2000H - 2070FH. It contains several reserved memory locations as
presented in Figure 2.3a.
8
Stellenbosch University http://scholar.sun.ac.za
! i
8XC196KC 8XC196KD
Addresses Addresses
OFFFFH OFFFFH External
Memory
or
1/0
,
OAOOOH
,
6000H ,,
5FFFH 9FFFH ,Program ,,
Memory
,,
2080H mOOHI 1--'/207FH Special-207FH
, J
Purpose ,.
2000H 2000H
Memory
- e- \
\
1FFFH 1FFFH Port 4 \ \- - - \ \
1FFEH Port 3
\
1FFEH \
\
\
1FFDH 1FFDH , \.. External \ \, Memory , \
200H 400H
\
1FFH 3FFH \Register \
OH OH
File
Reserved (FFH)
PTS Vectors
Upper Interrupt
Vectors
Security Key
Reserved (FFH)
Reserved (20H)
CCB
Reserved (FFH)
Lower Interrupt
Vectors
FIGURE 2.3a : RESERVED MEMORY LOCATIONS
9
8XC 196KC/KD
Addresses
205EH
2040H
2030H
2020H
201AH
2019H
2018H
2014H
2000H
AO090-DO
Stellenbosch University http://scholar.sun.ac.za
The register file is divided into upper and lower register files as illustrated in Figure 2.3b.
OFFfFI-I
OFFFI-I
207FI-I
IFFFI-I
IfFDH
OIFFI-I
OIFFH
External Memory
or I/O
Program Memory
Special Purpose
Memory
Port 4
Port 3
External Memory
Register File
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
/
Reserved (FFI-I)
PTS Vectors
Upper Interrupt Vectors
Security Key
Reserved (FFI-I)
Reversed (201-1)
Chip Configuration Byte
(CCBl
Reserved (FFI-I)
Lower Interrupt Vectors
,
20 5EI-I
20401-1
20301-1
20201-1
20lAH
20191-1
20181-1
20141-1
20001-1
-:
.---------------, 01 FFI-I
/
/
Register RAM
(Upper Register file)
0019H
0018H
____________ OIOOH
• Register RAM
OOIA
• Stack Pointer - HJgh Byte
* Stack Pointer - Low Byte
* CPU - Special Function Registers
_L--------------' OOOOH
• Lower Register File
FIGURE 2.3b : REGISTER FILES OF THE 80C196KC
10
Stellenbosch University http://scholar.sun.ac.za
2.1.2 Non-volatile ram/real-time Clock
The design requires the use of a device to store data in the absence of an external power source.
It also requires the presence of a real-time clock in order to time-stamp the required data.
A component with support for both requirements was identified as the DS 1244Y. The
DS1244Yis a 64-k bit NVSRAM with a phantom clock.
2.l.2.1 Phantom Clock
Data retention is maintained with the presence of a self-contained lithium energy source which is
guaranteed for 10 years.
2.1.2.2 Battery back-up Support
The on-chip clock is termed phantom since it is invisible to the microcontroller unless a pattern
generated in a 64-bit serial bit stream is matched
2.1.3 Dallas Touch Memory
In a situation where the radio or optic fibre communication between the microcontroller-based
system and a remote personal computer is neither viable nor possible, the Dallas Touch Memory
is utilized as a mobile data transfer mechanism.
This implies that in the event of a communication failure, all the data transferred to and from the
system via the radio or optic-fibre link, can also be transferred via the mobile touch memory tags
1 1
Stellenbosch University http://scholar.sun.ac.za
2.1.3.1 Mobility
The touch memory is a chip-based data carrier with a diameter of 16mm and a thickness of 6mm.
The physical shape of the device is illustrated in Figure 2.4.
FIGURE 2.4 : DALLAS TOUCH MEMORY MODULE
Due to the small size and weight of the container, it is effortlessly transported by the user.
2.1.3.2 Durability
The touch memory is housed in a stainless steel can which is engraved with a unique registration
number. The stainless steel can has been tested to withstand harsh environments with operating
temperatures ranging from -40°C to +70°C. The can is also highly resistant to dust, moisture and
shock.
2.1.3.3 Reliability
The manufacturer offers a 10 year guarantee on the data retention of all memory offered in the
Dallas Touch Memory product range. The data integrity is assured with strict read/write
protocols. The touch memory offers a unique, factory lasered and tested 64-bit registration
number. This number consists of an 8-bit family code, a 48-bit unique serial number and a 8-bit
CRC byte.
12
Stellenbosch University http://scholar.sun.ac.za
1
!
The memory device also complies with the UL#913(4th Edit) This implies an intrinsically safe
apparatus, approved under entity concept for use in Class 1, Division 1, Group A, B, C and D
locations.
The manufacturers provide a guarantee that the identity code of the device is unique. The unique
64-bit lasered ROM string is sown in Figure 2.5a. A I-wire Cyclic Redundancy Check is
generated using a polynomial generator consisting of a shift register and XOR gates as shown in
Figure 2.5b. The polynomial is X3 + X5 + X4 + l. The CRC is used to verify the integrity of data
being transferred to and from the Dallas Tag.
8-Bit CRC Code 48- Bit Serial Number
FIGURE2.5a: 64-BIT LASERED ROM
FIGURE2.5b: l-WIRECRC GFNERAlDR
2.l.3.4 Operation of the DS1996
The DS 1996 has three main components, the 64-bit lasered ROM, a 256-bit scratch pad and the
65536-bit SRAM. The busmaster first provides one of six ROM-function commands. 1) Read
ROM [33H], 2) Match ROM [55H], 3) Search ROM [FOH], 4) Skip ROM [CCH], overdrive
skip-ROM or overdrive Match-ROM [3CH or 69H]. Overdrive mode is where all subsequent
communication occurs at t higher speed.
13
Stellenbosch University http://scholar.sun.ac.za
After a ROM Function Command is unsuccessfully executed, the memory functions become
accessible and the master device may provide one of four memory function commands. 1) Write
scratchpad [OFH], 2) Read scratchpad [AAH], Copy scratchpad [55H], Read memory [FOHl
The Memory Function Flow Chart is presented in Figure 2.6a. All the data is read and written
with the least significant bit first. The other touch memory devices in the range operate similarly.
14
Stellenbosch University http://scholar.sun.ac.za
FlGURE6.2b: Mr<.MORY FUNCTION Fl,OW CHART FOR roUCIlI"IEMORY DEVICE
15
Stellenbosch University http://scholar.sun.ac.za
2.1.3.5 Storage Capacity
A block diagram of the 64-k bit touch memory is presented in Figure 2.7a, with the memory map
and address registers presented in Figure 2. 7b.
STARTING
ADDRESS
32-byte intermediate storage scratchpad
OOOOH
~
0020H
~
f-<
>-<
o:l
~ IFEOH
'<t
\0
32-byte final storage NV RAM
32-byte final storage NV RAM
I I I I I I I
I I I I I I I
I I I I I I I
1 : I I I I :
32-byte final storage NV RAM
page 0
page 1
page 225
FIGURE 2.7a : DS1996 MEMORY MAP
7 6 5 4 3 2 o
Target Address (TAl)
Target Address (TA2 )
Ending Address with Data Status (E/S) (Read Only)
FIGURE 2.7h: ADDRESS REGISTERS
16
Stellenbosch University http://scholar.sun.ac.za
Features of the Dallas Touch Memory used in the design is presented in Table 2.1
I-Wire 48-Bit ReadIWrite Secure Real-Time Maximum Package Stainless
Compatible Unique Memory Memory Clock Data Rate Style Steel
Identification Size (bits)
DSI990 y y ° N N 16 kbps R y
DS1991 y y 1,152 Y N 142 kbps RIF y
DSI992 y y 1,024 N N 142 kbps RIF y
DSI993 y y 4,096 N N 142 kbps RIF y
DSI994 y y 4,096 Y y 16 kbps RIF y
DSI996 y y 65,536 y N 142 kbps RIF y
Package R = Rounded rim MicroCan
Style F = Flanged rim Microcan
TABLE 2.1 : TOUCH MEMORY FAMILY
The 64 k-bit touch memory is used for the transfer of recorded transactions. The transactions are
transferred from the microcontroller-based system to the database located on the personal
computer. The 4-k bit touch memory is used for system configuration and interrogation with date
and time synchronization. The l-k bit touch memory is used as a user identification tag
containing system interrogated user control data.
17
Stellenbosch University http://scholar.sun.ac.za
21.3.6 Parasitic Power
The block diagram indicating the parasitic-powered circuitry is presented in Figure 2.8.
Lid
Contact
I-Wire Function
-<:'
Control
--- f------
Memory ~
Function
Control -<:'--
1---------------1 }
1 1
~ 64-Bit Lasered 1
Data.........".,. I ROM 1
1 1
L__ _
MEMORY
3V
Lithium
SRAM
(256-Bit Pages)
64K-Bit
T
Parasite-Powered
Circuitry
256-Bit
Scratchpad
FIGURE 2.8 :INTERNAL STRUCTURE OF THE DALLAS TOUCH MEMORY
The circuitry "steals" power whenever the data line is high. The data line provides sufficient
power as long as the specified timing and voltage of the parasitic power is that the lithium cell is
conserved and that if the lithium cell is exhausted of energy, the ROM identity serial number can
still be accessed.
2.1.3.7 Ease of Implementation
The touch memory tags are rugged read/write data carriers that act as localized databases that can
easily be accessed with minimal hardware. The data is transferred serially via a I-wire protocol
which requires only a single data lead and a ground return.
18
Stellenbosch University http://scholar.sun.ac.za
2.1.4 Intel 82510 Universal Synchronous Receiver and Transmitter (UAR1)
The design requires the use of two UARTS. One for serial communication with a remote
personal computer and the other for communication with the Dallas Touch Memory.
Communication with the touch memory requires the inclusion of an external UART with flexible
baud rate control. In order to establish communication with the touch memory, a reset pulse is
required. This reset pulse is obtained by configuring the band rate of the UART to 10473 band.
Once the reset pulse has initiated a response from the touch memory, the band rate must then be
altered to 115200 baud for further communication.
The Dallas Touch Memory also supports an 'overdrive' mode which increases the communication
speed by a factor of 10. This implies that the UART chosen should support the new speeds. The
Intel 82510 asynchronous serial controller is chosen for its intelligence and versatility. The UART
comprises two independent FIFOs and character control recognition (CCR) for the purpose of
data butTering and increased software efficiency. The controller also has two baud rate
generators/timers, an on-chip crystal oscillator and seven programmable VO pins. A block
diagram of the UART is presented in Figure 3.14.
2.1.4.1 , Register Support
The Intel 82510 has a set of registers which can be configured to appear identical to those of the
16450 UART. This feature provides complete software compatibility, with the IBM personal
computer environment.
2.1.4.2 Reduced Power Consumption
Both the Intel 80C 196KC microcontroller and the Intel 82510 UART support the "sleep" and
"idle" modes which reduce unnecessary power consumption.
19
Stellenbosch University http://scholar.sun.ac.za
2.1.5 Programmable Logic Devices (PLDs)
The address decoding requirements for the phase 1 hardware is implemented with the use of
GALs (Gate Array Logics), rather than discrete logic components. The 22V10-GAL was
selected for it's logic capacity and access time in order to comply with the design requirements of
the hardware. The minimum access time allowed for is 7,5 ns as reflected in the hardware timing
specification presented in Appendix A.
Due to the flexibility required from the hardware, a state machine is coded into the GAL in order
to facilitate multiple wait-states for a range of access times.
2.1.5.1 Configurability
A state machine is used to implement wait-states for the Intel 196 micro controller in a 22V 10
GAL. The reason for this being that the performance and time determinism are considerably
better in state machines implemented in gates and flip-flops than in a CPU The two basic types
of machines considered were the Moore and Mealy. The Mealy machine's outputs are a function
of the present state and all of the inputs whereas the Moore machine's outputs are a function of
the present state only. The Mealy machine then changes it's outputs immediately when the inputs
change whereas the Moore machine has to change state first. In the situation where the state
machine is used to implement a wait-state system, the Moore machine is the relevant choice since
it would wait for a clock cycle before the output values can be changed. This is illustrated in
Figure 2.9.
Register
Inputs
LOGIC ICLK]
Reset--l'-----'
I OutputsLOGIC -L...- -'
Current State
The Moore machine used
FIGURE 2.9 : MOORE MACHINE DESIGN
20
Stellenbosch University http://scholar.sun.ac.za
The state machine is implemented in the VHDL language then compiled and tested using available
synthesis and simulation tools. Since the state coding does not affect the behavior of the state
machines, it does not have to be described in the VDHL code. The synthesis tool usually includes
a state machine optimizer which is used to optimize for desired performance and area. Due to the
fact that the synthesis tool originally used in the development of the phase 1 system did not have a
state machine optimizer, the state coding was included in the VHDL code.
It is accepted that both the Moore and Mealy machines can have signal spikes on the outputs but
with the state decoding assigned in the VHDL code, the outputs are guaranteed to be spike-free.
This is due to the fact that the outputs are generated directly from the state flip-flops. The output
used as a wait-state signal is a clocked output and hence also yields a spike-free signal via the
extra D-type flip-flop, This is illustrated in Figure 2.10.
CLK
Register CLK Register
Input Output
LOOIC LOOIC I-
r-- (wait)
Reset _j Reset _j
Current state
FIGURE 2.10: MOORE MACHINE WITH CLOCKED OUTPUT
A synchronous state machine was used rather than an asynchronous machine in order to produce
the required results.
2.1.5.2 Programming Support
The software used to compile, synthesize and simulate the VHDL code used to program the
22V10 GAL is provided by CYPRUS. The title of the software package is WARP and the
version used in this design is ver 3.3
21
Stellenbosch University http://scholar.sun.ac.za
2.1.5.3 Reliability
The use of PLD technology introduces an increased sense of reliability due to reduced component
count, internal connectivity and sophisticated software analysis support.
2.1.5.4 Cost-effectiveness
The cost of a single PLD is far less than the cost of the equivalent gate-level hardware required to
accomplish the same task. Design time is also greatly reduced due to the reconfigurable nature of
the PLD.
2.1.6 Optic Fiber Communication
A communication platform was required for data communication between a remote personal
computer and the rnicrocontroller-based system. The communication hardware had to be
designed to support RS232 pin compatibility in order to operate otT the standard serial
communication port of the personal computer. A block diagram illustrating the design of the
communication hardware is presented in Figure 2.11.
+9V TO +12V de
V+IN
-
V-IN )
-9Vto -12Vde -
GND
-
MONITOR
-
TxIN
-
RxOUT
-
FIGURE 2.11 : OPTIC FIBER COMMUNICATION HARDWARE
22
Stellenbosch University http://scholar.sun.ac.za
The criteria which led to the selection of the communication are as follows:
2.1.6.1 Reliability
The communication system has to be reliable over a distance of up to 100 m and the system has to
support a band rate of 19200. Due to the nature of the project, the system needs to be immune
to electrical noise found in an industrial environment.
2.1.6.2 Safety
The project is developed for use in the fuel industry and a great deal of safety precautions need to
be considered when designing such a system. The optic fiber system provides full optic isolation
between the remote personal computer and the microcontroller-based system. The system also
offers intrinsic safety in regions of frequent lighting strikes.
2.1.6.3 Cost-effectiveness
The nature of the project required the use of a low cost polymer fiber to be used instead of glass
The polymer fiber allows for terminations to be performed without the need for expensive
equipment normally required for glass.
The polymer fiber thus proves more cost-effective to install or repair.
2. 1.7 Radio Communication
A problem encountered with the installation of the fuel management system brought about the
need for a means of communication which did not require any physical connection between the
microcontroller and a remote personal computer. The radio communication system incorporates
a communication module with a prepaid frequency band. This module is manufactured by
Radiornetrix. Additional circuitry had to be designed around the module in order to make the
complete radio transceiver RS232 compatible.
23
Stellenbosch University http://scholar.sun.ac.za
The transceiver unit operates at the UHF frequency of 433 MHz and supports half duplex data
transmission at speeds up to 40-klbits per second. The range obtainable from the unit is 120
meter in open ground. A block diagram of a fully buffered CMOS interface is presented in Figure
2.12.
Radio data
Transceiver
FIGURE 2.12: RADIO COMMUNICATION HARDWARE
2.1.7.1 Reliability
In order to improve the bit error rate performance on data sent, a 50:50 mark:space average is
implemented. This is accomplished by transmitting each byte twice. The first transmission sends
the actual byte and the second transmission sends it's logical compliment. The decoder thus
determines the integrity of each byte received and on a parity failure selects the subsequent
inverted odd byte.
24
Stellenbosch University http://scholar.sun.ac.za
2.l.7.2 Ease of Implementation
The modular nature of the design facilitates component replacement rather than on-site fault
diagnosis. The RS232 pin compatible design supports the plug-in replacement of the optic fibre
communication module with the radio communication module. The wireless nature of the radio
transceiver eliminates the need for cable installation or repairs.
2.1.8 Microcontroller Supervisory Support
A common problem with microcontroller based systems with on-board memory is that of data-
loss or data-corruption during a power failure or fluctuation in the supply voltage. The memory
used in this project is non-volatile battery backed with a 10 year guarantee of on-chip battery life.
The package used is the Dallas semiconductor DS 1244Y 32 K byte non-volatile SRAM with an
on-chip phantom clock. An embedded lithium energy cell maintains calender operation and
retains RAM data. The chip has internal control circuitry which constantly monitors the supply
voltage Vee for an out-of-tolerance condition. When such a condition occurs, the lithium energy
source is automatically switched on and write protection is unconditionally enabled to prevent
corrupted data in both the memory and the real-time clock.
The DS 1244Y provides full functional capability for Vee greater than a set threshold voltage of
4.25 Volts and write protects for any voltage below 4.25 Volts. When the supply voltage decays,
the RAM automatically write protects itself with all the inputs becoming "don't cares" and the
outputs reverting to a high impedance state.
As Vee falls below approximately 3.0 Volts, the power switching circuit connects external Vee to
the RAM and disconnects the lithium energy source. Normal RAM operation once again resumes
after Vee exceeds 4.5 Volts.
25
Stellenbosch University http://scholar.sun.ac.za
One of the issues which is however not addressed by the secure write protection strategy of the
NVSRAM is that there is a strong likelihood that data is currently being processed during a power
failure. This implies that the now fluctuating bus states are resulting in erroneous data or
addresses being passed in the system.
An example of this would be when the supply voltage (Vcc) has fallen below the allowable 10%
of the NVSRAM phantom clock and time has already elapsed for performing any system
housekeeping functions such as storing off data and storing the state of the microprocessor.
An essential requirement would be to save the data before write-protecting the memory.
This could only be done if the impending power failure could be detected well in advance of the
10% "shut -off-point". This early detection would allow enough time for the essential
housekeeping functions to be performed. The system implemented in this project is considered
sufficiently reliable for production systems where data integrity is a high priority.
2.1.8.1 Power Monitoring Systems
Two separate power monitoring systems are implemented together in order to provide a "back-
up" in the event of anyone of the two systems failing. The two systems chosen were selected
from different manufacturers in order to avoid the occurrence of common faults.
The first power monitoring system uses the DS1233 5% and the DS1233 10% 5 Volt reset
semiconductor chips manufactured by Dallas Semiconductor. The two Ies operate in sequence
during a power failure. The first Ie withdraws the signals from the busses then the second Ie
issues a microcontroller reset.
The second power monitoring system uses the MAX695 chip manufactured by MAXIM. This
chip takes control of the chip select signal to the NVSRAM during a power failure to avoid
unwanted chip access. The MAX695 also withdraws the signals from the busses and then issues a
microcontroller reset on power failure
26
Stellenbosch University http://scholar.sun.ac.za
The full implementation of both systems is presented in Chapters 3 and 4. The first system is used
in conjunction with the DS 1244Y in the PHASE 1 design, while in PHASE 2 the second system is
implemented as a back-up for additional protection against data corruption.
2.1.9 CPLDs and FPGAs
In the production and development of electronic systems today, there is a drive to increase the use
of high density PLDs because of the current similarities between these PLDs application specific
integrated circuit (ASICs) and application specific standard products (ASSPs) [7]. The factors
influencing this increased use of high density PLDs are:
high integration
high density
high performance
low cost
short time-to-market
design flexibility
Programmable logic includes all of the digital logic circuits configured by the end-user, which
includes the simple, low-density. Generic Array Logic (GALs), Programmable Array Logic
(PALs), Field Programmable Gate Arrays (FPGAs) and Complex PLDs (CPLDs). Figure 2.13
illustrates the CMOS logic product range offered by Altera [7].
27
Stellenbosch University http://scholar.sun.ac.za
Standard
Logic
FIGURE 2.13 : ALTERA'S CMOS LOGIC PRODUCT RANGE
The two prominent high density logic devices manufactured today are the FPGAs and the CPLDs
There exists great controversy between the use of each of these components with manufacturers
choosing to specialize in the one or the other. The CPLDs and FPGAs have different interconnect
structures. The segmented interconnect structure of the FPGA used multiple metal lines of
ranging lengths, connected by pass transistors or anti-fuses, to connect logic cells.
The CPLD uses a continuous interconnect structure with continuous metal leads to higher speeds
and smaller die sizes than comparable FPGAs. A further feature in support of the CPLD is that
the continuous interconnect structure eliminates the unpredictable timing associated with a
segmented interconnect structure and provides fast, fixed delay paths between logic cells. Figure
2.14 illustrates the architectural structures and differences between the CPLDs and FPGAs.
28
Stellenbosch University http://scholar.sun.ac.za
Register
Register
29
FIGURE 2.14: ARCHITECTURAL STRUCTURES OF CPLDs AND FPGAs
Stellenbosch University http://scholar.sun.ac.za
Other differences between CPLDs and FPGAs include the fact that while CPLDs are gate
intensive implying that they are well suited to wide input functions, FPGAs are register intensive,
but where input functions wider than 4 would require extra levels. The CPLD is not register
intensive with between 32 and 560 registers where the FPGA has between 282 to +5000 registers.
An important difference between CPLDs and FPGAs is that currently the latter is non-volatile, but
re-programmable whereas the FPGA is volatile and must be re-booted at power-up.
2.1.10 Flex Series CPLD Range of Altera
The selection and implementation of Altera's products is attributed partly to the quote that
"Altera's PLDs are the fastest and largest in the country". [7] Further reasons supporting this
selection are presented below.
2.1.10.1 Performance
Altera utilizes state-of-the-art CMOS processes, which results in the fastest possible performance
The continuous interconnect structures result in fast and consistent signal delays in the device.
Certain of Altera's devices also have specialized on-chip circuitry which further enhance the
performance.
2.1.10.2 High-density Logic Integration
Altera's high-density logic leads to the reduction in board space and cost. Altera's devices range
in densities from 300 to 250 000 usable gates. The logic densities allow the devices to easily
integrate large numbers of standard logic devices, PLDs, FPGAs or custom devices. Applications
previously implemented into ASICs can now just as easily be implemented into Altera's FLEX
devices.
30
Stellenbosch University http://scholar.sun.ac.za
2.1.10.3 Cost-effectiveness
"Altera offers the most cost-effective, highest performance programmable logic available". [7]
It is also important to note that Altera's PLDs are similar in cost to equivalent gate array logic
components.
2.1.10.4 Development Cycle
The shorter development cycles can directly be attributed to the easy-to-use MAX +PLUS II
software. With Altera's software, the design entry, processing, verification and device
programming require only a few hours to complete. The MAX +PLUS II development cycle is
presented in Figure 2. 15
I Design Concept I I Design Entry I Design Processing Design Simulation DeviceProgramming System Test
FIGURE 2.15 : MAX+PLUS II DEVELOPMENT CYCLE
AJtera has supported the development of direct integration of most EDA manufacturers software
with its own MAX+PLUS II. Altera has developed its MAX+PLUS II software with support for
industry-standard design entry, synthesis and verification tools. This project makes use of the
synopsis design verification tool, which contributed to the choice ofMAX+PLUS II software as
the possible solution.
31
Stellenbosch University http://scholar.sun.ac.za
2.1.10.5 Mega-function Support
AItera provides MegaCore functions and supports the AItera Mega-function Partners Program
(AMPpSM) mega-functions. Mega-functions are off-the-shelf building blocks that implement
useful functions such as processors, Digital Signal Processing (DSP) functions, bus controllers,
and interfaces. [7] The mega-functions provide a high degree of flexibility and performance which
is not attainable in fixed-function devices. These functions can be targeted to various applications
required by the design.
LPM-Megafunctions
A1tera's FLEX10K devices have created a paradigm shift in design methodology. Designers are
moving away from schematic-based design techniques and are turning to modem design
techniques that use hardware description languages (HDLs), megafunctions and libraries of
parameterized modules (LPMs).
The LPMs objective is to enable architecture-independent design without sacrificing silicon
efficiency. LMP functions take maximum advantage of the FLEX architecture thereby producing
high performance functionality. For instance a multiplier function implemented in a FLEX device
out-performs a multiplier function implemented in competing devices [26]
For performance optimization, designers can use the LPM-latency parameter to create a pipelined
multiplier that is suited to the FLEX architecture, utilizing the many chains. Competing vendors
provide significantly less, if any support for the LPM. For example, the XBLOCK methodology
used by Xilinx, does not support signed multipliers which are vital for certain application the
LPM-counter and the LPM-MUX megacore-functions.
The A1tera MegaCore functions are pre-verified Hardware Description Language (HDL) design
files for complex system-level functions. [7]
32
Stellenbosch University http://scholar.sun.ac.za
2.l.10.6 JAM Programming and Test Program
The JAM programming solution consists of two software components. The first being the JAM
composer and the second the JAM player. Figure 2.16 describes the basic JAM flow.
I
I
I
I I
88t®t
I I
I I
I I
I I
I I
I I
I I
I I
PLD Vendor Specific I
+
TDl
~
TMS
TCK
_IQQ_
l Jam Player tJ ...'l~,-.-,- ... .... TDI
~
TMS
CK
TDO-•......
TDI
~
TMS
TCK
TDO4-
Any IT AG Device
=
Target Device for ISP=
Any IT AG Device
=
FIGURE 2.16 : FLOW DIAGRAM OF ALTERA's JAM SYSTEM
The JAM composer writes the JAM file (*jam) that contains the user data and programming
algorithm which is required to program the design into a device. The JAM player interprets the
JAM file and manages the JTAG (Joint Test Action Group) port to program the device. The
JAM instruction set includes JTAG-based instructions as well as algorithmic instructions.
Most Altera devices comply with the JTAG specification IEEE 1149.1 std by providing BST
capability for input, output and dedicated configuration pins. The BST architecture can test pin
connections without the use of physical test probes and capture functional data while the device is
operating normally. [32] In order to perform the boundary test, the data has to be serially forced
into the boundary scan cells. The captured data is then serially shifted out and externally
compared to expected results. This technique is illustrated in Figure 2.17a and 217b
33
Stellenbosch University http://scholar.sun.ac.za
FIGURE 2.17a : IEEE STD. 1149.1 BOUNDARY-SCAN TESTING
34
Stellenbosch University http://scholar.sun.ac.za
o
o
o
o
o
o
o
o
~ Eac~ peripheral element is either an 1/0 pin. dedicated input pin
or a-dedicated configuration pin
TAP CONTROLLER
'IDI 'IMS TCK 'lUST 'IDO
FIGURE 2.17b: BOUNDARY SCAN TESTING LAYOUT
The BST technology can be used for in-circuit reconfiguration in the FLEX lOK devices used in
this project.
35
Stellenbosch University http://scholar.sun.ac.za
Figure 2.18 illustrates the hardware connections required to implement the BST technology for
the FLEX 10K device.
FIGURE 2.18: JTAG PROGRAMMING AND CONFIGURATION
WITH THE BYTE BLASTER
The BST mode requires the use of 5 specific pins. They are the TDI (Test Data Input), TOO
(Test Data Output), TMS (Test Mode Select), TCK (Test Clock Input) and the TRST (Test
Reset Input), where the TRST pin is optional. A description on the implementation of this
hardware is described in Chapter 4, section 4.1.5.
2.1.10.7 In-circuit Configurability
The Altera FLEX 10K device supports in-circuit re-configurability. The FLEX 10K device allows
various configuration schemes to be selected on power-up. These are presented in Table 2.2 with
their typical uses presented in Table 2.3.
36
Stellenbosch University http://scholar.sun.ac.za
Configuration Methods
The FLEX 10K architecture uses SRAM cells to store the configuration data for the device. The
SRAM cells have to be reloaded each time the circuit powers up and begins operation. The
devices configuration mode is entered, followed by the device initialization mode placing the
device into user mode where the device functions as programmed. The FLEX 10K device can be
either configured on power-up or during operation by allowing an external device to take control
of the dedicated pins assigned to configuring the device.
Initialization of the FLEX 8000 device can be controlled by the internal oscillator in the device or
by an external clock signal, whereas the FLEX 10K device initialization can only be controlled by
an external clock signal. This clock is provided by the EPROM or intelligent controller. Once the
device is reconfigured in-circuit, normal user-mode operation can resume. The process from
configuration to user mode takes less than 320 mseconds. A timing diagram illustrating the
configuration cycle of the FLEX 10K device is presented in Figure 2.19.
FLEX 10K Configuration Cycle
nCONFlG
nSTATUS _
CONf.DONE _
DCI.K ••• ULnSUL ...~
DArA ••• ~ ••• High-Z
MODE =::=::=-:~::;:=~=:=:=~~ X Ir.ilialization ••• ====~X =;u=se=r =
--~
FIGURE 2.19: TIMING DIAGRAM FOR CONFIGURATION OF
FLEX 10K DEVICE[41]
38
Stellenbosch University http://scholar.sun.ac.za
-0"1
The EPC2, EPCl or EPC1441 EPROM devices store the configuration data in its array and
serially clocks the data out with an internal oscillator. On the EPROM, the OE, NCS and DCLK
pins supply the control signals for the address counter and output tri-state buffer. The passive
serial configuration methods used in the project also allows for the configuration of a single FLEX
10K device or multiple FLEX 10K devices. Figure 2.20 shows the pin connections for the
EPROM configuration of both single and multiple FLEX 10K devices.
FIGURE 2.20 : PIN CONNECTIONS FOR CONFIGURATION OF FLEX IOK
DEVICE/S USING AN EPROM
During the development stage of this project, the byte blaster is used to upload the data into the
FLEX 10K devices. The configuration scheme is again the passive serial, where the byte blaster
provides the clock signal for serial data transfer. Figure 2.21 indicates the pin connections used
for PS byte blaster configuration of both single and multiple FLEX 10K devices.
39
Stellenbosch University http://scholar.sun.ac.za
FIGURE 2.21a : SINGLE FLEX 101( DEVICE
FIGURE 2.21b: MULTIPLE FLEX 10K DEVICES
Altera's MAX +PLUS II software is used to generate the necessary files for configuring the FLEX
10K devices. If the byte blaster is used for configuration, an SRAM object file (sot) is generated
by MAX+PLUS II. If the serial EPROM is used for configuration, a programmer object file
(pot) is generated by MAX+PLUS II.
40
Stellenbosch University http://scholar.sun.ac.za
2.1.10.8 FLEX lOK Architecture
Logic Implementation Structure
The FLEX 10K family is the first PLD family that is designed to implement designs that integrate
a complete system on a device. [33] Altera offers a range of speed grades in the FLEX 10K range
with the latest speed grades allowing FLEX 10K devices to achieve the best high-density
performance in the PLD market. Table 2.5a and 2.5b presents the FLEX 10K family features.
The SRAM based FLEX 10K device has a flexible, programmable embedded array which consists
of embedded array blocks (EABs). These EABs contain 2-k bits of RAM (4-k bits for the FLEX
10 KE).
Typical gates (logic and 10 000 20000 30000 40000 50000
RAM), Note (1)
Usable gates 7000 to 15000 to 22000 to 29000 to 36000 to
31000 63000 69000 93000 116000
Logic elements (LEs) 576 I 152 I 728 2304 2880
Logic array blocks (LABs) 72 144 216 288 360
Embedded array blocks 3 6 6 8 10
(EABs)
Total RAM bits 6 144 12288 12288 16384 20480
Maximum user l/O pins 134 189 246 189 310
TABLE 2.Sa
41
Stellenbosch University http://scholar.sun.ac.za
Typical gates (logic and RAM) Note (1) 70000 100000 130000 250000
Usable gates 46000 to 62000 to 82000 to 149000 to
118000 158000 211000 310000
LEs 3744 4992 6656 12 160
LABs 468 624 832 1520
EABs 9 12 16 20
Total RAM bits 18432 24576 32768 40960
Maximum user VO pins 358 406 470 470
Note of tables
(1) For designs that require ITAG boundary-scan testing, the built -in ITAG circuitry contributes up to 31 250
additional gates.
TABLE 2.Sb
42
Stellenbosch University http://scholar.sun.ac.za
A block diagram illustrating the internal structure of the FLEX lOK device is presented in Figure
2.22.
Element
Local
Interconnect
FIGURE 2.22 : DIAGRAM OF INTERNAL STRUCTURE OF FLEX lOK DEVICE
43
Stellenbosch University http://scholar.sun.ac.za
The logic array consists of logic array blocks (LABs) which communicate through a fully
populated local interconnect structure. The LAB consists of Logic Elements (LEs). Each LE
contains a four-input look-up table (LUT) and a programmable register with a local clock enable
control. Each LE then offers a dual-output structure that allows for both combinational and
sequential output. The fast track interconnect routing structure provides communication for both
the LABs and the EABs. Each interconnect row and column feeds multiple I/O elements (IOEs).
With the FLEX 10K family, it is now possible to implement a variety of mega-functions as
efficiently in a PLD as an embedded gate array. The EABs can be used to create ROMs, FIFOs
and asynchronous, synchronous and dual-port RAM. EABs can be configured for various width
and depths without the sacrifice of speed. All logic array capabilities offered by teh FLEX 10K
device remain unaffected by the use ofEABs for memory implementation. With the use ofEABs,
it is now possible to implement specialized arithmetic functions more efficiently than with
traditional logic arrays.
Multivolt I/O Support
The Altera devices offer MultiVolt I/O operation, allowing these devices to interface directly with
other devices of different voltages. Altera's 5,0 Volt range can interface with 3,3 V and 5,0 V
devices.
Internal Tri-state Implementation
The FLEX 10K family provides full tri-state emulation that enables the implementation of the
internal tri-state busses required in this project's design.
Flexible Package Option
Altera offers a range of FLEX 10K devices which support pin-compatibility within the same
packages. This project requires the use of the FLEX 10KIO device in the QFP package. The pin-
compatibility support offered by Altera means that it allows for migration from a 10 000 gate
device (FLEX 1OK10) to the FLEX 10K20, 10K30, 10K40 and 10K50 devices in the same QFP
package
44
Stellenbosch University http://scholar.sun.ac.za
This provides the designer with the option of modifying the PLDs internal design to such an
extent that the densities may increase by 400% while no modifications are required to the PCB.
2.1.10.9 Selection Criteria
A number of factors contributed to the selection of the FLEX 10K device for this project. The
logic density of the FLEX 1OK10 with its 10 000 gates was the smallest component which could
contain the design. The PCB designed for this project has support for FLEX 10K devices. They
are configured in cascade, with the 16-bit address/data bus passing through both devices. The
design methodology, along with the migration support offered for the FLEX 10K devices, allows
the logic density to vary from 2x 10 000 gates to 2x 50 000 gates, using the QFP 144 pin
package.
The FLEX 10K family was primarily chosen for its support of mega-function implementation.
This technology allows for the incorporation of many off-the-shelf building blocks that implement
useful functions such as processors, DSPs, bus controllers and interfaces.
The bus must therefore be able to present a tri-stated state and this requires the feature offered by
the FLEX 10K device.
2.2 The Support Software
All of the source code for this thesis is contained in the CD appended to this thesis.
2.2.1 80C196X A96 Compiler
An overview of the application development process offered by the BSO Tasking software is
presented in figure 2.23.
45
Stellenbosch University http://scholar.sun.ac.za
FIGURE 2.23: BSO TASKING'S APPLICATION DEVELOPMENT PROCESS
The ASM 196 compiler ofBSO Tasking is used to compile the files for microcontroller
initialization (startup.A96), temporary register initialization (tmpreg.A96) and LCD initialization
(LCDinit.A96). The reason for the use of assembly language rather than the C language for
implementation code, is for the purpose of speed optimization.
46
Stellenbosch University http://scholar.sun.ac.za
2.2.2 80C196X C196 Compiler
The Ansi-C compiler ofBSO Tasking is used to compile the source code for the 196
microcontroller-based system. The BSO Tasking compiler offers floating point support for the
80C196. A comprehensive set of libraries are offered as part of the BSO Tasking package.
2.2.3 PLD Programming Support
Cypress's WARP PLD programming software is used to compile, synthesize and simulate the
VHDL code for the GALS used in the PHASE 1 design. Figure 2.24 illustrates the development
process used by WARP.
FIGURE 2.24
47
Stellenbosch University http://scholar.sun.ac.za
2.2.4 Altera's MAX+PLUS II
The MAX+PLUS II programmable logic development system is used in the design of the PHASE
2 CPLD supported system. This provides an architecture independent design environment which
ensures easy design entry, fast compilation and uncomplicated device programming [7].
Figure 2.25 illustrates the MAX +PLUS II design environment.
EDlF Standard
EDA Design Entry
(e.g. Synopsys)
JlIAX+PLUS DCompiler
High Level Design Entry Automatic Error
Location
EDIF Standard
EDA Verification
(e.g. Synopsys)Design-Rule Checking
Graphis Design Entry Logic Synthesis & Fitting Timing Simulation
Text Design Entry Multi-Device Partitioning Functional Simulation
Multi-Device
Simulation
Waveform Design Entry
Timing Driven
Compilation
Timing Analysis
Hierarchical Design Entry
Device Programming
Floorplan Editing OpenCore Evaluation
FIGURE 2.25 : THE MAXPLUS II DEVELOPMENT CYCLE
48
Stellenbosch University http://scholar.sun.ac.za
MAX +PLUS II allows designers to combine text, graphic, and waveform design entry methods
while creating hierarchial single- or multi-device designs. The MAX +PLUS II compiler performs
minimization and logic synthesis, then lists the design into either a single or multiple devices, and
finally generates programming or configuration data.
The software design tool also offers design verification with functional and timing simulation with
delay prediction for speed critical paths. Simulation for multiple devices across multiple device
families is also supported by MAX+PLUS II. Altera's MAX+PLUS II software provides
interfaces to a wide variety of EDA tools. Synopsys is one of many companies with such an EDA
tool. The MAX+PLUS II software and these EDA tools share information via their EDIF netlist
files, SRAM object files (.sot), the library of parameterized modules (LPM), verilog HDL, VHDL
and Designware components.
2.2.5 Microsoft Visual Basic
Microsoft Visual Basic is used to develop a windows based fuel management software program
This program incorporates a microsoft access database, which stores data obtained from the
microcontroller-based system. The data is transferred between the personal computer and the
microcontroller via a RS232 serial communication link. The communication controls and data
packatized of information is coded into the software package. The software program also has
support for viewing a real-time memory map of the remote controller and its configuration. The
program has windows forms displaying data used for diagnostic purposes.
The main forms are presented in Appendix K.
49
Stellenbosch University http://scholar.sun.ac.za
Third-party Custom controls used in the development of the program include:
PDQ Comm controls
Dallas Tag Communication Controls
Real- Time Graphics Controls
Copy-Protection Controls
2.2.6 Microsoft Visual C++
Due to the fact that Visual Basic did not support the binary manipulation required to interpret the
packatized data obtained from the microcontroller, additional math functions had to be created in
Dynamic Linked Libraries (DLLs). These DLLs are developed in the Microsoft Visual C++
development environment.
2.2.7 Tango Design Package
The schematic PHASE 1 of the microcontroller electronic design and all of it's peripherals were
created using the Tango Schematic Entry software. The PHASE 1 printed circuit boards were
created using the Tango PCB software. The routing of the PHASE 1 PCBs was completed using
the Tango Router.
2.2.8 Protei Design Package
The schematic, PCB and routing of the PHASE 2 design is completed using the Protel 99
development software.
50
Stellenbosch University http://scholar.sun.ac.za
Chapter 3
Design of a PHASE 1
Microcontroller-based System using
Gate-level Logic Components
This chapter will review the design of the system consisting of the components illustrated in
Figure 3.1.
51
Stellenbosch University http://scholar.sun.ac.za
Figure 3.2 presents the completed design of the PHASE 1 microcontroller-based system.
FIGURE 3.2 : PHOTOGRAPH OF THE PHASE 1
MICROCONTROLLER-BASED SYSTEM
3.1 Hardware Design
The hardware design of the PHASE 1 system makes use of gate-level logic components with
simple PLDs to perform the function of system control.
52
Stellenbosch University http://scholar.sun.ac.za
3.1.1 Intel80C196KC Microcontroller
The 80C 196KC, 16-bit microcontroller is used in this design because of its comprehensive
peripheral support. The internal peripheral components are presented as implemented in this
design.
3.1.1.1 Design Considerations
Chip Configuration Byte (CCB)
This is the first byte fetched from memory after a device reset. A reset loads the CCB into the
Chip Configuration Register (CCR). The CCR is presented in Figure 3.3.
"7 6 5 4 3 2 0
II II I I I I II II II I I 1
Bit Function
0 =PD (Power-down Enable)
1 =BWO (Buswidth Control)
2 =WR (Write Select Strobe Mode)
3 = ALE (Select Address Valid Strobe Mode)
4 =IRCO (Internal Ready Control)
5 = IRCI Internal Ready Control)
6 = LOCO (Lock Bit 0)
7 = LOCI (Lock Bil I)
FIGURE 3.3 : CHIP CONFIGURATION REGISTER
The CCR control the internal READY mode, bus control signals, bus width operations and
power-down modes. The CCB is located at address 2018H A value ofFFH is written into the
CCB on power-up. This byte configures the microcontroller to allow for wait-states controlled
by the external READY pin.
Horizontal and Vertical Windowing
The 8XC196 supports both horizontal and vertical windowing which implements a scheme of
swapping three 24 byte memory blocks within the lowest 24 bytes of the lower register file. The
horizontal windows with their addresses are presented in Figure 3A.
53
Stellenbosch University http://scholar.sun.ac.za
HWINOOW 0 (Read)
17H
16H
ISH
14H
13H
12H
IIH
IOH
OFH
OEH
ODH
OCH
OBH
OAff
09H
08H
07H
06H
OSH
04H
03H
02H
OIH
OOH
IOS2
lOS I
IOSO
WSR
!NT_MASK I
!NT_PEND I
SP STAT
IOPORT2
IOPORT!
IOPORTO
TIMER2 (HI)
TIMER2 (LO)
TIMERI (HI)
TIMER I (LO)
!NT PEND
!NT MASK
SBUF (RX)
HSI STATUS
HSI_ TIME (HI)
HSI_TIME (LO)
AD_RESULT (HI)
AD_RESULT (LO)
ZERO_REG (HI)
ZERO_REG (LO)
HWINDOW 0 (Write)
PWMO CONTROL
lOCI
lOCO
WSR
!NT MASKI
!NT_PEND I
SP CON
IOPORT2
IOPORT!
BAUD_RATE
TIMER2 (HI)
TIMER2 (LO)
IOC2
WATCHDOG
!NT PEND
!NT MASK
SBUF(TX)
HSO COMMAND
HSO_TIME (HI)
HSO_TIME(LO)
HSI MODE
AD COMMAND
ZERO_REG (l-ll)
ZERO_REG (LO)
54
17H
16H
ISH
14H
13H
12H
IIH
IOH
OFH
OEH
ODH
OCH
OBH
OAff
09H
08H
07H
06H
05H
04H
03H
02H
OIH
OOH
HWINDOW I (Read/Write)
PWM2 CONTROL
PWMI CONTROL
Reserved
WSR
!NT MASKI
!NT_PEND I
Reserved
Reserved
Reserved
Reserved
Reserved
IOC3
Reserved
Reserved
!NT PEND
!NT MASK
PTSSRV (HI)
PTSSRV (LO)
PTSSEL (HI)
PTSSEL(LO)
AD TIME
Reserved
ZERO_REG (HI)
ZERO_REG (LO)
Stellenbosch University http://scholar.sun.ac.za
HWINDOW 15 (Read)
17H
16H
ISH
14H
13H
12H
IlH
IOH
OFH
OEH
ODH
OCH
OBH
OAB
09H
08H
07H
06H
OSH
04H
03H
02H
OIH
OOH
PWMO_CONTROL
lOCI
lOCO
WSR
!NT MASKI
!NT PENDI
SP CON
Reserved
Reserved
Reserved
T2CAPTURE (HI)
T2CAPTURE (LO)
rOC2
WATCHDOG
!NT PEND
!NT MASK
SBUF(TX)
HSO COMMAND
HSO _TIME (HI)
HSO_TIME(LO)
HSI MODE
AD COMMAND
ZERO_REG (HI)
ZERO_REG (LO)
HWINDOW 15 (Write)
IOS2
lOS I
rosa
WSR
!NT MASKl
!NT PENDI
SP STAT
Reserved
Reserved
Reserved
T2CAPTURE (HI)
T2CAPTURE (LO)
TIMERI (HI)
TIMERI (LO)
!NT_PEND
!NT MASK
SBUF (RX)
HSI STATUS
HIS _TIME (HI)
HSI_TIME (LO)
AD_RESULT (HI)
AD_RESULT (LO)
ZERO_REG (HI)
ZERO_REG (LO)
FIGURE 3.4 :80C196KCs HORIZONTAL WINnOWS
Vertical windowing is not used in this design.
55
Stellenbosch University http://scholar.sun.ac.za
3.1.1.2 Standard I/O Ports
The 80C 196KC has five 8-bit VO ports. The port pin functions are listed in Table 3.1
I i8~"Mt~);mmTi: lAsE " ,f&s •.••u: IAji~/ T! LliE W; L.·.SFRr •.•·••·•·•·••.•·••·•,••ruRttVbe .IC i : ....................} .......{mi ..? '."'."' .....
PO Input ACHO-ACH7 Input
Pl.O, Pl.l, Pl.2 Quasi-Bidirectional None
P1.3, PI.4 Quasi-Bidirectional PWMI,PWM2 Output IOC3
P1.5, P1.6 Quasi-Bidirectional BREQ#, HLDA# Output WSR
Pl.7 Quasi-Bidirectional HOLD Input WSR
pi.O Output TXD Output lOCI
P2.1 Input RXD Input or Output SPCON
P2.2 Input EXTINT Input lOCI
P2.3 Input T2CLK Input lOCO
P2.4 Input T2RST Input lOCO
P2.S Output PWMO Output lOCI
P2.6 Quasi-Bidirectional T2UP-DN Input IOC2
P2.7 Quasi-Bidirectional T2CAPTURE Quasi-Bidirectional
P3, P4 Open-Drain ADO-AD IS Bidirectional
Bidirectional
TABLE 3.1 PORT PIN FUNCTIONS
The configuring of the relevant port pins is done by writing to the input/output control registers
(lOCs). Figure 3.5 presents the four control registers lOCO, lOCI, IOC2 and IOC3 with their
configurations as used in this design.
56
Stellenbosch University http://scholar.sun.ac.za
57
7 6 5 4 3 2 0
lOCO Bit Function
0 = Enable HSLO as HSI input
I = Timer 2 software reset
2 = Enable HSLO as HSI input
3 = Timer 2 external reset source
4 = Enable HSLO as HSI input
5 = Timer 2 reset source
6 = Enable HSI.O as HSI input
7 = Timer 2 clock source
7 6 5 4 3 2 0
lOCI Bit Function
0 = Select P2.5/PWM output
= Select external interrupt INT07 source
2 = Enable timer I overflow interrupt
3 = Enable timer 2 overflow interrupt
4 = Enable HSO.4 pin as output
5 = Select P2.0rrxD output
6 = Enable HSO.05 pin as output
7 = Select HSI interrupt source
7 6 5 4 3 2 0
JOC2 Bit Function
0 = Enable timer 2 fast increment
= Enable timer 2 up/down count
2 = Enable PWM clock prescaler
3 = Enable AD_TIME register
4 = Disable ND clock prescaler
5 = Select timer 2 overflow boundary
6 = Enable locked CAM entries
7 = Clear all CAM entries
7 6 5 4 3 2 0
IOC3 Bit Function
0 = Timer 2 internal clock enable
I = Reserved / CLKOUT disable
2 = PWM 1 select
3 = PWM2 select
4-7
FIGURE 3.5 : I/O CONTROL REGISTERS
Stellenbosch University http://scholar.sun.ac.za
The port registers are presented in Figure 3.6.
7 6 5 4 3 2 o
0 = Port Pin 0
I = Port Pin I
2 = Port Pin 2
3 = Port Pin 3
4 = Port Pin 4
5 = Port Pin 5
6 = Port Pin 6
7 = Port Pin 7
Port Accessed by Read operation Write operation
0 IOPORTO Reads the current value of the port pins. The Not possible. Writing to IOPORTO does
port should not be read while an AID not affect Port 0, but does affect the baud
conversion is in progress. rate controller.
1 IOPORTl Reads the current value of the port pins. A Writes change the state of the port pin
port pin may have been written a value of latch. Changing the port pin latch has no
one but return a value of zero because it is effect on a port pin if its alternate function
being overridden externally. has been selected.
-
2 IOPORT2 Reads the current value of the port pins, Writes change the state of the port pin
except those pins that are output only. latch, except those pins that are input only.
Output-only pins return an unspecified value Input-only port pins have no pin latches,
and should be masked by software. so the value written is ignored.
3,4 IFFEH Reads the current value of the port pins. A Changes the state of the port pin latch.
port pin may have been written a value of Any external access of the bus controller
one but return a value of zero because it is overrides the value of the port pin latch to
being overridden externally. Ports j and 4 perform the bus operation. Ports 3 and 4
are always accessed together as a word read are always accessed together as a word
operation. write operation.
FIGURE 3.6 : 80C196KC PORT REGISTERS
Programming the Ports
Each VO port has an associated Special Function Register (SFR) which is used to read or write
the port pins. Not all the port SFRs are readable and writeable. Port 0 is only readable. Port 1 IS
readable and writeable. Port 2 is readable and writeable. The quasi-bidirectional ports 3 and 4
are also readable and writeable. When the value of an output pin is read, it's value is undefined
and should be masked. The port addresses are as follows:
I/O portO
I/O portl
I/O port2
OxOOOEH
OxOOOFH
OxOOlOH
58
Stellenbosch University http://scholar.sun.ac.za
Port 0
Port ° is an input port that is also an analog input for the AID converter. Bits 0, 1, 2 and 3 are
used to read in the columns off the keypad, while bits 4, 5, 6 and 7 are used to read in the status
of the pump nossels (nossel switches). All of port ° is also connected in parallel to an 8-bit bank
of DIP switches. These switches are used to establish board diagnostic routines when the
microcontroller powers-up. The keyboard connections are illustrated in Figure 3.7.
FIGURE 3.7 : PHASE 1 DESIGN PORT CONNECTIONS
Port 1
Port I is an input/output with bits 0, 1, 2 and 3 writing out to the 4 rows of the keypad. Bits 4, 5,
6 and 7 are used to write data to the LCD which is implemented in 4-bit mode. The LCD also has
full support for 8-bit data transfer but due to the port constraints, it was decided to use the 4-bit
mode. A bank of 8-bit leds is connected in parallel to port 1 as illustrated in Figure 3.7.
59
Stellenbosch University http://scholar.sun.ac.za
Port 2
Port 2 is an input/output port with many alternate functions as presented in Table 3.1. The timers
(timer 1 and 2) are used to generate interrupts for timed reading of ports as system status
monitors. Bit 6 is used as a control bit for the LCD, while bit 2 is used to hold the external
interrupt status. Bits 0 and 1 are the transmit and receive status bits used for the internal serial
communication port.
Ports 3 and 4
Ports 3 and 4 are not implemented as the AD bus is fully utilized in the system.
3.1.1.3 Serial I/O Port
The 8XC196KC includes a Universal Asynchronous Receiver and Transmitter (UART) with one
synchronous mode (MODE 0) and three asynchronous modes (MODES 1,2 and 3). Figure 3.8
presents the registers used in control of the serial VO port. In this design, the SP_CON register is
used to select the communication mode and enable or disable the receiver, enable or disable the
parity checking and control the nine-bit data transmission.
60
Stellenbosch University http://scholar.sun.ac.za
7 6 5 4 3 2 0
X X X
SP_CON Register Bit Function
0,1 = Serial communication mode
2 = Even parity enable
3 = Receive enable
4 = 7B8 (transmit bit 8) flag
5,6,7 = Reserved bits
7 6 5 4 3 2 0
X X
SP_ST AT Register Bit Function
0,1 = Reserved bits
2 = Overrun error bit (OE)
3 = Transmitted empty (TXE)
4 = Framming error (FE)
5 = Transmit interrupt (TI)
6 = Receive interrupt (RI)
7 = Receive parity error (PI PE) I Receive bit 8 (RB8)
7 6 5 4 3 2 0
X X X X X X X
INT MASK Bit Function
6 = Enable or masks the serial port interrupt
7 6 5 4 3 2 0
X X X X X X
INT_MASKI Bit Function
0 = Enables or masks the transmit interrupt
I = Enables or mask the receive interrupt
7 6 5 4 3 2 0
X X X X X X X
INT PEND Bit Function
6 = Indicates a pending serial port interrupt and is cleared on interrupt service
7 6 5 4 3 2 0
X X X X X X
INT PENDI Bit Function
0 = Indicates pending transmit interrupt and is cleared on interrupt service
= Indicates pending receive interrupt and is cleared on interrupt service
7 6 5 4 3 2 0
X X X X X X X
IIOCI Bit Function
5 = Enable/disable the TXD function of port 2 bit 0
15 14 13 12 II 10 9 8 7 6 5 4 3 2 0
BAUD_RATE Bit Function
0-14 = Baud rate value
15 = Selects the clock source
7 6 5 4 3 2 0
SBUF(RX) Bit Function
0-7 = Contains the data received from the serial port
SBUF(RX) Bit
0-7
Function
= Contains data ready for transmission
FIGURE 3.8 CONTROL REGISTERS FOR SERIAL COMMUNICATION PORT
61
Stellenbosch University http://scholar.sun.ac.za
Use of these registers in the implementation of the internal serial port can be seen in the flow
diagram presented in the section of software design on the PHASE 1 system. The baud rate of
the communication port can be set by entering a value into the baud rate register. The required
value used in this design was calculated as follows:
BAUDVALUE
Oscillator frequency
- 1
Baud rate x 16
20 MHz
9600x16
129
- 1
Hence the value entered into the Baud _Rate Register is 8081 Hex, since the most significant bit is
set in order that XTAL 1 may be used as the clock source for the baud _rate generator.
62
Stellenbosch University http://scholar.sun.ac.za
3.l.l.4 Interrupts
Table 3.2 presents all the interrupts used in this design.
Special Unimplemented
Opcode
Unimplemented
Opcode
Special
ISINT15
Software Trap
NMI (2)
TRAP Instruction
NMI
2010H
203EH
Each of the following, maskable interrupts can be assigned to the PTS
Any PTS interrupt has priority over all other maskable interrupts
INT14
INT13
HSI FIFO Full
EXTINTI (2)
HSI FIFO Full
P2.2
203CH
203AH
205CH
2S0AH
14
13
INTI2 Timer 2 Overflow Timer 2 Overflow 2038H 2058H 12
INTI I Timer 2 Capture (2) Timer 2 Capture 2036H 20SGH II
INTIO HSI FIFO 4 HSI FIFO Fourth Entry 2034H 2054H 10
9INT09 Receive RI Flag (3) 2032H 20S2H
8INT08 Transmit TI Flag (3) 2030H 2050H
INT07 7EXTINT (2) P2.2 or PO.7 200EH 204EH
INT06 Serial Port RI Flag and TI Flag (4) 200CH 204CH 6
SINTOS Software Timer Software Timer 0-3
Timer 2 Reset
AID Conversion Start
200AH 204AH
INT04 4HSI.O Pin (2) HSI.O 2008H 2048H
INTO3 High Speed Outputs HSO.O-HSO.S 2006H 2046H 3
2INT02 HSI Data Available HSI FIFO Full or HSI
Holding Reg. Loaded
2004H 2044H
INTO I AID Conversion
Complete
AID Conversion
Complete
2002H 2042H
oINTOO Timer Overflow Timer I or Timer 2 2000H 2040H
TABLE 3.2: INTERRUPT VECTOR SOURCES, LOCATIONS AND PRIORITIES
63
Stellenbosch University http://scholar.sun.ac.za
When the microcontroller detects an interrupt, it generates and executes a special interrupt call.
The contents of the program counter are pushed onto the stack after which the contents of the
appropriate interrupt vector are loaded. The upper and lower interrupt vectors in the special
purpose memory contain the addresses of the interrupt service routine. The CPU executes the
interrupt service routine at the relevant address. Once the service routine has been completed, the
program counter is reloaded from the stack allowing program execution to continue.
The priorities of the interrupts are as indicated in Table 3.2. The interrupt priorities are altered in
this design by controlling the interrupt mask registers. The registers flagging and controlling the
interrupts are presented in Figure 3.9.
64
Stellenbosch University http://scholar.sun.ac.za
7 6 5 2 o4 3
INT MASK Bit
o
1
2
3
4
5
6
7
7 6
Functions
= TIMER MASK
=AD MASK
= HSIDAT MASK
=HSO MASK
= HSIO MASK
= swr MASK
=SER MASK
= EXTINT MASK
5 4 3 2 o
INT MASKI Bit
o
1
2
3
4
5
6
7
7 6
Functions
= TI MASK
= RI MASK
= HS14_MASK
=T2CAP MASK
=T20VF MASK
= EXTINTI MASK
= FIFO_MASK
=NMI_MASK
5 4 3 2 o
INT PEND Bit
o
1
2
3
4
5
6
7
7 6
Functions
= TIMER PEND
=AD PEND
= HSIDA T PEND
= HSO PEND
= HSIO PEND
=swr PEND
= SER PEND
= EXTINT PEND
5 4 3 2 o
INT PEND I Bit
o
I
2
3
4
5
6
7
Functions
= Tl PEND
= RI PEND
= HSI4 PEND
= T2CAP PEND
= T20VF PEND
= EXTINT I PEND
= FIFO PEND
=NMI PEND
FIGURE 3.9 : INTERRUPT CONTROL REGISTERS
The interrupt pending registers set their bits as flags to indicate the occurrence of the relevant
interrupts.
65
Stellenbosch University http://scholar.sun.ac.za
3.1.1.5 Operating Modes
the 8XC 196 micro controller supports three special operating modes. The Idle, Power-down and
On-circuit Emulation (ONCE). All three modes are included in this design. Both the Idle and
Power-down modes reduce the power consumption while the ONCE mode is a test mode that
electrically isolates the chip from other system components.
The Idle Mode
The CPU clocks are frozen, but the external peripheral clocks (CLKOUT) remain active, allowing
the external devices to maintain operation if required. No instruction are executed, but internal
RAM, timers, counters, serial ports and interrupt systems remain functional. This reduces the
microcontroller's power consumption by about 40%. During this mode, the address/data bus
floats externally. The IDLPD #1 (idle/power-down) software instruction controls the entry or
exit of the idle state.
The Power-down Mode
The power-down mode places the microcontroller into a very low power state. In this mode, all
of the peripherals are powered down and the external peripheral clock (CLKOUT) is frozen at
logic state zero The power consumption is reduced to the microwatt range. During this mode,
the address/data bus floats externally. The IOLPD #2 (idle/power-down) software instruction
controls the entry of the power-down state. In order to exit the power-down state, the Vpp pin
must be driven low or the /RESET pin must be asserted or the external interrupt must be
generated. The power-down mode is disabled when the PO bit (bit 0) of the CCR is cleared (refer
to Figure 3.2).
The ONCE Mode
This mode is a test mode used to electrically isolate the microcontroller from other devices on the
PCB. This mode is used purely for test purposes in the PHASE 1 design, but the PHASE 2
design requires this mode while the CPLOs are being configured. All of the pins, except the
XTAL1 and XTAL2, have weak pull-ups or pull-downs and are not high impedance. The
/RESET pin must remain high during the ONCE mode execution. The ONCE mode is entered if
port 2 bit 0 is held low during the rising edge of !RESET. To exit the ONCE mode, the port 2 bit
o must float while the /RESET pin is asserted.
66
Stellenbosch University http://scholar.sun.ac.za
3.1.1.6 Timing Considerations and Calculations
The timing diagrams and analysis of the PHASE 1 design is presented in Appendix A. All the
calculated values are based on the 80C 196KC operating at 20 MHz. The values are taken from
the November 1994 version of the 80C 196KC Commercial/Express CHMOS microcontroller data
sheet. The Intel order number is 270942-005.
3.1.2 Programmable Logic Devices (PLDs)
The PLDs used in the PHASE 1 design are the 22VI0Ds from Cyprus. This Generic Array Logic
Device (GAL) is chosen for its pin support and its internal capacity. The GAL is used to provide
the additional control signals required for the system to operate. The GAL also allows for the
implementation of a state machine for generating the required wait-states. These wait-states are
used in conjunction with external logic to lengthen the ALE pulses as well. This provides for full
extended access times supporting a range of components.
67
Stellenbosch University http://scholar.sun.ac.za
3.1.2.1 Control Signals
The capacity requires that two GALs be used to implement the required logic support. Tables 3.3
and 3.4 present the control signals as used in both GALs. Appendix C presents a detailed
memory map of the peripheral control signals. The physical connections of both GALs are
illustrated in the schematic of the PHASE 1 design presented in Appendix L.
1,.Em' - iii ...'·.... IrmW;'-ri .. J.,; ••••··.·.·y( G II ;;[ \~PI1~~ I................ rpy i c .•.•·•.•...•···.·.·•····•• ) )iCLKOUT INPUT CLOCK 8XC196KC system clockout ---
STALE INPUT ACTIVE HIGH Stretched address latch enable ---
/HOLDA INPUT ACTIVE LOW 8XCI96KC hold acknowledge ---
A8 INPUT ACTIVE HIGH Latched address ---
A9 INPUT ACTIVE HIGH Latched address ---
AIO INPUT ACTIVE HIGH Latched address ---
AI I INPUT ACTIVE HIGH Latched address ---
A21 INPUT ACTIVE HIGH Latched address ---
A3 INPUT ACTIVE HIGH Latched address ---
AI4 INPUT ACTIVE HIGH Latched address ---
AI5 INPUT ACTIVE HIGH Latched address ---
!RESET INPUT ACTIVE LOW Reset pin ---
fCS510 OUTPUT ACTIVE LOW Enable the external UART IEOOH-IEFFH
fCE2 OUTPUT ACTIVE LOW Enable the NVSRAM COOOH-FFFFH
/BUS WIDTH OUTPUT ACTIVE LOW Place processor in 8-bit mode IEOOH-IEFFH
OUTO OUTPUT ACTIVE HIGH State counter bit 0 ---
OUTI OUTPUT ACTIVE HIGH State counter bit 1 ---
fWAITE OUTPUT ACTIVE LOW Hold 8XCl96KC in a wait-state ---
OUT2 OUTPUT ACTIVE HIGH State counter bit 2 ---
ICEO OUTPUT ACTIVE LOW Enable both EPROM devices 2000H-BFFFH
ICEI OUTPUT ACTIVE LOW Enable both SRAM devices OOOOH-OFFFH
lOOOH-llFFH
INST INPUT ACTIVE HIGH Select for memory overlap ---
TABLE 3.3 : GAL NO 1 PINOUT
68
Stellenbosch University http://scholar.sun.ac.za
IY(
m
t :t:: I' :,: \tiff ',U V \~r ::,':: ll;;' ;1;:;;':::::0:: ::::::' I"/"'·'::::·}:····::··:::·:/: .iT ,:,',I
Al INPUT ACTIVE HIGH Latched address ---
A2 INPUT ACTIVE HIGH Latched address ---
A3 INPUT ACTIVE HIGH Latched address ---
A9 INPUT ACTIVE HIGH Latched address ---
AlO INPUT ACTIVE HIGH Latched address ---
All INPUT ACTIVE HIGH Latched address ---
Al2 INPUT ACTIVE HIGH Latched address ---
Al3 INPUT ACTIVE HIGH Latched address ---
Al4 INPUT ACTIVE HIGH Latched address ---
Al5 INPUT ACTIVE HIGH Latched address ---
IRD INPUT ACTIVE LOW Read signal issued by 80CI96KC ---
fWR INPUT ACTIVE LOW Write signal issued by 80Cl96KC ---
CELED OUTPUT ACTIVE HIGH Enable the leds indicating pump active lC06H
DIPSWI6 OUTPUT ACTIVE HIGH Enable the lo-bit diagnostic switches IC04H
CEI OUTPUT ACTIVE HIGH Enable I2-bit counter no I IC06H
CE2 OUTPUT ACTIVE HIGH Enable l2-bit counter no 2 lC04H
CE3 OUTPUT ACTIVE HIGH Enable 12-bit counter no 3 lC02H
CE4 OUTPUT ACTIVE HIGH Enable 12-bit counter no 4 lCOOH
CSRELAY OUTPUT ACTIVE HIGH Enable the write to pump relays lCOOH
RESA OUTPUT ACTIVE HIGH Reset counters I, 2 or 3 IC08H
RESB OUTPUT ACTIVE HIGH Reset counters 1,2 or 3 ICOAH
RES4 OUTPUT ACTIVE HIGH Reset counter 4 lCOEH
TABLE 3.4 : GAL NO 2 PINOUT
3.1.2.2 Wait-state implementation
The Moore machine is used to implement a wait-state in the PHASE 1 hardware. The machine is
coded in VHDL and programmed into a 22V 10 GAL The implemented machine offers a
selection of up to six wait-states which are fed to the WAIT# output pin on the GAL. This
WAIT# pin controls the READY input pin on the 196 microcontroller. The READY pin on the
196 microcontroller is an active high input pin which indicates that external memory is ready to
69
Stellenbosch University http://scholar.sun.ac.za
send or receive data. While the READY pin is held low, the bus controller inserts wait-states into
the bus cycle. In order to implement the wait-states into the 196 microcontroller, the CCR (Chip
Configuration Register) bits 4 and 5 in the Chip Configuration Register (CCR) of the
micro controller must be asserted to allow the READY signal control of wait-states.
A schematic diagram illustrating pin connections is included in Appendix L. A simulation
displaying 1, 2 and 3 wait-states as required by the external components is presented in Figures
3. 10 and 3. 11.
FIGURE 3.10
FIGURE 3.11
70
Stellenbosch University http://scholar.sun.ac.za
The VHDL code listing for the state machine is presented in Appendix J-l. The state diagram for
the Moore machine implemented is given in Figure 3. 12.
async_start hold2
FIGURE 3.12: STATE DIAGRAM OF MOORE MACHINE FOR WAIT-STATES
3.l.2.3 PLD Programming
The PLDs are programmed in VHDL since the language supports hierarchies, re-usable
components, error management and verification. All of these features allow the design to be
continually altered to support the components used in the design. The VHDL components are
designed technology-independent, allowing libraries of existing components to be used, requiring
little effort. The VHDL code is functionally verified with the WARP simulator.
The VHDL code used in the PHASE 1 GALs makes use of both concurrent and sequential data
processing. Figure 3.13 illustrates the structural use of both constructs in this design.
71
Stellenbosch University http://scholar.sun.ac.za
Architecture GAL 1 of design is
concurrent declaration part
begin
concurrent VHDL
process ( ....)
sequential declaration part
begin
sequential VHDL
end process;
1 The process is oneconcurrent statement
concurrent VHDL
end;
FIGURE 3.13: VHDL CONSTRUCTS
3.1.3 Intel 82510 UART
The 82510 is used because of its vast range of configurable options. The 82510 has banks of
registers which are used to control the operation of the device.
3.1.3.1 Control Signals
The 82510 has an L'O peripheral interface, a demultiplexed bus (8-bit data bus and 3 address
lines), Interrupt, Read, Write, Chip Select and Reset pins which make up the system interface. A
block diagram of the 82510 is presented in Figure 3.14.
72
Stellenbosch University http://scholar.sun.ac.za
INf TIMING
BLOCK
(BRGS, SYS CLOCK)
l\K)DEM
INIFRFACE
l\K)DULE
INfERNAL
FIGURE 3.14
The four banks of registers provide support for the seven functional blocks shown in Figure 3. 14.
The registers allow configuration, provide status information about events/errors and may be used
to send commands to each of the functional blocks. In this design, the 82510 is used as a
communication interface to the Dallas touch memory. The two baud-rate generators/timers and
on-chip crystal oscillator provide the functionality required for the Dallas touch memory interface.
The register map for the UART is attached in Appendix D. The pin connections and schematic
diagram for the UART can be found in Appendix L. The package outline can be seen in Figure
3.15.
73
Stellenbosch University http://scholar.sun.ac.za
INTEL
82510
ASYNCHRONUOS
SERIAL CONIROLLER
FIGURE 3.15:
3.1.3.2 Timing Considerations
The timing equations for interfacing the 82510 with the microcontroller are as follows:
74
Stellenbosch University http://scholar.sun.ac.za
Read Cycle
Address to Read Low Tclcl - Tclavmax+ Tclrlmn
- Latch Delaymax
2Tclcl - Tclr~ - Tclvcl
- Transceiver Delaymax
Trlrh
2Tclcl- 46
Read Access Time
Read Active Time
Write Cycle
Address Valid to Write Active Tclcl + Tcvctrmin - Tclavmax
- Latch Prop Delaymax
Twlwh
2Tcld - 40
2Tclcl - Tcldvrnax
- Transceiver Delaymax+ Tcvctv.j,
Write Active Time
Data Valid to Write Inactive
For this design
Ready Cycle
Read Access to Data Valid
82510 Trldv
additional time required
Read active width
82510 Trlrh
additional time required
Address Valid to Read Active
82510 Tavrl
This indicates that additional wait-states are required for this design.
3.1.4 Non-volatile Memory/Real-time Clock
A device is required for the retention of data acquired during system operation. In order to retain
the data during power-loss, a non-volatile SRAM device had to be selected, but the requirement
of a real-time clock led to the selection of a device with support for both real-time clock and
NVSRAM. The DS1244Y Phantom clock manufactured by Dallas Semiconductor was chosen
for this purpose. The package outline is presented in Figure 3. 16.
75
Stellenbosch University http://scholar.sun.ac.za
DS1244Y
256KNVSRAM
WI1H
PHANfOM CLOCK
FIGURE 3.16 :
3.1.4.2 Phantom Clock Operation
The micro controller communicates with the phantom clock once pattern recognition is established
on a serial bit stream of 64 bits. This bit stream must be matched by executing 64 consecutive
write cycles containing the proper data on DQO (data pin 0). All of the other chip accesses which
occur before the recognition of the 64-bit pattern is directed to memory
76
Stellenbosch University http://scholar.sun.ac.za
Directly after the recognition is established, the next 64 read or write cycles will either extract or
update data in the phantom clock chip. During this time, memory access is inhibited. The write
cycles generated to gain access to the phantom clock are also writing data into the memory
location in the matched RAM. To avoid overwriting data in the RAM, one address location in the
RAM is set aside as a phantom clock scratch pad. Once a bit stream match is established, the
pointer increments to the next location and waits for additional write cycles. If a read cycle is
encountered before the full 64 bits of clock data is read, the clock access is aborted.
The clock information is contained in 8 registers of 8 bits, making up the 64 bit stream containing
clock data. Reading or writing registers, requires that all registers are read or written, starting
with bit 0 of register 0 and ending with bit 7 of register 7. Figure 3. 17 presents the phantom
clock register definition as programmed in this project.
77
Stellenbosch University http://scholar.sun.ac.za
FIGURE 3.17 :
The control sheet used to format the data required for updating the phantom clock is presented in
Appendix E.
78
Stellenbosch University http://scholar.sun.ac.za
3. 1.5 Peripheral Interfaces
The peripheral components interfaced to the 80C 196KC microcontroller are discussed in more
detail in this section.
3.1.5.1 Keypad
The keypad is the main user interface with its columns driven via 4 bits from port 1 and the rows
read via 4 bits from port O. This is illustrated in Figure 3.7. The driving capacity of 20 rnA is
sufficient to obtain secure input from the keypad. A debounce routine is included in the software
in order to improve the key press operation.
3.1.5.2 Liquid Crystal Display (LCD)
the LCD used is a 16x4 LED backlight display. The LCD control is performed by port 2 bit 6 and
port I bits 4, 5,6 and 7. The LCD can be interfaced with a 4 bit address/data bus or an 8 bit
address/data bus. This design uses the 4 bit option. The intensity and backlighting is controlled
via hardware as illustrated in Figure 3.7 or Appendix L. Appendix F presents the LCD control
data required to configure and communicate with the LCD.
3.1.5.3 Pump Status Indicators
A set oftri-color LEDs are used to provide status indication for the pumps controlled by the
system. The hardware design allows the LEDs to be forced into one of the colors indicating
unused pumps. This implies that the system designer has the option to drive any LED colors as
required. The LEDs are driven via the ULN2803A darlington pair drivers. The output current
from the ULN2803A is controlled via in-line resistors to control LED intensities.
79
Stellenbosch University http://scholar.sun.ac.za
3.1.5.4 Input/Output Signals for Pump Control
The microcontroller-based system monitors the status of the pump nossels. This is accomplished
'.
by feeding the input signals through Schmidt triggers and into the 4 input pins of port O. This is
illustrated in figure 3.7. The pumps are enabled by the micro controller via four interpolar relays.
The relays are 47 Watt, 5 Volt PCB mounted relays. The interpolar relays are driven by a
ULN2803A darlington driver. The darlingtons are switched via tri-state latches of the
address/data bus of the system.
The four asynchronous pulse counter outputs are fed onto the micro controller data bus via
Schmidt triggers and 74LS541 tri-state latches. A buzzer is also driven via an interpolar relay ..
The buzzer is used to provide an audible indicator for user confirmation of Dallas tag or keypad
input.
3.1.5.5 System Diagnostics
A diagnostic mode is entered on power-up of the system if any of the DIP switches in the 16 bit
bank are asserted. The diagnostics modes vary according to the state of the bank of DIP
switches. The diagnostics program test the following:
NVSRAM read and write cycles
16-bit SRAM read and write cycles
all pump status indicators
LCD initialization and control
all relay driven outputs
all keys on the keypad
data integrity via the communication link
Dallas tag communication
counter inputs
80
Stellenbosch University http://scholar.sun.ac.za
3.l.5.6 Dallas Tag Communication Interface
The hardware configuration for the Dallas touch memory requires a I-wire bus consisting of a
single line. Due to the feature that multiple tags can be connected to the bus simultaneously, each
device must have an open drain connection or a tri-state output. The DS 1996 used in this design
has a open drain configuration as shown in Figure 3.18.
FIGURE 3.18 :
At the regular speed, the bus has a maximum data rate of 16,3 k bits/second. The speed is
boosted to 142 k bits/second by activating the overdrive mode. A pull-up resistor of 5 kQ is
required by the l-wire bus. All of the transactions on the l-wire bus begin with an initialization
sequence. This sequence consists of a reset pulse transmitted by the bus master which is followed
by a presence bus transmitted by the slave (tag). The reset pulse width (tRSTL) is 480 f1S minimum
for regular speed operation and 48 f1S minimum for overdrive speed operation. The timing
diagrams can be found in [64].
81
Stellenbosch University http://scholar.sun.ac.za
The schematic for the hardware developed for communication with the Dallas touch memory is
presented in Figure 3. 19.
V+l
D2
6V2
GND D3
SCHOTTKY
RXD TAG
CON2
TXD TAG
D4
SCHOTTKY
FIGURE 3.19
82
Stellenbosch University http://scholar.sun.ac.za
The same hardware is used for communication with a pc and the microcontroller board, since it is
interfaced via the RS232 serial communication port. The Dallas touch memory devices used in
this project are listed below with their functions:
DS1991
DS1994
DS1996
used as either a driver or vehicle identification and interrogation
used as a system configuration and real-time clock tag
used to transfer data blocks form remote system to pc
The memory maps for the DS 1991, DS 1994 and DS 1996 as used in this design, are presented in
Appendix Z-I, Z-2 and Z-3.
3.1.5.7 RS232 Communication Support Hardware
The micro controller-based system has one internal UART and one external UART. The internal
(on-chip) UART located on the 80C196KC is used to provide the communication link between
the system and a remote personal computer (pc). The baud rate for the serial link can be adjusted
between 9600 baud and 19 200 baud. The data transferred between the two systems is tested
against error with the use of a 16-bit CRe. The communication makes use of software
handshaking for data transfer.
The distance between the controller-based system and the host pc may vary between 5m and
100m. A twisted pair cable with common ground may be used for short distances, but the
attenuation is too great over larger distances. Because of this factor and the danger of lightning
strikes damaging the equipment, optic fiber or radio communication provides a safer alternative.
All three options are presented:
Optic Fiber
Both the plastic and glass fiber provide protection against voltage spikes, EM! and radio
frequencies, but glass fiber with its associated components, is up to 10 times more expensive than
plastic fiber. The glass fiber connections use laser diodes or high-end LEDs as a light source,
while plastic fiber uses simple, inexpensive and widely available LEDs and photo diodes. The
plastic fiber used in this design is both rugged and inexpensive. The optical fiber is composed of a
83
Stellenbosch University http://scholar.sun.ac.za
polymethylmetha-crylate (PMMA) core which is encased in fluoride-based carbon polymer. The
cable has a diameter of approximately 2,2mm when coated.
..
The plastic fiber, when used over short distances with allowances for attenuation, can be
effectively cleared and finished with a heated blade or hot plate. Recent experiments with this
plastic fiber have demonstrated speeds in the gigabit per second range. Different wavelengths
have varying attenuation characteristics and must be selected based on the application. The
emitter and detector used in this design operate in the 650nm range of red visible light and is
suitable for optical transmission at up to 100m. It is important to note that the maximum data
rate is heavily influenced by the following:
distance
attenuation of the fiber
loss due to connections
sensitivity of the detector
The fiber used in this design is relatively inexpensive, and supports a baud rate of up to 19 200 for
minimal error transmissions. A board converting the RS232 to optic pulses had to be designed.
The completed board is displayed in Figure 3.20. The schematic PCB and bill of materials of the
conversion board are presented in Appendix H.
84
FIGURE 3.20: PHOTOGRAPH OF RS232 TO I-WIRE COMMUNICATION SYSTEM
The design use a LM311 to amplify the transmitted signal from the TXIN pin of the RS232 port
sufficiently to drive the transmitter diode. The transmitter diode used has a wavelength of 650nm
which places it in the visible range. This supports visual inspection for diagnostic purposes. With
the correct feedback design and set references, the incoming light pulses detected by the photo
diode are fed through a precision amplifier CA314DE once offset against a common reference
This output can be monitored via a monitor pin. This output is then passed through another
LM311 amplifier which is then fed to the RXOUT pin of the RS232 port These connections are
shown in the schematic in Appendix H.
Radio Link
The radio transmission is accomplished with the use of a transceiver module manufactured by
Radiometrix. Only the peripheral hardware required for the conversion ofRS232 to the interface
format provided by the module had to be designed. Transmission occurs at a frequency of 433
MHz and the band is prepaid by the manufacturer. The range is limited to 120m outside of
buildings by the module design. One module is connected to the microcontroller-based system
and the other to the remote pc.
85
3.1.6 Supervisory Control Circuitry
As discussed in section 3.l.4 the NVSRAM used to store the data is the DS 1244Y Ie write
protects itself for any voltage below 4.25 V. This is however insufficient and test conditions
yielded results to support this. Data corruption still occurs under conditions where data is
currently being processed in the event of a power failure. In order to overcome this problem,
additional hardware is utilized.
Figure 3.21 represents the system which uses both the DS 1233 10% and DS 1233 5%, 5 Volt
econo-reset semiconductor chips manufactured by Dallas Semiconductor.
vee
U31
NMlI 6 5·r----~2---1 GNDH-t--_-----,;4'---i IRESET GND j------,
~~---~3~ vee
MC74FI4
DSI233-5%
vee
U32
.-- ....::;2'---iGND
4 !RESET GND f----l-.--J
~~---~3~ vee _j _l_
Me74FI4 12 lWo
-
RESPIN2 10
POWER SurPL Y MONITORS
FIGURE 3.21 :
86
In the event ofa 5% voltage drop from Vee, the DS1233 5% component issues a signal connected
to the non-maskable interrupt service routine of the 196 microcontroller. This service routine
withdraws all of the data and addresses from the busses and places the micro controller into an idle
state. If the supply voltage rises again without falling below 10% of Vee, then the microcontroller
will time-out of the interrupt service routine after a set interval to resume with processing.
If the supply voltage however continues to fall below 10% of Vee, then the DS1233 10% will
issue a signal resulting in a total reset of the microcontroller based system.
3.1.7 Electromagnetic Interference Reduction Techniques
The Electromagnetic Interferences (EMI) are the electrical noises other than those inherent in the
circuit components. Supply line transients are EMIs resulting from the switching of heavy loads
onto off AC or DC power lines. Figure 3.22 shows a typical circuit presenting these transients.
FIGURE 3.22 : SWITCHING CIRCUIT WITH TRANSIENTS
Ifboth loads R, and R2 draw current, the line current flowing through the line inductance
establishes a magnetic field of some value and when anyone of the loads are switched off, the
inductor generates a voltage transient called an "inductive kick". This is worse when the switch is
opened. The design must should be modified to avoid this.
87
Noise in ground lines which are referred to as ground loops should also be avoided. When two
earth-grounds are at different potentials, an unwanted current is established in the wire. Radio
Frequency Interference (RFI) can cause noise in the form of electromagnetic radiation. To
overcome this noise, effective shielding techniques are required. In the ground loop, the area of
the loop is what matters. If the feed and return paths are parallel to each other, the magnetic
fields will cancel out, thus this is the best solution to the problem and where possible is
implemented in this design.
The best way to minimize loop areas is to use a ground plane. This may be expensive and an
alternative is to use the gridded-ground PCB layout. This technique is implemented in this design.
Ground traces are laid out between signal traces where possible. This is done with vertical traces
on one side of the PCB and horizontal traces on the other side. These must be connected by a
through feed. The hardware (relay) and signal grounds are kept separate to avoid interference of
noise on the signals.
Due to the fact that the current loop in the typical power supply is a relatively large one, a fair
amount of noise is picked up. A typical circuit is shown in Figure 3.23 where a load is trying to
draw current spikes from a supply voltage through the line impedance.
FIGURE 3.23 : DECOUPLING CAPACITORS IN SWITCHING CIRCUITS
88
A decoupling capacitor is added to the circuit as shown in order to supply the current spikes
through a smaller line impedance. The temptation to add a resistor or inductor for a filter should
be avoided since it would lead to slowing down the speed which the decoupling cap is refreshed
[19]. The two types of decoupling caps used in this design are the board decoupling capacitors
and the chip decoupling capacitors. The board decoupling caps are normally 10 to 100 ,uF
electrolytic caps placed near where the power supply enters the board. These caps are to refresh
the charge of the chip decoupling caps. The chip decoupling caps are ceramic and are normally
0,1 to 1 ,uF placed as near to the chip as possible.
3.1.8 Cost-effective Design Methodology
The micro controller system has five memory sockets. The sockets can be populated with either
ROM or RAM. The RAM and ROM can be configured for both 8 or 16-bit operation with the
aid of jumper settings. The 80C 196KC also has support for 16 K of on-chip ROM. This implies
that the minimum external memory may be one 8-bit RAM chip. The lEA pin on the 80C 196KC
microcontroller sets the ROM as internal or external memory. The real-time clock required by the
system is provided on a 32 K byte phantom clock which is a non-volatile RAM chip with a clock
built into it. The JEDEC pinout of the DIP package also supports the use of a smart socket
supplied by Dallas Semiconductor. This socket has a battery built into it for converting volatile
memory to non-volatile memory.
The design includes two UARTS, one internal and one external. Ifrequired, the external UART
may be omitted where either the Dallas tag is not required or the serial communication link is not
required. The plastic fiber used is far cheaper to purchase and install than the glass alternative.
The complete AddresslData bus with control signals is made available via a 60 way IDC header.
This is to facilitate future development where additional interface boards need to be added to the
system. The board was routed as a double-sided board in order to make prototyping and fault-
finding easier.
89
3.2 Software Design
3.2.1 Microcontroller Program
The BSO tasking assembler and C compiler was used to compile the source code for the
80C 196KC. A flow diagram is presented with the source code in Appendix I.
3.2.2 Generic Array Logic Program
A GAL (generic array program) is used to perform the function of controlling access to the
external devices connected to the 80C196KC microcontroller. The VlIDL code programmed into
the GAL has a static component and a sequential logic component. The chip select control
signals are generated using the static logic component while the state machine implementation is
done in the sequential component. The high and low write control signals (/WRH, IWRL) are
also generated with the help of the BUSWIDTH signal issued by the GAL. The VlIDL code was
compiled, synthesized and simulated using the 'WARP' software package supported by
CYPRUS.
A screen plot from a logic analyzer presenting the wait -states required by the external UART, 16-
bit EPROMS, 8-bit NVRAM and the 12-bit counters are presented in appendix T.
The results from the synthesis, simulation and software analysis software used (WARP) is
presented in Appendix J-3. The software simulation is verified with the aid of a hardware logic
analyzer. These waveforms are presented in Appendix K.
3.2.3 PC Based Program/or Serial Communication Link
The software code written in visual basic is included on the attached CD, with only the windows
forms and operation brochure presented in Appendix K.
90
3.3 Manufacture and Implementation of PHASE 1 System
3.3.1 Printed Circuit Board Design
The system design was entered into the ACCEL Tango schematic package located on a pc with
the DOS 6 operating system. A netlist file was then generated from the completed schematic.
The footprints for the required components were placed on the board outline in the ACCEL
Tango PCB package. The netlist was the loaded into the PCB software and the board was routed
according to the required setting using the ACCEL Tango Router package. Further modifications
were made to the PCB to reduce the possible electromagnetic interferences (EMI). The
schematics and PCBs of the PHASE 1 system are presented in Appendix L.
3.3.2 Power Supply
A switch-mode power supply is used to provide power to the system. The design of the power
supply incorporates an "off-the-shelf' device since it was found that the development of a similar
device would have proven far more expensive. The power supply is a standard 250 Watt personal
computer power supply. The microcontroller board has three transorbs, 5V, 12V and
-12V devices placed across the supplies. The transorbs are used mainly for transient suppression
and protection against reverse polarity. The non-volatile memory is backed by a 10 year
guaranteed battery to assist in the avoidance of memory loss. Capacitors are used in the circuit to
suppress further voltage transients created by switching external inductive loads.
91
3.3.3 System Installation
The system is installed in a rigid state structure with the external connections as illustrated in
Figure 3.26.
FIGURE 3.26 :
92
3.4 Commissioning and Field Tests of PHASE 1 System
On completion of the system installation a comprehensive diagnostic sequence is followed. This
sequence tests all of the peripheral components, the memory block, Dallas tag communication and
the serial communication link.
3.4. 1 Problems and Solutions
3.4. 1. 1 System Corrosion
The PCBs and wire connectors developed corrosion which may eventually have led to increased
noise and poor conduction. The PCB was then coated and the connectors cleaned with contact
cleaner and sealed.
3.4.1.2 Overheating
The main microcontroller board developed timing problems due to an increase in temperature
brought about by poor ventilation in and high ambient temperatures. Some of the component
grades were altered to accommodate greater temperature fluctuations A small fan with
additional ventilation openings were introduced to solve the problem.
3.4.1.3 Transient Voltages
The system was severely damaged by inductive-kicks produced when external relays were
switched under load. The circuit responsible for the transient is similar to that of Figure 3.24. A
voltage spike similar to that shown in Figure 3.24 was superimposed on the 15 V supply. This
disturbance resulted in the destruction of the 80C196KC microcontroller. A 0,1 ,uF 250 V
decoupling capacitor was installed to irradicate the problem The solution proved successful
93
3.5 Recommendations for Improvements to the PHASE 1 System
It is recommended that the component count be reduced on the board in order to minimize
possible fault occurrences and component costs. The power consumption needs 1"0 be reduced in
order to reduce the fault possibilities. Greater configurability needs to be offered by the system in
order to provide a more versatile system. Improved peripheral support is required for the addition
of larger control systems.
Hardware offering "plug-in" replacements for a range of gate densities is a necessity. The
replacement of most gate-level components with a CPLD, would reduce the EMI of the PCB and
provide most of the recommendations mentioned above.
It would also allow for a reduction of fault diagnosis and repair time. Any future upgrades may
then be simulated prior to implementation, reducing development time. The inclusion of further
transient suppression techniques is recommended with the use of in-line fuses.
94
Chapter 4
Design of a PHASE 2
Microcontroller-based System using
Complex Programmable Logic
Device Technology
4.1 PHASE 2 Hardware Design .
The new PHASE 2 design incorporating the two FLEX 1OKCPLDs is presented in figure 4.1.
FIGURE 4.1 : PHOTOGRAPH OF THE PHASE 2
CPLD INCORPORATED DESIGN
95
All of the conclusions and recommendations drawn from the PHASE 1 design are implemented in
the PHASE 2 design in order to produce an improved product.
4.2 Alterations to PHASE I Hardware Design
In order to implement the necessary recommendations made on the PHASE 1 design, the
following improvement were made.
4.2.1 Memory Map
The original memory map of the 80C 196KC microcontroller system only provided for a 64 K
memory block whereas the new PHASE 2 design makes use of the INST pin on the
microcontroller. This supports ROM and RAM overlap by differentiating between instructions
and data. The greater gate density offered by the use of CPLD allows for the implementation of
support for eight pump control instead offour. Appendix C-2 presents the new peripheral I/O
addresses.
4.2.2 Supervisory Control Circuitry
Figure 4.2 represents the circuit configuration implemented for the second system.
R6
IOK
FIGURE 4.2
96
This system uses the MAX 695 chip manufactured by MAXIM. This supervisory circuit is
designed to provide the following:
an adjustable low voltage reset signal
a non-maskable interrupt issued as power failure warning
RAM write protection by controlling the chip select line of the memory
an adjustable watchdog timer to verify software execution
a battery-backed power supply voltage
automatic battery switch-over on adjustable variation between battery voltage and Vcc
As can be seen from Figure 4.2, the NVSRAM is powered from VOUT'VOUTis the voltage output
which is internally connected to Vcc when 5 Volt power is present, or to the battery supply (VBAT)
when Vcc is less than the battery voltage. VOUTis capable of supplying up to 50 rnA. The
additional current is provided via the external pnp transistor.
A voltage detector monitors Vcc and generates a reset output to hold the microcontroller's reset
line low when Vcc is below 4,65 Volt. An internal monostable holds the reset line low for 50
milliseconds after Vcc rises above 4,65 Volt. This prevents the repeated toggling of the
microcontroller's reset line. The MAX695 issues a non-maskable interrupt to the microcontroller
when a power failure occurs. The supply voltage (Vcd is monitored via two external resistors
connected to the power fail input (PFI). When the voltage at PFI falls below 1,3 Volt, the power
fail output (PFO) drives the microcontroller's non-maskable interrupt (NMI) low. If a power fail
threshold voltage of 4,8 Volt is chosen, the microcontroller will have the time when Vcc falls from
4,8 Volt to 4,65 Volt to save the data into NVSRAM.
The design allows for the sequence where the MAX695 issues the first interrupt as a power fail
warning at 4,8 Volt. If the microcontroller is not already in the non-maskable interrupt service
routine (ISR) when the supply voltage has fallen to 4,75 Volt, then the DS 1233 5% will initiate
the interrupt and force the microcontroller into the (lSR). From this it can be seen that the
97
DS 1233 5% is the backup for the MAX695 for initiating the NMI. The microcontroller reset line
is pulled low either by the MAX695 or the DS1233 10% at 4,65 Volt after the necessary
"housekeeping" has been performed on the system. This is done to avoid data corruption in the
two CPLDs which are programmed via an EPC 1441 serial EPROM. The system is designed to
reconfigure the two CPLDs on a system reset. A backup is provided irrespective of the sequence
of reset line initiators.
The chip select issued by CPLD 1 (CE IN) is fed into the MAX695 which has a chip select output
line (CE OUT) which drives the chip select inputs of the memory. The signal CE OUT follows
CE IN as long as Vee is above the 4,65 Volt reset threshold. If Vee falls below the reset
threshold, the signal CE OUT goes high, independent of the logic level at CE IN. This prevents
the microcontroller from writing erroneous data into RAM during power-up, power-down,
brown-outs and momentary power interruptions. The low line output is used to indicate when
Vee falls below 4,65 Volt on the board.
The MAX695 has a watchdog timer which is used to verify that software execution is being
performed by the microcontroller. This timer must be reset after an adjustable time interval and a
failure to do this would result in a system reset. The system reset would be initiated by the
watchdog output (WDO) signal driving the reset line low on the microcontroller. The address
decoding for the watchdog timer input pin (WDI) is performed by the CPLD in order to ensure
that it is also still functional. A system reset would result in the CPLD also being reconfigured.
When considering the timing at which the supply voltage would fall, we assume a reasonable time
of 100 microseconds for the voltage to fall from 5% of Vee to 10% of Vee. The time chosen is
based on actual measurements.
98
The micro controller in this project runs at a clock speed of 20 MHz. Since the microcontroller is
a 16-bit device, requiring on the order of approximately 12 clock cycles (6 state times) to execute
a single instruction, it is possible to calculate the average number of instructions that the
controller would be able to execute between the 5% and 10% trip points.
1
--- X 2 = 100 nano seconds = 1 state clock cycle
20MHz
at an average of 6 state times per instruction = 6 clock cycles/instruction
With a total time of 100jLs it can be seen that a total of 166 instructions can be executed during a
power-down prior to the NVSRAM write protecting itself or the system resetting. If required,
the rate of fall of a voltage of a power supply during a power failure can be slowed by adding
capacitance.
4.2.3 Improved Configurability
The PHASE 2 design has support for 2 FLEX 10K CPLDs. The system control signals are
implemented in the first CPLD with peripheral support for four pumps. The second CPLD need
only be introduced onto the PCB if additional support for a further four pumps is required. The
external UART can also be implemented in the second CPLD as a megafunction if required. The
second CPLD also has some of it's spare outputlinput pins brought out to a IDC connector.
Since both CPLDs have the system bus passing through them, internal memory can also be
implemented with support for most megafunctions. Any of the timing alterations which need to
be performed on the system can be done inside any of the two CPLDs. The pin configurations for
the five 28 pin JEDEC sockets on the PCB are carried out in the first of the two CPLDs. The
configurability allows for various capacities of ROM or RAM chips to be used in any of the
sockets.
99
4.2.4 CPLD Inclusion
The use of CPLDs in the new design allows for a reduced component count which -in turn reduces
problematic component sourcing and faults due to incorrect component population. This
reduction in component count allows the new design to be implemented on a single PCB. The
inclusion of megafunctions into the design leads to improved system performance and eliminates
the need for hardware components where megafunctions can be used to implement a substitute.
The external UART can be substituted with a megafunction reducing component count still
further.
The feature of in-circuit reconfiguration of the FLEX range of CPLDs also supports rapid
prototyping allowing for immediate upgrades to be simulated, synthesized and analyzed ana finally
implemented.
4.2.5 JTAG and BST Implementation
The JTAG and BST systems can be implemented into the system in order to facilitate bare-board
testing of PCB and therefore produce reduced production times. This has not been included in
the thesis due to the time constraints experienced.
4.2.6 Peripheral Upgrades
The Dallas tag communication circuit has been included in the main PCB. The LCD support
circuitry has been included in the new PCB. Dedicated keypad and LCD headers have been
incorporated into the new design. The new PCB incorporates support for twelve interpolar relays
for switching external devices.
100
4.2.7 Flexible Timing Design
The PHASE 2 design passes the system bus through both of the two FLEX 10K devices. The
system control signals which are now generated by the first CPLD can therefore be altered to
suite the timing requirements of the supported components. Due to the fact that both CPLDs
(FLEX IOKIOs) have 20% spare capacity any future timing modifications can easily be
implemented on these devices without the immediate need to migrate to a device with higher
densities.
4.2.8 Electromagnetic Interference Reduction Techniques
The phase2 design greatly reduces the presence of EMI since the component count is considerably
reduced. The technology utilized in the construction of the FLEX IOK CPLDs, also guarantee a
large improvement in the internal to external shielding of EM!. The new multi-layer CPLDs also
allow the internal busses of the CPLD to operate at very high frequencies without passing
unwanted interference to the external circuitry.
The EMI reduction techniques implemented in the phase I design have also been included in the
phase 2 design. The EDA design package, Protei, offered options for reduction in capacitive
coupling and cross-talk during PCB routing. All of the interference reduction capabilities offered
by Protei were used in the design of the phase2 board.
4.2.9 Power Analysis and Optimization
The peak and average power consumption of a circuit are tied to the reliability and integrity of the
circuit. Some of the phenomenons effecting the reliability are: electromigration, high resistive volt
drops, increased noise margins, increased clock skews and ground bounce. Reducing the circuits
peak and average power consumption, has the beneficial side-effects of improving the circuit's
reliability. The use of the idle and power-down modes supported by the 80C 196KC greatly
reduce the power consumption in the design.
101
The design methods affecting the power optimization of the circuit can be considered at three differe
nt stages. The behavioral (functional), structural and physical. The behavioral view specifies the
functionality of the design. The structural view represents the circuit as an interconnection of
elements or building blocks. The physical view represents the circuit as a set of geometric entities
placed an a chip or board. Synthesis tools can be used today to automatically convert or refine a
design from a higher level of abstraction to a lower level of abstraction. These tools may refine
the design for the reduction of power consumption at the various stages of development. The
stages at which this may occur are; the behavioral description (VHDL) stage, the functional RTL
stage, the structural RTL stage and the gate-level netlist stage. The benefits of high-level power
analysis and optimization using the available tools, are presented in
Figure 4.3.
Power Reduction Opportunities Power Analysis Iteration Times
IO-20XSystem Level
Behavior Level
seconds - utes
Layout Level
2-SX t::~
min tes - hours ~......
co 6b
t:: 'Vi
'Vi 0)
OJ [1
0)
~-day,
co....
20-Sm'O o 1-\t::>-<
Register -transfer Level
Logic Level
Transistor Level
FIGURE 4.3
102
The parameters to be considered when optimizing the power consumption of a circuit are, the
supply voltage, the clock frequency, the switching activity per clock cycle at various signals in the
circuit and the parasitic capacitances. In order to reduce the power consumption, one or more of
these parameters need to be reduced. If the supply voltage is reduced however, the delay of the
circuit elements increase according to the equation.
dela = k Vdd
Y (Vdd - Vr)2
where k is a constant [2].
VT is the threshold voltage of the transistors
Vdd is the supply voltage
The Altera range of FLEX IOK devices with support for interfacing with both 3,3 V and 5 Volts
systems allows for great versatility in grouping components requiring different supply voltages,
while still maintaining a reasonable power consumption. Altera also allows the designer the
option of separating the supply voltages for the IJO circuitry and the chip's core. The system
which implement the use of multiple supply voltages have been shown to reduce power as
compared to systems which implement the use of single supply voltages [2].
The parameter of switched capacitance can be reduced by physical techniques such as
partitioning, placement and routing, transistor and wire sizing, transistor re-ordering and clock
tree construction [2]. These techniques are supported by many new EDA tools available today.
The tool (Protei) used in the design of the PHASE 2 PCBs provided support for this feature.
The reduction in clock frequency will result in power reductions, but it will not reduce the amount
of energy required to perform a task, which is not always beneficial. The idle and power-down
modes of the 80C 196KC shut down the internal or external clocks in order to reduce power
consumption is not necessary. The design incorporates power reduction methods at both board
level and chip level using the tools available.
103
4.2.10 Cost Effective Design Methodology
The inclusion of CPLDs into the new design provides the following cost effective advantages:
Improved functional complexity at no extra cost
Option to increase the chip density without the additional cost and time for the
development of new supporting hardware. This is accomplished by using the chip
migration feature.
Immediate implementation of new designs and upgrades through the reconfigurable nature
of the CPLD.
Internal diagnostics via either pre-configured code or via the download cable.
4.3 The CPLD Implementation into PHASE 2 Design
4.3.1 Design Implementation using the Hierarchal Interfaces
The design of the PHASE 2 system has two CPLDs incorporating all of the three hierarchal
design levels supported by Altera. The three design levels supported are, the graphical user
interface, the text definition files and the symbol files.
4.3.1.1 The Graphical User Interface
The entire CPLD configurations are linked through their graphical user interfaces and then
compiled. Schematic diagrams of these designs are presented in appendix N.
104
4.3.1.2 Text Definition files
These files were used to include the VHDL and AHDL source code for the following:
the control logic implemented through symbols GALl and GAL2.
the state machines used for timing alterations, included in symbols GALl and GAL2
the watchdog timer linked to the external reset of the system
Listings of the source code for each of these files is presented in appendix O.
4.3.1.3 Symbol files
Altera provides megafunctions which are available for inclusion into the configuration of the
CPLD. These megafunctions are generally provided in their symbol form, offering limited access
to the VHDL or AHDL code. There are however conditions under which this code can become
available to the MAXPLUS IIuser.
Megafunctions provided by Altera which were used in this project are listed below:
I x al6450 uart (a16450 - MegaCore_ Function))
8 x 16 bit counters (LPM COUNTER)
6 x 74373 (D LATCHES)
I x 16 bit multiplexers (LPM MUX)
The text definition files containing the control logics, watchdog timers and state machines were
also used to generate symbols allowing them to be incorporated into the graphical user interface
(GUI). These symbol files are presented in appendix P
4.4 Design Methodology using the EPFIOKIOTC(144)
After an investigation, it was decided to route the 16-bit busses through both of the two CPLDs
This would allow the bus multiplexing to be performed inside the CPLD. In doing this, any signal
alterations, either timing or logic could then be carried out inside the CPLD itself. This provided
105
the signal versatility required for the design.
A wait-state generator (state machine) , is implemented inside the CPLD in order to adjust the
microcontroller timing to suite the components being addressed.
Due to the improved support of LPM_Megafunctions by Altera, it was decided that the following
Megafunctions be implemented in the phase 2 design:
the a16450 uart
the LPM_COUNTER (a 16-bit counter)
the LPM_MUX (a 16-bit multiplexer)
These megafunctions are included in the design in symbol form.
The gate count requirement of the two designs led to the selection of one FLEX 1OK10 and one
FLEX 10K20 device. Since the FLEX lOK range is in support of migration, it is possible to
increase the combined densities from 20 000 gates to 100 000 gates. This versatility provides
gates sufficient for most possible upgrades, avoiding immediate product obsolescence.
An internal watchdog timer has also been included into the CPLDs. This was done so that the
CPLDs could be reconfigured automatically in the event of a fault.
When routing the FLEX 10K devices, multiple ground pins were used to minimize the ground
bounce by keeping the lines short and using the internal ground plane of the device.
Critical signals were routed to pins near the groung pins in order to minimize the cross-talk.
The bus signal pins are spread across the device so that simultaneous signal switching on certain
pins would not all share the same ground pins. Because of the fact that the use of ic sockets
would have resulted in an increase in unwanted disturbances due to an increase in the device lead
length, the components were soldered directly onto the printed circuit board.
106
The MAXPLUS II software tool provides the designer with an option of adjusting the slew rate
of the FLEX IOK CPLD. By slowing down the slew rate of the CPLD, it is possible to reduce the
ringing in the CPLD. This option does however result in a sacrifice in speed.
It must be noted that this option is not supported by all PLDs, and therefore influenced the
selection of the chosen device used in this project.
4.5 Bi-directional Tri-state Bus Implementation into the EPFIOKIOTC(144)
Due to the fact that Altera devices do not have internal tri-state buses, logic inside a device cannot
communicate directly via bidirectional buses. MAXPLUS II can emulate tri-state buses by using
multiplexers and by routing the bidirectional line outside of the device and then back in through
another pin.
In this project, the tri-state buses are used to multiplex signals internally.
MAXPLUS II converts the logic to a combinational multiplexer. Figure 4.4 represents the tri-
state buses for bidirectional communication. Device I communicates with device 2 via
bidirectional lines.
FIGURE 4.4
107
This communication can be performed inside an Altera PLD since there is a tri-state buffer
available at each I/O pin.
If the communication occurs via bidirectional lines inside the device, it cannot be implemented as
indicated in figure 4.5.
FIGURE 4.5
In order to overcome this limitation, one must route the bidirectional lines outside of the device.
This is presented in figure 4.6.
FIGURE 4.6
108
This method makes use of tri-states present at the l/O pins. This Phase 2 design does however
not allow for the bus signals to use the l/O pins as an intermediate register for multiplexing, due
to the fact that there would then be a shortage of l/O pins.
Another method is to convert the tri-state buses into a multiplexer as shown in figure 4.7.
FIGURE 4.7
MAXPLUS II can convert internal tri-state buses into multiplexers for graphic editor designs as
used in this phase 2 design.
109
4.6 The a16450 MegaCore Function
This device is implemented in one of the two CPLDs in order to reduce the physical component
count on the main board. It replaces the Intel 82510 uart set on the PCB.
The choice of function was due to the fact that the 82510 uart has it's first set of addressable
registers identical to the NS 16450 uart. This meant that the existing control circuitry could still be
used.
The FLEX 10K device is designed with full support for MegaCore functions, with the a16450
function optimized specifically for the FLEX architecture.
The FLEXI Ok10 device however proved to insufficient in terms of gate density and the FLEX
10k20 had to be implemented as the second CPLD.
The a16450 MegaCore function includes the following features:
- programmable word length, stop bits and parity bits
- programmable baud rate generator
- supports both synchronous and asynchronous operation
- supports full duplex operation
- supports prioritized interrupt control
- provides internal diagnostic/ loopback capabilities
The a16450 MegaCore function uses approximately 372 FLEX logic elements (Les)
Due to the fact that two different baud rates are required from the a16450 for communication
with the Dallas touch memory, a uart with a fully programmable baud rate generator was chosen.
The a16450 was simulated and found to be operating correctly. The MegaCore function could
however not be implemented immediately into the project, since a license for the function would
first have to be purchased from the AMPP suppliers.
110
4.7 Synthesis ans Routing of the EPFIOKIO/20TC(144) Internal Designs
The compiler uses a default logic synthesis style for the entire project. Altera provides Normal,
Fast and WYSIWYG logic synthesis styles which specify a setting for every available individual
logic option. Altera does however not recommend editing the logic option settings in these styles.
Because the MegaCore functions used for the FLEX 10K designs contain cascade and carry
buffers, a style other than Normal is used as the default logic synthesis style.
Altera's logic synthesizer provides two basic types of synthesis;
the multi-level logic synthesis and the standard synthesis.
In this project the multi-level synthesis option is used.
The results are reflected in the synthesis and routing outputs presented in appendix Q.
4.8 Simulation of the EPFIOKIOTC(144) and EPFI0K20TC(144)'s internal design
The internal operation of the both of the CPLDs were simulated and are operating correctly.
4.9 System analysis of the EPFIOKIOTC(144) and EPFI0K20TC(144) CPLDs
The timing analysis is presented in appendix S.
4.10 Cascaded Phase 2 CPLD configuration on power up
It was found that the 80C 196 microcontroller created bus interference while the CPLDs were in
their configuration cycle. The entire system excluding the CPLDs were issued a global reset after
the CPLDs had been initialized, but it was found that since the 196 was operational during part of
the CPLDs cinfiguration process, interference still occurred and the ONCE command was then
used to electrically isolate the 80C 196 microcontroller from the rest of the board until the CPLD
had completed it's initialization cycle. This proved successful.
III
4.11 Manufacture and Implementation of the Phase 2 System
4. 11.1 Printed Circuit Board Design
The schematics were drawn by myself in the Protei EDA environment. The schematics are
presented in appendix U.
The netlist files were generated in Protei and transferred to the Protei router. The frequencies and
voltages were specified for the routing process and the Software routed to minimize the crosstalk
and voltage interferences. The routing guidelines mentioned earlier in the thesis were implemented
in order to produce preferred results.
The entire design previously required three PCBs, whereas with the new CPLD technology, the
design has been reduced to a single board with a much reduced component count.
The printed circuit board containing all of the required hardware is presented in appendix U
4.11.2 System installation
The Phase 2 system has replaced the previous Phase 1 system and was found to be more reliable
and easier to install With fewer components to test and fewer boards to populate, the installation
has been much improved.
112
Chapter 5
Conclusions, Recommendations and
Future Work
5.1 Conclusions
The Phasel system initially seemed easier to implement, but in hindsight it was realized that this
was due to the relatively new and unknown technology used in the Phase 2 system.
The phase 2 design which includes the CPLDs could be simulated and tested in much less time
than the Phase 1 design. It is thus fair to say, that a big advantage of using the newer CPLD
technology, is a greatly reduced time-to-market of the product. This is largely due to the drive
toward rapid prototyping in order to avoid product obsolescence.
The Phase 2 system proved to be the more electrically stable system. This can also be attributed to
the alterations in the design process based on the recommendations following the problems
encountered in the phase 1 system.
The reduction in electrical noise in the later design can also be attributed to the construction of
the CPLD as mentioned in the thesis.
The MegaCore function offers a means of testing the new uart before a purchase is made. This
allows the designer the option of testing a far greater range of products before finally deciding on
the most suitable one for the application
The CPLDs support of JTAG and BST technology now also allows the designer to perform
continuity tests on the PCB without wasting time with bare-board testing.
One important consideration still to be made in designing with CPLDs, is that the designer must
over-design with the support hardware in order to utilize the migration features of the CPLDs
It also important to note that newer CPLDs are becoming faster and at the same time minimizing
113
the interferences.
5.2 Recommendations
The comparison between technologies used in this thesis leads to the recommendation that were
feasible, all of the newer designs make use of the newer CPLD technology. It will in future
become increasingly difficult to compete in the electronic design market unless the designer
strives to avoid short term product obsolescence. One of the ways to assist in this regard is to use
a system which supports density migration and fast upgrades (e.g. by using the in-circuit
programmability feature of Altera's CPLDs)
With the increase in densities of the newer CPLDs, it is inevitable that the future holds a complex
system on a chip immediately adaptable to every designer's requirements.
Altera does however need to provide a greater support for the development of an internal tri-state
bus, eliminating the need for the use of multiplexers.
5.3 Future work
There remains a need for greater control of the driving capabilities on the L'O pins of the device
itself. I believe this is one of the areas where some of the large FPGNCPLD manufacturers need
to do some development.
The AMPP program also needs to grow in order to provide a greater range of products required
for the Mega function usage to develop.
114
Bibliography
[1] Stefan Sjoholm and Lennart Lindh, VHDLfor Designers. Prentice Hall, Europe, 1997.
[2] Anand Raghunathan, Niraj K. Jha and Sujit Dey,
[3] Zoran Salcic and Asim Smailagic, Digital Systems Design and Prototyping using Field
Programmable Logic. Kluwer Academic Publishers, Massachusetts, USA, 1998.
[4] Ramesh S. Goankar, Microprocessor Architecture, Programming and Applications. 2nd
Edition. Merril Publishing Company, Columbus, Ohio, l-989.
[5] Intel Corporation, 8XC196KCI8XC196KD User's Manual, USA, 1992.
[6] Radiometrix Limited, "Low Power UHF Data Transceiver Module", in BIM-UHF Data
Sheet, Issue 3, 21sl October 1997.
[7] Altera Corporation, "Introduction to Programmable Logic and ASICs" , in Altera
documentation, January 1998, Version 5.
[8] Steve Money, Newnes Microprocessor Pocket Book. Heinemann Newnes Publishing,
Oxford, 1989.
[9] Intel Corporation, EV80C196KD Evaluation Board User's Manual, USA, Release 1, 8
May 1992.
[10] Altera Corporation, "FLEX 10K Embedded Programmable Logic Family", in Altera
documentation, October 1998, Version 3.13.
[11] C.H. Jordaan, "the Implementation of a Microprocessor in a FPGA", in Thesis for
Masters Degree in Electronic Engineering of University of Stellenbosch, February 1998.
[12] G.c. Loveday, Designing Electronic Hardware, Longman Scientific and Technical, UK,
1992.
[13] Thomas C. Hayes and Paul Horowitz, The Art of Electronics, Cambridge University
Press, USA, 1989.
[14] Dan Garish and Tsvika Kurts, High Performance driver for 82510, Application Note 310,
Intel Corporation, June 1987.
[15] Faisal Imdad-Haque, Designing with the 82510 Asynchronous Serial Controller,
Application Note 401, Intel Corporation, December 1987.
[16] John Adams, Techniquesfor accurate time measurement with the DallasSemiconductor
DS1994 Time-in-a-Can, Application Note 60, Dallas Semiconductor, March 1993.
[17] Dallas Semiconductor, Understanding and Using Cyclic Redundancy Checks with Dallas
Semiconductor Touch Memory Products, Application Note 27, Dallas Semiconductor,
October 1995.
[18] Dallas Semiconductor, 64K NV SRAMwith Phantom Clock, Dallas Semiconductor Data
Sheet on DS1243Y, December 1995.
[19] Tom Williams, Designing Microcontroller Systems for Electrically Noisy Environments,
Application Note 125, Intel Corporation, December 1993.
[20] Altera, 1995 Databook, San Jose, CA, 1995.
[21] Intel, 16-Bit Embedded Controller Handbook, Santa Clara, 1989.
[22] Intel, 8-Bit Embedded Controller Handbook, Santa Clara, 1990.
[23] Intel, Embedded Microcontrollers Databook, USA, January 1998.
[24] Neil Slay, Safety-Critical Computer Systems, Addison Wesley Longman Inc, New York,
1996.
[25] Von L. Burton, The Programmable Logic Device handbook, TAB Book Inc, USA, 1990.
[26] Geoff Bostock, FPGAs and Programmable LSI: A Designer's Handbook, Butterworth-
Heinemann, London, 1996.
[27] R.C. Seals and G.F. Whapshott, Programmable Logic: PLDs and FPGAs, MacMillan
Press Ltd, Great Britain, 1997.
[28] Parag K. Lara, Digital System Design using Programmable Logic Devices, Prentice Hall,
Eaglewood Cliffs, New Jersey, 1990.
[29] Kenneth J. Hintz and Daniel Tabak, Microcontrollers : Architecture, Implementation and
Programming, McGraw-Hili Inc, USA, 1992.
[30] John W. Carter, Digital Designing with Programmable Logic Devices, Prentice-Hall, Inc,
New Jersey, 1997.
[31] Geoff Bostock, Programmable Logic Handbook, 2nd Edition, Newnes, Great Britain,
1993.
[32] Altera Corporation, "IEEE 1149.1 (JTAG) Boundary-Scan Testing in Altera Devices",
Version 4.02, in Altera Application Note 39, November 1998.
[33] Altera Corporation, "FLEX 10K Device Family", in Altera Documentation, March 1999.
[34] Nathan Gurewich and Ori Gurewich, Teach yourself Visual Basic 4 in 21 Days, 3rd
Edition, Sams Publishing, USA, 1995.
[35] Boston Systems Office/Tasking, Software Development Under Control, Tasking Software'
BV, The Netherlands, 1994.
[36] Siemens, "Plastic Fiber Components (PFC): A Cost-Effective Sollution for Optical
Signal Transmission", Application Note 40, 1997.
[37] Siemens, "Plastic Fiber Optic Photo transistor Detector", Siemens Data Sheet.
[38] Siemens, "Plastic Fiber Optic Phototransistor Diode", Siemens Data Sheet.
[39] Intel,' 8251A Programmable Communication Interface", Santa Clara, November 1986.
[40] Altera Corporation, "Byte Blaster Parallel Port Download Cable", Version 2.01, in
Altera Data Sheet, February 1998.
[41] Altera Corporation, "Configuration EPROMSfor FLEX Devices", Version 9, in Altera
Data Sheet, October 1998.
[42] Motorola Semiconductor Technical Data, "12-Stage Binary Ripple Counter-High-
Performance Silicon-Gate CMOS', Motorola Literature Distribution, Arizona, Revision
1, 1995.
[43] Altera, "Reflow Soldering Guidelinesfor Surface-Mount Devices", Version 3, in Altera
Application Note 81, January 1999.
[44] Altera, "Implementing Tri-States Buses in Altera Devices", Altera Application Note,
webmaster@altera,com, http://www.aJtera.comlhtmJ/atlas/examples/ged/tri-state.html. 9
February 1998.
[45] Altera, "AHDL: Tri-State Buses Connected to a Bidirectional Bus", Altera Application
Note, webmaster@altera.com, http://,,,,,vw.altera.comlhtmllatlas/examples/ahdlla-tri-
bb.html, 9 February 1998.
[46] Altera, "Synthesizing and Optimizing VHDL and Verilog HDL with Synopsis Software",
Altera Application Note, webrnaster@altera.com,
http://wwv ...altera.comlhtmllmaxkey/synopsis/compilers/vsynt.htm. 29 January 1998.
[47] Altera, "Running Synopsis Compilersfrom the MAX+PLUS II Software", Altera
Application Note, webmaster@altera.com,
http://www.altera.comlhtml/maxkey/synopsis/compilers/syncom.htm. 29-January 1998.
[48] Altera, "Setting up the MAX +PLUS Il/Synopsis Working Environment", Altera
Application Note, webmaster«4altera.com,
http://www.altera.com/htmlimaxkey/synopsis/intro/setup.htm,29 January 1998.
[49] Altera, "MAX+PLUS Il/Synopsis Interface File Organization", Altera Application Note,
webmaster@altera. com, http://www.altera.comlhtml/maxkey/synopsislintro/fileorgn.htm.
29 January 1998.
[50] Altera, "Altera Packaging Solutions: Package Outlines", Altera Application Note,
webmaster@altera. com, http://wvvw.ahera.com/html/adas/packages l.html#code,
26 March 1999.
[51] Altera, "98251 -Programmable Communications Interface", Version 2, Altera Data Sheet,
June 1997.
[52] Altera, "Operating Requirements for Altera Devices", Version 8, Altera Data Sheet,
January 1998.
[53] Altera, "Bit Blaster Serial Download Cable", Version 4.01, Altera Data Sheet, February
1998.
[54] National Semiconductor, "1M311 Comparator General Description", National
Semiconductor Corporation, Data Sheet, USA, 1995.
[55] Harris Semiconductor, "CA3140 - 4,5 MHz, BiMOS Operational Amplifier with MOSFET
Input/Bipolar Output", Harris Corporation, Data Sheet, File Number 957.4, 1998.
[56] National Semiconductor, "CD4093BM Quad 2-Input NAND Schmidt Frigger", National
Semiconductor Corporation, Data Sheet, USA, February 1993.
[57] National Semiconductor, "CD4001BM Quad 2-Inpllt NOR Buffered B Series Gate",
National Semiconductor Corporation, Data Sheet, USA, March 1998.
[58] Motorola Semiconductor Technical Data, "MC14C88B-Qllad Low Power Line Driver",
Motorola Literature Distribution, Revision 0, Arizona, 1996.
[59] Motorola Semiconductor Technical Data, "MC1489A - Quad Low Power Line Driver",
Motorola Literature Distribution, Revision 5, Arizona, 1996.
[60] Dallas Semiconductor, "How to Save Data During a Power Failure without Corrupting
it", Application Note 51, Dallas Semiconductor, April 1998.
[61] Dallas Semiconductor, "Using the Phantom Real Time Clocks", Application Note 52,
Dallas Semiconductor, February 1994.
[62] James W. McCord, Developing Windows Applications with Borland C++3.I, 2nd Edition,
SAMS Publishers, USA, 1992.
[63] Dallas Semiconductor, High-Speed Microcontroller Data Book, USA, 1995.
[64] Dallas Semiconductor, DSI996 64k bit Touch Memory, Dallas Semiconductor Data Sheet,
February 1995.
[65] Siemens, "Fiber Optic Links at Lowest Cost: Plastic Fiber Components", Siemens
Literature Sheet, http://www.siemens.de/semjconductor/products/37/37741.htm. 1998.
[66] David Hinerman, "Making Non-volatile Data Reliable", Microcom Corporation,
Westerville,OH, 1997.
[67] Altera Corporation, "Using Synopsys FPGA Express Software to Synthesize Designsfor
MAX+PLUS II Software", Altera Technical Brief 42, Version 1, 1998.
[68] Altera Corporation, "Using Synopsis Compiler & FPGA Compiler to Synthesize Designs
for MAX+PLUS II Software", Altera Technical Brief39, Version 1, April 1998.
[69] Altera Corporation, "Generating Post-Route Files ill the MAX+PLUS II Software for
Third-Party Verification Tools", Altera Technical Brief49, Version 101, October 1998.
[70] Altera Corporation, "Passing Hierarchical Timing Constraints from Synopsys Tools to
MAX+PLUS II Version v", Altera Technical Brief48, Version 1,1998.
[71] Altera Corporation, "Importing Synthesized Files from EDA Tools into the MAX+PLUS
II Software for Place and Route", Altera Technical Brief 45, Version 1, 1998.
'111\~JJJml Ul\UJJJJ I'~IIIII- -

Swanepoel, S
Development of an integrated fuel management
system with the aid of CPLDs / by S. Swanepoel.
(!J)
UNIVERSITEIT VAN STELLENBOSCH
BIBLIOTEEKDIENS
Raknommer:
KTES 621.395 SWA ,
JS Gericke Biblioteek
Kompaktus
Itemnommer : 3007731701
Appendices
Appendix A-I
System Bus Timing
XTAL1
CLOCKOUT
ALE/ADV'
RD'
BUS
WR'
BUS
(1S-Bit Mode) ADDRESS OUT
ADDRESS OUT
BHE'.INST VALID
AD8-1 5
(a-Bit Mode)
ADDRESS OUT
Appendix A-2
Timing Analysis of the 80C 196KC
System Board
All values used are based on the 80C 196KC operating at 20MHz. They are taken from the
November 1994 version of the 8XC 196KC commercial device information data sheet. The Intel
order number is:
Tavyv = 32 ns MAX
Tavyv(WAIT) = 5.5 ns (FCT373CT LE to Qn Tp MAX) + 7.5 ns (pALIEPLD Tpd MAX)
+ 7.9 ns (AC08 Tplh MAX) + II ns (AC112 RES to Q Tp MAX)
= 3l.9 ns.
Tllyv is irrelevant in this design.
Tclyx = 20 ns MAX.
Tclyx (WAIT) = 9.4 ns (AC112 CLOCK to Q Tplh MAX).
Tllyx is irrelevant in this design.
Tavgv = 32 ns MAX.
Tavgv(BUSWlDTH) = 5.5 ns (FCT373CT LE to Qn Tp MAX) + 7.5 ns (pALIEPLD Tpd MAX)
= 13 ns.
TlIgv irrelevant in this design.
Tclgx is irrelevant in this design.
Tavdv = 95 ns MAX, for zero wait states.
Tavdv(l6bit RAM) = 5.5 ns (FCT373CT LE to Qn Tp MAX) + 7.5 ns (pALIEPLD Tpd MAX)
+ 45 ns (RAM Tavqv MAX)
= 58 ns.
Tavdv = 195 ns MAX, for one wait state.
Tavdv(EPROM) = 5.5 ns (FCT373CT LE to Qn Tp MAX) + 7.5 ns (pALIEPLD Tpd MAX)
+ 150 ns (EPROM Tee MAX)
= 163 ns.
Tavdv = 295 ns MAX, for two wait states.
Tavdv(UART) = 5.5 ns (FCT373CT LE to Qn Tp MAX) + 7.5 ns (pALIEPLD Tpd MAX)
+ 190 ns (UART Tavrl MIN + Trldv MAX)
= 203 ns.
Trldv = 28 ns MAX, for zero wait states.
Trldv( 16bit RAM) = 20 ns (RAM Tglqv MAX).
Trldv = 78 ns MAX, for one wait state.
Trlcl is irrelevant in this design.
Trldv(EPROM) = 60 ns (EPROM Toe MAX).
Trldv = 178 ns MAX, for two wait states.
Trldv(UART) = 173 ns (UART Trldv MAX).
Tcldv is irrelevant in this design.
Trhdz = 50 ns MAX.
Trhdz(I6bit RAM) = 25 ns (RAM Tghqz MAX).
Trhdz(EPROM) = 50 ns (EPROM Tdf MAX).
Trhdz(UART) = 40 ns (UART Trhdz MAX).
Trxdx = 0 ns MIN.
Trxdx(l6bit RAM) = 0 ns (RAM Tghqz MIN).
Trxdx(EPROM) = 0 ns (EPROM Toh MIN).
Trxdx(UART) is not specified.
Txheh is irrelevant in this design.
Tclcl = 100 ns.
Tclcl(W AIT) = 9 ns (PALIEPLD Tp MIN).
= 9 ns (ACII2 l/Fmax MIN).
Tchcl = 40 ns MIN.
Tehcl(WAIT) = 6 ns (PALIEPLD Tc02 MAX) + 4 ns (ACII2 Ts MIN)
= 10 ns.
or = 6 ns (PALIEPLD Tc02 MAX)
+ 7.9 ns (AC08 Tplh MAX) + 3 ns (AC1l2 Tree MIN)
= 16.9 ns.
Tcllh is irrelevant in this design.
Tlleh is irrelevant in this design
Tlhlh is irrelevant in this design.
Tlhll = 40 ns MIN
Tlhll(AO-AI5) = 5 ns (FCT373CT Tw MIN).
Tavll = 35 ns MIN.
Tavll(AO-AI5) = 2 ns (FCT373CT Ts MIN).
Tavll(WAIT) = 5.5 ns (FCT373CT LE to Qn Tp MAX) + 7.5 ns (PALIEPLD Tpd MAX)
+ 8 ns (ACOOTphl MIN) + 5 ns (ACII2 Tw MIN)
= 26 ns.
Tavll(BHE#) = II ns (AC14 Tplh MAX) + 5 ns (AC112 Tw MIN)
= 16 ns.
Tllax = 10 ns MIN.
Tllax(AO-AI5) = 1.5 ns (FCT373CT Th MIN).
Tllax(BHE#) = 0 ns (ACII2 Th MIN).
Tllrl = 20 ns MIN.
Tllrl(UART) = 7 ns (UART Tavrl MIN)
Trhlh = 50 ns MIN.
Trhlh(ST ALE) = 9 ns (AC08 Tplh MAX) + 3 ns (AClI2 Tree MIN)
= 12 ns.
Trlrh = 245 ns MIN, for two wait states.
Trlrh(UART) = 173 ns (UART Trlrh MIN).
Tllwl = 40 ns MIN.
Tllwl(UART) = 7 ns (UART Tavwl MIN).
Telwl is irrelevant in this design.
Tqvwh = 27 ns MIN, for zero wait states.
Tqvwh(16bit RAM) = 25 ns (RAM Tdvwh MIN).
Tqvwh = 227 ns MIN, for two wait states.
Tqvwh(UART) = 90 ns CUART Tdvwh MIN).
Tchwh is irrelevant in this design.
Twlwh = 30 ns MIN, for zero wait states.
Twlwh(l6bit RAM) = 25 ns (RAM Twlwh MIN).
Twlwh = 230 ns MIN, for two wait states.
Twlwh(UART) = 123.5 ns (UART Twlwh MIN).
Twhqx = 25 ns MIN.
Twhqx(l6bit RAM) = 9 ns (74AC32 Tplh MAX) + 0 ns (RAM Twhdx MIN)
= 9 ns.
TwhqxCUl4) = 0 ns (RAM Twhdx MIN).
Twhqx(UART) = 12 ns (UART Twhdx MIN)
Twhlh = 40 ns MIN.
Twhlh(l6bit RAM) = 9 ns (74AC32 Tplh MAX) + 5 ns (RAM Twhax MIN)
= 14 ns.
Twhlh(UART) = 0 ns (UART Twhax MIN)
Twhlh(STALE) = 9 ns (AC08 Tplh MAX) + 3 ns (AC112 Tree MIN)
= 12 ns.
Twhbx is irrelevant in this design.
AppendixB
80C196KC 68 Pin PLCC Package
ACH5/PMOI>E. l/PO.S
ACH4/PMOOE.O/PO.4
ANGND
VRH
Vss
[XTINt !f>ROG/P2.2
RESET
RXO/PAlE/P2.1
Txo/pvER/P2.0
P1.0
p 1.1 .
P1.2
PWt.i lip 1.3
PWIoI2/P1.'(
HSI.O
HSI.l
HSI.2/HSO ••
x,_
(;)
~ ~
P3.0/AOO
Pl. t/AOI
P3.2/AD2
P3.3/A03
PJ.'(/A04
P3.5/AD5
P3.6/AD6
P3.7/A07
N.olAoe
P4.1/A09
N.2/AOtO
P4.3/A011
P4.4/ADI2
P4.5/AD13
P4.6/A014
P4.7/AD15
P2.3/T2ClK
L-___________ _
68-PIN PLCC
N8XC196KC, TN8XC196KC
TOP VIEW
looking Down on
Compon.nt Sid.
of PC Boord
31 52 55 54 35 36 37 36 39 40 41
Appendix C-l
7FFF
Memory Map for Peripheral Outputs
OFFFFH
16 K Bytes External Memory
or I/O.
BFFFH ---------- 1- -- -------- BFFFH
40 K Bytes
7FFFH
OFFFFH /
/
/ 8 Bit RAM
/ Non-volatile
memory/
Real-time
clock
COOOH
-----------f----- 1--- __L _
207FH
16 Bit ROM
Special Purpose Memory
L..- -.J. L-_-L- -l 2000H2000H
Appendix C-2
Memory Map of PHASE 1 and
PHASE 2 Control Signals
RD WR A15 AI~ All All All AI. A!J A8 A7 M A~ AJ Al AI Addr<"
RES8 I o o o I I I o o 0 0 I 0 I J OXICI6
RES7 I o o o I J I o 0 0 0 J 0 I 0 OXICl4
RES6 I o 0 0 I J J o 0 0 0 J 0 0 I oxicrz
RESS I 0 • 0 J I J o 0 0 0 J 0 0 0 OXICIO
~ J o 0 0 J J I 0 0 0 0 0 I J J OXICOE
RES3 J 0 0 0 I I J 0 o 0 0 0 I I 0 OXICOC
RES2 I 0 0 0 I J J 0 0 0 0 0 I 0 J OXlCOA
RESI I 0 0 0 I I J 0 0 0 0 0 I 0 0 OXIC08
ENCI J 0 0 0 I I I 0 0 0 o J I 0 I OXICIA
ENC2 J 0 0 0 J J I 0 0 0 0 J I J 0 OX1CIC
ENC] J 0 0 0 J J J 0 0 0 0 I J J J OXICIE
ENG< J 0 0 0 J I J 0 0 0 I 0 0 0 0 oxiczo
ENCS J 0 0 0 J J J 0 0 0 J 0 0 0 J OX1C22
ENC6 I 0 0 0 I I I 0 0 0 J 0 0 J 0 OXIC24
ENG7 J 0 0 0 I I J 0 0 0 I 0 0 J J OXIC26
ENCS J 0 0 0 I J J 0 0 0 J 0 J 0 0 OXIC28
CEI I 0 0 0 J J J 0 0 0 0 0 0 J J OXIC06
CE2 J 0 0 0 J J J 0 0 0 0 0 0 J 0 OXICO-l
CEJ J 0 0 0 J J J 0 0 0 0 0 0 0 J OXICOl
CEA J 0 0 0 J J J 0 0 0 0 0 0 0 0 oxrcoo
CES J 0 0 0 J J J 0 0 0 J 0 J 0 J OXlelA
CEO J 0 0 0 J J J 0 0 0 J 0 J J 0 OX1C2C
CE7 J 0 0 0 J J J 0 0 0 J 0 J J J OXIC2E
CE8 J 0 0 0 J J J 0 0 0 J J 0 0 0 oxicso
SITI6lED J 0 0 0 J I J 0 0 0 0 0 0 J 0 OXICQ..t
CEI.ED J 0 0 0 J I J 0 0 0 0 0 0 J J OXIC06
CSREUY J 0 0 0 J J I 0 0 0 0 0 0 0 0 oxicoo
EXL\l>!P J 0 0 0 J J J 0 0 0 0 J J 0 0 OXICIS
EXFAN J 0 0 0 J J J 0 0 0 J J 0 0 J oxicaz
NOZ2l£ J 0 0 0 J J J 0 0 0 J J 0 J 0 QXIC]4
SBUllER J 0 0 0 J J J 0 0 0 J J 0 J J OXIC36
SWOI J 0 0 0 J J J 0 0 0 J J J 0 0 OXIC38
LEDBANK J 0 0 0 J J J 0 0 0 J J J 0 J OXlelA
PORD_R1 J 0 0 0 J J J 0 0 0 J J J J 0 OXIC1C
TESTCPLD J 0 0 0 J J J 0 0 0 J J J J J OXICJE
Memory Map of PHASE 1 and
PHASE 2 Control Signals for GAL 1
Appendix C-3
Signal Description Address Wait Active
States Low/High
CeO Chip select for 16-bit eproms 2000H-BFFFH 1 L
Ce1 Chip select for 16-bit status ram OOOOH-OFFFH 0 L
1OOOH-11FFH
Ce2 Chip select for 8-bit real-time COOOH-FFFFH 2 L ~
clocklnv ram
Cs510 Chip select for 8251A usart IEOOH-IEFFH 2 L
Buswidth 8/16 bit buswidth selection IEOOH-IEFFH & 0 H-167
COOOH-FFFH L-8
inst Memory overlap signal, Only implemented in phase 2 0 L
distinguishes between instruction design
and data
Intel 82510 UART Register Map
AppendixD
- Refer to bibliography for reference
Phantom Clock Control Sheet
AppendixE
Ik~ Ik~ 7 s ~ • J 2 I 0 OIR
0_1 Itt om sec 0.1 sec
0 0 0 0 0 0 0 0 0 0 • A
9 9 I 0 0 I I 0 0 I A •
100« SEa)NDS SEa)NDS
0 0 0 0 0 0 0 0 0 0
~ 9 0 I 0 I I 0 0 I
10 min MINUJtS MINUTES
0 0 0 0 0 0 0 0 0 0
~ 9 0 I 0 I I 0 0 I
12 AlP HR HOUR HOURS 12 H MODE
0 I I 0 0 0 0 0 0 I lAM
I 2 I 0 0 0 I 0 0 I 9AM
I 0 0 I 0 0 0 0 lOAM
I 0 0 I 0 0 I 0 12AM
I 0 I 0 0 0 0 I IPM
I 0 I 0 I 0 0 I 9PM
I 0 I I 0 0 0 0 IOPM
I 0 I I 0 0 I 0 12PPl.I
24 20
24 HMODE
0 0 0 0 0 0 0 0 0 0 I AM· 01:00
2 4 0 0 0 0 I 0 0 I 9AM-09:00
0 0 0 I 0 0 0 0 lOAM ·10:00
0 0 0 I 0 0 I 0 12 AM ·12:00
0 0 0 I 0 0 I I I PM - 13:00
0 0 I 0 0 0 0 0 8 PM - 20:00
0 0 I 0 0 0 I I 11 PM· 23:00
0 0 0 0 0 0 0 0 12 PM - 00:00
OSC RST DAY DAY
0 I 0 0 0 1 0 0 0 1 SUNDAY
0 7 0 0 0 1 0 1 I I SATIJRI)AY
NOSe AND If RST ARE ACTIVE LOW
IODate DATE DATE
0 I 0 0 0 0 0 0 0 I 01
3 I 0 0 I I 0 0 0 I 31
10m MONTH MONTH
0 I 0 0 0 0 0 0 0 I
I 2 0 0 0 I 0 0 I 0
IOYac YEAR YEAR
0 0 0 0 0 0 0 0 0 0
9 9 I 0 0 I 0 I I 0
AppendixF
LCD Control Data
COMMA. NO
1-0S 1-RSH
O-CM O-LSH x
1.64rrs
DlSFtA Y CLEAR
RS RNV DB? 0136 0135 0134 DB3 0132 DB1 DBO EXECTME
RETURN 00 ME
a aa a a a a a a 1.64rrs
ENTRY M8DE SET
a aa a a a a a x
a a 1-If\JC 1-CON
a-DEC O-CO'F
40us
DlSFtA Y OfIVOFF 40us
a a aa a
a a 1-DON 1-CON 1-BON
O-OOFF O-CO'F O-EOFF
SHIFT 40us
a a a a
a a a a a x
SETFUNCTON
1 -8BlT
O-4BlT
1-2UNE 1-5X10
0-1L1NE 0-5X7
a aa a x x 40us
SETCG RAM
ADDRESS 40usa a a CG RA M ADDRESS
READ BUSY
ADDRESS
40usa a DO RAM ADDRESS
REA 0 BUSY FlAG &
ADDRESS
1-BUSY
O-READ
Y
A DDRESS COUNTER FOR BOTH
00& CG RAMADORESS
40us
WRITE OlI.TA 40us
a
a WRITE [)6. TA
READ DATA 40usREAD DATA
Schematic of Dallas Tag
Communication Interface
Appendix G
.. NJ~ 5
U
ez::-N 0
Z
0r::~N
IN>0\0 -ti>- '"::.c '")i v r: 0-.90 0-030 U ~- 0--0::r: o ~.~~, d?;5 ,...,>- <:e: ::: 9_~::.c f- z N ..f-
~ -0f-0 ..J::r:
~MUO(/J ",0
'"f::
I
i III
if 0-->OMI ! V
i II ,
I I
i I
I N
N I (/Jw
ez::
U
o -~v< :<
r-' r-
0 0
~.,. Z ~> o :-
.-----~~---..---l'~----'--------~-'
o I u--..__.. . J _
.,'
----I~~-
-- - _j - - ----- ________J
I
_j
-- -- -_ -- ---
-e
; .
CN2~J' ° go 00 ° 0 []O~[] O~ []
:{]]~ []~O OOO[] []iO[]~oUJ([]C"O)
~~ ° ° ~~ [] 0 [] 0':n ~ 0 ~ ICI [] 7 0 [] II 0 0 TXEB COO 0000 L ° I G)g 0j 0 0UQ 0 0" O~ 0 0
o r~n R3 ° 10~ ([]C<lO~@ 0 (OC1IO)
o ([]C110)~~~:~EC2: I 0 ~ ~I+ CI03 10 RXO
EBo §OEjO(OC70X[]C50)[]@ 0 ([]CBO) G)o rc 0 @ 00 0Er 0[] 1 0 ~
[]~O o []~~~[]~ OC9 ~ 0 rc 0 0[] ° 00 0 0 ~
01 °R:5 loci R16 10 ~~ ~ c~ 00 c
AppendixH
Bill of Materials for Optic Fiber
Communication Transceiver
RESISTORS
lx RI 20K C14w)
Ix R2 4K7 ('!.tw)
lx R3 15 (4w)
Ix R4 20K ('14w)
Ix R5 I20K C14w)
IxR6 6K2 ('!.tw) 1%
lx R7 IOK ('14w)
IxR8 47K ('!.tw)
lx R9 IK ('!.tw)
.Ix RIO 150 (Iw)
-Ix RII 5KI ('14w)
lx RI2 1M ('14w)
Ix Rl3 - lOOK ('!.tw)
Ix R14 - 27K ('14w)
lx RI5 - 47 (2w)
Ix R16 - 47 (2w)
IxRI7 - 22K ('14w) 1%
lx RI8 x
lx RI9 - 150 C14w)
Ix R20 - 3K ('14w)
IxR21 - 3K (y.w)
Ix R22 - 10K ('14w)
lx R23 - 340 C14w)
lx R24 - 4K7 ('14w)
ICs
Ix ICI - LM311P
Ix IC2 - LM311P
I x IC3 - CA3140E
l x BCBoard
l x I Plastic Box JC0440
120x65x40
CAPACITORS
lx Cl 100 nF
Ix C2 470 ;:,<F (I6V) electrolytic axial
lx C3 470 ;:,<F (IOV) electrolytic axial
Ix C4 100 nF ceramic
lx C5 100 nF ceramic
Ix C6 100 nF ceramic
lx C7 100 nF ceramic
Ix C8 2,2 pF (63V) ceramic
Ix C9 470 pF (63V) ceramic
lx CIO 100nF ceramic
lx CII 100 nF ceramic
lx CI2 100 nF ceramic
Ix CI3 - 200 ;:,<F (l6V) electrolytic axial
DIODES
Ix 01 BAT49
lx 02 - IN4148 Signal diode
Ix 03 IN4001
Ix D4 - BZX79C 3V3 or 3,3 Volt
lx D5 - IN4148 Signal diode
Ix 06 - IN4001
lx 07 - IN4001
Ix D8 - IN4148 Signal diode
Ix D9 - IN4148 Signal diode
Ix DTX
Ix DR)(
Ix 3 Pin male and female PCB connectors
l x I VREF test pin
x OB9 female connectors
lx DB9 male connector 90 degrees
80C 196KC Microcontroller Source
Code
Appendix I
All of the embedded source code can be found on the CD appended to the rear cover of volume 2 of this thesis .
._------ -- ~~-----------
Appendix J-J
VHDL Code for PHASE 1 GAL 1
Design
-- Binding archltecturc
-vlibrary work;
--usc work.cypress.all;
--use work.rtlpkg.all;
library ieee;
use ieee.std _Iogic _1164.aU;
package pctgal_ xpkg is
component pctgal
pOI'"(clockout, stale, holda, a8, a9, alO, all, a12, an, a14, alS, rcset: in bit;
csSIO, ce2, buswidth, waite, ceO, ccf , outO, out l , out2 : out bit;
mapp : lnout xOlz);
end component;
end pctgal_xpkg;
entity pct.gal is
port (clockout, stale, holda, a8, a9, alO, all, a12, an, a14, a l S, reset: in bit;
csSIO, ce2, buswidth, waite, ccO, ce l , outO, out l , oul2 : out bit;
lIlapp : inout xOh);
end pctgal;
ARCHITECTURE appnote Ofc22vl0 is
BEGIN
Ul : petgall'ORT MAl' (
clockout => pin I,
stale => pin2,
holda => pin3,
a8=> pin4,
,,9 => pinS,
,,10=> pin6,
all => pin7,
,112=> pin8,
an => pin9,
al4 => pinlO,
alS => pln l I,
reset => pin13,
fbx(csSl0) => pinl4,
nlx(ce2) => pin l S,
fbx(buswidlh) => pinl6,
fbx(outO) => pinl7,
fbx(ouU) => pinl8,
fbx(waite) => pinl9,
fbx(out2) => pin20,
fbx(ceO) => pin21,
fbx(ce 1) => pin22,
mapp => pin23,
inst => pin24
);
cnd appnolc;
architecture fsm of pel gal is
signal sO, sl, 52, 83, s4, sS, s6, s7, 58, s9, s10, 511, 512, 513, s14, s16, s17, s18, sl9, s20, s21, s22, s23, s24: bit;
signalnwait_I, nwait_2, nwait_3,nwait_ 4, nwait_S, nwait_6, nwait_7, ck, mappdl , IIlsig, msig l , waitt: bit;
signal slatc:bil_ vector (2 downto 0);
constant async_start: bit_ vector (2 downto 0) := "000";
constant hold_2: bil_veclor (2 downto 0):= "001 ";
constant hold_3: bil_ vector (2 downto 0) := "011 ";
constant hold_ 4: bil_ vector (2 downto 0) := "II I ";
constant hold_S: bit_vector (2 downlo 0):= "110";
constant hold_6: bil_ vector (2 downlo 0) := "IOU";
constant hold_7: bil_ vector (2 downto 0) := "101 ";
-----------_.
--NOT AS SHOULD COME OUT
constant rcmove jrokl: bit_vcctor(2 downto 0):= "010";
constant rcmove Tiold l : bit_ vector (2 downto 0) := "000";
<='0';
<= NOT s19; -- S'bit real time clock nvram
<= NOT sIS; -- 16 bit sram slots for stack
<= NOT 917; -- UART
<= NOT siS;
<= NOT 916; -- 16 bit sim
<= '1';
<= '1';
<= not waitt;
<= (A15 and A14 and A13 and A12); -- 1'00011
<= (sIO);
<= (sl or 5201' s3 or s4 or 5501' s6 or 97 01' 5S or 59); -- 2000H - AFFFII 16 bit eprom sim
<= (NOT A15) and (NOT A14) and (NOT A13) and AI2 and All and AIO and A9 and (NOT AS); --IEOOII-IEFFII UART
<= (s19 or sI7); -- eprom shu or UART (buswidth)
<= (slO or sll 01' sl2 or s13 or 914); -- noooll- FFFFH S bit rca I time clock nvram
<= (NOT A15) and (NOT A14) and (NOT Al3) and AI2 and All and AIO and (NOT A9) and (NOT AS); --I coon _
I DFFII PERIPH
if (reset = '0') then
state <= async. start:
elslf (clockout'event and clockout = 'I ') then
case state is
when async jstart =>
if(nwait_1 = 'I') then
waltt <= '1';
end if;
if(nwait._1 = 'I' and nwait_2 = '0') then
state <= remove_hold;
elsif (nwait_ 2 = 'I ') then
state <= hold_2;
else
state <= nsync jstart;
end if;
when hold _ 2 =>
waitf <= '1';
if (nwait_3 = 'I') thcn
<= (NOT A15) and (NOT A14) ami (NOT Al3) and (NOT AI2); -- 000011 - OFFFII
<= (NOT A15) and (NOT A14) and A13 and (NOT AI2); -- 200011
<= (NOT A15) and (NOT A14) and A13 and A12; -- 300011
<= (NOT A15) and A14 and (NOT A13) and (NOT A12); -- 400011
<= (NOT A15) and AI4 and (NOT A13) and A12; -- 500011
<= (NOT AIS) and AI4 and A13 and (NOT AI2); -- 600011
<= (NOT A15) and A14 and A13 and A12; -- 700011
<= A15 and (NOT A14) and (NOT A13) and (NOT AI2); -- SOOOlI
<= AI5 and (NOT A14) and (NOT A13) and AI2; -- 900011
<= AI5 and (NOT A14) and A13 and (NOT A12); -- AOOOII
<= AI5 and (NOT A14) and A13 and A12; -- noooll
<= AI5 and A14 and (NOT A13) and (NOT A12); -- COOOH
<= AI5 and AI4 and (NOT A13) and AI2; -- DOOOH
<= AlS and A14 and A13 and (NOT AI2); -- EOOOH
<= (AlS and A14 and A13 and AI2); -- FOOOI-I
<= (sO or 921);
<= (91 or 92 or s3 or 94 or 95 or s6 or 97 or sS or s9 or sI0); -- 2000H - IJFFFH 16 bit eprom sim
<= (NOT AlS) and (NOT A14) and (NOT A13) and A]2 and All and AI0 and A9 and (NOT AS); --JEOOH -IEFFH UART
<= (s]9 or sI7); -- eprom sim or UART (buswidth]
<= (sll or 912 or s13 or s14); -- COOOH - FFFFH S bit realtime clock nvram
<= (NOT A1S) and (NOT A14) and (NOT A13) and A12 and All and AIO and (NOT A9) and (NOT AS); --]COOH-
lDFFH PERINI
<= (NOT A]S) and (NOT A]4) and (NOT A13) and A12 and (NOT All) and (NOT AIO) and (NOT A9); --IOOOH -11 FFH
16 - bit RAM
nwait_] <= stale and hold a and (nwait_2 or sI6); -- S bit eprom sim
nwait_2 <= stale and holda and (nwalt_3 or 9] 7 or sl9 or s20);
begin
sO
sl
s2
53
s4
s5
s6
s7
5S
s9
slO
sl1
s12
913
s14
sIS
916
s17
sIS
s19
s20
92]
nwait 3
ee2
ce]
es5]0
buswldth
ceO
mapp
inst
waite
s]4
sIS
sl6
sl7
sIS
sl9
s20
processn-cset, clockout)
begin
end if;
cnd process;
outO <= statc(O);
out l <= statc(l);
out2 <= statc(2);
end fsm;
end case;
state <= hnld_3;
else
state <= remove hold;
end if;
when hold _3 =>
waitt <= 'I'.
state <= rcmovc_hold;
when I'cmovc_hold =>
waitt<= '0';
state <= async _start;
when remove hold l =>
waitt c= '0';
state <= async _start;
when others =>
state <= async jstart;
Appendix J-2
VHDL Code for PHASE 1 GAL 2
Design
-- pcriphf .vhd
cntity PERIPHERAL is
port(A9 : in bit;
AI0 : in bit;
WR : In bit;
RD : In bit;
AIS : in bit;
A14 : In bit;
A13 : in bit;
Al2 : in bit;
All : in bit;
A3 : in bit;
A2 : in bit;
Al : in bit;
RESA : out bit;
RESn : out bit;
CELED : out bit;
IlIT 16LED : out bit;
CEI : out bit;
CE2 : out bit;
CEJ : out bit;
CE4 : out bit;
CSRELA Y : out bit;
RES4 : out bit);
attributc plnjurmbers of PERII'IIERAL:cntity is
"A9:1 "&
"AIO:2 "&
"AI:3" &
"A2:4 "&
"A3:S"&
"'VR:6" &
"RD:7"&
"All:8" &
"AI2:9"&
"A13:10" &
"AI4:11 " &
"AlS:13 " &
"RES4:14" &
"CSRELAY:IS" ,-,«
"CE4:16" &
"CEJ:17" &
"CE2:18" &
"CEI:19" &
"IllTI6LED:20 " &
"CELED:21 " &
"RESIl:22 " &
"RESA:23";
end PERIPHERAL;
nrchitecturc FSM of PERIJ'J1ERAL is
signal sl , s2, sJ, s4, sS, s6, s7, s8, s9, slO: hit;
b('gin
sl <= «NOT WR) and «NOT AIS) and (NOT A14) and (NOT Al3) and AI2 and All and AIO and (NOT A9) and A3 :tI1i1
(NOT A2) and (A I or (NOT A I»»;
CEI
52 <= «NOT WR) and «NOT AIS) nnd (NOT A14) anti (NOT AI3) anti A12 anti All anti AIO nnd (NOT A9) anti A3 anti «A2
anti (NOT AI» or «NOT A2) anti AI»»;
<= (NOT sl);
<= (NOT 52);
<= (NOT«(NOT AlS) and (NOT A14) and (NOT A13) and AI2 and All and AIO and (NOT A9) and (NOT AJ) and (NOT
A2) and (NOT AI» and (NOT RD»);
<= (NOT«(NOT AIS) and (NOT A14) and (NOT Al3) and AU and All and AIO and (NOT A9) and (NOT A3) and (NOT
A2) and AI) and (NOT RD»);
<= (NOT«(NOT AIS) and (NOT A14) and (NOT Al3) and A12 and All and AIO and (NOT A9) and (NOT A3) and A2 and
(NOT AI» anti (NOT RD»);
<= (NOT«(NOT AIS) anti (NOT A14) and (NOT Al3) and Al2 and All and AIO and (NOT A9) and (NOT A3) and A2 and
AI) and (NOT RD»);
RES4 <= «NOT WR) and «(NOT AIS) and (NOT A14) and (NOT A13) and Al2 and All and AIO and (NOT A9) and (NOT A3)
and (NOT A2) and AI»);
nIT16LED <= «NOT WR) and «(NOT AIS) and (NOT A14) and (NOT Al3) and Al2 and All and AIO and (NOT A9) and (NOT A3)
and A2 and (NOT AI»»;
CELED <= «NOT WR) and «(NOT AIS) and (NOT A14) and (NOT Al3) and Al2 and All and AIO and (NOT A9) and (NOT AJ)
and A2 and AI»);
CSRELAY <= «NOT WR) and «(NOT A15) and (NOT A14) and (NOT Al3) and Al2 and All and AIO and (NOT A9) and (NOT A3)
and (NOT A2) and (NOT AI»)));
RESA
nnsn
CE4
CEJ
CE2
end FSM;
AppendixK
Host Machine Communication
Software
All of the source code for the forms presented in this appendix, can be found on the CD appended to the rear
cover of volume 2 of this thesis.
~ AutoGas: Site: Budget - PE f3
D-atabase Transaction Tag User GrClUp Site A~porls Options Help
Dalabat~.~ L..-,--~_Ja_n_s._a_ct_B_n_: ....J1 cam~J~ L ut; . U$cr: ILes
ljwmk t T'mfo'
: ~ Ci ~ Iel-i___.J1 G~re I
Ii ~Ci>~ ~I
@/29/98
110:14:50 PM
I~J(\ lll\k
eportJ:•W
o«« ,-
Ipackets Ready
ICornms Rea.dy
Status: Iidle Login Time: 110:14:40PM
1Move mouse to select icon and click
; Tag Configur<ltion - -- - Illl!lIiI f3
ControllerConfiguration Tag Configuration Read Serialno. Company Transactions Exit
Controller: Tag: Identification: Transactions:
ctf: '0109'010 tutoRY11--- II II
~ • ~•
~
t
II• •
Move Mouse to Select Icon and Click
;it View Site 13
;- -
Name: laudget. PE
Address: IAirport
Phone: 1041.12345
Fax:
Data:
Site Number: 1100
r Exact Match
,IPort Elizabeth
Postal Code: 16Q01
~~
~
Group: IBudget -Group
.z., PreYi~us I Record lout of 1
R Transaction Maintenance 13
- . -
Number of Processed. Transactions: 10
Number of Unprocessed Transactions: ....'O----_.:...-
, Number of Transactions that can be Deleted: 10
Date last "'alnt~ined: 13/13/98
Oldea:tTransaction: Date: IN0 Transactions
Newest Transaction: Date: INo Transactions
Ir···'··..·H·~i~ ll
..................... _ - ,
Controller Configuratior(
Tag: Identification: Tran~action~:Conholler:
CP--'
Ii
r..·.····_······_·········..··· · ···j
!DallasTagl
• ••• - •••• - .........• ,._ ••_ ••!•...:;u.t..
i bl 'c~~~~~~
Move Mouse to Select Icon and Click
~ Controller Transaction HistOJ.V E3
Tag Rom Code:
T ranaaclion No.:
Entry No.: r ~
Site Code: 1
Tag Valid:
Pump No.:
Fuel Type:
TES:
litres Pumped:
Odomeler Reading:
Transaction Date: I II II dd / mm / yy
Transaction Time: r. II II hr / min !tec
Site Statl,:ls
Start Date: 1.1/1/98
Time: 1""'-2:-00-----
End Date: 129/5/98
Ti...e:I.--'s-:o-_Q.,.....-_.::,_--
Show Hitlist
E~it
&:~SIte Status EJ
Start Date: 14129/98
Time: 118:00
Tank: Status
" ••••_ u "! Download rag 1.........................~ ,r NoN esseqes
Filename: IIc: \petrol\site\test1. txt _
IN0 Unprocessed Jransections
E~itHelp
Size (Bytes):
15839
Packets:Group:
12IBudget - Group
IDefal_Jlt Start Date:
Budoet - PE From:
Site Number Tank Type State Cal
100 Tank 1 Unleaded 8796.39 90(
Pump Fuel Pumped
1 169.65
Sove Report 2 33.86
Total Fuel 203.61
L. Include Bypasses
~ Include Powerr Include Pumps
Time Down Date Up Time Up Minutes Off
Group: IBudget - Group iJ Fuel Type: ICombined
Totallitres: 1321523.7 Total Cost J6701 03. 9
litre a Since Reeet: 1319090 Coat Since Reaet: IS70103.9
Master Reset
Time Reset: INever Reset
Help
.I ~ J., u••••••,, ,
i El{it i
;" "' ;
rensecuon no. :276 :-·-1 ,1 ,0,0,100,0,0,0,2717 198 , 9 : 24, L= 11 . 71 ,02000000496C7808 ,201 ,
ransaction no. :277 :-.-1 ,1 ,0.0.100.0.0.0.2717 198 . 10: 38. L= 28. 77 •D2000000496C7808• 201
'<ln~:adi,~n no. :278 :-·-1 .1 •a . 0 .100.0.0.0.2717 198.10: 43. L= 42. 93. 02000000496C7808 • 201
ranssction no. :279 :-·-1 .1 .0.0.100.0.0.0.2717/98.11: O. L= 9.17. 02000000496C7808. 201 .
IT, ...nsachon no. :280 :---1 .1 .0.0.100.0.0.0.27 J7 198. Tl : 6. L= 3. SS. D2000000496C7808. 201 •
,;on.:;orli"n no. :281 :---1 .1 .0.0.100.0.0.0.2717 198 .11 : 9. L= 43. 24. 0200oo00496C7808 . 201 .
ransaction no. :282 :---1 .1 .0. 0.100.0.0. 0.27/7/98.11: 14 _ L· 10.23. 02000000496C7808. 201
ransaction no. :283 :---1 , , ,0.0,100,0.0,0,27/7/98,11: 43, L = 34.55, D2000000496C7808, 201
ransaction no. :284 :---1 .1 .0.0,100.0.0.0.2717 198.11: 50. L = 11.55. 02000000496C7808, 201
Transaction no. :285 :---1 .1 .0.0.100.0.0.0.2717 198.12: 8. L= 18.7. 02000000496C7808. 201 .
Transaction no. :286 :-.-1 • 1 • 0 . 0 . 100 • 0 , 0 . 0 • 27 I 7 198 , 12 : 17 • L= 5. 59 •D2000000496C7808 • 201 .
Transaction no. :287 :---1 .1 .0.0.100.0.0.0.27/7/98.12: 20. L = 9.12, 02000000496C7B08, 201 .
ransaction no. :288 :---1 .1 .0.0.100.0.0.0,2717/98.14: 20. L = 1 .7, 02000000496C7808. 201 •
ransaction no. :289 :---1 .1 ,0.0.100.0.0.0,27/ 7/9B. 14: 40. L = 21.39. 02000000496C7808, 201
ransaction no. :290 :---1.1. 0.0. 100.0.0.0.2717/98.15: 17, L· 58.76, D2000000496C7808, 201
ransaction no. :291 :---1 .1 .0.0.100.0.0.0.27/ 7/9B_, 15: 29. L:: 0 ~4. o2000000496C7808 . 201 . ..:J
~eperate :rra~actions Q.uit I
Transaction no. :286 :---1 .1 .0.0.100, 0.0. 0.2717/98.12: 17. L:: 5.59. 02000000496C7808. 201 .• :
Transaction no. :287 :---1 .1 .0.0.100.0.0. 0.2717/98.12: 20. L= 9.12. 02000000496C7808. 201 .
[Trensecnon no. :288:---1.1.0.0.100.0.0.0.2717/98.14: 20. L = 1.7. 02000000496C7B08. 201.
Transaction no. :289 :---1 ,1 ,0.0.100.0.0. 0.2717/98.14: 40. L .. 21 .39, 020000OO496C7808. 201
Transaction no. :290 :---1 .1 .0.0.100.0.0.0.2717/98.15: 17. L= 58.76. 020000OO496C7808. 201J
Transaction no. :291 :-"1.1.0,0.100.0.0.0.2717/98.15: 29. L- 0.4, D2000000496C7808 ,201.
Transaction no. :292 :---, • , .0.0.100.0.0.0.27/7/98.15: 37. LaO. 20. 02000000496C7808. 201 .
8ypass Tm no. :294 :-. Site Code:- 100 Pumpbypassed:- 1. L~resPumped:· 1 .0
Start Time:- (2717/98--15: 55: 0) - .. End Time:-(27 17 /98-15: 55: 8)
Bypess Trnno. :294 :-. Site Code:- 100 Pumpbypessed:- t . Ures Pumped:- 10 - 71
Start Time:- (2717198--15:55:n )-_. End Time:-(201 11231108--73:0:0)
Transaction no. :295 :---1 .1 .0.0.100.0.0.0.27/7/98.16: 9. L= 48.73. 02000000496C7808. 201 .
Transaction no. :296 :---1.1.0.0.100.0.0.0.2717/98.16: 13. L = 0.92. 02000000496C7808. 201 .
Transaction no. :0 :-- 0,0.0,0.0,0.0.0.0 10/0.0: O. L = 0 _0 .08,0,
Transaction no. :0 :-- 0.0.0.0.0,0.0,0.0 I 0 I 0.0: O. L= 0.0.08.0.
Transaction no. :0 :-- 0.0.0.0.0.0.0. 0.0 I 0 1 0.0: O. L = 0.0.08.0.
Transaction no. :0 :-- 0.0.0.0.0.0.0.0.0 I 0 I 0,0: O. L= 0.0,08,0.
Transaction no. :0 :-- a . 0.0.0.0.0.0.0.0 I 0 I 0.0: O. L = O. 0.08.0.
Transaction no. :0 :-- 0, 0.0.0. o. 0.0,0. a I 0 I 0.0: O. L· 0 _0 .08,0,
Transaction no, :0 :-- c. 0.0.0,0, c. o. 0.0 I 0 I 0,0: O. L= 0.0.08,0. ...1
Transaction no. :0 :-. o. 0.0.0.0.0.0.0.0 I 0 I 0.0: O. L= 0.0.08.0. ...:_j
~eperate Tra~actions Q.uit I
~ Configuration Tag Edit , ' . E3
Pin No.: l!234 [MAX: 99991 Max Trans: 1'?.!10_" r T~gValid::-
Site Code: ~l"')x: 129 i .Key.: 12.55.J Timeout: 1200
Pump No 1: 11 Pump No 3:
Pump No 2:.ff Pump No 4:
Configuratile User Prompting:
lit Update the Clock
~ Calibrate the Pumps
E' Initialile the NVRAN
1'-' Update Fueltjlpes
r Append ~ew Hitli$l
C Update Group Code($)
~ Update Site Code
....~ • it "1IiL..!::!.e~.~~~:.~.!?.:._~!.!~.~P..~.r: 'Reod Co"'i~urationr Bypas~Vehicle PINNO
-
(1 ~Leaded Poboll
(2 Unleaded Petrol)
r Download to Databa~e
r D'ownload to file
r f)ownload to printer
r View latest Download File
Download Filel :
Id!]ldf1.bin
Download File2 :
Idnldf2._bin
Download File :
Download STATUS:
I,f·················~a~c;i'-····'······'··'!I................................................ _ ....,
AppendixL
PHASE 1 Design Schematics
PHASE 1 Design PCBs
AppendixM
o~ .,,_ ~ ~r,,"
'};;:
[;:::; i<"I e-
;: H ~ I-
~ f..J
o
oo o
0000000000
-------0000000000
o
o

[]
o
o


o
o o
o 0
o
o
o
@
[]
0ncZz 01
0
~O ~
fO f
0
0 0
-----------------_j
AppendixN
PHASE 2 Design's Graphics
Definition Files
--------------------------------------------------------~------- --~--.--- ----~-~. -_- -- -------------------
.,f-->------""""'''--'''------------,
L_ __ _j , ,
... /1'Io4.}oVALLIE.
'- - - - - - - - - -~ .. D~(CIIOII'U·>I
W-t.I(IDVLU90 I
- - - - - - - - - - ;-~~~~~~~~--
LPM COlJI'IrrER I
~_oclr
.,/-------''''''''-''-'=-------------1
.,f-->------'''-''''''''''=-------------1
IlESCNI'U '
___ d
"I-- ~~~L_ _J
, '.~--- '
_--------------
,...A, ...... ~~-!.... ,
::~::~~~'-= 7l~~~5~;~:~I:~:
,(,o.nK - -,~~tJ: E~NTRILfl«:NrRl' -'---~- ,, ', ,
.!"'~ - - - I
~tftJ7"--':_-"'£","'N,"'R"""-~~- ,, ,
, '
!"'!.---,
'!""!._- p.n..- - - I
, ""N'",,----,
,
~""!- - I
"or - -,
,,
~---:
jL<.n:lir - -,
~-~~!------~~!.!.~-----:-cJ: ------
~---:
CU<OVT : f?~~~~,-~~;-::tf:"_- _9 _-~s!_:Pib_-_-~,i.i:"fioir
'.......... _-----,
1---
ir'U_Av';I)£'- - - .
IP.. _OJJl£C1Q."\JP"r·,,_IoIOI)U\US' 'P"'_SV"I.(JE' '-lPM-Co..MER- _11'~~r~"2~ - ~
''1' ~------~~~----------------_j
I
( ' ,
"'i~------~~~----------------_j
",.~ ~~~L_ _j
~_;l! --::-_-~-_-_-~
nESE~ISIoJ'l£I'OJTEDlltAO..O! IIECf'~OWI(N ne
INTERNAol """C.ACX:H: F\JfClOO IS NOlIN use .
f·~~0ci~».);_-_-~_-_-~
f:;~~~:;':~~::::::~'
r ,
( :\
-.;I
I
;~t'l
~
r 1
~
~
~---~"----------~------------------------------
"
AH~"50-- - - -
W<DJI """
05.
-ce _u;uu, ,.TaJ(
.ccc.,.. O<>lR
RCU<
eo
"'"SCUl
tOJ11' •
'j.JL 1
PHASE 2 Design's Text Definition
Files
Appendix 0
library IEEE;
use IEEE.std logic 1164.all;
entity maxper3A is
port(WR
RD
A1S
A14
A13
A12
All
Ala
A9
A8
A7
A6
AS
A4
A3
A2
Al
AO
LEDBANK
port2_RI
RESCNTRI
RESCNTR2
RESCNTR3
RESCNTR4
RESCNTRS
RESCNTR6
RESCNTR7
RESCNTR8
EXLAMP
EXFAN
SBUZZER
SWDI
NOZZLES
ENCI
ENC2
ENC3
ENC4
ENCS
ENC6
ENC7
ENC8
CE CNTRS
CELED
BIT16LED
Cmux sel
CSRELAY
TESTCPLD
end maxper3A;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
:out bit;
:out bit;
: out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out std_logic vector(l downto 0);
out bit;
out bit);
architecture FSM of maxper3A is
signal sl,CEl,CE2,CE3,CE4: bit;
<= ((NOT AlS) and (NOT A14) and (NOT A13) and A12 and All and Ala andA8)and (NOT A7)and (NOT A6));
<= ((51 and AS and A4 and (NOT A3) and (NOT A2) and (NOT AI)) and
<= ((51 and AS and (NOT A4 ) and A3 and A2 and AI) and (NOT RD));<= ((51 and AS and (NOT A4) and A3 and A2 and (NOT AI)) and (NOT
<= ((51 and AS and (NOT A4)and A3 and (NOT A2) and AI) and (NOT
begin
sl
(NOT A9) and (NOT
CE8
(NOT RD));
CE7
CE6
RD) ) ;
CES
RD) ) ;
CE4
AI)) and (NOT RD));
CE3
and (NOT RD));
<= ((51 and (NOT AS) and (NOT A4)and (NOT A3) and (NOT A2) and (NOT
-- (ADDR: ICOOH)
<= ((51 and (NOT AS) and (NOT A4)and (NOT A3) and (NOT A2) and AI)
-- (ADDR: IC02H)
<= ((sl and (NOT AS) and (NOT A4)and (NOT A3) and A2 and (NOT AI))
-- (ADDR: 1C04H)
<= ((sl and (NOT AS) and (NOT A4)and (NOT A3) and A2 and AI) and (NO!
-- (ADDR: 1C06H)
RESCNTR8 <= ((NOT WR) and ((sl and (NOT AS) and A4 and (NOT A3) and A2 and
CE2
and (NOT RD));
CE1
RD) );
AI) ));
RESCNTR7
(NOT AI) )));
RESCNTR6
and AI)));
RESCNTRS
and (NOT A1))));
RESCNTR4
AI) ));
RESCNTR3
(NOT A1))));
RESCNTR2
and AI) ));
RESCNTR1
and (NOT A1))));
ENC8 <=
AI) )));
<= ((NOT WR) and ((sl and (NOT AS) and A4 and (NOT A3) and A2 and
<= ((NOT WR) and ((sl and (NOT AS) and A4 and (NOT A3) and (NOT A2)
<= ((NOT WR) and ((sl and (NOT AS) and A4 and (NOT A3) and (NOT A2)
<= ((NOT WR) and ((sl and (NOT AS) and (NOT A4) and A3 and A2 and
-- (ADDR: 1COEH)
<= ((NOT WR) and ((sl and (NOT AS) and (NOT A4) and A3 and A2 and
--(ADDR: 1COCH)
<= ((NOT WR) and ((sl and (NOT AS) and (NOT A4) and A3 and (NOT A2)
--(ADDR: 1COAH)
<= ((NOT WR) and ((sl and (NOT AS) and (NOT A4) and A3 and (NOT A2)
-- (ADDR: 1C08H)
((NOT WR) and ((sl and AS and (NOT A4) and A3 and (NOT A2) and (NOT
ENC7 <= ((NOT WR) and ((sl and AS and (NOT A4) and (NOT A3) and A2 and AI)));
ENC6 <= ((NOT WR) and ((sl and AS and (NOT A4) and (NOT A3) and A2 and (NOT
AI) )));
.1) ) ) ;
ENCS <= ((NOT WR) and ((sl and AS and (NOT A4) and (NOT A3) and (NOT A2) and
<= ((NOT WR) and ((sl and AS and (NOT A4) and (NOT A3) and (NOT A2) and
-- (ADDR: 1C20H)
<= ((NOT WR) and ((sl and (NOT AS) and A4 and A3 and A2 and AI) ));
-- (ADDR: 1C1EH)
ENC2 <= ((NOT WR) and ((sl and (NOT AS) and A4 and A3 and A2 and (NOT A1))));
-- (ADDR: 1C1CH)
ENC1 <= ((NOT WR) and ((sl and (NOT AS) and A4 and A3 and (NOT A2) and AI)));
-- (ADDR: 1C1AH)
BIT16LED <= ((NOT RD) and ((sl and (NOT AS) and (NOT A4) and (NOT A3) and A2
and (NOT A1)))); --(ADDR: 1C04H)
CELED <= ((NOT WR) and ((sl and (NOT AS) and (NOT A4) and (NOT A3) and A2 and
-- (ADDR: 1C06H)
CSRELAY <= ((NOT WR) and ((sl and (NOT AS) and (NOT A4) and (NOT A3) and (NOT
A2) and (NOT A1)))); --(ADDR: 1COOH)
EXLAMP <= ((NOT WR) and ((sl and (NOT AS) and A4 and A3 and (NOT A2) and
(NOT A1)))); -- (ADDR: 1C18H)
EXFAN <= ((NOT WR) and ((sl and AS and A4 and (NOT A3) and (NOT A2) and
-- (ADDR: 1C32H)
<= ((NOT WR) and ((sl and AS and A4 and (NOT A3) and A2 and AI)));
-- (ADDR: 1C02H) *
SWDI <= ((NOT WR) and ((sl and AS and A4 and A3 and (NOT A2) and (NOT A1))));
-- (ADDR: 1C38H)
<= ((NOT RD) and ((sl and AS and A4 and (NOT A3) and A2 and (NOT
-- (ADDR: 1C34H)
CE CNTRS <= CE1 OR CE2 OR CE3 OR CE4;
LEDBANK <= ((NOT WR) and ((sl and AS and A4 and A3 and (NOT A2) and AI)));
-- (ADDR: 1C3AH)
port2 RI <= ((NOT WR) and ((sl and AS and A4 and A3 and A2 and (NOT A1))));
-- (ADDR: 1C3CH)
TESTCPLD <= ((NOT WR) and ((sl and AS and A4 and A3 and A2 and AI) ));
-- (ADDR: 1C3EH)
ENC4
(NOT AI)) ));
ENC3
AI) ));
AI) ));
SBUZZER
NOZZLES
AI) )));
process
Cmux sel <= "00";
begin
CE CNTRS <= '1'; -- none of the counter outputs are latched onto the
output bus
IF CE1 = '1' THEN
Cmux se1 <= "00";
CE CNTRS <= '0';
ELSIF CE2 = '1' THEN
Cmux sel <= "01";
CE CNTRS <= '0';
ELSIF CEj = '1' THEN
Cmux sel <= "10";
CE_CNTRS <= '0';
ELSlf CE4 = '1' THEN
Cmux sel <= "11";
CE CNTRS <= '0';
END IF;
end process;
end FSM;
-- Steven Swanepoel's VHDL Template for a heartbeat indicator
library IEEE;
use IEEE.std logic 1164.all;
ENTITY heartbeat IS
PORT
(
clk
flash
: IN
: OUT
STD LOGIC;
STD LOGIC clock used to increment the counteroutput from heartbeat , indicates a time fortoggle of the heartbeat
) ;
END heartbeat;
ARCHITECTURE vhdl Code OF heartbeat IS
signal toggle~time_out STD LOGIC;
BEGIN
PROCESS (clk) -- 1 clock cycle lOOns (10MHz)
VARIABLE count : integer range 0 to 2500000;
BEGIN
IF (clk'EVENT and clk = '1') THEN
transistion only
IF count <= 2500000 THEN
count := count + 1;
time out<='O';
ELSE
enter this code section on pos clock
if counter <= 1000 , continue counting
reset time out<='l'; -- produce a counter lapse signal, used for e.g. cpu
IF toggle = '1' THEN
toggle <= '0';
ELSE
toggle <= '1';
END IF;
END IF;
END IF;
IF time out = '1' THEN
count := 0; -- reset counter
IF toggle = '0' THEN
FLASH <= '0';
ELSE
FLASH <= '1';
END IF;
END IF;
END PROCESS;
END vhdl code;
library IEEE;
use IEEE.std logic 1164.all;
entity maingall is
PORT (
clockout: in std logic;
stale: in std logic;
holda: in std-logic;
a8: in std logic;
a9: in std-logic;
a10: in std_logic;
all: in std_logic;
a12: in std_logic;
a13: in std_logic;
a14: in std_logic;
a15: in std logic;
reset: in std logic;
cs510: out std_logic;
ce2: out std logic;
buswidth: out std logic;
outO: out std logIc;
waite: out std logic;
ceO: out std_logic;
ce1: out std_logic;
inst: in std logic;
LEDBANK: in std logic
out1: out std logic
) ;
end maingal1;
architecture fsm of maingal1 is
signal sO, sl, s2, s3, s4, s5, s6, s7, s8, s9, s10, s11, s12, s13, s14, sIS, s16,
s17, s18, s19, s20, s21, s22: std logic;
signal nwait 1, nwait 2, nwait 3, nwait 4, mappd1, msig, msig1, waitt: std logic;
signal state:std logic vector (1 downto-O);
constant async_start: std_logic_vector (1 downto 0) := "00";
constant hold_2: std_logic_vector (1 downto 0) := "01";
constant hold 3: std logic vector (1 downto 0) := "10";
constant remove hold: std logic vector (1 downto 0) .- "11";
begin
sO <= (NOT A15) and (NOT A14 ) and (NOT Al3) and (NOT A12) ; OOOOH - OFFFHsl <= (NOT A15) and (NOT A14) and A13 and (NOT A12); 2000Hs2 <= (NOT A15) and (NOT A14 ) and A13 and A12; 3000Hs3 <= (NOT A15) and A14 and (NOT A13) and (NOT A12) ; 4000Hs4 <= (NOT A15) and A14 and (NOT·A13) and A12; 5000Hs5 <= (NOT A15) and A14 and A13 and (NOT A12); 6000Hs6 <= (NOT A15) and A14 and A13 and A12; 7000Hs7 <= A15 and (NOT A14 ) and (NOT A13) and (NOT A12) ; 8000Hs8 <= A15 and (NOT A14 ) and (NOT A13) and A12; 9000Hs9 <= A15 and (NOT A14 ) and A13 and (NOT A12); AOOOHs10 <= A15 and (NOT A14 ) and A13 and A12; BOOOHsl1 <= A15 and A14 and (NOT Al3) and (NOT A12) ; COOOHs12 <= A15 and A14 and (NOT A13) and A12; DOOOHs13 <= A15 and A14 and A13 and (NOT A12); EOOOHs14 <= (A15 and A14 and A13 and A12) ; FOOOHsIS <= (sO or s21);
s16 <= (sl or s2 or s3 or s4 or s5 or s6 or s7 or s8 or s9 or s10); -- 2000H -BFFFH 16 bit eprom sim
sl7 <= (NOT A15) and (NOT A14 ) and (NOT A13) and A12 and All and A10 and A9 and(NOT A8); --lEOOH -lEFFH UART
s18 <= (s19 or s17) ; -- eprom sim or UART (buswidth)s19 <= (s11 or s12 or s13 or s14); -- COOOH - FFFFH 8 bit real time clock nvrams20 <= (NOT A15) and (NOT A14) and (NOT A13) and A12 and All and A10 and (NOT A9)and (NOT A8) ; --lCOOH - 1DFFH PERIPH
s21 <= (NOT A15) and (NOT A14) and (NOT A13) and Al2 and (NOT All) and (NOT AIO)and (NOT A9) ; --1000H -IIFFH 16 - bit RAM
--nwait 1
--nwait 2
<= '0';
<= '0';
nwait 1
nwait 1
<= stale and ho1da and (nwait 2 or s16 or sO); -- 8 bit eprom sim
<= (nwait 2 or s16); -- 8 bit eprom Slm
1 wait state for eproms
nwait 2 <= stale and holda and (nwait 3 or s17 or s19 or s20 or LEDBANK);
--NOT A8 SHOULD COME OUT
nwait 2
COME OUT
<= (nwait 3 or s17 or s19 or s20); --NOT A8 SHOULD
2 wait states for sram, nvram & peripheral outputs (for 4040 counter ics)
nwait 3 <= '0';
nwait 4 <= INST;
3 wait states not required
ce2 <= (NOT s19) AND (NOT inst); -- 8 bit real time clock nvram
when the INST pin is high indicates instruction is fetched otherwise data is fetched
buswidth <= NOT s18;
buswidth <= NOT s18;
ceO <= NOT s16; -- 16 bit sim or EPROMS (ADDR: 2000H - BFFFH)
ce2 <= (NOT s19); --AND (NOT inst); -- 8 bit real time clock nvram
(ADDR: COOOH - FFFFH)
ce1 <= NOT sIS; --AND (NOT inst); -- 16 bit sram slots for stack (ADDR:
OOOOH - OFFFH and 1000H -llFFH)
csS10 <= NOT s17; EXTERNAL UART (ADDR: 1EOOH -lEFFH)
ce1
csS10
buswidth
ceO
<= NOT sIS;
<= NOT s17;
<= NOT s18;
<= NOT s16;
-- 16 bit sram slots for stack
UART
-- 16 bit sim
waite <= not waitt;
process (reset, clockout)
begin
if (reset = '0') then
buswidth <= '1';
state <= async start;
ceO <= '1';
ce2 <= '1';
ce1 <= 'I';
csS10 <= '1';
elsif (clockout'event and clockout = '1') then
buswidth <= NOT s18;
ceO <= NOT s16; -- 16 bit sim or EPROMS (ADDR: 2000H - BFFFH)
ce2 <= (NOT s19); --AND (NOT inst); -- 8 bit real time clock nvram
(ADDR: COOOH - FFFFH)
ce1 <= NOT sIS; --AND (NOT inst); -- 16 bit sram slots for stack (ADDR:
JOOH - OFFFH and 1000H -llFFH)
csS10 <= NOT s17; -- EXTERNAL UART (ADDR: 1EOOH -lEFFH)
--chip selects are placed here in order to guarentee a spike free
-- output since it is a clocked output
case state is
when async start =>
if (nwait 1 = '1') then
waitt <= '1';
waite <= '0';
end if;
if (nwait 1 = 'I' and nwait 2
state <= remove hold;
elsif (nwait 2 = 'I') then
state <= hold 2;
else
state <= async start;
,0') then
end if;
when hold 2 =>
waitt <= '1';
waite <= '0';
if (nwait 3 = '1') then
state <= hold 3;
else
state <= remove hold;
end if;
when hold 3 =>
waitt <= ' 1' ;
waite <= ' 0 ' ;
state <= remove hold;
remove hold =>
waitt <= , 0 ' ;
waite <= ' 1' ;
state <= async start;
when
when others =>
state <= async start;
end case;
end if;
end process;
outO <= state(O);
--outl <= state(l);
end fsm;
library IEEE;
use IEEE.std logic l164.all;
entity maxper2B is
port (CLKOUT
ALE
BUSWIOTH
nWAITN
nWRL
nWRH
WR
RO
AlS
A14
A13
A12
All
AlO
A9
A8
A7
A6
AS
A4
A3
A2
Al
AO
RESCNTRI
RESCNTR2
RESCNTR3
RESCNTR4
RESCNTRS
RESCNTR6
RESCNTR7
RESCNTR8
EXLAMP
EXFAN
SBUZZER
SWOI
NOZZLES
ENCI
ENC2
ENC3
ENC4
ENCS
ENC6
ENC7
ENC8
CE CNTRS
CELEO
BIT16LEO
Cmux sel
CSRELAY
TESTBIT
end maxper2B;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
in bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
:out bit;
:out bit;
: out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out bit;
out std_logic vector(l downto 0);
out bit;
out bit);
architecture FSM of maxper2B is
signal sl,CES,CE6,CE7,CE8: bit;
begin
sl <= ((NOT A1S) and (NOT A14) and (NOT A13) and A12 and All and A10 and
(NOT A9)and (NOT A8)and (NOT A7)and (NOT A6));
CE8 <= ((s1 and AS and A4 and (NOT A3) and (NOT A2) and (NOT Al)) and
(NOT RD)) ;
CE7 <= ((s1 and AS and (NOT A4 ) and A3 and A2 and Al) and (NOT RO)) ;
CE6 <= ((s1 and AS and (NOT A4) and A3 and A2 and (NOT AI)) and (NOT
RO)) ;
CES <= ((sl and AS and (NOT A4)and 1'''.3 and (NOT A2) and AI) and (NOT
RO)) ;
CE4 <= ((sl and (NOT AS) and (NOT A4)and (NOT A3) and (NOT A2) and (NOT
A1)) and (NOT RD));
CE3 <= ((sl and (NOT AS) and (NOT A4)and (NOT A3) and (NOT A2) and Al)
and (NOT RD));
CE2 <= ((sl and (NOT AS) and (NOT A4)and (NOT A3) and A2 and (NOT Al))
and (NOT RD));
CE1 <= ((sl and (NOT AS) and (NOT A4)and (NOT A3) and A2 and A1) and (NOT
RD) );
RESCNTR8 <= ((NOT WR) and ((sl and (NOT AS) and A4 and (NOT A3) and A2 and
Al) ));
RESCNTR7 <= ((NOT WR) and ((sl and (NOT AS) and A4 and (NOT A3) and A2 and
(NOT Al))));
RESCNTR6 <= ((NOT WR) and ((sl and (NOT AS) and A4 and (NOT A3) and (NOT A2)
and Al))) ;
RESCNTRS <= ((NOT WR) and ((sl and (NOT AS) and A4 and (NOT A3) and (NOT A2)
and (NOT A1))));
RESCNTR4 <= ((NOT WR) and ((sl and (NOT AS) and (NOT A4) and A3 and A2 and
A1) ));
RESCNTR3 <= ((NOT WR) and ((sl and (NOT AS) and (NOT A4) and A3 and A2 and
(NOT A1) )));
RESCNTR2 <= ((NOT WR) and ((sl and (NOT AS) and (NOT A4) and A3 and (NOT A2)
and A1) ));
RESCNTR1 <= ((NOT WR) and ((sl and (NOT AS) and (NOT A4) and A3 and (NOT A2)
and (NOT A1) )));
ENC8 <= ((NOT WR) and ((sl and AS and (NOT A4) and A3 and (NOT A2) and (NOT
,1))));
ENC7
ENC6
<= ((NOT WR) and ((sl and AS and (NOT A4) and (NOT A3) and A2 and Al)));
<= ((NOT WR) and ((sl and AS and (NOT A4) and (NOT A3) and A2 and (NOT
A1) )));
ENCS <= ((NOT WR) and ((sl and AS and (NOT A4) and (NOT A3) and (NOT A2) and
Al) ));
(NOT
ENC4
A1) )));
ENC3
ENC2
<= ((NOT WR) and ((sl and AS and (NOT A4) and (NOT A3) and (NOT A2) and
and (NOT
ENC1 <=
BIT16LED
Al) )));
CELED <=
<= ((NOT WR)
<= ((NOT WR)
((NOT WR)
<= ((NOT
and
and
and
WR)
((sl and (NOT AS)
((sl and (NOT AS)
((sl and (NOT AS)
and ((sl and (NOT
and A4 and A3 and A2 and Al)));
and A4 and A3 and A2 and (NOT Al))));
and A4 and A3 and (NOT A2) and Al)));
AS) and (NOT A4) and (NOT A3) and A2
((NOT WR) and ((sl and (NOT AS) and (NOT A4) and (NOT A3) and A2 and
Al) ));
CSRELAY <= ((NOT WR) and ((sl and (NOT AS) and (NOT A4) and (NOT A3) and (NOT
A2) and (NOT Al))));
EXLAMP <= ((NOT WR) and ((sl and (NOT AS) and A4 and A3 and (NOT A2) and
(NOT Al))));
EXFAN <= ((NOT WR) and ((sl and AS and A4 and (NOT A3) and (NOT A2) and
Al))) ;
SBUZZER <= ((NOT WR) and ((sl and AS and A4 and (NOT A3) and A2 and Al)));
SWDI <= ((NOT WR) and ((sl and AS and A4 and A3 and (NOT A2) and (NOT Al))));
NOZZLES <= ((NOT WR) and ((sl and AS and A4 and (NOT A3) and A2 and (NOT
A1)))) ;
CE CNTRS <= CES OR CE6 OR CE7 OR CE8;
Cmux sel <= ~OOO~;
TESTBIT <= CLKOUT OR ALE OR BUSWIDTH OR nWAITN OR nWRL OR nWRH;
process
begin
CE CNTRS <= '1'; -- none of the counter outputs are latched onto the
output bus
IF CES = '1' THEN
Cmux sel <= ~OO";
CE CNTRS <= '0';
ELSIF CE6 = '1' THEN
Cmux sel <= "01";
CE CNTRS <= '0';
ELSIF CE7 = '1' THEN
Cmux sel <= "10";
CE CNTRS <= '0';
ELSIF CE8 = '1' THEN
Cmux sel <= "11";
CE CNTRS <= '0';
ELSIF CES = '1' THEN
Cmux sel <= "100";
CE CNTRS <= '0';
ELSIF CE6 = '1' THEN
Cmux sel <= "101";
CE CNTRS <= '0';
ELSIF CE7 = '1' THEN
Cmux sel <= "110";
CE CNTRS <= '0';
ELSIF CE8 = '1' THEN
Cmux sel <= "Ill";
CE CNTRS <= '0';
ELSE
CE CNTRS <= '1';
output bus
END IF;
end process;
end FSM;
-- none of the counter outputs are latched onto the
Synthesis of the FLEX 10Ks Internal
Design
AppendixP
10 Any Colo Col 1 Co!2 Col3 Col4 Co16 Co16 Col7 Col8 Col 9 Col10 Col11 Col12 ColEAS Col 13 Col 14 Co116 ColiB Col17 Col18DDDDDDDDDDDDDDDDDD
1 ::
D
Row
10
1
1
0
Row
C
Ooll_lnO.O
TEST_CPL0410
U2"_A14/A16.0
U24_A13·0
U201l.l21_A13.0
U22_A14·0
U22N23_A14/A16.0
U20_A14.0
A7.0
HIGI-f'IN_O.!!HE_.
U23_A14.0
(110)00
U21_A14.0
INST_O
U201U21_A14/A16.0
WOl4l0
""_LImP.O
Ex...Fan·O
BUZZER.0
CS610.0
~,
!•o
1; 1!
!' !'••00
:e,
!•o
,._.',
!•o
:2,
!•o
1l
!'•o
o
:E
;'
c•o
.,
i
!'•o
..
i'•o
on
i
!'•o Io
;
Io
Coli B Col 20 Col21 Col 22 Col 23 Col 24DDDDDD
1o
.,
i' ~
II
DO
I
Io
ii:
f:!'..
~
Io
§
Io
..<,
9
Io
.:
II
00
o,
e
o,
~
o,
w
u
o,
I
o,
!
o,
!
o,
~
o,
~
DO
"~ ~
o
t,
B
00••~' ~'e, _
c c
o•",
~
o.,
~c
o•~'e,
c
o•~'
~
DDDDODDDDDDDDDDDDDDDDDDDD
O_AO
0_A1
0_A2
0_A3
O_M
0_A6
O_AB
O_·'"T_OONE
O_AB
O_AB
O_A10
O_A11
0_A12
O_A13
0_A14
0_A16
O_PLE01A1
0_PLE01A2
O_PLE02A1
O_PLE02A2
O_PLEOllA1
0_PLE03A2
0_PLE04A1
o,
~
DDDDODDODODDODDDDDDDDDDDD
DDDDDDDDDDDDDDDDDDDDDDDDD
ADD
D
AnyC~
D
CoIl Col 2 Col 3 Col 4 Col 5 cole Col 7 Col 8 Col9 Col 10 Col 11 Col 12 COiEAB Col 13 Col 14 Col 15 Col 16 Col 17 Col 18 Col 19 Col20 Col 21 Col 22 Col 23 C4>i24DDDDDDDDDDOODDDODDDDOOOOD,
Any
Row
CJ
Row•
C]
Row
8
CJ
Row
C
CJ
Row
o
CJ
Row
E
CJ
Row
F
CJ
0...-,nl·0
0II1II-,""·0
0892_5_8."'_ 0
0892_'_01_0
o891_5_S."'_ 0
C8RELAV_0
PITXD_O
,,,r_O
o892_7_Rr$_0
0892_,_DTR_0
089'_'_OCo_ 0
lITXD_O
08"_'_CTS_ 0
0891_,_oTR_0
INS'T_O
0892_'_oSR_0
RESET_O
0891_7_RTS_0
0892_'_CTS_0
0801_'_oSR_0
PIRJ<ll_O
~'•o
~Ig•o
'g :E
g' g'••DO
;'•o
'~I
~•o
.,
~•o
,
o .iDO
,
o 1o ~Io
DDDDDDDDDDDDDDDDDDDDDDDDD
DDDDDDDDDDDDDDDDDDDDDDDDD
D~DDDDDD~DDDDDDDDDDDDDDDD
~
Io
O_,NSTOUTO_IWR
O_PO_'
0_"
0_A2
0_"
0_"
0_"
0-"0_.7
0_"
0_"0_.,0
0_·t10_.,20_.13
O_A14DDDDDDDDDDDDDDDDDDDDDDDDD
DDDDDDDDDDDDDDDDDDDDDDDDD
DCJ~DDDDD~CJDDDCJCJDDDDDDDCJDD
o•~ o,I
o,
!
o,
!
o,
!
DO 0" ,i ; ~
Ils
o, DO'I~ ~
!1
11:'
DO' ..l' 1 o..i ot,1 o•i'!5 o•i'!5 o..~
0_.,5
O_PlE05AI
O_PlEDSA2
O_PlEDO.,
O_PlE06A2
0_PlED7AI
0_PlE07A2
0_PlED8A1
o
i
Appendix Q
Routing of the FLEX 10Ks Internal
Design
lJ24_A13
U201U21_A13
U22JU23_A141A15
U20_A14
(VCCIO)
(VCCINT1
A7
HIGHI''''
lJ23_A14
1"'1
U21_A14
NST
IG~Ol
(G""""l
U201U21_A1NA15
Ex...Fen
BUZZER
CS510
IMSEUl)
(MSEL1)
(VCCM)
(ntOtoFIG)
CE2

Copyright (C) 1988-1999 A1tera Corporation
Any megafunction design, and related net list (encrypted or decrypted),
support information, device programming or simulation file, and any other
associated documentation or information provided by Altera or a partner
under Altera's Megafunction Partnership Program may be used only to
program PLD devices (but not masked PLD devices) from Altera. Any other
use of such mega function design, net list, support information, device
programming or simulation file, or any other related documentation or
information is prohibited for any other purpose, including, but not
limited to modification, reverse engineering, de-compiling, or use with
any other silicon devices, unless such use is explicitly licensed under
a separate agreement with Altera or a megafunction partner. Title to
the intellectual property, including patents, copyrights, trademarks,
trade secrets, or maskworks, embodied in any such megafunction design,
net list, support information, device programming or simulation file, or
any other related documentation or information provided by Altera or a
mega function partner, remains with Altera, the mega function partner, or
their respective licensors. No other licenses, including any licenses
needed under any third party's intellectual property, are provided herein.
N.C. = No Connect, This pin has no internal connection to the device.
VCCINT = Dedicated power pin, ~hich MUST be connected to VCC (5.0 volts)
VCCIO = Dedicated power pin, which MUST be connected to VCC (5.0 volts).
JINT = Dedicated ground pin or unused dedicated input, which MUST be connected to GND.
GNDIO = Dedicated ground pin, which MUST be connected to GND.
RESERVED = Unused I/O pin, which MUST be left unconnected.
CHIP "petscha1" ASSIGNED TO AN EPF10K10TC144-4
TCK 1
CONF DONE 2
nCEO
TDO
VCCIO
VCCINT
AO
Al
A2
A3
A4
AS
A6
INIT DONE
r"DIO
~ JINT
A8
A9
AIO
All
A] 2
A13
A14
VCCIO
VCCINT
A15
PLED1A1
PLED1A2
PLED2A1
PLED2A2
PLED3A1
PLED3A2
PLED4A1
TMS
nSTATUS
PLED4A2
OIPSW 0
OIPSW 1
OIPSW 2
GNDIO
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
D1PSW 3 41
D1PSW 4 42
D1PSW 5 43
D1PSW-6 44
VCCIO 45
D1PSW 7 46
count1 clk 47
eount2 elk 48
eount3 elk 49
GND10 50
eount4 elk 51
VCC1NT 52
VCC1NT 53
Pi NOZZEL 54
P2 NOZZEL 55
P3 NOZZEL 56
GND1NT 57
GND1NT 58
P4 NOZZEL 59
RLl 60
VCCIO 61
RL2 62
RL3 63
RL4 64
SPAREl 65
:)10 66
~I:'ARE2 67
SPARE3 68
SPARE4 69
CE1 70
VCC10 71
CEO 72
CE2 73
nCONF1G 74
VCC1NT 75
MSELl 76
MSELO 77
CS510 78
BUZZER 79
Ex Fan 80
Ex_Lamp 81
WD1 82
U20/U21 A14/A15 83
GND1NT 84
GNDIO 85
1NST 86
I'') 1 A14 87
.3ERVED 88
U23 A14 89
/BHE 90
USEREADY 91
A7 92
VCC1NT 93
VCC10 94
U20 A14 95
U227U23 A14/A15 96
U22 A14 97
U207U2l A13 98
U24 A13 99
U24-A14/A1S 100
TEST CPLD 101
Data inO 102
GND1NT 103
GND10 104
TD1 105
nCE 106
DCLK 107
DATAO 108
Data in1 109
Data-in2 110
Data-in3 111
Data in4 112
Data in5 113
Data in6 114
VCCIO ll5
Data in7 116
Data in8 ll7
Data in9 118
Data-in10 119
Data in11 120
Data-in12 121
Data-in13 122
VCCINT 123
/RESET 124
CLKOUT 125
ALE 126
GNDINT 127
Data in14 128
GNDIO 129
Data in15 130
/RD 131
BUSWIDTH 132
/WAITN 133
VCCIO 134
/WRL 135
U22/U23 A13 136
/WRH 137
,)BANK 138
GI'WIO 139
PORT2 RI 140
OUTO 141
U24 A14 142
/HLDA 143
/WR 144
Simulation of the FLEX 1OKs Internal
Design
AppendixR
L__________~~~_~~ __ ~ ~ _
Name: soo.ons 1.0us 1.5us 2.0us 2.5us 3.0us 3.5us 4.0us 4.5us 50us 5.5us 6.0us 6.5us 7.0us 7.5us 8.0us 8.5us 9.0us 9.5,
:::~~~:,lJ{}J}nffil1hl_[@ili-b{JJ1lJi:H~~Jj_}frLH
[I)/RO : ,::::::::::',:,:,'::::' : , : ' , : : :: ,:,::::::::::::::::::: ,::: , " : :: :
[O)A[150) XXXX:X : O::(FC: : : I : : : 1G3A :1:' 19:00: I 2QOO' , :1 ' COOD::' t 'lG08::: 'l : : : 1GOA:: I::: 1GOC: :1 : 1GOE: : I: 1G1A : I 1G1C':: I : 1G1E
[I) ta_in[150) xx:xxX02FeX :FFfF: ixxxxi1~AX 'FFfF XXXXXX1E,OOX 'FFfF: iXXXXX_2_DPO FFfF: XxxxxXcQOOX :FFfF: XxxxxX1qoaX FFf~: ixxxxi1_9)AX :FFfF: XxxxxX1CPcX 'FFfF: XXXXX:1CPEX :FFfF: ':xxxx 1q1A :FFfF :XXXX':lC~CX FFfF XXXXXX1C,1EX :FFfF
[O)ta_in[15 0) :' :': ' , , " :: : xxxx: :: : ': ::::' ::: :::
[I) MlR : : : : W : ~ Lj_j u__r : _:_ :: _,_ : : : ___i_j, :: u__r
[O)USWIOTH ~ , :~ ,: :: :: :: " :: :: :: ::
[I)/BHE ' :
[O)MlRL:L : : , :L _,_ J : : : , : : ' 'L ~---;,Jr--':~_~--;:L-----,---.',~_:' -~:'-___.,~---.----"J~---~1,----;---,--__,j-;'r--" _: :, _'___.,c_--'-.---: ---;J"r---_': _~~:_,~-;_;_---;',--" _ _;_:_~: __ ,: _.:,L'----;---'--J-.:---.:_:__ ,:__ :_..,:L~'------;-i------
[O)MlRH , , :, : ' : ' :Lj :.: ,: ::: : : , : : : : : : : : : : : :q
[O)MlAITN n ' ::1 :1::1 :L,: , :1 '~:-:~, ---':1 :1 1 : ' :1 :1 : : :1 : : : :1 , :1 : : :1 :1 : : :1 :
[O)IHLDA ::::'::,: I : : : : : ' : : ' :
[I) HIGHPIN ::,:'::::::: :' , , : :::: ~-----~-~-~~------:-----:~----:----:----:~---~---~---~----~-~---~:-:~-----:--~: --:-:----:
[I) PSW_j7 ..01 ' , , , , :: ':: :::
- -c
, :
: ' : ' liA: : : : '
J r- ,[I] count4_clk ,--r____,----I---.---t--i-I--1f---r--<---,__,--t--1-,.---r->_~--r___,--,__;___;,____.->_~--.....__,--,_~-.>---.____._~-_~~~--,-~-.)--:-...J-.~~-J'_;--- _~~f---.....__,--_~,--
[IJ count3_clk \ -
[I] count2_clk r-o-r-r___,--- -<--,._ -->---.--,__,-->____;--,__,-->-_~--,__,--,__1_,i ;-r~-- .....__,---~,--.>---:--.-~---~~--,-~~->---:-...J-"~~-J'~c-~~~----,--,-~,---'.--:--.--j-~~-J-~--,-~-->---·..____}-~-~~---~~-->---'..____}-c__j----}---...l----_~~~-__~~ ~~t_~_~~__j---;__.~L-.....c--i.
rI-,--rt_-i- r-~--,.--t--r-~--,---r--r-r---,--t--1-,__,---~---;-~,-~~-,--,>---'~~I---j~- .....-<--,__,~~ ~~ __ ~~_,>---~->___<L-J'__,C-I___<~-....._}_~_~L-~~,_L~>__~~,__~~,__~ •..____}_>__L~~_<~~_~~'..____}-..~- ....._}_~,_~L-~~_L-~ __r-~,__~-~,__1~~~_~~ __ ~I_
[I) countl_clk = t-r-r- ~ _ _ '== l-r-r- ~ =
[0)",,01 ~~~~~Q1~~~~~m~_~s~~~~~~m~~_$$~~~~~~~~~~~~~b!®~m~-Sgmoo<:~()(~()(~<XX_~~~~~m~d~~~~~~~w~®~m~d88l~~g=~~oo@~~~~~~~lI~~~~~~~~~~~b@~_~ma~m~$~~
[O)U24_A14 :L: :: --'- ::::: _:_ j _:_: : ::L ~. --:- :,::: --'- J : : : :: _:_ ::::: _:_ ::::
[O)4_A14/A15 :: :::::::: , : :::,: :: :::: ::: :,:::::::::::::: ::
[O)U24A13 ~,--:-~~~~~~~: ~-:--~~~~~--~~--~------;-__;_-;--__;_--;-~:~~-~~~:~~~-;---;--__;_~~-;----;---;--;---;----;-.~~-;----;---;--;---;--~~~~-~:,-;---;--~__;_~-;----;-~-;---;--~~~-;--:--;---;-~:~--;---;--;--~:~~-;--~.
[0) U23=A 14 ~~~~==,==±=±=,==±=±==±"==,==,=±=±==,==,=±=;:,=: ±=i==±=±=±=,===±=f= :!:=,=±=i==±=±=±='===±"'~~_:_: __;_...:...__;~~:: =±=o±=±=='=='="=='=.±.':': =±==,='==±==,==,=~::~=,=±=i==±=±=±="=:!: =±=,===±==,==,=,,==,=± :!i'=±==,=,==±==,==±=±==:;i~!==,==±=:c=;==±=±==,=:h:l; ±=i:=±~
[0)3 A14/A15 " :
[O)2~J23 _A 13 p:l~~:--+-__i____i---+-+--!___+_~:I~__i____i---+-+--i---+--r!:I-+-+-+-+--+---i---+_f~I-+-+-+-+--+---i---+-;J:, I_:.___:__:__.:_"....:___.:;__;__;_:lL-+--+-+-+-+-+-+--+:I_,_+-----+-+-+-+-+--;f-:I_,_+-----+-+--+-+_+_+.:I-+-+-+--+--+-+_,_+ :!I_+__r---+--+-+-+-_,_+- :~I-+--::---r--+--T-+-+-4-+- :1-+--+-+-+
[O)U22_A14 ~ : ': ::: :: :: ' -'-'
[0) U21_A 14 ~~='=='l:L-+--'cjj='==±=='=±=±=='J:L: -+--:rj=='=='=±=±:~: =:l;-,L-T-_:_-JP:="=::' =f:=='===':,----+-L-ji;=±=='=='=~:..____:,:L --'- j~_;:~~=i=::i;-:L--id-j+r=±==i:="==i~=i;-L__:__j-+----:--+rj=i:==i:::=±==i:="==i,--;----:--Ji-;==±:=i==i:==i'=:+rtr+::==±: ="=:,=±:=::i;-~:1~-ii--i-;:: =i=::=±:="=:,=='~'=='=:"::lL;_j-Ti---1-;=:==':=='==::, ":=i=,, =l;\;-+-ijr=:,
[O)l_A14/A15 ,
[O)OIU21_A13i1><~7<:JQ<;)..,--~:-~---:, -.... ~! !!:I :;:1:: ~I ::
[O)U20_A14 :L _;_ , : '~: ::::L _;_ J ' , : : : : : : :L_j : ':L__:__j : :l__;__j : : : : : :L_J
[OJEST_CPLD~~=~~~~~~~~~~I:~:~:~-~': _':;:--r:=T" :::-:]:1 r+r~_,__.::==-~~- :~:--'==;:I:'-+-+__;.-.;__:_--:--___;....-+---+--+-+--;.-.;~:I : ,
[0) SPARE4 : ": ::: ,---+---+--+---+--+-+--;.-.;--:----+----;....-+-.:..;' '--;.I : :, :' ,
[O)SPARE3 : ::'::::: :::,,: : , : : : : , , , : : : : : : , , , : ' , , , ,
~~AA8 :,""""",:,' ,: : : : : : , :
[0]SPARE1 :," ""'" '" ::: : : : : :
[0]RL4 : : : :':::: : , : :' : ":',::,"",:,',:: :::: , , : : : : '
[0]RL3 ' , : : : : : : : :: : :, ::':"" """",:: " ",::: , :::::i
[0) RL2 : : : : : : : : : :: ::: "":::,:"""",:: :: : : , : ~
[0) RU : , , , :: :::, :: :: : ::::,,:,:"" ::,' :' :: :: : : : , : : i
[OJPORT2_RI t--'--+,--+--+--+--+-+_+--+--r-+--+--+--+--+-+_+-i------l--+---+--+--i'--+--+--+--+--+-+_+-+--r-+--+--+--+--+-+_+-+-::r-+-+---+--+--+-+_+-+---:--:-:---+---+--+--+-+_+-;.-.;--:---+--+--+--+-+-+-T----+-+-+--+--+--+'-+-+-: -+---+-+-+-T----+-+-+-+--+--+-+--+----i'--:----+--+--+---+--t1
[OJ~E~~ ~~-7~~~~7-T-~-7~~~~T-~~-7~~~7-T-~~-7~~~7-T-~~-7_7~~~~-7~~7_7-~~-7~'~~7_7_~~-7~~~~7_~~~~~~+-~~'~~~~~~~~~~~~~'~~~
[0] PLE04A 1: , ': ' : ' : : ' , -: :: : :,::::::::"",:::,'" ::: :: : : : : : : , , :
[0]PLE03~ ~~,,-7~~~7-7-T-~-7~-~'~~~~~7-:~::~'-7:-7-'~,' ~:~'-7-~'~-7_7~~:~:-7:~-:~:~:-~::~~:~:_7_:~::~:~:-~':-~':~: -~,'-~':~:~'-7-'~"~:-7:_~"-~"~'-+-'~:~:~:~:~~+-~~: ~~~:~~~~~: ~~:-+-'~"~'-{
[0]~E03A1 :::: : ' , ::'" ::: : ' , -, , :: :,:',:::::::,"',::: , : : ,: : : : ' : : :: '" .'
[O]~ED~ ~~-7:~-~::~:-7-:~':~:_7:-T-:~:~-T-:~':~'-7_'~'::~'_7'~~~~7_~':~:-7:-~:'-~"~'-7-'~"~'~'-~':-~':~:-7_'~'~:-7-~':~~:~:-~':-~"~'-7_7~~7-7-~-7:~~:~:~~~~:~:-7-7-:~:'~:~:-~:~::~:-~"-~':~ ._~'~'~
[OJPLED2A1 : : ' : : : ' : ' : : ' , : , , , , , : :, :::::',:,""",:,:,:::::: : ::: ::: : """',::,:
[0]~ED1A2 ~'~:-7:-7-'~':~:-7-'~"~:-7:-T-'~"~:-T-'~'~'-7-;~:~:-7-7-'~:'~'-7_'~"~-7:_7~~~7_~~_7:~-~':~~~'~' ~~:-7:~-:~:_7:~:~~~:-7_7-:~:-7~-:~:-7:-~::~:~'-~:'-~::~:~'-7-'7-:~"~'-~'~"~'-~':-~':~:-7-:~:~~.
[OJ~ED1A 1 ,::::::,',:::,,:, : : , , , , , , ,: , : :: ::::: : :,::::::::',::,":" ,:,""::
[O]OUTO :1 ::L :1, : :1 " :1 :1 ,:1
[0) LEDBANK : I I: I I I I I I: I I
[0) Ex_Lamp
[0] Ex___F~n
[0]CS510
[0]CE2
[O)CE1
[0) CEO
[0) BUZZER
, ,
-
, 'U--J ~, : :r:~,:
:1
, , , : , : , , ::.
, , , , , , , , , , : : : : : : : , , :,
, , , : : : , : ' : : : ' : : : : : : : : : : : , , : : :
[B)STALE.Q =h ,1
[B) STALED : :
[B]ALE.CLRN, :
[B) TALE.CLK +-fl-1---, -+-+-1---:--+-+-1
, , : ::::::
~
~~ : : : :~ : : : : : : : : :~: ~:, :,: :::: QI;, ,:::~::: :~: : : ::88: : " ' , , :': :: : ~ : :I~ j---:--:-;--:;---::---:---:--:;---:j--:---;--:: -:-~:---:-:~:--:-:: -:+-;-i-:--:-:: -:--::~:__;__:-~::: :=!=~:==±=,=::±=,=±=±-_;_~"__;__' __;_-:_;'4:-~ '~"__;_'__;___;__;_+~~~:__;___;_' -~:' -.:!-~:-~:_;_::~::__;_:-_;_:~:_;_: _.;:,-~::_;:__;_:__;_:_.;!.: I_:.__;::_;_:_;__:,-:' _;::_;_:-4: I_~::~:~:-Lk:;:,
: , : :::::. , : ' : : , • I, : ' : : : :~ : : : : : :: :::::::: :: ::,,:: I ' ; : :
~ : : : : : : : :" , :: : :::::, :~ : , : : :. :, :: :: : ::::::::::,::::::: :::::::: ::,',:;:: ::
~ ~ ~ ~
,
, i--'-' ";';
:1 ::I'-i-_'_+--i':1 : :;l'--i--+--i--i':1 ' , _:] ,;'--i---;--i--i' , ,
,
:
; :
: : : : : : :
: :
: ,
:1 : 1 : :1
: : : : : :: ':'r-~-:~....._.,:
:
, : , ,
: : : : : : :
:
, ,
, :1 : 1
, : : : : ~
:
:: : : : : : : : : :
:
: : : : : :: : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : :


200.0ns 400.0ns 600.0ns BOO.Ons
-[I]--R-E-SC--N-T-R-4--:~~~--c.==-~.~~______I~~==~_~ __ :
[I]RESCNTR3
[I] count4_ elk
[I] count3_clk
[I] count2~clk
[I] count1_clk
[I]CE_CNTRS
[I]SEL[1..0]
[0] Data_i n[15..0] t===~:=OO=O~O==~~ F~ ~;==~ ~=F~ ~;==~ ~=F~ ~;==~ ;====i=~ ;==;==:::; ;:====i=~ ;::::::=~~ ;::=F==:; ;::::::=;==~ ;::=F==:; ;::::::=;==~ ;::=F==:; ;::::::=;==~ ;:==F~ ;::::::=;==~ ;==F==:; ;::::::=;==~ ;::=F~ ;::::::=i==~
[B] ata_out[ 15..0] ~::::j:=OO=O::::jO===f~ =±==-:f~==±:==-/ )==:::±:::===;Y )=:=,==;i/~=i==-:f,:':=:±==:! r'==±==Y ;==±::::==f;C~===f ;=::::::±==-:'(;===±:==f )=:=±:====;~~=,==;i')==i==-:f,==:±::::==:! ;,==±==f ;C~==f ~==:±=-:f ;===±:=f )==±:===;r ~::±::===;!/;=:±:===f.
[B]I data0_[ 15..0] F==::::;:P=O=OQ:::==~;= ;:::===::;==:::===;: ;:===;:::===::~ ::==~: ;===;:::===::;==:::===; ;===;:::===::; :::::=:::===::;; ==;:::~ ;::::::=:::==::::;:;===;:::=::::;::::::=:::==::::;; ==;:::=::::;::::::=:::==::::;:; ==;:::=::::;:==:::==::::;;::==;:::~ ;::::::=:::==::::;:; ==;:::=::::;::::::=:::==::::;:;===;:::~ ;::::::=:::==::::;:
[B]ldata 1_[15..0] F==::i9=0=00::i::::'~;::::::=::i::::=~ ;===j==::::;;:==::i::::=~;::==!::~;:==::i::::=~ ;===i==::::; ,....--!--___,: ;=~=::::;;::=~~ ~~=::::;;==::j=~ ;==j:::~;==::i==;: ~==c=~ ~~~ ~~=::::; ;:==~~ ~~=::::; ;:==~~ ~~=::::;;::::::=::!=::::;: ;===i==::::;
[B) [dataz ] 15..0] F==!:O=O=OO::;::'~;: : =~::::;: ;::~~ ;::::::=~~ ;::~~;::::::=~=::;: ;=~~;::::::=~=::;: ;=~~;::::::=~~ ;::~=::::; ;==~~ ;=~~;::::::=~=::;: ;::~~ ;::::::=~=::;:;::~~ ;::::::=~=::;:;::~~ ;::::::=~~ ;=~~;==::!:=~ ;=~~
[B) 1data3_[ 15..0] ~::::;:P=O=O::;::Q=~ :::;===';.'==::;==~==:;=~=;====::;~=i=~==~~=::;::==~=i===';.'===i=~====;==~==;::=::::!.~::::;=~==:;=~=::;::==!;':=:::::;===';.'==::;==~====;==~=;=~-'==::::;:=~=;==~=::;::==';:=:::::;====';.
[I] m ux: 81se I[1..OJr=:::i:::==='==>.'-;===i:==t===±:=t==±==;:r=='====;!r=::i==t=±==t=±==t==i==t====,==t==::±==t==±:=;!r===i:::==;:r=='====;!r=::i==t=±==t=±:==t===='==t===i:==t===±:=t=::::i::==:r=:::i:::===;!r::=:==t=:=={
[B) n te r: 11q [1 5 ..0] F===!:O=O=Od::;::=~,=;:::~ ;:==::;::=::::;::==;:::=::::;:==::;::=::::;~==;:::=::::;;::::::=::;::=::::;;::==;:::=::::;::::::=::;::==::;; ==;:::~ ;==::;::=::::;:;::==;:::=::::;==::;::=::::;:;::==;:::=::::;:==::;::=::::;:;=~=::::;: ;==::;::==::;;::==;:::=::::;:==::;::=::::;:;::==;:::=::::;:==::;::=::::;;::~=::::; ;::::::=::;::=::::;
[B) er:1Idffs[15 ..0]1---~9_0_00~,____J '---~-', '--~____J,'---~-','--~____J, '---~-.J, '--~____J '---~-.J,'--~____J '---~-' '--~____J, '---~-' '--~____J '---~-','--~____J, '---~-','--~____J '---~-','--~____J,'---~-', '--~____J,'---";"'--~,--~____J,
Name:
[IJ RESCNTR2
[I]RESCNTR1
[IJ ENCNTR4
[I] ENCNTR3
[I] ENCNTR2
[I] ENCNTR1
I .~
3.6us 3.Bus 4.0us 4.2us 4.4us 4.6us
I----.------l-~I--~--+ ,---+---,---1------.-
2.4us 2.6us 2.Bus 3.0us 3.2us 3.4us
+--~-f_~--_+__~--+-~--,I----~I--~--f---.--- -~--~ --/--
1.6us 2.0us 2.2us1.0us 1.2us 1.Bus1.4us
b
Software Timing Analysis Results
using MAX+PLUS II
AppendixS
~~~~~-~--~--~~~-
Dekry Molf;,
ceu
" .... /n.10I
1'r1.", t~ ... l ''''u,)
?I,J."I'~J,., 1).'-:1','1., 11.r.,,/J..1 .. 11"",11)10,
[''S'I.-, 1'., .... 1I~,,) ~.~ ~ ••I M.~ ~"d ~.~IU
n.60,!!J.)tu lJ,""fJIJo. 77.(00.1')1_...., n!.o./.>IJoI 1(;),,/.1...111, 'lliJo'/JJ.I., 1'1;'111./.,)""
1"".111 ,,,,, .. 1) 111"1111
76.10./,11., 11L1•• I')3... , '/Ii "'If.ll r.~ ]').1.. /1.>,10, 7'JIIo,!.iI.'lo,
~==I====t===t===t===~==t===t=~====t===t===~===t===I~
'"
"'I'
0... lUlu I~.I.'
~I."
.-11.4
_ld
~"d.
"'''.....
[l,h,;'1
tItI • ..,
Ill"';')
0wI ... 4
l1li • .-5
l1li •.•
D.I ... 7...........
011 10
1Itt 1I
[M, ,
1111 1)
bwI, .. li
1IwI'''I~""'."'OJ
, rf..,..1
: If'5lJ
: tf'Sl.l
, l)"jI~
l'''.;f.l...)
1./•
I).)"
tUn
I).)"
16.11H
...
JUIlIAi
I\IIII.
'U""''U,..
,'''11.,
IU
IU.,
"'''''9'''''
9'.)
"'''''•• DID
""-",
tno,Ml.Al)
1/IOMI.ItJ4t.
uri».
IQUI'
vnM'1.A11
V1?,Ml.4l4/A1.
1Il1"'4
1I'11.A1]
""Ult/At.
UU.Alt-../10
/011
/lilt
1&.511
11& .. 1I.lioi tUn
....
"'"'lS.'"
11.'"........
n",
ll...
11.&" J6~
11.1., )) ....
?l.r., )5l1t1
IUn JOn
1'1;'''' )1.1...
}41M •• _
llJu/}t.'" .._
I6.ZM/}tin 45l1n
~~
11,0... n.""nu.,
}(I.1M 1l.I.,/lL'-s nA1>5
1\.)11 l1Jo.s/)1&o1 10.1..
19.... /)1 .., "./-,,200\ 1IIJ,olt.A1Io. It..).,/ldt1 7II..).. /IJ.4111 7II")",/~
17.1101 761111 lfU., 76.• , ~ ...
lUlu W'IO' "hI, HAIH )ta..
1!1~ ))6.. 1JlIo. IUlll 13.10,
)1.1.. 71]" lJ').. ll., 11$••
1I!Jo,f.tl.:~1I ?t)"/JJ.')'u 16.2'.o1~.lH lI.J!1t/'.h.• , 16~~tJ11., )U",/.>lbo.
7.... , ltr.., )1.," 1I~ 16.10' WIn
~ .• , 16.'" 1'Uft )4~ IUu lIi.I_,
)J.&I, '4.,., ?S.!.. )4.Btt! lU", 24.""
)J'&', m", ll.l., 16... )0111 nJ",
)U .. / ••Hlo. :r..IoIjY...~,
1+.&0. H~
)1;.&0, n.l.,
?Ijll1 16.~
It.. )4.&,
16.!r1•.h.\Jo' 7\JUt.J.MI
)1;.1.0, 16311
U.llI )tUn
n., )Holl
n!wo. 7Hl1
r....,_,/!I+.,'"
7+.1..
n.lt1
141••
16.• ,
~/ft.hn lOJo1/l1.e.. )t.lH/+lb.. lOJu/4ft.CIII, .. Ju/.Dt1 lO.lo./I1JII :lUt1/ft.... lO1tt/n.s.. ~/D' ?bo1/41.I.. 7UnjOJn lUIII/O.ln )U .. /,)AI. )UM/4Il~ 11.&tl/CJt1 77Ju/f1.JH
11.5u/ft1111 11•• /47.lH l1.&rs/+l.ln n'&v+1"». 79A,/O!at )')•• /4)1111 l1.Btt!/U, l1JU/'UM ".,/elll ".,/t6... ","/ •.m " .. /", ~.• ';4II!ort )!I,4u,MJ", 11.ltt/+l'., »,.,/+1 ....
l!Ju/iII!oo, lO.bol/lUu JD~ XlAI./JI1a. 1I.~./JIJM 1I .. t/41.111 1IAtt/+U.. 7UII1/41.1-. 1UII,J)lI., 'l'UufJ1"" ~ 7llJo,mll. :u.,(J1lM 1'8.. I/ltAt. 11.!-s/)J.• , ntt-s/)!r.lM
l1J.. /4J.ln Xl~/lI.'" :I.lltt/41.... lOAlI/H., llllH/ll-," ))"""',1.," lUtI,/4l.c:.. l1JM/t).... 18.Itt/O.", 7\1101/1(1.110."""".,lrI. 11.6M/".1t, 2UJ1/--. 1IUas/iLitt )lWrllrtt 71..1/+1","
:n~/tltn :n.JH/f]~ llJ.t,iOhrl J'1.l"lrl"'. nJII/ru.. JJJ"t,ItilM ~.ltt/4l6" nJn,!4lJM :'U.. /I:u.t. lI.tnjIL]I. :»Jls/t1.... lIJJ1VIlJ.i 1IJM/'1.1'II, ll..tM/rl.. ".a../12t.n "."'/11~
)U .../4!i.Lll1 1.I.,/1}!., ~4)b!t 1.I"v44.,," 1.IA-I/ttAtt 1.IiMI".Ou J.,'~'/IU:~" J4J1ov"" mill/ttl", )1-"'1/12 .• , ru..}O!.t nJov12.'" ll.,/oJu n 41.5H l1.5.,/41Jln 11.4IK/tl.s.,
hllll/e..... 1.I.•• /4lJio. J!,.4III/'I4.h. 1.I •• t/44!M, f.t.• '/u.... 1.I..';'Ut, 1.I.•• /tII.", ".lu/""," }4ll",/tC-. }4 •• m., J4.DH/I2Jio. }4.IM/tl.. }4~"41J", }4 t/.a.. Jau/"")'" DAII/441ft
?'Uot Ju..,/ft)u )'J."'./47.)n -"1M/"" )9)t,/ftJ, )9J.,/ilJIn )9.>- .....0.,., )t1t.,AJ.o. )U,.,t.o1M )7.6111/'" J7bo" •• , JJ.6nj •. m n.,/...... 17.a.. /~ nAII/I1.lM )1.""/ • .10 )I;•• mln
nbt.s '-'.,.,/.1M JIi~/HJM )l;lu/f'J.tM JliJu/f.JJws JU~,/4!i1Jn Utw/I),h. ::'-""/411", )l;Jn/01H J4!n/f5.lItt J4.vn.. }4.l.tjOJ... }4A1v4lJ.o. }4.fttt/tl!itt 34&1/44.", )).1.t/6.1n n .. t/tu ••
r...Jws lU .. /ftJ", )llM/HJ", )I."'/u.. )t.1lt,/.J" )'J1t1/tl.1M )t~.nl "lMtAJw. 1I.Ioot{:(llM )7bovCl'll 371M/iii'" 37.1n/tII.)M nil.j",," JJ.6n/• .!M, J7... ~/41}n XhoI/"l" )5",/4) ••
tl.a., )l.4tt/ •. }o, Jl"l/l1.n, :I."'/t).!M )8.)111/0'&. )l.1.l/tl."" :lJnjftJI' ll)MJftJ.. )8.,/ft."" 37.lo./41'&1I n~';tIi.l.. 37Ju/4II1., J1..l1oIItC.11I J7.)o,/.AI. J1.lo,/41.11tt )l)1n/"Jn •. Ioo,;.I.lo,fl.. tI1 .. /'>I!oI! 41i,f.(lJlu tl!.lllA_"" tl,!.,t.o-," 4I.~"-'!on 41!M1/A.5n tl.5n/J?!oo. tl. ... /Jf.5n .. 1........'-'111 fOJIII/1l.tn • .IH/ftlll. 1O.lu/4II.," 1O.ln/tIbo, .o.I.,/JI.. )tAl, ...... , )I!.""/.G.I"
)t.!M .a!oo,f";t,&.. 4Il.s/.I7Ju U.!"JI.6u .s.,/-IJ.ln 1II.&1.,,1bt, lII~till", ",tAbt, 411.)0,,,., •• " .• ,fjI11t, 41.",f,JIiJ.t 47....., ...JII 41.",/-,," " .... '-".1., +1.• s/J1.lat tIi.J.t/l1.7M """'N .•,
,J.... "" .. /AlII, ".,/J1!.. ft.IMf';}brt "1II1!-a! .. ft",/..lnot ""'v9'JAI, .. ~.ftlIlII, .~ '}.Bol/AI", 47""1/"'.4111 47 /'A!... 0.10,'-' .•• 4}JII/"".lo, 0-"',!.I1.5.. tUn/J}Ju 46.• ,/-1'.,
)'J.lII .",./Mo, ".10''''')111 ftlal'","" """".4.1n ".lI1/A"" .,.""~,,... ft.mt\lDJ~1 ~.lII.,AilIlH +1.1n/AJu fJ.lo,t!U", 47.& ,).. 4}J.,,,,-," +1.&1~. 4'."").ho. "",/.41 .... ,!.I1'&1
71.5.,
71!on
,I
Delay Mol fix
lIS10W..."" Will«
"!oo,/Il.)"1
",...""'"
11J11U
a.
a,
a,
r.t .... t~",..
If'SlJ
:tt")"I.J
, [f1IJ
~ It'Sl.t
,If'5l.!l
""'.""']
(al •
• u. ...
"'"'UI(t _
M.
IUU1Al
1\l11IA1,tl....
'tl""!II'"IU•.,
'tl...
IU",",.,.
I't.JCli'1(l~,.n"
~'"''''P4JIll1U
'"'"'.,,.,
It.).,
"'..,-,-,....,
".IN
WI.ut
U"
IQt~l~,AI,
/01 •
•,.
'""~
~..,~...
~.I,"
v.",
lI~
lI .........
n........
n,~1....
>.»0
)I.'n"...,........
n.... ",.
n",
11.1tt
no..
u.
~J..
"'",J..
:I,1to1n,.
'"."'",.....'",,'"
"In
I'IJ(I7i'l1 I?Nlllh 'JJCII"1
'.)00
l!.t.".,"," 1).sjCl_ 151111/«1.,," JIJa.t/.~ ~CI.," ll";.!.on l8JMjClJH J7~1 nJoa
11 /40.... :11.).,'_.1.. l1lt1/ClJM 31.1M/__ IUM/ClJn 17,""__ JI.M/«J1tt JJ... m..,., 11,'"
1I mlM ~ __ ~~ 7.I!.tI11.&r1 ~~ 2".UHhlbrt If~ 1UM/1'a, ~ __
)1~ I~ }I~.ltt )l...;l4.'-t Jl.a...,t}(Jtt )IJos/}l'" },"/l4Jn )1!M/.Jl1'JI1 JJJ..
DJIIt/}U... )2.~ :n.~ln rlltt/}OM n_~ :D.t.t/k7M n.~.itt 12.l.sf»." ''In
)UIIt,m..- ~JIn 1I~ ~/l)_" 1I~ 1Uat/.J2&o1 lI.»t/DDiI :»JH/.lO.!.o, ), .. ,
1I~ :IUtt/lUrtI lI-m.Wt 1Jat/l)JM ))~.IIM lUol/DJn lIJIIt/D... I~_"I JUl.,
JoI.lrtt/)l.... )4..~.-' Jt.m/]1JH R1-II17_ }4.J.t/l1.>at }L1.t/)1llt1 J,t;"'/)JJn }4.IIM(,lUn :u.,
}1.. J/}t11l JI.1MjJtI.. }1,Jr.t,/)4J.. )1.J.t./}4." )1.1H/)4JrH )tJr./)1l1H )1.,"/)4"" )1.tq,I)l)l1 n.a ..
}4.1a1JlJ"" >t1l1./J7.ln }(.7M/,D.1M }4JHm.~ }4.~," )tJ.,mllt1 J4.1IoVDlM J4,MM7111 x..
14.!.,/X-," }4JMfbtt ~/)I)M }lJIJtt/)f!., 14.mJl5.m lUM/)I!oot }lJII,/)IJ.. n.J./}4.lo, ~
:S~.4IH J1J1MI1.. rI-rJf!.t J1~.ltt J1~t/lt,!,tt. 11Jas/)l.lot J1JII1/lt,!,tt. :s.Mt/.lJ.r., 13 ..
u.lol/IUM ttln/ •. '" H.ltt/fi.a... +o"'/.JI1 U~II.a... U__ /II.&II, u...,/*.tat .t~/f4.ltt t.....
.t.t/II.iM ~1I.iM tt~"O.DII .c..t• ., u.!ltt./IJ_ .c..;._ IUot/t7_ ulM/......... 6 .....
14"""47.1.t H.7w/.J.I.. u.J.,!OJM «.'"141_ 4tJ.t,l17JM +tM/l1.tat HJIK/.7JM H.""/«.7., 46..
'lIlIi'll lit!
IHII
lI11M1JJ) '-'nN1!..IH/AI~ 1.113...111
,H.,
----
----
....
" ....
n...
"'"~...
?1.!Hnt ....
71.."/)1.",,
f1S.,(rl.I.
11.&0,/)2....
"...
15.1",
IUu
,,,",
,'"
.....
f-----·~--4----+--~I-----
11 .... 14.1,",41.0111
.".~...
".,.........)).,.
".)"
)5.1 ..~.......
~'"._..."..'"........
"'"
1~.7"
:J2.IM/)I!lo, 15""l1~ 12.1.n,/)1AI J)J"r;~~ 12.lM/)1!oot li.Ilot/)6." Jl.4H/)I._ ::IM.. IX .•
)1.!.et/)'J..itKn~ ~ )1.J.t./.MII )1.)M/1.4!tt JI.IM,IJS.a. JI~.&t }1"'~
,,-...,~ lL..,.... 1lMt/Jl .. , t1J.s/X1lM :II.t...,t;I.. 1I.1M/Jlm lIJII/)I.m lU.t/».)n
12.1.1)5.* Jl.~ ».IMIJ:!..t )2~ l11M/.'1" J2.~ .. J2.tll(.U" J2.w.t:s.ttK
n!.J/,utI 7l~~ 7l~ n.J..h5.iM n.1M/1l~ tUltt/lS" n.&-t/JIbtt n •• /lUtI
11.4In/.fI.... )I.~1M )I.~ JI~ lU .. /1.I.... 3IlM.ffi'" t~~," )I.M/]U.I
)1~1M " ....... JM J1At1/J.)oJ J:JM/J51M :u~ ltiM/1l.s ))'.111/11.1.. t1.5tl/Xt ..
"","/tl.GM lJJ.WfIl",. 1.1.101/ .... , 1I111/CI,On 1.I.a..,leAt 1.IJat,/)I.5H J.,JtK,!:bn J.>Ju/JU"
J) .... /Jl.Ou n....m.., J"IlflmJJt., 12.1111,111", J"I.a..,/)J,OtI nJu,l)l~ Jl""""JJot )J~jnII.,..."'" JU",f."" :r..AoI/tlOot lI.lM/fJ..OIn MioV._ '-'~lIf, '-'J.I/)l.'-t ll~laI
1.>.I.,J)1.!-t hll1J]J~ .!l.IM{JI!..t 1Ut/)t.!.et hltt/lt!oot 1I.-,;)J.tM 1.I.411/Jt._ lIAot/)t.6n
»""/0-'" l1~Oit J1-'"141.lM )l!.t/nJat .1t1/0... :IJIotInlM lVIo1/41.h1 lUM{O.ltt
f'.UMje.Mt rJ.lJoJ/ft... 6.mje.5tl hW.,.., 6...,/e.. 6!.t/.,.. 6!M/«!.t 6..!.t1e~
6...,/ea., h.."U., h.,/e.8M atu/.,., 6Jo.t/"" 6.1M/ftht 6.?t,/t1)M f' J.tIftJet
6....,..~ t..I.t/.tJJIrI 6....,..~ 6.1u/~ 6"',..u., f.I.JIol/lUtI t5.tn/'UIII 4'> .,"111
Delay Malrix
Destination
CS[{LAY Oolo.inO [)Olo~nI [)o10~n2 [)o10~n3 [)o10~n4 DotO_)flJ [)ola~1I6 [)olo~n7 [)olc0118 Oo10~n9 [)olo~nlO Dolc.inl l [)o10.in12 [)Olo.inl3 [)010.in14 Llo10_in15 IlI3'J1:i.SGNO IlI3'JIJRlS [)()'12:i.SGND IJ[3<J)_)JnS [JB92.YJ,1 /INll INS10Ul LEIJIJANK
ALE
AD
AI 21.911s 257ns/44 611s 258ns/4UfIS 269ns/n9ns 26Jns/H.lns 26Jns/44 Ons 26.3ns/44 Ons 26.3ns/445ns 26.3ns/43.6ns 26.2ns/44 Ins 268ns/43.9I1s 26.7ns/4}BIIS 26.6ns/ 4} gns 265ns/442n5 25 6ns/4} 2ns i5.UIlS/43.4flS 254I1s/43.4ns 28.Bns
A2 24.2 liS nlns/4lLns 22.2ns/4 Uns 23.3ns/40.5l1s 22)",/407I1s 227ns/406I1s 22.7n5/40 Gns 22.7ns/4 I. lns 22.7ns/402ns n611s/407ns 23 2ns/40 5f1S 2J.lns/40.4f1S 23.0n5/ 40.5ns 22.9I1s/408ns 22.0ns/39 B[lS 22 O[ls/40 0[15 21.8ns/400ns 30.ln'
A3 24.011, 26.2n,/415[1' 26.3n,/4I.Gns 27. 4n5/ 40.7l1s 268[1s/41.7n, 26.Ans/41.6ns 268[15/41.6[1s 26 Bns/42 1[1' 268115/4I.2n, 25. 711s/41.711' 27J1I5/41.5[1s i72os/41.5n, ~7.1 "s/41.6[1s 17.0ns/41.8ns 26. I[ls/40 Gns 26.1 [15/40.2", 25'ln5/40 2ns 30.1[15
A4 17Jns 2'1.4[1s/447ns 29.5"5/44 .8ns 30.6ns/H9ns 30.0[ls/449ns 30.0ns/44.8ns 30.0ns/44 .8ns 30.0ns/45Jns 300ns/44.4ns 26.2ns/44.9ns 26.2[1s/H.7ns 26.2I1s/44.7[1s 26.1 nS/4 4.8[1s 26.0ns/45.0n5 25lns/H8ns 25I"s/43.4ns 24.7[15/43.4[1s 24.2115
A5 16.8(1s 31.4ns/467ns 31.5ns/46.8[1s 32.6ns/459"s 32.Ons/ 46 9ns 32.0lls/468(1s 32.0lls/468ns 320(l,/473[1s 32.0(ls/45.40s 26.3[1s/46.9ns 26.2[1s/467ns 26.2ns/46.7(1s 26.1 ns/46 8[1s 26.0"s/470[ls 25.1 ns/45.8ns 2] 1(15/45.4(15 24.7(13/45.4fI3 24.7115
AS 28.7(1s 313[1s/48.6(15 314ns/48.7(1s 34.5(15/478ns 33Yns/488ns 319[1s/48.7ns 319[1s/487ns 33 9ns/49 2ns 33.9[1s/48.3ns 33.3[1s/48.8(1s 34.4[15/48.6ns 34.3ns/48.6ns 34.2,,,/18.7[1s 341[1s/489ns 312ns/477ns 33.2n5/473[1' 33 O(ls/47Jns 35.1ns _
A7 28.7l1s 33.3ns/48.6"s 31 4ns/ 487[1s 34.5"s/47 Bns 33.9[1s/48.8ns 33.9[1s/ 48.7ns 33. 9[1s/ 48. 7ns 33.9I1,/49.2ns 33.9[1s/48Jns 318(1s/48.8ns 34.4I1s/48.6ns 34.3[1s/48.6ns 34 2ns/487ns 34.1 nS/48.9ns 33.203/477ns 33.2ns/47Jns 33.0n5/47.3ns 35.ln3
A8 34.1 ns 210[ls/540ns 23.lns/54.lns 23.1 ns/53.2ns 23.1 ns/54.2ns 23.1 ns/54.1 ns 23.1115/541 ns 23. I[ls/54.6[1s 23.lns/537ns 39.2I1s/54.2ns 39 8"s/54 Ons 39.7ns/54.0rIS 39 6"s/54 ins 395ns/54.3"s 38.6"s/53.1 lIS 38 6ns/52.7ns 38. 4(1S/52.7ns 40.5ns
A9 32.5"s 20.7",/52.4ns 20.8"s/52.5ns 208ns/516ns 20 8ns/52 Sns 20.80s/52.5ns 20.8(1s/52.5(1s 20.8(1s/53.0(ls 20 8ns/52.1 ns 37.5ns/52.6"s 38.2"s/52 4ns 38 I"s/52. 411s 38.0ns/52 5ns 37.9ns/52.7(1s 370ns/515ns 37.0ns/51 Ins 36.8(1s/51.1 (IS 38.9ns
AIO 34.1 II. 23.0n9/540ns 23.1119/54.1 lIS 23.1 ns/532ns 231 "s/542"s 23.1 ns/54.1 ns 231"s/54.llIs 231I1s/546"s 23.1 "s/53.7ns 39.2n9/54 2ns 398ns/54.0ns 3970s/540ns 396"s/54.I"s 395ns/5U"s 38 6[1s/53 lns 38 6"5/52.7[15 38.409/52.7n5 40.50s
All 34.I"s 230n5/5400s 23.1 "s/54. Ins 23. I09/53.20s 23.1 ns/500s 23.los/54 los 23.109/54.1 "5 23.los/54.609 23.ln5/53.7os 39.2ns/54.2ns 39.80s/54.0ns 39.7I1s/540n5 39.6n5/54.lns 395ns/5Uos 38.6n9/53.1 ns 38.605/52.709 38.4ns/52.7ns 40.5n5
AI2 36.5[1s 25.4ns/56 4ns 25.509/56.5ns 2S5ns/55.6ns 25.5ns/56.6ns 25.5ns/56.5os 25.5"s/56.5(1s 25.5ns/57 Ons 25 5ns/56. !ns 416ns/566n9 422ns/56.4ns 42 Ins/56Ans 42.0ns/56.5ns 4190s/567ns 41.00s/55.5l1s 410ns/55.los 40 8ns/55.1 ns 42.9ns
AI3 36.003 24.90s/55.90s 25.0ns/56.0ns 25.0ns/55.1 ns 25.0[ls/56.1 ns 25.00s/56.0ns 25 Ons/56.00s 25.0ns/56.5ns 25.0ns/55 6n5 41.1 n5/561"s 417ns/55.9n5 41.605/55.9ns 4 [.5ns/56.0ns 414ns/56.2ns 40.5ns/55.0ns 40.5l1s/54.6[1s 40Jns/54.Gos 42.4ns
AI4 36.5"s 25.4n9/56 4[1s 25.5ns/56.Sns 25.5ns/55.6"s 25.5ns/56.6ns 25.5ns/56.5ns 25.50s/56.5ns 255"s/57.0ns 25.5"3/56 Ins 4160s/566n9 42.2n5/56.4ns 42.1 ns/56 4,~ 42.0ns/56.5ns 419,,9/56.7ns 41 Ons/55.5ns 41.0ns/55I lIS 40 8ns/55.I"s 42.9n5
AI5 40.1"5 29.0n5/60.0ns 29.1 ns/60.1 rs 29.1 n9/59.2ns 29.1 ns/60.2ns 29.1 ns/60.1 ns 29.1 os/60.1 ns 29 Ins/60 6ns 29 10./597ns 45 2ns/60 2ns 45 8ns/60 Oro 45.7n9/600", 45 6ns/60 Ins 45.5n9/60.3ns 44.6ns/59.1 ns 44.6ns/587"s HAns/58.7ns 46.5n5
ClKOUl \ 213ns/540ns 23.5"s/5t8ns 24.lns/570ns 26.5"s/57.0ns 25.00s/58.7os n [os/59.2ns 24.6n9/60 Ins 24.4ns/587ns 13.2n9
counl5_clk 29.4n. 29.5"s 29.ln. 29.00s 29.0ns 29.00s 29.ln. 28.9ns 29.4ns 29.lns 29.I"s 29.2ns 295ns 28.9ns 27.0ns 27.0ns
counl6.elk 26.5n. 26.6"s 26.3n. 28.9n. 26.6"s 26.6ns 28.7n. 26.2ns 26.7"s 27.9ns 26Ans 26.5ns 26.8ns 29.0ns 28.9"s 28.9"s
counl7..clk 26.2ns 26.303 20n. 26.6ns 24.6"s 24.6"s 26.9n. 27.3ns 249ns 24.5"s 26.lns 24.5ns 24.6ns 2Um 2Uns 24.2ns
counl8_elk 29.2ns 29.3"s 27.7ns 24.5ns 26.2"s 26.2ns 246n9 25.lns 26.lns 27.7"s 25.0n. 26.8ns 27.5ns 25.7ns 25.7n. 23.1"s
Dulo~1I0
Doto.inl
[)ola~02
Dulc0n3
Dulc0n4
Dulc0,,5
Dulo~1I6
Dulo~n7
Dulo~n8
Dulo~n9
DulojnlO
Dolo~1I11
Dulo~n12
Llolc0nl3
Dulojnl4
[)ola"nl5
[lfJ<JUJJCD
[lfJ<J1_6JJ5R
[lfJ<J1.B.C1S
[lfJ<JL9..R1
[lfJ<J2_IJJCD
16.7ns
[lfJ<JHllTR
18.lns
[lfJ<J2-6JJ5R
18.8ns
[lfJ<J2_B_ClS
18.5n.
~PSWJl 20n.
~psw_g
219ns
~PSW.10 218n.
~psw.1[
218ns
~PSW.12
218n.
~PSW.13
21.5ns
~PSW.14
215n.
~PSW.15
23.7ns
INSl
18.BnsPIRXD
P2_0
P2RXD
P5.N02ZEL 2Uns
P6.N022EL
21.3ns ,
P7.N022EL
21.30.
PB.N02ZEL
2Uns/11l 32.5ns/17.811s 32.609/47.90s 33.7"s/47.0(ls 33.1nS/48.Ons 33.lns/47.90' 33.109/47.9ns 33.1 nS/48Ans 33.lns/47.5(~ 22.Ons/48.0ns 20.7ns/47.8ns 20.7ns/47.8ns 20.6ns/47.9[1s 20.5ns/ 48.1 ns 197ns/46.90s [9.7ns/46.5ns 19.7ns/46.50sRESEl
/'IKi. 27.0(lS 34.6ns/42.lns 31.6os/39.3(15 34.5ns/39.1 rs 34.6(19/39.1 ns 34.6ns/41.1ns 3Un9/41.7ns 3Uns/41.7ns 33.9(1s/418ns [9.5(1s/33. 4ns
I
IA
Deloy Mutrix
Des!inotion
..
fHOSAI f1EOSA2 f1EIJ6AI f1EIJ6A2 fH07AI f1E07A2 fH08AI PLED8A2 PllXO P2J pmo RL5 1<1.6 RL7 r18 SPARf5 SPAR(6 SPARf7 SPAf<t:8 UI,X[)
ALE
AO
AI 26.011,/30605 26 Ons/30 6n, 26 Ons/30 7ns '6.4n,/30.7ns 26.2ns/30.7n3 26.3ns/30.7n5 26.3ns/30lns 225n5/30lns 26 2n,/30.3n5 26.2n:;/30Jns 262n5/303ns 262ns/30.3n5 262ns/30Jns 26.3n5/30.2ns 26Jns/JO.2ns 248n5/30.2ns
A2 27.4n5/32.0ns 27. 4ns/32 Ons 27. 4ns/32.1 ns 27.8n5/32.1 ns 276n5/32.1 n5 27.7n5/32 Ins 27. 7r,s/32.1 ns 219ns/32.1 ns 285r'5/32.6ns 28 5n5/32 6ns 185(13/32.6ns 28511s/316115 285m/326ns 28 6ns/32 5ns 28.6ns/32.505 27.1 ns/32 5rlS
A3 27.1n5/32.0ns 27. 4n5/32 Ons 274n5/32.ln5 27.8n5/32.ln5 27 6ns/32.1 ns 27.7n5/32.ln5 17.7(13/32.1 ns :!3.9n5/32.1 ns 28.3113/32.4n5 28.3n5/314ns 28.3n5/32 4n5 28.3ns/32 4ns 283n5/32.4ns 28.4n5/32.3ns 18.4n5/32Jn3 169n5/32Jns
A4 21.61<3/26.2n5 11.6ns/262n5 11.6ns/26.305 nOn5/263ns 218ns/263ns 11.91<5/263rI5 219ns/263ns 18.1ns/26.3n5 116n5/15.7ns 21.6n5/15.7ns 21.6n5/25lns 21.6ns/25705 11.6n3/15.7ns 2I7n5/25.6ns 217ns/256ns 202n5/25.6n5
A5 217I<s/26.3ns 2I7n5/26.3ns 2I7ns/26.4n5 n In5/26. 4n5 21.9ns/26.4ns 22.0ns/26.4ns nOns/264(13 IB.2ns/26. 4ns 21.1ns/25.2n5 21.1 ns/25.2ns 11.1 ns/25 2ns 21.1 ns/252ns 21.1ns/25.20s 21.2ns/15.1 ns 21205/25 Ins 19.7ns/25 los
A6 32. 4r,s/ 37.0n5 32.4ns/37.0n5 32.4ns/37.105 32 8ns/37.1 ns 326ns/37.lns 32.7rls/37.1rls 32. 7ns/37.1 ns 28 9ns/37.1 ns 33.0(15/37.1 (\3 :.3.0ns/37.1 ns 33.0ns/37.1 ns 33.0(15/37.1 fI'3 33.0ns/37 Ins 311f1s/37.0ns 33.los/37.0rl5 31.6n:;/37.0rts
A7 32.4rls/37.0ns 32.4ns/37.0ns 32. 4ns/37.1 ns 32.80s/37.1 ns 32605/37.105 327ns/37.1 ns 327n5/37.1 ns 28 9n5/37.1 rlS 33 On5/37.1 ns 33.0ns/37 Ins 33 Ons/3 7.1ns 33.0ns/37.lm 33 On5/37 Ins 33.1 (15/37.0ns 331 n,/37.0n3 31.6rls/37.0ns
A8 37.8ns/42.405 37.8ns/424ns 37.8ns/42.5n5 38.2ns/425ns 38.0ns/42.505 38. Ins/42.5ns 38. 1(15/42.5n5 34.3n'J/42_5r15 384ns/425ns 38. 4ns/ 42.5ns 38.4os/4250s 38.4ns/4250s 38.4n5/42.5ns 38Sns/ 42. [ns 3850s/424ns 37.0ns/42.4ns
A9 36 2ns/40 8ns 36.2n,/40.8ns 36.2ns/40.9O$ 36 60s/40 9ns 364ns/40.9ns 36.5ns/ 40.9ns 36.503/40.9ns 327n3/40.9ns 368n3/40.9ns 36.8n,/40 9ns 36.8n,/40.9ns 368ns/40.9ns 36.8n5/40 9n$ 36.9n'/40.8ns 36 9n5/40 8n5 35.4(15/40.8ns
AIO 37.8ns/42.4n$ 378ns/42.4ns 37.8n'/42.50s 38 20s/42.5n$ 38.0ns/42.5n5 38.1",/42.5n5 38. Ins/42.5n5 343n5/42.5m 384ns/425n5 38.4",/42.5ns 38.4n,/42.5ns 38.4n,/42.5n5 38.4ns/42.Sos 385",/42.4n$ 38.5ns/42.4f13 370",/42.4n5
All 37.8n,/42.4ns 378n,/42.405 378n5/425O$ 38.2ns/4250s 380m/42.5n5 38. In5/42.5", 38 In5/42.5n5 343n5/42.5n5 384n5/42.5n5 384n5/42.5ns 38.4n,/42.5"$ 38.4r13/42.5ns 38.1n3/42.5ns 38.5n5/ 42.4n$ 38.5n5/424n, 37.0"5/42.4ns
AI2 40.2'13/44.80$ 40.2ns/44.8n$ 4~ 2ns/44.9ns 40 605/44 9"$ 40.4"3/44.90$ 40.5n5/449"s 40.Sos/44 9ns 36.7n,/449n5 40 8ns/44 9ns 40 8ns/44.9ns 40.8n5/449O$ 40.8ns/H.9O$ 408ns/44.9n$ 40.9n5/H 8ns 40 9ns/44 8ns 39.4n5/44.8n$
AI3 39.7n5/44.3O$ 39.7ns/40ns 39.7",/44.409 40. Ins/H.4ns 39.9"s/H.4n5 40.0n$/44 4"$ 40.0n$/44.40$ 36.2ns/44 4ns 40.3ns/4440$ 403ns/ H. 4ns 403ns/44.4M 40.3n5/H 4ns 403m/44.4n$ 40.4n5/4Uns 40.4os/40n, 38.9n5/4Un$
AI4 40.2n,/44.8O$ 40.2ns/44.8n$ 40.2",/44.90$ 40.6n$/44.9"5 40.1n5/44.9"s 405n5/44.9"5 405ns/H.9ns 3670$/44.9n5 40 8n5/ 44.9n$ 40 8ns/ H. 9"$ 40.8ns/44.9ns 40.8n5/44905 40.8n5/44 9ns 40.9n5/44.8ns 40 9n$/443O$ 39.4n5/ H 8n$
AI5 43.8n5/ 48. 4n$ 438ns/ 48. 4n5 43.8"s/4850s H.20$/48.5ns H .Ons/ 48.5ns 44.lns/48.5ns 441 n$/48.5"5 40305/48.5ns 44 4ns/48.5"$ 44.4"5/48.5"$ 44.4n$/ 48.50$ 44 4ns/ 48.505 44.4ns/48.5ns 44.5"s/48.4ns 44.5n5/484n5 430n5/484n$
QKOUl .. 19.0ns/19.3ns
counl5_elk
counl6_clk
-
counl7_clk
counl8_elk
DolojnO
Doloj" I
DolcUn2
Doloj03
Dolojn4
Dolojn5
DolcU06
Dolojn7
DolcUn8 16.9"s 16.0ns
DolcUn9 16.9ns 16.0n5
DolojolO 16.8"$ 15.6n5
Dolojnll 167"s 15.6"$
DoicUnl2 16.8ns 15.9"s
Dolojn 13 16.7(1s 15.9ns
DoicUol4 16.6ns 15.9ns
Dolojn 15 16.105 16.0ns
009UllCD
009L6JJSR
009LB-C1S
009L91<l
0092-1llCD
009HlllR
0092-6JJSR
0092 ..B_C1S
IlPSWJl
IlPSW_9
IlPSWJO
IlPSW_l1
IlPSW_l2
IlPSW_l3
IlPSWJ4
IlPSW_l5
INSl
PIRXD
P2_0 12.4ns
P2RXD 15.5ns
P5J.JOZZEl
P6J.JOZZEl
P7J.JOZZEl
P8J.JOZZEl
tW
RfS[]
/VfiI. 20.5ns/35.3O$ 20.5n$/35.3n5 20.605/35.4(1s 20.6n5/35.4n$ 20.6ns/35.4(1$ 20.6ns/35.4(1$ 20.6n5/35.4"s 20.6ns/35.4(1$ 20.0"$/35.4"5 20.0n5/35.4"s 20.0n5/35.4ns 20.01l$/35.4n$ 20.0ns/35.4I1s 19.9"5/35.3n$ 19.9n$/35.3n$ 19.9(1,/353(15
Hardware Timing Analysis using the
Logic Analyzer
Appendix T
0 :JL C
Q) Q) a "<;J'c +J Q) +J
:J C L 0
~ Q) u enr-:
U (f) .,-t
L
f-
x (I)
Q) :Jau
+J "<;J'C
tof)(0 en COU
.,-t
L ('.I
f-
a
L
(I)+J
0 :JC
r-I a a COU +J tof)
If)
0- X
"<;J'u
ID (L
OJ
rl
.w
(I)or! u N L Q).w LL CO Q) Eh w N 0 ..Y. .,-t
Z 0 N L f-;:5 H (0
:r: A- A- I::
U I I(L
X 0I::
E (I)
CL z»a (f) x (00'+- Q)
Q) :::J :r:OJ Q) 0> (L 0 "<;J'(0
3: Q)
W :r:> Z f-(f)(f)(f)(f)(f)(f)0 HO (L:::J
:::J:::J:::J:::J:::J:::Jf-(f)(f)(f)(f)(f)(f)(f)(f)~(LOJ D(f)
OJOJOJOJOJOJH:::J:::J:::J:::J:::J:::J:::J:::J(f)WO~OOW~:::J
OOOooozOJOJmmOJOJOJOJ:::J~W~~W~~OJ(L(L(L(L(L(LH(L(L(L(L(L(L(L(LOJ~U~~~(LU(L
0)
u
c
(D
U
o
L
+oJ
C
o
U
w
Z
H
I
U
<r:
I:
E
L
o
It-
O)
o-
(D
£
L
0)
N
::n
(0
c
<r:
L C
0) 0)
+oJ 0)
C L
0) u
U(J)
(J)
L
Q)
~
L
(D
A A I:
I I
(f)
wn:::oo<:I
x
0)
I
u
u
<:I
o
o
+oJ
.......
L
I-
x
o
+oJ
0)
.......
L
I-
o
o
+oJ
x
Q)
o
(D
o I- :>- (J)::r::1-o ~ WO WI-W I- 0~ 0 ~n::: n:::£(f)O~~H ~
~W<:In:::On:::O(f)WI-I-I-<:IO~~m~~I-(f)n:::£O~n:::HHH£WWW(f)U<:I(f)~~~<:Im~mmm~UUUU
ID
U
C
ID
U
o
L
-+oJ
C
o
U
rr
U
«r
w
Z
H
:r:
U«r
:r:::
E
L
o
It-
ID
c-
ID
::!::
L
ID
N
=:J)
ID
C
«r
(f) (f)
C C
00
00
00
"'J""'J"
" II
"0 "0
o 0
or-f .,.-t
L L
ID ID
0....0....
ID ID
0.. 0...E E
ID (0
(J)(J)
-+oJ -+oJ
C X
ID Q)
LZ
L
:J
U
~
:J1t-
EIt-
:Jo
U
U
er
Q)
-+oJ
ID
ID --Em......('.l
t- --
toc ..-
o
...... O"l
-+oJ O"l
...... O"l
(f) ..-......
:J 0')
cr :J
UcI
«r
co('.l
(f)
L
ID It-
.Y It-
LO
ID
:r:::
ID
o
=:J)
IDO
::>- (f)
......c
CD
(f)
o
o('.l
ID
t- ::>- (J):r:t-
~ wo wt-w t- 0o _JO:::: O::::::!::(J)O..-('.lH
~WcIO::::OO::::O(J)Wt-t-t-cIo..-('.lm_J_Jt-(J)O::::::!::O~O::::HHH~WWW(J)
UcI(J)~~~cIm~mmm~uuuu
LO
rl
Q)
u
c
(0
U......_.
o
L
~
C
o
U
w
Z
H
I
U
«r
1::
E
L
o-Q)
c-
(0
3:
~
L
Q)
N
z»
,-
L C
ill Q)
_. Q)
C L
ill UU(J)
x
(I) (I)
I:=-
o:J
I- :>- (J)II-~ wo Wl-w I- 0o ~~ ~3:(J)O~~H -~Wc:r:~O~O(J)wl-l-l-c:r:o~~m~~I-(J)~3:0~~HHH~WWW~Uc:r:(J)~"c:r:~,~~~,UUUU
ill_.
o:J
-;-E-
::::JO
u
u
er
- I-L_ ~
Q) Q)
(f) (f)
c cQ)
u
c
(0
U
00
00
00
IDCO
o II II
L
+-'
C
o
U
-0 -0
o 0
L L
Q) Q)
n, n,
cr
u
<r::
0... 0...E E
(0 (0
(f)(f)
+-' +-'
C X
Q) Q)
LZ
L
:J
U
ui
Z
H
:r::
U
«r
1::
E
L
o.._
Q)
::>
(0
~
Q)
+-'
(0L
Q)
N
:::n
(0
c
«r
o
"'J"
Q) --
E...o
·......N
I- --
I")
c~
o
(f) ~
.......
(f)
L
Q)
.Y.
L
(0
1::
Q)
o
c-
o
o
N
(0
I- ::::- (f):r::1-
~ wo WI-W I- 0o _j0::: O:::::!::(f)O~NH
~W<r::O:::OO:::O(f)WI-I-I-<r::O-Nm_j_jI-(f)O:::~O~O:::HHH~WWW(f)
U<r::(f)~~~<r::~~~~~~UUUU
(f) (f) 00) c c ('.Iu
0) --C 00 Et')o:J 00 •.-4 ..-U 00 I- --
"f "f
t')
c ..-
0
0 II II
L
+oJ U U (f) ..-
C 0 0 •.-4
0 •.-4 •.-4
~ U L L
-01 0) 0)0.. 0.. ... .................. .-W 0-
• 'U 0) Q)
rl «r 0. 0.
(}) E E
if) o:J (0
I (.f)(.f) (f)Lr4 +--' +oJ Q)
(}) C X .:::L.W 0) Q)0 z: L z: L(0H L
1::I ::J
U U
<r
1::
E
L
0
10-
0)
Q)::> 0o:J
3::
0)
+--'
L (0
0) ~
N ~
(0:::n 0 I- :>- (.f)II-
(0 u 0 ::J WO WI-W I- 0('.I 0 _jQ:: Q::3::(.f)O~('.IHC u ~W~Q::OQ::O(.f)WI-I-I-~o..-('.Im<r «r _j_jI-(.f)Q::3::0::JQ::HHH3::WWW(.f)
U<r(.f)::J~~~~~mm~~uuuu
(f) (f)
0Q) c c
(J (\J
Q) --c 00 EI")(0 00 ....... ..-U 00 I- --
"'q"'q
I")
c ..-
0
....... O't
0 II II +-' O't
L ....... O't
+-' D D (f) ..-
C 0 0 .......
(Y) 0 ....... .......
.--l U L L
Q) Q)
0... 0... . .... . . . .. ...
••••• •••••• 0 •••••••cr
(J Q) Q)
U a: 0.. 0..
(}) E E
rl (0 (0.w U) U) (f)
-01 +-' +-' LQ).w c x ~W Q) Q)c z L Z L(0
:::J H L J::I :::JU Ua:
J::
E
L
0
'+-
Q)
Q)> 0(0
3:
Q)
+-'
L (0
Q) ~
N ~
(0::n
0 r- :>- u)Ir-
(0 (J 0 ::J WO Wr-W r- 0(\J 0 _j0:::: O::::3:u)O"-(\JHc (J ~Wa:O::::OO::::Ou)Wr-r-r-a:o..-(\Jma: a: _j_jr-U)0::::3:0::JO::::HHH3:WWWU)
Ua:(J)::J~'a:m~mmm~uuuu
(f) (f)
IDQ) c c
u
Q) --c 00 EI.O(D 00 .......1'0U 00 I- --
'f'T c-
O
....... (J'I
0 " " of.oJ(J'IL ....... (J'I
of.oJ "'0 D (f) -
C 0 0 .......
0 ....... .......
~ U L L
-ri Q) Q)
.w u, 0... ... . . . .. .. .. . ................. .0-
• U Q) Q)
U) ([
Cl... Cl...3: E E
N (D (D
I (f) In (f)
rl ....... of.oJ L
Q)..e c X ~o, W Q) Q) Lz: L z: (0H L
L:I ::3U U
([
L:
E
L
0
It-
Q)
Q):>
0(D
3:
L
Q) ..
N
=n (Do I- :>- lnII-o ~ wo W~W ~ 0
0.1 0 _J~ ~3:lnO-0.lH
~W([~O~OlnWI-I-I-([O-0.lm
_J_Jl-ln~3:O~~HHH3:WWWlnU~ln~~~([~~~mm~uuuu
(f) (f) 0Q) c c
C\IU
Q) --c 00 Et0(0 00 .............U 00 I- --
""J"""J" toc ......
0
....... O'l
0 II II o+-JO'l
L ....... O'l
o+-J D D (f) ......
C 0 0 .......N 0 ....... ....... :3 CJ)
r-l U L L 0- :3
Q) Q) U<I:
0... 0... <I: . . ...................
0- (DU Q) Q) C\I
'D <I: 0... 0..
OJ E E
rl (0 (0
-W (f) (f) (f)
-r! o+-J o+-J L
Q) --W c X .Y. -W Q) Q) L 0h z L Z (0
~ H L :r::r: :3U U<I:
:r:
E (f)
L ~0
(0 0-Q) Q)c-
0(0
~
Q)
o+-J
L. ID :> (f)Q) -;- ....... C .--.--N
ID~ E-
O I- :>- (f)II-:30 0 ::::Jwo wl-w I- 0(0 U
C\I 0 _j0:::: O::::~(f)O""""C\lHc U ~W<I:o::::oo::::o~WI-I-I-<I:o""""~m<I: <I: _j_jI-(f)O::::~O::::JO::::HHH~WWW~
U<I:~::::J~~<I:m~mmm~uuuu
PHASE 2 Design Schematics and
PCBs
Appendix U

II 6 I
C
III 42
D
I 2 I
Title
SlZtl INumber I Revis","
A3
Date: 12·Dee·l999 Sheet 01
File: D:ltemo\Colds.,eh Drawn Bv:
4 I 5 I 6 . I 7 I 8
D
vee
-
UlA
DCLK 107 I TCK
CLK 1]1' 125 DCLK l:;: l:;: ~ f; Iz Iz t; §§8§§ §§ ~M~CLK 7 AO
P2 N07.Z-E 55 OCLKO BBoB BB e o o o o o o o o-""':'USR 1--i-1""43:--';';;"/H""""A-
CXJNF DONE 2 OCLKI U U U U U U U :> :> :> :> :> :> :> :> CS 1--+1744i-';$n'""'IRrC-
CXJNF DONE" :> :> :> :> :> :> CS D-+,i,;'-';';"""",.,..,.,..-
...---.~,...,.,,..,..._I:..::06~.('j CE - DO 1--+1"'08:;.-~D~A'Ac.:;~O~
neEO UlA 3 CEQ DI 109 All
nCXJNF10 74 - 110 AD2
PI l'foZ1.Ll.! 54 CONFJG D2 1--+1';':11;:-':':AD~3--
!RESET 124 JN D3 1--i-1",12i:-':":AD:;;:;'4--
P3NOZ: ::E 56 JN D4 1--+1';;13<-':':A"'D;;'S--
ALE 126 JN D5 1--;'1-i-'14:-':":AD~6--
JN D6 I-+;-;;___!~--
+- ---i7~7__1 MSELO D7 1--+1.,;;;16:;.-.:.::;;:AI:,;.,7;--_
+-_:o:=""",,.-__,7;;:6__1 MSELI DEVCLR b--+l~22<-.:.:AD~3::-_
!.:!NMI2:;3"-_l!IO~'X"1l ~.!.1!..1 ~_4JlS1~A~.E~~3~S-d STATUS DE\' OE 1--.;;128;;:::--...;AI:rnlc.;:4__
I1lliE 90 10 - 10 1--;;26;;-...;A;.;I:.;;5=-,.,-
iNHREADY 91 10 10 1-~27i;-",;PmlLED~+,IAr;I;-
1.6 92 10 10 28 I'LELIA2
)20 A14 95 10 10 29 LEI 2Al
:J227[J23 AI4T.-965 10 10 c--.;;.30i'-_..PLED;=;·~2A2rrm A14 97 31 Pl.ED3AI
lJ201U21AI3 98 10 10 1-";:3';"2-':'PL;:::ED=S;3~A2:';'"
024 AI3 99 10 10 1--;;3;':'3-+<pMJ..E[~4'f-:A"_1
lJ24 AI4/AISl00 10 10 1--;;376-~Pi"i..li~4i'iA2:;'-
TESTCPLD 101 10 10 1--;;3*7-';"D~IPSWr.rr.-O
Al5C 102 10 10 1--;;37;-S"'D",IPii:Ti:;Wri'-1
AI S 10 10 1--;;3*9-"'D"'IP~SW:"";""2
A2 9 10 10 1-"'::4"'"1-"'D';;';;IP:S"'W'r-i-3
A3 10 10 10 1--;;4';'2-~DI'*"'I'S:rr\WT+4
AS 12 10 TO 1---i4;;'3-"'D'"'IP":;';':SW:'-';-5
A6 13 10 10 1--ci4~4-*'D'*"'I1':S;m-W76
AS 17 10 10 1---i46";'----;;;'"'IP":;';':S\W'r-i-7
A9 18 10 10 1-"';4*7-""eoun1~+'1'-::c;"'1k
AI 19 10 10 1---i4';"g-';:;coun=12;;'-:cTIk
ADS 117 10 10 1-"';4*9-~Co::>UI1~t3:;;-::e:;r.lk
AD9 118 10 10 1-';;5'""1-C~0l::::IO:!!:t4~elk~
ADI0 119 10 10 I--i'S*9-"'P74:rn;N(Oof.i'~:.E~
ADII 120 10 10 1-_'60~-';';'RL.rl=~
ADI2 121 10 10 62 RL2
All 20 10 10 63 RL
AI2 21 10 10 64 RL4
10 10
:i'\l'5I) 130 10 10 1-;;65;-...;;SP""ARE:m""I_
7ili: 131 67 SPARE2
BUSWIDT 1 132 10 10 1-":;;68i:--=SP,"""'ARlE1;;I:l3:;;-10 TO I-";;:';;'-';;;':~"_
""'Arm 133 10 10 1-..;;6~9_."SP..)ARrUi4,-,--
NJR. 13S 70 coo
imjmA13136 10 101-""7""2--ii/CE""'I--
10 10 I-*"-;~,.---
iilWR~~~1~3~7:j IO 10 1--i;7'5-3_'i/CE~2~_
;;. 13S 10 10 1-..;,7*8_",/CS~I..0;..-
:;.:PO~R~·~"2,",Rl::::...._l~4~0~10 JO 1--i;7~9_rBlUZZERT=-
,!;!A.!.:;13:-__ ..;;2:;c2--l10 10 1--.;;8,;:-O_..,Ex::....:;.:::Flal1,--
!;.A,:;f4"-__ ~2~3~ 10 10 1--ii8:;;1_.;:rn,Ex,;:Lam=oP::_
;,;.A7!...-__ ......1:;.4--llNIT DONE 10 1--ii
82"_-..;,WD,*,J=-:--:
~A4;!",.,...-_ _,..;I,;..I-d RDYB~ 10 83 lJ201U21 A14/AI5
;;;)t~:-_~1;.;;4:.:.1-<i RS - 10 1-.;;8~6_~IN""JiS!-!ir..,..,...:-
Dl lOS 87 I AI4
TOC 4 TTT~,~ ~ ~ ~ ~ ~ 0 0 0 0 00 0 0 0 J11g
o
I 88 SCI'lMlDr BHE
fiiT~~SA;:;:14=~I~iti ~ Wf ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~~. f-...:e:.89:..__.::U23=Al~4
U26E
MC74F14
C
B
A
-
B
CPLDI
-
A
I I 2 I 3 I 4 I 5 I 6 I 7 I 8
Vf
..:... f54
Ul9 68 T I j_XI 1~rORI vee VSS
lEA 2 67 ~. U
C55 tl
P07 NMI 3
EAiI XTALI 66 YSTAL
~
PO 4 NMl XTAL2 65 LKOl r~crrOR -=:=-
PC.I 5 PO.31ACH3
CLKOur
PO.I/ACHI BUSWIDTH
64 suswnrm
D PO. 6 PO.OIACHO INST
63 INSr D
PO.2 7 PO.21ACH2 AUYADVII 62
ALECO PO.6 8 PO.6IPMODE2IACH6 RD# 61 IR
I I
9 PO.7IPMODE31EXTINTfACH7 P3.OIADO
60 ADO
PO.5 10 59 ftJl <,CN PO.4 II ACH5IPMODEIIP0.5 P3,I/ADI 58 AD2ACH4IPMODEOIPO.4 P3.21AD2
CONFDoj3
Al'roND 12 ANaND P3,3fAD3
57 AD3 "VREI' 13 56 AJ 4
14 VREF P3.4fAD4 55 ADS
.], ]>2,2 IS
VSS P3.5/AD5 54 AD6
EXTINTIPROG#IP2.2 p3.61AD6fRESPIN 16 RESET# 1'3,7/AD7 53
AD7
=: 1'2.1 17 RXDIP ALE#lP2.1 P4.OIAD8 52 ADS1'20 18 TXDIPVERIP2.0 P4,I/AD9 51 Ai 9- 1'1.0 19 1'1.0 p4.21ADIO 50 ADI -1'1.1 20 49 ADII
1'1.2 21
1'1.1 P4,3/ADll 48 ADI2
1'1.3 22
1'1.2 P4.4/AD12 47 ADI3
1'14 23
pMWIIPI,3 P4.51AD13 46 ADl4
HSl.O 24 1'WM2IP1.4
p4,61ADI4 45 AI 15
HSI.l 25 HSI.O
P4,7/AD15 44 1'2.3
HSI.2 26
HSI.I p2.31T2CLK 43 mArm ''SfHS1.3 27 HSI. 2IHSO.4 READY 42 1'2.4
Hso.o 28 HSl.3fJ-ISO,5 T2RST IAJNC#/P2.4 41 IBHE
HSC.I 29 HSO.O
VVRH#lBHE4I 40 IWR ~;I
P1.5 30
HSO.I WRL#fWR# 39 P2.5
1'1.6 31
BREQ#lPl.5 PWM0IP25 38 1'2.7
>RESI
1'1.7 32
HLDA#fP1.6 T2CAPTUREIP ACT#lP2,7 37 vpp
<
P2,6 33
HOLD#IPI.7 vpp 36
C }]SC ,2 34 T2UP-DN/CPVERlP2.6 VSS 35 HSCl3
C
HSO.2 HSO.3 ~
8OCI96KD C"I""AmOR-="=-
- f--
B ~ B~
LOBYTES Hl BYTES U22 LOBYTES HlBYTES 81 lTMIlM
U20 U21 U23 U24
Al 10 AO DO
11 ADO Al 10 AO DO II AD8 Al
10 AO DO
11 ADO AI 10 AO DO
II AD8 AO 10 AO B DO
II ADO
s: 9 Al D1 12 ADI A2 9 Al D1 12 JlJ 9 A2 9 Al Dl 12 A I A: 9 Al DI
12 j.J 9 Al 9 Al DI
12 ADI
A3 8 13 AD2 A3 8 13 AJ 10 A3 8 13 AD2 A3 8 13 AJ 0 A2 8
;> 13 AD2
A4 7
A2 D2 IS AD3 A4 7 A2 D2 IS ADII A4 7
A2 D2 IS AD3 A4 7 A2
D2 IS ADII A3 7
A2 D2 15 AD3
AS 6 A3
D3 16 AD4 AS 6 A3 D3 16 AD12 AS 6
A3 D3 16 AD4 AS 6 A3
D3 16 AD12 A4 6 A3
D3 16 AD4
A6 5 A4
D4 17 AD A6 5 A4 D4 17 AJ 13 A6 5
A4 D4 17 A 5 A6 5 A4 D4 17 ADI3 AS 5
A4 D4 17 AI
AS D5 AS D5 AS D5 AS D5 AS D5A7 4 A6 D6
18 AD6 A7 4 A6 D6 18 ADI4 A7
4 A6 D6 18 AI6 A7
4 A6 D6
18 AD14 A6 4 A6 D6
18 AD6
AS 3 A7 D7
19 AD7 All 3 A7 D7 19 A 15 AS 3 A7 D7 19 AD7 AS 3 A7 D7
19 AD15. A7 3 A7 D7
19 AJ
A9 25 AS
A9 25 AS
A9 25 AS
A9 25 AS
AS 25 AS
AIO 24 AlO 24 Al 24 Al 24 A9 24
I-- All 21 A9 All 21
A9 A I 21
A9 All 21 A9 AIO 21
A9 f--
AIZ 23 AIO A12 23
AIO AI2 23
AIO AI2 23 AIO All 23
AIO
All All All All AllAl3 2 Al2
AI3 2 Al2 A13
2 Al2 AI3
2 Al2
AI2 2 Al2
U201U21 Al3 26 U201U21 AI 26 U221U23 A13 26 U22IU23 Al3 26 U24 Al3 26
U20 AI4 27 Al3 U21 Al4 2
A13 U22 AI4 27
AI3 3 AI4 27
AI3 ~A4 27
A13
AI4 A14 Al4 AI4 AI4
IRD 22 OE IRD 22 OE IRD 22 OE IRD
22 OE IRD 22 OE
CAl() 20 CE CEe 20 CE ICE I 20 CE CE 20 CE
nCB2 0 CE
~U201U21 Al4fADS U201U21 AI4fADS U22IU23 AI41ADS U221U23 AI41ADS U24 AI41AI5 1VPP VPP vpp vpp vpp
27256 27256 27256 27256 !7230
:!
A
-=..g::- A
Title
MEMORY INTERFACE FOR THE 8OCI96KD MlCROCONTROLLER
Sw I Nun;ber I Revision
A3
1.1
Date: 13-Dec-l999 Sbeet 10C 1
File: D:\temoIMICROI96.sch Drawn Bv: STEVEN WANEl'OEL
1 I 2 I 3 I 4 I 5 I 6 I 7 I 8
Dc
B
A
2 3 5 6 8
RP5
SJP9
~l{~J~l~Nvee
- - 1-
0-00 .-10 "' ... "''''-
1)]4
L..-
PLED1Al I
116
PLEDIA2 2 lNl .oUT 1
18 LED1Al
PI.Ei 2AI 3 lN2 our 2
17 LEDIA2
I 2h
PLED2A2 4 lN3 .oUT 3
16 LED2Al
3 4F-.
PLE )3Al S lN4 .our 4
15 LED2A2
S 6
P_LE 3A2 6 lNS .oUTS
14 £lL3Al
7 81->
~ 4AI 7 lN6 .oUT 6
13 LEI:3A2
9 10
!'_LE 4A2 8 lN7 .oUT 7
12 LED4Al
-v; II 12 h-
I ~~DE CLAMP~10 .oUTS
11 LED4A2
-v, 13 14
'- 15 16 I->
--
_
L...
1)]6
vee
+
UL'N2803A(18)
HEADER8X2
Jl7
1 2
3 4
5 6
7 8
9 10
11 12
13 14
IS 16
HEADER8X2 -ULN2803A(18)
D
m'i<---.;..1 __J IN I
=,;.-_ __;2:O__j IN 2
r.;=:;-_ __;3:__j IN 3
m''i---;;..4 __J IN 4
5
.oUT I t---;';;~~~!..
our 2 t---i'.,,--m;:rM~
oor s I-...;.;;....;;:;~~!._
QUT4 r-*~~~
our S ;---=-~~=-
.oUT 6 f---*~~~
QUT7 t--...,.;;....;::.;.~~
.oUTS r-...!.!...~~~
v:
ClND
UJS
vee
T
m:;;:-__ 6~_ji IN S
7 I ~6
""'''''''''--10':''8 -~iDE CLAMP~
ULN2803A(18) 1
DlPSW 0
SWI T""
DlPSW I
I _/_ 16
DlPSW 2
2 _/_ 15
DlPSW 3
3 _/_ 14
);)ItSW 4
4 _/_ 13
~W5
S _/_ 12
DlPSW 6
6 _/_ II
DlPSW 7
7 _/_ 10
8 _/_ 9
[:","' ... <1'\'" .-000- )W-Wl'8'
. .s:'S yy
I~~~<~~~~littti-{~
6d1S
RP4
SlP9
SW2
vee
1 _/_ 16
2 _/_ IS
3 _/_ 14
4 _/_ 13
5 _/_ 12
6 _/_ 11
_/_ 10
8 _/_ 9
1)]7
c
Ex Lamp 1
"E.x::"';;;Fan=:__"';2- IN 1 .oUT I
B~ 3 lN2 .oUT 2
~SP;':ARE~;;:I:"'--4L__J IN 3 .oUT 3
SPA 2 S IN 4 .oUT 4
Sl1Op;';PA~E;_3-26~ IN 5 our 5v
l
ee1'SIP;":;:;;AI"'E!4:r-""';;'7_.JIN 6 .oUT 6
SPA;S 8 lN7 .oUT 7
,--_::o:..!_,:;:;_~_:::._-___;I~O=~ IN 8 9 .oUT 8
DIQDE CLAMPS
18 DRV-Ex Lamp
I 7 RV-EXl'an
16 DRV-BlJ77F1
IS DRV-SPAREI
14 DRV-=SPARE2
13 DR -SJ5ARR,
12 DR CSl'ARE4
11 DR -SPARES
ULN28D3A(18)
_'-
vee
PERIPHERAL CIRCUITRY
2 3 4
vee
B
A
Title
.:;--
>R48
RPI
<
Vf"( LPI
U36
1 I 20 WDO
"Och 1
~
2 '--t- Al KI 19 .oW [JNE C
II -:l-3 A2 K2
~
3 18
4 4 A3 K3
19 2 ADO
~y.""'\ S A4 K4
17 18 IQ
lD
5
2Q
3 AIl
~ ~\I.'vA 6
AS K5 16
17 2D
6
3Q 4
J\I 2
f;V. 'A~ 7 7
A6 K6 15
16 3D
14 4Q
5 AI3
8
A7 K7
15 4D
~v. 8 13
SQ 5D
6 AD4
9 9
AS K8
14
12 6Q
7 AI5
LIVVV 10 A9 K9
13 6D
10 II
7Q 7D 8 AD6
A10 KIO
12 SQ 9
AD7
SlPID LEDBANK
8D
74LS573 LEDBANK
1137
RP2
"Oc 1
~A.
LP2
c 11 +10 1 209 2 Al K1 1919 1Q lD 2 ADS
8 A2 K2
18
o~
3 18
2Q 3 AD9
7 A3 K3
17 2D
4 17
3Q
4 J\D1O
-~A'I 6
A4 K4 16
3D
f71~<,..'v,.. 5 AS
16 4Q 4D
5 AD11
5
K5 15
6 15
5Q 6 ""'Al5i2
~'A\lA'A. 4
A6 K6 14
50
7 14 6Q 6D
7 ADl'3
~
3
A7 K7 138 AS
13 12 7Q 7D
8 AD14
2 9
K8 8Q
9 7\I5i 5
A9
12 TES :::I'll.) 8D
1 10
K9
7c:c
A10 Kl0 II CONF DONE 74LS573
SlPID R9 LEDBANK
RESI
vee
5 6
ReVISIon
1.0
-
I I 2 I 3 4 I 5 I 6 I 7 J 8
D D
U28A
U25 82510
INT510 5 17 RESET
I V- D9 UfXD 6
!NT RESET 18 I(S510-vrI. TXD CS
~
3 2 P2TXD IRESET -I.~ 16 RTS RD 20 IRD
5 DB92 5 SClND +V~ 14 V+ Dlb~ ,~ DTR WR 191WK~ 9 DB92 9 Rl 14C88 \JRXD 13 RXD AD 22 AO4 DB92 4 DTR i >"-#--c DCD Al 23 AI8 DB92 8 eTS rtk DSR A2 24 A2~ 3 DB92 RX! vee 4 25 AD7 DB92 7 RTS ~T~ C48 /URI.~ CTS DO 26 ADI2 DB92 2 TXD p~~LLRI Dl 27 AD2D2- 6 B92 6 DSR X2 D3 28 A 3 -~ I B9: I DCC D4 I AJ:4
~
2 A 5
I 3 P2R.XD ,IT 9 D5 3 ADoXI D6
(~
'I D7 4 AD21
-=:=- \~
vee 7VSS... - +-==-
U28B
5
Vf RS232COMMS
C
~
P TXD 6 I
C
5 DB91 5 SClND 4 PITXD
" 9 DB91 9 RI4 DB91 4 TR 6 RXD TAG TXD TAG8 DB91 8 crs 14C88 ;~ ;r- .:" 3 DB91 3 RXD7 B91 7 RTS2 DB91 2 TXD P RXD 4 6 PIRXD~ 6 DB9 6 DSR CO Co Co1 DB91 I DCD 1 P RI I I P RXD I I P TXD
~
U29B 1
U28C 14C89
C;3 ~L
~
9 Rl
~~RI
I-- P RI 8 I
'" DB91 2 TXD
-
10
14C88
V ,
B B
PORT2 RI FPIRXD FPITXD FRI FP2RXD FP2TXD
TPl~1 W901 WI~I Wl~1 WI~I Wl~1Co Co Co Co Co Co
I I DB92 9 RI I I P1RXD I I PITXD 1 I RI I 1 P2RXD I
1 P2TXD
r-- Ci~L C"L C:L C"L C"L C"L I--DB92 9 RI P2.D
A A
Title
EXTERNAL 82510 UART CONNECTIONS
Size I Nun;bor IReru~
A3 1.0
Date: I 3-Dec-l 999 Sheet 10 1
File: D: temp1UART.80 1 Drawn By: STEVEN SWANEPOEL
I I 2 I 3 4 I 5 I 6 I 7 I 8
> o
,
I
.... 1
1-
'1W! :: ~1~~
"ff
;:;
~~'-d:
1:;
I(l
~
o~ ";;0
- ~
I~ ,~ I
I I 9
I
.Z;, '0 I
II I 1 ~ ,
~ I 1;Xi I
I I PI ~ I II
I~
I
_, "
J
:..
- - ,- --- - ---
'"
r, 0
o
I~
1
I-
o I I
-
o
.....
~z
oo <
-i
t
I
I
J
I
I
<:
~. ....
e! is
f.1J
e!
O'P' <:
-e ~ o;e- -' -e9 ~'"~'~ p u:do . ~ ~
'1 ::l;
ilu!;!
...
:a5
I
98
::l;
~
NI
u II'!;!
uo
I I Io
~ ~
~~, ~~,
V ., 0 BUZOUTI:!V v ., 0 Ex Fan-OlIT
VO", 8 VO", 8
vee aJN ()V 11 aJhl 0"- II
~ .,()-ftt-
£1 lION 0 BUZOlIT5V £1 lION 0-..
r-- 6 6
DRVBUZZER vee DRV-Ex F{] vee
I 91 1 91
1 ~
~()-' 9 ~0"I.9
v . 0 RLIOlIT v., 0 RL20UT
VO~ 8 VO~ 8
~()-'II ~O-II
£[ lION <r £1 lION 0"-
DRV~' 0 :,va; DRV-~' 0 :,va;
i i
v+ v~o- 9 v+ v~reo- 9
~o RL301JT ~o RL40UT
VO~ 8 VO~ 8
aJN: <r'll aJhl 0- II
-D-1ft- ~
£1 lION 0-..
6
£1 lION Q- 6
DRV-'";'0 "va; DRV-";' 0 "va;
i i
~0-9 ~O-<9
v VO~ 0 8RL50UT V VO~ 0 8RL60lIT
aJN: 0- II aJN: O« II
"'O-1H- ~
EI lION 0- £1 lION 0>-6 6
DRV-~5 0 91 vee DRV-~6 0 91 vee
; ~
~0-9 ~0-9
" ;"0 RL 70UT "., 0 RL80UTVO~ 8 VO~ 8
aJN: Q- II aJN: 0- II
"'O-1H- ~
EI lION 0- EI lION O«
6 6
DRV-~' 0 "va; DRV-'";'0 "vee
i ~
~0>(9 ~0>;_9
" ot, - Ex Lamn-OlIT V ;'l 0 SPAREI2V-OUTVO~ ~ _ VO~ 8
aJN ()-' II vee aJN a- II
EI "'O-1H- ~o SPARE5V-OUT
HON 0- 6 lION 6
DRV-,""'1J "va; DRv-ru>r{] "vee
PI NOZZLillJcoun1l elk i I
RLlOlIT I z
GND £.,.v z>=:S
~
RL60UT i z
GND I E I :l
~:!Z·S
P2NOZZ~
)c0unt2 elk ! ~
RL20lIT
GND J ~ Zt.....:._~S
~
RL70lIT i z
GND £ Z
~~S
-
P3 NOZZLrr-:-
jc0unt3 elk I I
RL30UT ~ ..-
GND Z
C:_!:!S
P4 NOZZL_Er-
count4 eU: I
RL40UT z
GND £ Z
V "'S_-
BUZOUTI2~
GND 11
BUZOUT5VI z I
GND .: zs"'"___ --'L_.E!
SPAREJ2V PUT DRV-SPARE2__r.-
SPARID(V-otn ORV-SPA1lE3 1
OND _Z ~ £ORV-SPAJE4 z
E' ~ SORV-SPAJE5 ! £
~ vee " I"
SPARE6 $ S'
SPARE 9 9
SPARES L
GND .s '8 0
GND _jl_ J 6 Z
01 ~r2S
-
I I Io
