Electronic Voting System Using an EIA RS-485 Network by Liebsch, Thomas Alan
South Dakota State University 
Open PRAIRIE: Open Public Research Access Institutional 
Repository and Information Exchange 
Electronic Theses and Dissertations 
1987 
Electronic Voting System Using an EIA RS-485 Network 
Thomas Alan Liebsch 
Follow this and additional works at: https://openprairie.sdstate.edu/etd 
Recommended Citation 
Liebsch, Thomas Alan, "Electronic Voting System Using an EIA RS-485 Network" (1987). Electronic 
Theses and Dissertations. 4457. 
https://openprairie.sdstate.edu/etd/4457 
This Thesis - Open Access is brought to you for free and open access by Open PRAIRIE: Open Public Research 
Access Institutional Repository and Information Exchange. It has been accepted for inclusion in Electronic Theses 
and Dissertations by an authorized administrator of Open PRAIRIE: Open Public Research Access Institutional 
Repository and Information Exchange. For more information, please contact michael.biondo@sdstate.edu. 
ELECTRONIC VOTING SYSTEM 
US ING AN 
E IA RS-485 NETWORK 
BY 
THOMAS ALAN LIEBSCH 
A thes is  submitted in partial fulf il lment 
of the requirements for the degree 
Master of Science 
Maj or in Eng ineering 
South Dakota State Univers ity 
1987 
ELECTRONIC VOTING SYSTEM 
US ING AN 
E IA RS-485 NETWORK 
This thes i s  i s  approved as a creditab l e  and 
independent investigat ion by a 
degree , Master of Science , and 
meeting the thes is requirements 
Acceptance of this  the s i s  does 
candidate for the 
is acceptabl e  for 
for this degree. 
not imply that the 
conclus ions reached by the candidate are necessarily 
the conclus ions of the maj or department. 
D. E .  S ander , Ph . D .  
Thes i s  Advisor Date 
V .  G .  E l lerbruch , Ph. D .  
Head , Electrical Engineering Department Date 
ELECTRONI C  VOTING SYSTEM 
US ING A 
RS-485 NETWORK STANDARD 
ABSTRACT 
THOMAS ALAN LIEBSCH 
i 
A des ign o f  an electronic vot ing system is presented. 
Th�_s des ign utilizes a RS-485 network standard which 
encompasses the electrical properties of receivers and 
generators on the network . 
The hardware and so ftware i s  discussed in this thes i s. 
The hardware includes the CPU cons idered , the network 
interface device , the voting consoles , and the disp l ay 
interface . Al l so ftware for the respect ive hardware 
is outl ined . 
i i  
ACKNOWLEDGEMENTS 
The author wishes to extend thanks to 
Daktronics Incorporated o f  Brookings , SD,  and Al red 
Kurtenbach for the opportun ity of this proj ect. The 
help of this candidate ' s  advisor , Dr . Duane Sander , i s  
greatly appreciated . The author would also l ike to 
thank the electrical engineering faculty for all the 
help and support throughout this endeavor . 
iii 
TABLE OF CONTENTS 
Page 
Abstract . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . i 
Acknowledgements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  ii 
Table of Contents . . . . . . . . . . . . . . . . . . . . . . . . . . . .  iii 
List o f  Figures . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  vi 
I. Introduction . . . . . . . . . . . . . . . . . . . . . . . .  1 
II . RS-485 Standard . . . . . . . . . . . . . . . . . . . . .  6 
III . 
A .  Electrical Characteristics . . . .  6 
1 .  
2 .  
3 .  
4 .  
5 .  
6 .  
Hardware 
Drive Capability . . . . . . . . . 
DC Load Characteristics 
AC Load Characteristics 
Generator Characteristics 
Receiver Characteristics. 
Fault 
Design 
Conditions . . . . . . . .  
. . . . . . . . . . . . . . . . . . . .  
7 
9 
12 
12 
16 
18 
19 
A. CPU . . . . . . . . . . . . . . . . . . .  � . . . . . . 19 
B. Network Interface Device . . . . .  21 
1 .  Processor . . . . . . . . . . . . . . .  23 
IV. 
2 .  Communication Chip . . . . . .  24 
3. Memory . . . . . . . . . . . . . . . . . .  27 
c. Vot ing Console . . . . . . . . . . . . . . .  28 
1 .  Processor . . . . . . . . . . . . . . .  28 
2 .  LCD Opt ion . . . . . • . . . . . . . .  33 
3. Magnet ic Card Opt ion . . . .  34 
4. Memory . . . . . . . . . . . . . . . . . .  34 
D. Display I nterface . . . . . . . . . . . .  35 
So ftware 
A .  NID 
1 .  
2 .  
3. 
4. 
5 .  
6 .  
Des ign . . . . . . . . . . . . . . . . . . . .  
S o ftware 
Hardware 
Command 
Flushing 
Network 
Network 
Network 
. . . . . . . . . . . . . . . . .  
Reset 
Control 
. . . . . . . . . .  
. . . . . . . . .  
Data . . . . . . . . . . .  
Pol l ing . . . . . . . . .  
Jamming . . . . . . . . .  
Node Reset . . . . . .  
37 
37 
38 
40 
43 
46 
48 
48 
iv 
B. Operations Software . . . . . . . . . .  49 
1. User Entry So ftware . . . . .  49 
a .  Names Editor ...... 51 
b .  Calendar Editor ... 53 
c. Heading Editor .... 53 
d. Test Mode ......... 54 
2. NID Control Software .... 55 
c. Voting Console Software ...... 58 
1. Network Software ........ 58 
2. 
3. 
LCD Control Software 
Card Reader Software 
61 
62 
D. Di splay Interface Software ... 64 
V. Conclus ion . . . • . . . . . . . . . . . . . . . . . . . . . . 65 
Append ix A :  TMS70C02 Microprocessor ........... 66 
Appendix B :  DS 3695 Bus Transceiver ............ 69 
References .................................... 70 
Vita . . . . . . . . . . . . . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . .  7 1  
v 
LIST OF FIGURES 
1 .  
2 .  
Basic Electronic Voting System 
RS-485 Interconnecti on Scheme . . . . . . . . . . . . . . . •  
vi 
Page 
2 
8 
3 .  DC Loading Measurement • . . . . . . . . . . . . . . . . . . . . . .  10 
4 .  Unit Load Input Current vs Voltage . . . . . . . . . . .  10 
5 .  Example o f  a . 8  & 1 . 2  Unit Loads . . . . . . . . . . . . .  11 
6 .  Generator Open Circuit Measurement . . . . . . . . . . .  13 
7 .  Generator Output S ignal Wave form . . . . . . • . . . . . .  15 
8 .  Receiver Input Voltage Range • . . . . . . . . . . . . . . . .  17 
9 .  Proposed Electroni c  Vot ing System ·········�·· 20 
10 . Network Interface D·evice • . . . . . . . . . . . . . .  · . . . . . .  22 
11 . DS 3695 Bus Transce iver 26 
12 . Network Voting Console . . • . . . . . . . • . . . . . • . . . . . .  29 
13 . LM054 LCD Block D iagram . • . . . . . . . . . . . . . . . . . . . . 3 2 
14 . Voting Display Interface . . . . . . . . . . . . . . . . . . . . .  36 
15 . NID Reset Flowchart . • . . . . . . . . . . . . . . . . . . . . . . . .  39 
16 . Command Control Flowchart . . . . . . . . . . . . . . . . . . . .  41 
17 . Network Packet Format • . • . . . . . . • . . . . . . . . . . . . . .  42 
18 . Transmit Queued Data . . . • . . . . . . . . . . . . . . . . . . . . . 4 4 
19 . Polling Network Flowchart . . . . . • . . . . . . . . . . . . . .  47 
20 . User Entry Main Menu Display . . • . . . . . . • . . . . . . .  50 
21 . Names Editor Menu D isplay . . . . . . . . . . . . . . . . . . . .  52 
vii 
22 . NID Runtime Software . . . . . . . . . . . . . . . . . . . . . . . . .  56 
23 . Voting.console S oftware . . . . . . . . . . . • • . . • • . . . . .  59 
24 . Magnetic Card Reader Timing . . . . . • . . . . . . . . . . . .  6 3  
25 . TMS70C02 Pinout . . . . . • . . . . . . . . . . • . . . . . . . • . . . • .  67 
26 . TMS70C02 Block Diagram . • . . . . . . . . . . . . . . . . . • • . •  68 
I .  INTRODUCTION 
1 
The el ectronic vot ing system (EVS) plays a vital 
role in today's legislat ive process . The system 
performs many of the tasks that normally could take 
hours to complete such as the displaying o f  da ily 
events and totals , and the process ing and print ing o f  
vote totals and mot ions . S ince this is such a help ful 
des ign , it i s  used widely . Systems vary in size 
from those which are used in small city governments up 
to larger federal assembl ies . 
Daktronics Inc . o f  Brookings , SD currently 
produces a larger voting system consisting of four 
basic components .  They are the Central Logic Control 
Unit (CLCU) , the votestore CPU , the vot ing consoles 
and f inally the displays . Putting these items 
together ,  as in Figure 1 ,  produces a large system that 
can readily store moti ons , b i l l s , and vote tota l s , 
which can be printed andjor displayed in the manner 
requested by the operator . 
Member's 
Desks 
f 
I 
Clerk's 
console 
lcLCU 
I 
- CRT 
Wall Vote 
Display 
rl Controller I I 
Status Board 1--
Display 
Printer 
�------------��ote �torage L D1sk 
Figure 1. Basic Electronic Voting System 
2 
3 
The main component o f  the present voting system 
i s  the CLCU . This conta ins the hardware and so ftware 
logic for operat ional control of the vot ing system . 
One drawback o f  the CLCU i s  that mod i f icat ion is very 
t ime-consuming . Since each EVS ordered is un ique for 
each customer , most o f  the costly engineering hours 
are devoted to the modi f ication of each system's 
so ftware and hardware . Furthermore , the CLCU is 
controlled by the RCA1802CD 8-b it microproces sor , 
which is relat ively slow . It runs at a 1 . 645MHz clock 
rate and has a limited instruction set . Thi s  the s i s  
will present a poss ible solution by us ing a di fferent , 
and faster processor . 
The next element o f  this system is the votestore 
personal computer .  Thi s  PC i s  tied directly into the 
CLCU and controls the files for storing the totals and 
the calendar-day items , such as motions and b ills that 
are on the docket that day . Usually an IBM PC-XT w ith 
two floppy disk drives is used . One drive is used for 
entering the actual votestore program and the other i s  
for the storage o f  the part icular voting events . So 
the PC is only used as a storage device . When us ing a 
4 
newer PC such as an IBM Personal System/2 , there i s  
suff icient processor power to handle both the vote 
storage and also the system control that is presently 
done by the CLCU . Thi s  the s i s  will present the idea 
of us ing the PC for both storage and system control . 
The next important component i s  the displays . 
They are usually large , wall-mount displays us ing a 
typ ical 20ma current-loop interface . Presently , the 
displays are capable of rece iving the ir data from the 
votestore PC . Thi s  arrangement would take too much 
dedicated processor t ime from the PC i f  the PC also 
controlled the system operation . Therefore , an 
alternative display arrangement is presented . 
The last major component of the vot in9 system 
is the vot ing console . Presently , it i s  three or more 
switches with ded icated cables connected to the CLCU 
for each console . Therefore , 
be ing ut ilized in thi s  EVS 
transmitted to the CLCU . 
acceptable in some respects , 
d i f f icult at the customer 
little-mult iplexing is 
be fore the data is 
Dedicated· wires are 
but installation is 
location . A network 
5 
solution that will handle the necessary data I/O to 
the vot ing consoles and di splays is discussed . 
The author was a Systems Engineer during the 
beginning of this project . His bas ic dut ies included: 
1) Analys i s  o f  wirewrapped hardware 
components . 
2) Locati ng through various vendors poss ible 
LCD's , switches , and proces sors . 
3) Analysi s  and testing of the Network 
Interface Device ( NI D) software . 
4) Initial so ftware for PC user control . 
6 
I I. RS-485 NETWORK STANDARD 
The Electronic Industries Association ( EIA) 
RS-485 network standard was publis�ed in April , 198 3. 
It covers the electrical characteri stics o f  generators 
and receivers on a balanced digital multipo int system. 
Thus , EIA did not i ntend th is to be an interface 
standard , but that it should be referenced by 
interface standards that employ generators and 
receivers having these characteristics. 
This section discusses the electrical 
characteristics , AC and DC , and typical application o f  
this standard. Although the AC component is not 
standardized , it must be cons idered when des igning 
with thi s  standard. 
A. ELECTRI CAL CHARACTERISTICS 
The circuits that are speci fied in this 
standard shall not have a data rate higher than 10 
Mbits per second . Also , devices in the system must be 
able to operate at the +7 to -7 common-mode voltage . 
7 
The device power supply i s  not standardized , but for 
thi s  particular applicat ion , the network conta ins a 12 
volt line which is regulated to 5 volts at every node . 
1 .  DRIVE CAPABI LITY 
Figure 2 shows an interconnection scheme o f  
generators and rece ivers having the properties of thi s  
standard . The load o n  a receiver and pass ive 
generator is defined in terms of unit loads (U . L . 's) , 
and the unit load i s  de f ined by current and voltage 
characteristics , whi ch are expla ined in greater deta il 
in a following secti on� The electrical p�rameters 
chosen in this standard were selected so that a s ingle 
generator can drive 32 unit loads which have an 
ef fective total terminal res i stance , Rt , as low _as 60 
ohms . 
Balanced 
Interconnecting 
. Cable 
G - Generator 
R - Receiver 
G/R - Combination Generator/Receiver 
Rt - Termination Resistance; The location and value are 
not specified in this standard, but a generator can 
drive 32 unit loads plus a Rt of 60 ohms. 
Figure 2. RS-485 Interconnection Scheme 
8· 
B 
9 
. 2 .  DC LOAD CHARACTERISTICS 
To keep the current required from a generator 
in the active state to a pract ical limit , the load ing 
i s  standardized . Re ferring to Figures 3 and 4 ,  the 
loading effect produced by the hypothet ical unit l oad 
is def ined by varying Via o f  
volts , while Vib i s  held at 
Figure 3 from -7 to +12 
0 volts . The resultant 
current , I ia ,  shall rema in within the shaded regi on o f  
Figure 4 for one unit load . The actual curve shall 
always have a pos it ive slope to lower the poss ibil ity 
o f  osc illations caused by a negat ive input res i stance 
on the balanced network . 
To determine the number of unit loads o f  an 
actual pass ive generator or receiver , the slope of the 
bounds in Figure 4 shall be modi fied to fully conta in 
the current-voltage parameters . The -3 and +5 voltage 
intercepts must be ma inta ined . Then , the number o f  
unit loads i s  equal t o  the larger o f  the two ratios o f  
the new currents over the unit load currents . An 
example of a . 8  and 1 . 2  unit loads are shown in Figure 
5 .  
Load 
c 
Figure 3. DC Loading Measurement 
-. Bma 
I· l. 
Figure 4. Unit Load Input Current vs Voltage 
10 
. -. 64ma 
-. 8ma 
-. 64 --= .8 -. 8 
=:� = 1.125 
r. 
1 
I. 1 
.75 
1.0 
.75 
1.2 = 1 2 
1.0 · _+l.2ma -
+l.Oma 
Figure 5 . Example of a .8 & 1.2 Un i t  Load 
11 . 
12 
.3. AC LOAD CHARACTERISTICS 
Loads connected in this scheme also exh ib it 
react ive characteristics . When des igning a RS-485 
network the following should be considered : re flec­
t ions , unbalance ,  di stort ion in the s ignal . These are 
not standardized , but i f  the system has d i f f iculty 
with data integrity in the network , these should be 
cons idered as poss ible problems . 
4 .  GENERATOR CHARACTERISTICS 
A generator i s  in e ither pass ive or act ive 
state . While in the pass ive state , the generator 
characteristics are de f ined in terms of unit loads . 
In the active state , a generator circuit will produce 
a d i fferential voltage , Vo , on the balanced , 
connecting cable in the range o f  1 . 5  to 5 volts . This 
is shown in Figure 6 .  
13 
Figure 6. Generator Open Circuit Measurement 
u E 
14 
The signaling b inary states are : 
a) The A terminal is negat ive with respect 
to the B terminal for a binary 1 .  
b) The A terminal is posit ive with respect 
to the B terminal for a binary o. 
For either b inary state , 
shall not be less than 1 . 5  and 
the magn itude o f  
not more than 
Vo 
6 . 0  
volts . Furthermore , Voa or Vob , shall not be more 
than 6 . 0  volts . 
During transitions o f  the output , one to z ero , 
the d i fferential voltage shall be between 10% and 90% 
o f  Vss , when measured as shown in  Figure 7 .  Vss i s  
the steady state voltage at the one b inary state with 
reference to the zero binary state . 
A 
B 
� � . W" - ' 
-
-�� - 1\ \ 
�· � � 
--......._, -
tb Time duration of the unit interval at the 
applicable data signalling rate 
Vss = Difference in the steady state voltages 
Figure 7. Generator Output Signal Waveform 
� 
+t 
"" 
"" 
> ..... . 
0 
+t 
15 . 
16 
5 .  RECEIVER CHARACTERI STI CS 
The receiver characteristics are specified by 
the unit load parameter previous�y described . A 
circuit meeting those requirements results in a 
dif ferential receiver having a high input impedance 
and a threshold that lies in the region of - . 2  to + . 2  
volts . This is shown in Figure 8 .  
The binary state sense is the same for 
receivers as for generators . 
1 
+11.8Y 
-7V 
Figure 8. Receiver Input Vo-ltage Range 
17 
18 
6. FAULT CONDITIONS 
The fault conditions are to insure that damage 
will not occur due to a s ingle fault on a node . 
Devices meeting 
thi s  standard 
conditions . 
the 
must 
electrical characteristics for 
meet these fault tolerant 
a) With the generator output terminals short­
circuited , the generator shall not be 
damaged . 
b) The generator will not be damaged as·a 
result o f  its output terminals connected to 
a voltage source . 
c) The current l imit on any pin on a generator 
shall not exceed 250ma . 
19 
I I I . HARDWARE 
In this sect i on ,  the modi fied hardware for 
the electronic voting system is presented . S ince thi s  
i s  currently a n  act ive engineering proj ect , as o f  
September , 1987, the hardware spec i fications will 
only be outlined for proprietary reasons . The 
modi f ied hardware includes : the CPU , the network 
interface device (NID) , the vot ing consoles , and the 
display interface . A block d iagram of the vital 
hardware is shown in Figure 9 .  
A .  CPU 
The first revised component o f  the EVS is the 
CPU . As already discuss ed in the introduction , the 
CPU previously was the CLCU , which contained the 
logic for system control . Thi s  worked well for large 
systems with a substanti al amount of data requirement , 
but is costly for the usual three switch voting 
console on smaller systems . Therefore , an alternate 
CPU des ign is the f i rst consideration . The IBM 
Personal System/2 Model 30 i s  cons idered in this 
20 . 
IBM 
Personal System 2 
Model 30 
Personal Computer 
RS-232 
N ID Port 
h I 
Printer 
. 
Voting . 
Consoles 
. 
,� 
Wall 
- Displays 
with 
Network 
Interface 
1-. 
t RS-485 Network Standard 
Figure 9. Proposed Electronic Voting System 
21 
thes is . It has three expans ion slots , which can 
accomodate the necessary data I/0 .  Also , it has a 
newer and , more importantly , faster processor , the 
Intel 8086 . It runs at 8MHz ,  thus the process ing 
speed does not become a l imiting factor in this 
des ign . Typical ly , two 3 1/2 inch disk drives are 
standard . One drive for the system's operat ion 
so ftware and the other for the storage o f  several 
day's events . Finally , the cost of the Model 30 is  
very acceptable , which w il l  de finitely help market 
this new EVS . So the expans ion slots , the improved 
processor , and the cost, make this PC the most obvious 
CPU . 
B. NETWORK INTERFACE DEVI CE (NI D) 
The network interface device i s  the 
communicat ions driver between the PC and the nodes on 
the network , such as vot ing consoles . The network 
is accompl ished by a two wire cable util izing the EIA 
RS-485 hardware protocol standard . This protocol is 
di scussed in the last section o f  this paper . A block 
diagram of the NID is shown in Figure 10 . 
I 
I 
Bus 
Status & 
Control 
Lines 
Personal Computer Bus 
Interrupt 
Request 
Lines 
Memory 
Select 
Logic 
TMS70C02 
I 
Bus 
Transceiver & 
Logic 
I 1 
RAM 
8Kx8 
EPROM 
8Kx8 
Communications 
Interface 
� 
RS-485 Network 
I 
Figure 10. Network Interace Device 
22. 
23 
The basic function o f  the NID i s  to control 
what data is on the network. For instance , when the PC 
requests a particular vote console's status , the NID 
must poll that console's address. Then it wa its to 
receive the address and data from that console and 
conveys this information to the PC. I f  there has 
been a change of status for that console , then the PC 
will update the vote totals and have the NID send the 
new totals to the display's address on the network. 
Therefore , it is an information network with the PC 
be ing the controller and the NID being the driver. 
The main components of the NID 
microprocessor , the communications chip , 
memory. 
1 .  PROCESSOR 
are the 
and the 
The microprocessor used in thi s  des ign is the 
Texas Instrument TMS70C02 e ight b it microprocessor. It 
i s  a CMOS , ROMless processor that conta ins 192 bytes 
of RAM . To ease the overall des ign o f  th is system , 
it is also used in the vot ing consoles and the 
24 
display interface. It has a flexible instruction 
set containing eight addres s ing modes. This · is  very 
important because in l ong-term ma intenance, software 
w i l l  be the most costly item . Consequently, anything 
that can reduce this cost is  always favorable . This 
processor has 32 I/O l ines to  handle the data bus and 
interrupt requirements into the PC. Furthermore , the 
TMS70C02 can operate at 8MHz , thereby a iding the speed 
of the overal l  system. Finally , the price and 
ava ilabil ity of this processor are very attractive. 
Thus , the instruction set , I/O capab i l ity , cl ock 
rate , and cost make the TMS70C02 attractive for this 
system. 
2. COMMUNICATION CHIP 
The communication chip used in the network is a 
National Semiconductor DS 3695. This package is a 
d i f ferential , TRI-STATE bus transce iver des igned to 
meet the EIA standard , RS-485. It is presented in 
more detail in Appendix B ,  but its operation in the 
EVS is outl ined here . 
25 
The ma in funct ion of the DS 3695 is  to accept 
data directly from the NI D processor and convey it 
onto the network in a d i fferent ial form . A functional 
schematic of the DS 3695 i s  shown in Figure 11 . S ince 
there is  only one channel per package , the DS 3695 
isolates any faulty channel from shutting down 
adj acent good channel s . Thus , the chip is  used by al l 
units on the network . Thi s  a l s o  helps not i fy the NID 
o f  any mal functioning units . For instance , when a 
unit is polled , the unit must respond . I f  that unit 
fai l s  to respond , then the NID acknowl edges a faulty 
unit to the PC . Thi s  type o f  fault checking i s  
incorporated i n  a test mode i n  the PC software . 
RO 1 
RE 2 
DE 
3 
DI 
4 
F igure 11. Nat ional S em ic o nduc t or DS 3695 
Bus Tran s ce iver 
26 
8 
vee 
7 
RI 
6 
BUS 
RI 
GND 
27 
3 .  MEMORY 
The last .key component of the NID i s  the memory . 
The NID has an Intel 27C64 (8Kx8) EPROM and a Hitachi 
6264L (8Kx8) RAM . These are basic 64K CMOS memory 
chips , but are ut il ized in an uncommon way. The 
EPROM contains the NID processor program initial ly . 
After boot-up , it i s  then transferred to the RAM . 
Then , the program i s  operated from there . Thi s  
technique enables the NID processor t o  have faster 
access times in the RAM . Also , variables are eas ier 
to modify in RAM because of the obvious ab i l ity to 
write to RAM . 
In summary , the Network Interface Device is  
comprised of three ma in components: the processor , 
the communications chip , and the memory . These , 
together ,  with add itional l ogic chips , enable the NID 
to communicate between the PC and the RS-485 network . 
28 
C. VOTING CONSOLE 
The voting conso l e  i s  the basic data input un it 
of the system. S ince this  des ign_is very sensitive to 
any customer requests , both electrical and 
mechanical ,  this section wil l  only outline the 
essential and availab l e  options. The interacti on o f  
these components in the consol e and with the network 
is presented here. A b l ock diagram is  shown in Figure 
12. 
1. PROCESSOR 
The processor considered is  the TMS70C02. It 
is resp�nsible for the interaction with the network 
and the operation of the console. 
The operation o f  the consol e  processor first 
entails the monitoring of the network and-control ling 
each voting consol e's status. The processor i s  
connected t o  the network through a DS3695 
communicat ions chip. It receives the data on the 
serial port on the TMS70C02. I f  the packet received 
Latch 
EPROM 
8Kx8 
Optional 
LCD 
Display 
Figure 12 . 
TMS70C02 
Magnetic 
Card 
Reader 
l I 
Comrnunicatior 
Interface 
w 
RS-485 Network 
3 to 8 
Multiplexers 
ll::} voting 
Switches 
Network 
�...-.$ Address 
Switches 
Network Voting Console 
29 
30 
is an address and is the consol e's address, then the 
proces sor checks the s erial l ine for the command 
andjor data to be processed. Another function of the 
console is to monitor the data switches which 
correspond to the customer vote of "YEA" , "NAY" , or 
"ABSENT". These switches are connected through a 3 to 
8 multiplexer , as is  the console's network address. 
The network address of the voting console i s  set 
using a 7 pos ition DIP switch. If the data switch 
status changes , the processor wil l  notify the NID and 
update the LCD with the proper character codes. 
Other hardware cons iderations for the TMS70C02 
are the crystal for generati ng the cl ock rate and the 
voltage requirements .  The crystal used is a 4 . 915MHz 
crystal. It i s  connected to the XTAL pins on the 
processor . The voltage requ irement is five volts , so 
a Motorola MC7805 voltage regulator is used . A 12 
vol t  l ine is one of the cables in the network. Thi s  
12 volts i s  regul ated t o  5 volts for every node o n  the 
network. 
31 
Another function of the processor is  the 
pos itive feedback to the user. Th is can be done by an 
LCD display on .each console or s imple LED l ights above 
each switch , which would i l luminate when the 
respective switch is depressed. Thus , some type o f  
feedback is given t o  the user when the vote status i s  
changed. When us ing a n  LCD display , the processor 
sends the character code for the current status of the 
console. For example , i f  the console is in closed 
voting status , the 
S imilarly , when voting 
LCD w i l l  display 
proceeds the LCD 
"CLOSED". 
displays the 
respective "OPEN" , "YEA" , "NAY" , or "NV" depending on 
the present vote status. nNV" stands for no vote or 
abstain. Al l of these character codes are internal 
fonts in the LCD's driver , HD44780 ,  which is  only 
contro l l ed by the 70C02. The block diagram for the 
Hitachi LM054 LCD is in Figure 13. Thi s  is a 
representive LCD. It has the largest l etter s ize 
ava ilable for a one l ine LCD found at this  t ime . A 
graphic LCD provides l arger letter size but is  more 
costly. 
� - - - - - - - - - - -
I 
I 
I 
t 
I 
L 
Liquid Cry s t a l  D i spl a y  (LM054) 
HD44780 
LCD 
Driver 
Dot Mat r ix Cont rol l er Driver 
- - - - - - - - � �� - - - - - - - -
M i c roproc e s sor (TMS70C02) 
F igure 1 3 .  H i t a c h i  LM054 LCD Block D iagram 
32 
33 
The next funct ion of the processor is the 
control of the magnetic card reader. The 70C02 must 
accept the address from the card reader on the 
multiplexed data l ine. The strobe and card present 
l ines are connected to interrupts on the processor. 
The processor wi l l  operate normaly unless the card 
present l ine goes low. Then , the strobe controls the 
inflow of data read. 
2. LCD OPTION 
The most probable LCD used in the voting 
console is the Hitachi LM054. It is a one l ine by 
eight character display w ith almost one-hal f  inch 
alphanumeric character height. This was the largest 
character height found without us ing a more expen�ive 
graphic module ,  which would require in-house so ftware 
for the character fonts. The connection to the 
TMS70C02 is almost direct , except for the enable p in , 
there fore saving board space and enabl ing a smal ler 
console package . The only major problem with this , 
and most LCDs , is the v iew�ng angle. The typical 
viewing angle for LCDs is a 30 degree range from a 
34 
person's straight l ine o f  s ight. To reduce thi s  
problem , the LCD is insta l l ed at an angl e facing the 
user. 
3. MAGNETIC CARD OPTION 
The opt ional magnetic card reader is  produced 
by MAGTEC of Carson , Cal i forn ia. The connectivity o f  
the card reader is relatively s imple. The data l ine 
is multiplexed into a p in on the A port on the 
processor. Finally , the strobe l ine and the card 
present l ine are connected to two interrupt l ines , so 
the processor can operate as normal until the · card 
present l ine goes low ,  ind icating a card i s  present. 
The card reader could be ut i l ized two different ways. 
Thi s  is determined by the software in the processor , 
which is covered in the last sect ion. 
4 .  MEMORY 
The memory used in each console is an Intel 
(8Kx8 ) EPROM with an opt ional
_
H itachi (8Kx8 ) RAM. The 
EPROM contains the processor program and can be burned 
35 
with a GTEK prom burner. The RAM would be used on 
systems with typically more than four switches per 
console. These systems would require more data I/O ,  
thus requiring more speed. A s olution i s  to add 64K 
of memory. 
D. DISPLAY INTERFACE 
The display interface i s  a serial to 
current-loop converter. First , it accepts data from 
the RS-485 network via a DS 3695 , and then redefines 
the data , us ing power trans istors , into 20ma 
current-loop , which the wal l-di splays usual ly require. 
A bl ock diagram of the interface is given in Figure 
14. It conta ins a TMS70C02 processor configuration 
that is similar to the conso l e  setup. 
Latch 
EPROM 
8Kx8 
I 
L 
Parallel to 
serial Data 
Converter 
Logic 
r---J--
Shift Register 
1 r 
Power Circuit 
�or Each 
TMS70C02 
communications 
Interface 
w 
RS-485 · Network 
3 to 8 
Multiplexers 
- - - ----- - - . 
I 
� D1splay 
� Lights 
I 
I 
I 
, Repeats For 
,/Each Name 
• Module 
I 
Name Module Light 
�}. I 
Figure 14. Voting Display Interface 
36 
37 
IV . SOFTWARE 
The so ftware for the voting system is 
discussed in this section. It is comprised of four 
maj or programs: the NID program , the CPU control 
so ftware , the voting conso l e  software , and the display 
interface software . S ince this  is  an active 
engineering proj ect , al l 
with flowcharts where 
currently analyz ing and 
the time of this  writing . 
A. NI D SOFTWARE 
code will  
ava i l able . 
test ing the 
only be outl ined 
The author is 
NID so ftware at 
The purpose o f  thi s  code is to control the 
communications between the PC and all  the nodes on the 
RS-485 network . Nodes include the vot ing consoles and 
the displays . Each of these nodes has an individual 
address which the NID must transmit to , and receive 
from when needed . Furthermore , the NID must accept 
commands from the PC's bus . From the bus , the PC must 
control the action o f  the NID ,  such as pol l ing 
consoles , flushing data onto the network , j amming the 
38 
network , etc . Each function o f  the NID's code is 
covered in this sect ion . 
Al l the NI D software is written in TI 
assembler language and is  stored on the Intel 64K 
EPROM initially . After boot-up , the program is  
trans ferred to a Hitach i  64K RAM for faster access 
t imes and easier variable manipulation . 
1 .  HARDWARE RESET 
The NID has a hardware reset when power is 
appl ied to the PC or when requested by the PC via a 
software command . A general fl owchart is presented in 
Figure 1�. To begin with , the interrupts must be 
d isabled to avoid other command s ignals from the PC . 
Then a delay is incorporated so the PC has time to 
power up . The program then i s  trans ferred to the RAM 
from the EPROM . This  is  done by indexed. load and 
store commands to the addres s  o f  the EPROM and RAM . 
Now , all the flags and buses are cleared and the 
TMS70C02 is set in microproce�sor mode . This  is done 
for compatib il ity with the previous NID that used a 
D i s abl e 
In�errupt s 
& Power 
Del ay 
Load 
P rogram 
Int o  RAM 
From EPROM 
C l ear 
Al l Fl a g s, 
Bu s s es & 
Por t s  
Enabl e 
Int er rupts 
& 
Del ay 
D i sabl e 
Interrupt s 
& 
Check 
Int errup t  
F igur e 15. NID R e s e t  F l owcha r t  
39 
40 
processor that is equivalent to the 70C02 , but has 
several modes . Now , the NID is ready for input from 
the PC , so the interrupts are enabled . The NID loops 
through the location of the PC bus , and wa its for a 
command . I f  a command is  present , the NI D wi l l  read 
the command and j ump to the command process ing 
section . The commands are covered individually in the 
fol lowing sections . 
2 .  COMMAND CONTROL 
This code interprets the received command/data 
packet from the PC. A g·eneral flowchart o f  the 
software is shown in Figure 16 , and the general packet 
format is shown in Figure 17. When a packet is 
transmitted from the PC , it is  always a data/command 
packet . First , this  software checks the register with 
the command . I f  the e ighth b it is set , then the 
packet is a command , otherwise is data and _the program 
j umps to the data section. When a command is 
rece ived , the program shi fts to the correct funct ion 
for processing ,  such as pol l�ng , flushing data, etc . 
After the function is completed , the status is checked 
COMMAND 
Load 
Co mmand/ 
Da ta 
Pack e t  
G o  t o 
ISDATA 
Go t o  
FLUSH 
Go t o  
POLL IT 
Go t o  
JAMIT 
Go t o  
RESETR 
Figure 16. Command Cont ro l  Flowc hart 
4 1  
Start Address or 
Bit Data/Cornmand Bits 
7 Bits plus D/C Bit 
Start - Logic One 
D/ C - Logic One = Ccmnand l?acket 
Logic Zero = Data Packet 
A/D - Logic One = Address Packet 
Logic Zero = Data/Command Packet 
Stop - Logic Zero 
Tbtal of 11 bits/packet. 
I 
I 
I 
D/C I 
Bit I 
I 
I 
Figure 17. Network Packet Format 
42 
AID Stop 
Bit Bit 
43 
for change from the previous state. I f  a change has 
occurred , then the PC bus is given the respective flag 
andjor data. Now the wa iting for the next command 
starts again. 
3 .  FLUSHING DATA 
When flushing data onto the network from the 
NID , the address of the receiv ing node should al ready 
be in a variable. That address is first sent on the 
network to "wake-up" the receiving node , so it is 
ready to rece ive the incoming data packets. Next , a 
total byte count of the data i s  put on the network . 
This  conveys to the receiving node the quantity of 
data being transmitted. Then the queued data is sent 
onto the network. The general flowchart is shown in 
Figure 18. Flushing means to dump al l queued data 
onto to the network. There is another routine that 
speci f ically sends one packet o f  information to the 
rece iving unit , but this  uses a software loop to dump 
all  queued data. After the data is sent , then a zero 
checksum is sent i f  no errors occured in transmitting 
the data. The data can be a number of e l even bit 
Check 
Data 
Leng t h  
Send 
Address on 
Network 
Send 
Data 
By t e  
Count 
Send 
Data Pa c ket 
& Dec rement 
Byte Count 
No 
Return to 
Interrupt 
Go to 
. ERRORF 
Figure 18. Transmit Queued Data 
Send 
Checksum 
Receive 
Console_�.s 
Address 
Receive 
Byte 
Count 
Receive 
Checksum 
& Chec k 
44 
45 
packets but the checksum i s  just one packet as is the 
address . The transmitted checksum from the node 
should be zero. , if a l l  the data was received 
correctly. When 
command is used. 
rece iving and .sending , the 
It is a one byte command that 
TAAP 
sends 
register A contents to the address referenced in the 
command. The byte count is a control for how 
data loops to do. After a l l  data has been sent , 
many 
then 
the routine goes back to the ma in interrupt routine to 
wa it for another command from the PC. 
46 
4 .  NETWORK POLLING 
This code sends out a pol l to the requested 
node and waits for a reply from that pol led address . 
First , the address is  sent to "wake up" the receiving 
node . Then a zero data field and zero checksum is  
transmitted from the NID. Thi s  should generate a 
response from the rece iving node . The response must 
have a OOH hex address for the first packet , which is  
the NID's network address .  The next packet must have 
the byte count of the amount o f  data being sent . Then 
a loop is incorporated using the byte count packet for 
a control on the loop . Th·i s  loop reads in all· the 
data sent by the node . Numerous error checks are done 
in this , and every rout ine , to prevent faulty or· no 
data . A fl owchart is shown in Figure 19. 
) 
POLL IT 
S end 
N e t work 
Addre s s  
S end 
Z ero 
By t e  
Co unt 
S end 
Z ero 
Che c k sum 
Rec e ive 
Addre s s  
Pa cket 
Go to 
POLLTIHE 
Go to 
POLLERROR 
Go t o  
POLL ERROR 
B.e c eive 
Byt e 
Count 
Re c eive 
_ Dat a & 
Checksum 
F igure 19. Pol l ing N e two rk Fl owchart 
47 
48 
5. NETWORK JAMMING 
Generator content ion occurs when there i s  more 
than one node talking on the network at once. One 
solut ion to this network d i l ema i s  to jam the network 
with 512 bytes of "nothing" data. By the time 512 
bytes are sent , the network w i l l  be cleared because 
the set bits wi l l  eventual ly override every node 
contention. I f  the network i s  st i l l  jammed ,  then the 
PC is fl agged and a so ftware or hardware reset can be 
performed. 
6. NETWORK NODE RESET 
If a particular node has to be reset , then the 
NID f irst sends that node's address and then a reset 
command is transmitted. The node is then reset by the 
internal TMS70C02 processor and the node then remains 
"quiet" until "spoken" to. I n  the node , the processor 
cl ears all the ports on the proces sor and clears al l 
registers , so they contain no previous data. Keep ing 
this  in mind , a reset i s  not done l ightly , so the PC 
has control over a reset. 
B. OPERATIONS SOFTWARE 
Operations 
defining all the 
software i s  a very broad 
so ftware contained in the PC. 
49 
term 
Two 
main sections of so ftware are in the PC: the user 
entry program, and the NI D control program. 
1 .  USER ENTRY SOFTWARE 
The user entry code conta ins the software for 
entering and modi fying the voting member's names , and 
seat number. The names must be alphabetized and 
stored according to either the date or session number. 
This  type of entry and storage can be accompl ished in 
many ways. The method chosen uti l izes the c language 
cal l ing a util ity cal l ed Greenleaf Datawindows. These 
windows make menu driven data entry extremely easy. 
An example beginning menu i s  shown in Figure 20. 
Electronic Voting System 
Main Menu 
Names Editor 
Calendar Editor 
Heading Editor 
Network Test Mode 
Vote Period Open 
Vote Period Closed 
Exit 
Use Cursor Keys 
To Select 
The 
Program Function 
Needed 
F igure 2 0. Us er Ent ry Ma in Menu D i splay 
50 
5 1  
a. NAMES EDITOR 
When the . Names Ed itor is selected , program 
control goes to the menu in Figure 21 . In  this menu 
first the appropriate name file must be se lected , i f  
this i s  a n  option requested by the customer. After 
the file is selected , the program reads the file and 
displays the names , i f  any. The user selects a name 
to modi fy by moving the sel ect window with the cursor 
keys and presses "Enter". The name's information is 
then displayed on a window on the same screen. After 
changes are finished , the user presses "Fl" to accept 
the changes or "ESCAPE" to abort the changes. It wil l  
then return t o  the previous menu with the changes 
displayed on that menu. After al l changes have been 
made , the user presses "ESCAPE" to return to the 
menu. At this time , the names are sorted 
alphabetized and written back onto the file. 
menu system is very convenient for both. user 
programmer. 
ma in 
and 
This 
and 
F il e  Name : 
Seat No. 
Name s Ed itor Ma in Menu 
Last F irst 
U se Cur sor Key s 
t o  Sele c t  a 
Na m e  
Pre s s  En ter 
to Mo dify 
P r e s s  E s cape 
t o  Ex it 
F igure 21. Name s  E d itor M enu D isplay 
52 
53 
b. CALENDAR EDITOR 
The calendar editor i s  arranged very s imilar 
to the name editor , except that the user is  allowed to 
enter l ines of text l ike motions and b i l l s  that can be 
displayed or printed at the user request. The l imit 
on the length of text is usual ly dictated by the s ize 
o f  display used in the system. Three l ines by thirty 
characters is a common arrangement . Each entry can be 
stored by either sess ion numbe r  or date , and the user 
can save a number of files. 
c. HEADING EDITOR 
The heading editor i s  a lmost identical to ·the 
calendar editor , except that more text is typically 
a l l owed and the text is only printed on the top of the 
output l isting as a heading . A number o f  the calendar 
editor subroutines are shared b etween the heading and 
calendar editors. 
54 
d. TEST MODE 
When running the test mode , the PC has the NID 
test all the nodes or units on the network. The test 
insures that the consoles are responding correctly. A 
table o f  network addresses i s  stored in a file  on the 
PC . After selecting the test mode , the PC reads this 
file and proceeds to have the NID pol l  these addresses 
one at time. The pol l ing procedure is described in 
the NID so ftware section. If a node fai l s  to respond , 
then the PC is notif ied that the unit at that address 
is  faulty. The PC loops through all the network 
addresses that are capabl e  o f  generating a response. 
This test mode is j ust a general test and does not 
insure data integrity. 
55 
3 .  NI D CONTROL SOFTWARE 
After the voting period is  opened , the system 
should run automat ical ly . As soon as the voting 
opens , the PC must initial ize the consoles and 
di splays . This is accompl i shed by sending the open 
s ignal on the network to a l l  appl icable nodes . After 
that , the PC loops through a l l  the voting consol es' 
network addresses for a change in voting status . I f  
there i s  a change in status, the PC tal l ies the vote 
totals and displays the voting member's vote in the 
name display and . changes the vote totals display . 
This  is  done by flushing · the data as previously 
described in the software s ecti on o f  the NI D .  The PC 
conveys these total s  to the NID then the NI D puts the 
updated total s  to the correct d i splay addresses on the 
network . After updating i s  completed , the pol l ing o f  
the consoles continues from where i t  l e ft off . A 
general fl owchart is presented in Figure 22. . When the 
vote closed s ignal is sent , every console locks its 
input and then the PC pol l s  a l l  the consoles one last 
time and updates the displ ays , if  needed . This is  a 
very general outl ine o f  the rout ine that controls the 
Clear 
All Port s 
& Regi s t er s  
T o  The NID 
Send 
Vo t e  Open 
Signal 
To All Node s 
Pol l The 
Next 
Net work 
Ad d re s s  
Poll All 
Nodes Once 
More & 
Update Displa 
Total 
The 
Vote Tally 
Send 
Vo t e  In fo. 
To The 
Displays 
Figure 2 2 .  NID Run t ime Sof t ware 
56 
5 7  
system , because this program varies for di fferent 
customers . For instance , print ing of the vote totals 
and heading can be done at the end of each vote 
sess ion or at the end of the day or at other spec ified 
times . 
58 
C .  VOTING CONSOLE SOFTWARE 
So ftware for the voting console i s  yet to be 
completed as of S eptember 1987 , but the requirements 
wil l  be outl ined here . A general flowchart is  given 
in Figure 23 . The major components o f  this  software 
are the network so ftware , the LCD control software , 
and the magnet ic card reader control software . 
1 .  NETWORK SOFTWARE 
First , the interrupts are set for the magnetic 
card reader . The enab l e  p in is connected to interrupt 
#1 and the strobe pin to interrupt # 3  on the TMS70C02 
processor . Then , at power up or at a reset condition , 
al l ports and registers are cl eared . The TMS70C02 
then loops through the network port address searching 
for its own console address . Thi s  is accompl ished by 
checking the eighth b it on the packets . I f  th i s  b it 
is set , the packet is an address and is then 
to the console ' s  own address , which is a 
compared 
hardwired 
address us ing a DIP switch in each console . The 
switch is connected 
CONS OLE 
C l ea r 
All Po r t s  
& Reg i s t er s  
& D i sabl e 
I n t errup t s  
Che c k  
Netwo rk fo r 
Ad d r e s s  
P a c ket 
Re c e iv e · & 
Che c k  
Byt e Co un t 
No 
o n t o  N e t wo r k  
Go t o  
S UMERROR 
Re c e iv e  
Dat a  & 
Che c ksum 
Z ero 
Checksum & 
Hand l e  Dat a  
Figur e 2 3 . Vo t in g  Co n so l e  S o f twa r e  
5 9  
60 
through a multiplexing chip and into port B on the 
processor. So the comparison is between the rece ive 
buf fer and port B .  I f  the comparison i s  exact , the 
console waits for the next packet which contains the 
byte count for the numbe r  o f  data packets. Then the 
data is read into the processor us ing the byte count 
as the control for the l oop. I f  the address rece ived 
is correct , but the data is zero then this is a pol l  
from the NID ,  andd the conso l e  must answer with the 
present voting status o f  the console. The last packet 
read into the console is the checksum. It should 
conta in a total . count o f  al l bytes sent to the 
console. I f  the checksum · is wrong , then a status 
error is sent to the NID. The NID wil l  see the error 
in the pol l ing routine and flags the PC. Most o f  the 
error checking is to aid sett ing up the system and 
insure data integrity. 
6 1  
2. LCD CONTROL SOFTWARE 
The liquid crystal d isplay is an option for 
all consol es , therefore the controll ing so ftware is 
discussed here . The LCD cons idered is the Hitachi 
LM054 .  It i s  an e ight character by one l ine display 
with approximately one-hal f  inch character height. 
The bas ic principle o f  the program is  that 
when a switch is depressed , the processor accepts the 
switch status and sends out the corresponding 
character codes t.o the LCD driver ( HD44780) . This 
particular driver contains 1"80 characters internally. 
The LCD'S data bus is connected d irectly to the 
TMS70C02 bus on port A ,  so when a switch is depressed 
the procesor sends out the appropriate sequence. 
First ,  the enable line i s  taken low. The read/write 
l ine is then taken low. Now , the LCD is ready to 
receive the character codes .  This  is a very straight 
forward display approach , whi ch is the reason it was 
chosen . 
62 
3. MAGNETIC CARD READER SOFTWARE 
The card reader is  controlled by interrupts on 
the console processor . It i s  connected to the f irst 
and third interrupt l ines , so that if the reader has a 
card pass through it, the processor program is  
interrupted and program control goe s to this sect ion 
o f  software . The card present l ine is connected to 
interrupt #1 and when that goes low , the procesor w i l l  
know a card is present . Interrupt l ine # 3 ,  the strobe 
for the reader , tel l s  the TMS70C02 when each data bit 
is on the bus . A t iming diagram is shown in Figure 
24 . If the address read o f f  the magnet ic card equal s  
that o f  the preset address i n  the console ,  the console 
is unlocked for vot ing , provided the voting period is 
open . There is an opt ional t iming loop to close the 
console automat ical ly to avo id extra voting . 
Therefore this magnetic card reader option gives two 
lock-outs .  
C"' 
\0 
c A R o  P R E s E N T  ( Signal Timing Diagram 1 
o 0 I' I I I 1 1: DATA I I I t I' ' ' : I ' : I ' : 
1 I I I 
1 I I 1 1 
I I 
(I (J 0 0 (., (J 0 0 
I I I I 
I I I 
ST A0£3E 
I I I 
I I I I I
I : I I I I 
F igur e 24. Magnet ic Card Reader Tim tng 
..r.�, .. - - ' 
64 
D .  DISPLAY INTERFACE SOFTWARE 
The wal l  display interface uses a data shift 
technique , so all the data must be placed in the 
correct sequence before being sent to the actual 
displ ay. This is the main purpose o f  the TMS70C02 in 
this interface des ign. I t  arranges the data according 
to the placement of the name on the display . When the 
displ ay network address is on the network , the 70C02 
gets the data s imilar to the other nodes previously 
discussed. After receiving the data , it sets up a 
sequence and sends it to the name display . The name 
display has a shi ft register associated with each name 
module on the display , so that when the data sequence 
comes to the module it is shifted down to the next 
module until the strobe sequence l ine is taken high . 
Then the data is shi fted out to the actual power 
trans istor circuit to il luminate the correct l ight. 
V .  CONCLUS ION 
65 
This thesis has i l lustrated the fleasabil ity of 
us ing a RS-485 network in an eletronic voting system. 
Thi s  approach multiplexes the data onto a balanced 
two-wire network with the vot ing consoles and displays 
being nodes on the network and the NID control l ing the 
network. This design repl aced a more expens ive system 
that did l ittle multiplexing and was difficult to 
instal l. 
The most difficult problem was locating and 
choos ing critical components·. These components must be 
cheap , rel iable ,  and compatible with present and future 
des igns and options. Thus , cons iderable thought . went 
into the sel ection of certa i n  components. 
I 
/ 
APPENDIX A :  TMS70C02 MICROPROCESSOR 
66 
The TMS70C02 is an 8-bit , CMOS microprocessor that 
conta ins 256 bytes of on-chip RAM , a serial port , three 
t imers , and 32 I/O l ines. It features register-
to-register architecture that a l l ows direct arithmetic 
without using an accumulato r . 
The TMS70C02 uses 20 o f  the I/O l ines for address , 
data , and bus control . This makes the TMS70C02 ideal 
for large ROM appl ications. 
The TMS70C02 is a l ow cost microprocessor that is  
suited for low power operations . Being CMOS , the 
processor has a high noise immunity with wide operating 
conditions . The voltage range, Vee , is 2 . 5v to 6 . 0v ,  
while the frequency range i s  . 5MHz to 6 . 0MHz. 
. �  
6 7  
A pinout o f  the TMS70C02 is shown i n  Figure 25 
below and a funct ional block diagram is shown in Figure 
26 . 
B 5 · R W 
8 7 :C L K O UT 
BO ·T 2 0 U T  
8 1  -1 1 0UT 
82 
AO 
A 1  
A 2  
A 3  
A � iSCLK 
A 7 1E C 1  
I N T 3 
INT 1 
R E SET 
A6/EC 2 
A 5 lR X D  
X T A L 2 lC L K I N  
XTAL 1 
0 7  
0 6  
N PACKAGE 
(TOP VIEW ) 
V s s 
8 6 .:-:E N�. A.,....,E,_.L-=E 
84/A LA T C H  
8 3 :T X O  
M C  
C 7  
C 6  
c s  
C4 
Figure 25 . 1MS70C02 Pinout 
1 
./ 
� - � � - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ,  
I RESET' 
m­ , �  
iN iT J  l I 
I 
I 
I 
I 
_rl 
I N T E R RUPT 
CONTROL 
, 
8 -BIT 
C PU 
L D I O S C I L L A T O R  
--q 
XTA 
I - -j 
INT4 
I N T S  
- INT2 
R A M  
2 5 6  BYTES 
. 
. 
�: ) 
P E R I P H E R A L / M E M O R Y  
�: C O N T R O L  
� 
RO M 
4K B Y T E S  
T i M E q  3 
r-r-r/' SERIAL 1 1 0  POR T  
j 
TX AX S C LK 
1 
i 
.;1 PO�T A 
L 
� PORT 8 
T 1 0UT 
T 20UT 
� 
TIMER/  TIMER/  
EVENT EVENT 
'__) COUNTER 1 COUNTER 2 A N D  A N D  
CAPTU R E  CAPTURE 
LATCH LATCH 
l l INT3 IN T 1  
� PORT C 
' l 
i PORT 0 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
l/ r 8 110 LIN E S :  
�C LK/RX FUNCTION: 
I 
I 
I J 
I 8 OUTPUT LIN ES/TXt 
j TIMER OUTPUTS 
I 
� 8 1 1 0  LINES > 
� 
K---8-1-, 0-L-IN_E_S _ __,) 
- -MOO 
CONTROL L -- - - - - - -- - - - - - - - - - - - - - - - -- - - - -- - - - - - - - - 1  
F igur e 2 6 .  TMS 70 C0 2  Block Diagram 
0"1 
co 
/._,�:.._ ... ' 
APPENDIX B :  DS 3695 BUS TRANSCEIVER 
69 
The DS 3695 is a h igh speed , differential , three 
state bus transceiver that is des igne� to meet the EIA 
standard RS-485 for mul tipoint data transmiss ion with 
a common mode range of + 12V to -7V. 
Bus contention or fault s ituations are handled by 
a thermal shutdown circuit that forces the device into 
a high impedance state. 
The temperature operating range is over o to · 70 
degrees Celcius at a supply voltage range o f  4 . 7�V to 
5 . 25V. The device has a m inimum receiver input 
impedance o f  12000 ohms. 
70 
REFERENCES 
EIA Standard RS-485 , E lectronics Industries 
Associat ion , April 198 3. 
Hitachi Liquid Crystal Displays , Hitachi Ltd . , Japan , 
1985 , p .  240 . 
IBM Annoucment and Specificati on Sheets , I nternat ional 
Bus iness Machines Corporati on , 1987. 
IC  Memories , Hitachi , September 1987 , p. 152 . 
Interface , Nat ional Semiconductor Corporation , 1986 , 
p .  1-79 .. 
Moore , Programming In C ,  Prent ice-Hall , 1985 . 
MT-211 Appl ications , Magtek Incorporated , Carson , 
Cal ifornia , 198 7. 
TMS 70C42/TMS70C02 CMOS . Microprocessors , Texas 
Instruments ,  Houston , Texas , 1986 , pp. 1-5 . 
71 
VITA 
Thomas ·Alan Liebsch was born in Brookings , 
South Dakota on July 30 , 196 3 ,  the son of Don and Jean 
Liebsch . 
Mr . Liebsch enro l l ed at South Dakota State 
Univers ity in Brookings in the fa l l  of 1981 , maj or ing 
in Electrical Eng ineering . He received a Bachel or o f  
Science degree i n  El ectrical Engineering with minors 
in Math and Computer S cience in May , 1985. He 
enrol led in graduate schoo l  at S DSU in the fa l l  · o f  
1986 , and rece ived a Master o f  Science degree i n  
December of 1987. 
From May , 1985 to August , 1986 , Mr . Liebsch was 
employed by the Boe ing Commerc ial Airpl ane Company at 
the Fl ight Test Cal ibration Laboratory in Seattl e ,  
Washington . Wh ile at Boe i ng , he helped ma inta in and 
implement new Digital Equipment Corporation computers 
and instal led an Ethernet network . These computers 
were used for the cal ibrat ion o f  equipment on Boeing 
airpl anes . 
