The development of a distributed interfacing system by Gray, Peter
Durham E-Theses
The development of a distributed interfacing system
Gray, Peter
How to cite:
Gray, Peter (1986) The development of a distributed interfacing system, Durham theses, Durham
University. Available at Durham E-Theses Online: http://etheses.dur.ac.uk/7028/
Use policy
The full-text may be used and/or reproduced, and given to third parties in any format or medium, without prior permission or
charge, for personal research or study, educational, or not-for-proﬁt purposes provided that:
• a full bibliographic reference is made to the original source
• a link is made to the metadata record in Durham E-Theses
• the full-text is not changed in any way
The full-text must not be sold in any format or medium without the formal permission of the copyright holders.
Please consult the full Durham E-Theses policy for further details.
Academic Support Oﬃce, Durham University, University Oﬃce, Old Elvet, Durham DH1 3HP
e-mail: e-theses.admin@dur.ac.uk Tel: +44 0191 334 6107
http://etheses.dur.ac.uk
The Development of a Distributed 
Interfacing System 
by 
Peter Gray, BSc. 
The copyright of this thesis rests with the author. 
No quotation from it should be published without 
his prior written consent and information derived 
from it should be acknowledged. 
A Thesis submitted in accordance with the regulation for the degree of 
Master of Science in the Department of Applied Physics and Electronics at 
the University of Durham. 
May 1986 
ABSTRACT 
The Thesis submitted describes the origins and development of an industrial 
distributed interfacing system. The component modules of the system are 
described individually and sample flowcharts and software listings are 
provided. 
ACKNOWLEDGEMENTS 
The author would like to acknowledge the assistance and support for this 
project given by the staff of the University of Durham, especially 
Professor G.R. Roberts (now at Oxford University) and Professor T. 
Spracklen (now at Aberdeen University), and also by the management and 
staff of Glaxo Pharmaceuticals (referred to herein as 'the Company'). 
Special thanks are due to Messrs W.H. Presley and R.A. Pearson of the 
Company's Management Services Department for approving the project 
development and granting permission to submit this Thesis, to my immediate 
superiors Messrs J. Howe and J. Prytherick, to Messrs H.G. Myatt and 
L.Rodrigues for checking production drawings, and to Mr R.W. Atkinson, who 
developed professional working systems from the test software described in 
this document. My thanks are also due to Messrs J.M. Wood and S.M. Wood of 
Labcon Ltd. (referred to herein as 'the Contractors') and to Messrs I. 
Robertson and J. Williams for prototype layout and much stimulating 
discussion, and also to Mr R.J. Hickson (now with R.J. Designs, Shildon) 
for producing the CAD artworks for production boards. 
Chapter 1 
II 
II 
II 
II 
II 
II 
II 
II 
2 
3 
4 
5 
6 
7 
8 
9 
References 
Appendix 1 
II 
II 
II 
II 
II 
II 
II 
II 
II 
II 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
CONTENTS 
Introduction 
The Pilot Scheme 
The Expanded System 
Memory Expansion 
Communications Interfaces 
Serial Port Interfaces 
The Analogue Board 
Running MCS BASIC-52 On the System 
Project Review 
Crystals/Oscillator Components 
Pilot Scheme Data 
The 8751 Serial Port 
HPIB Overview 
Features of the 8748 
BCD Board (Testing/Firmware) 
A Sample HPIB-RS232 Converter 
The 8052-BASIC CPU 
Serial/DART Board Functions & Options 
Power Supplies 
Details of RAM Memory Devices 
1 
6 
23 
53 
63 
86 
104 
114 
127 
132 
134 
147 
158 
163 
168 
169 
173 
176 
182 
187 
189 
Figure 2.1 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
II 
2.2 
2.3 
2.4 
2.5 
2.6 
3.1 
3.2 
3.3 
3.4 
3.5 
3.6 
4.1 
5.1 
5.2 
5.3 
5.4 
6.1 
6.2 
6.3 
7.1 
7.2 
7.3 
8.1 
LIST OF PLATES AND ILLUSTRATIONS 
Pilot Scheme - Schematic 
Power Supplies 
Schematic Diagram of a Node 
The NE567 Configured as a PLL 
II II II II vco 
7 
10 
11 
14 
17 
Circuit Diagram of a Node 18 
Backplane Connector Pin-out 26 
8751 Pin-out 28 
Timing Diagram for External Memory Access 30 
CPU Board Circuit Diagram 32 
DVI Board Circuit Diagram 40 
Watchdog Board Circuit Diagram 45 
RAM Board Circuit Diagram 58 
HPIB Board Circuit Diagram 65 
BCD Board Circuit Diagram 72 
UART Board Circuit Diagram 76 
Schematic Diag. Showing HPIB Board Testing 80 
Serial Board Circuit Diagram 90 
R.F. Board Circuit Diagram 95 
Schematic Diag. Showing R.F. Board Testing 101 
Analogue Board Circuit Diagram 109 
Measured ADC Response 110 
Test Rig for ADC Evaluation 111 
Port 1 Monitor Breadboard & Audio Monitor 124 
Figure Al.l CPU Oscillator Tests 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
" 
Plate 
II 
II 
II 
" 
" 
" 
II 
" 
" 
II 
Al. 2 
A2.1 
A2.2 
A2.3 
A2.4 
A2.5 
A2.6 
A4.1 
A6.1 
A6.2 
A7.1 
A8.1 
A9.1 
A9.2 
3.1 
3.2 
5.1 
5.2 
6.1 
6.2 
7.1 
8.1 
8.2 
8.3 
8.4 
CPU Clock l.Javeforms for 3 Selected Xtals 
VCO Freq. Variation with Mod. Voltage 
Serial Data l.Javeforms 
Flowchart of Polling Firmware 
II 
" Monitoring Node Firmware 
II 
" Subroutine "NOUT" 
" " Subroutines "INCH" & "OUCH" 
HPIB Schematic 
Schematic of 8748/8751 Interaction 
II II 8748/8243 Firmware 
II II HPIB to RS232 Converter 
II 
" a Typical BASIC-52 System 
Current Loop Configurations 
UART Initialization Sequence 
The Sub-Miniature Rack 
The DVI Board 
The HPIB " 
The BCD " 
The Serial Board 
The R.F. Board 
The Analogue Board 
Alternative CPU Chips 
The 'BASIC' System Configuration 
MCS BASIC-52 Running On the System 
The Port 1 Monitor Breadboard 
135 
136 
148 
150 
154 
155 
156 
157 
164 
170 
171 
174 
177 
183 
184 
24 
24 
70 
70 
87 
87 
107 
116 
1-16 
119 
119 
CHAPTER 1 - INTRODUCTION 
As the world's population becomes increasingly dependent on manufactured 
goods, so the trend towards industrial automation in manufacturing industry 
becomes more dominant, and the demand for plant monitoring and control 
equipment increases. The introduction in the 1960's of minicomputers such 
as the D.E.C. PDP-8 into industrial applications greatly extended the scope 
for monitoring and control of industrial plant. For the first time a 
flexible controller, for example, could be realized; the hard-wired 
dedicated machines, often based on wired core storage technology, rapidly 
fell into disfavour. Purpose-built electronic devices began to be 
displaced by general purpose computer based units; traditional analog 
equipment was often superseded by digital hardware. The introduction of 
microprocessors in the 1970's, with the corresponding increase in the 
performance/cost figure, increased this trend towards computer-based line 
monitoring/control equipment. 
The author, who has worked since the 1960's on monitoring/control 
projects, currently works for a large international company, dealing with 
problems relating to the various hardware/software aspects of the 
monitoring and control of industrial plant in the Company's U.K. sites. 
The Company, which has a heavy financial investment in both "mainframe" and 
microcomputers, has a logical policy of single source supply from a major 
American manufacturer. This policy, as well as being financially sensible 
as regards bulk purchase discounts etc., also has the advantage of avoiding 
the familiar pitfalls of the multi-vendor situation. Thus, when 
considering purchasing monitoring/control equipment to link, for example, 
sensors on a production line to a microcomputer, the natural first choice 
of supply was the approved computer manufacturer mentioned above, who is 
also a major manufacturer of laboratory instrumentation equipment. 
- 1 -
As an aid to this general discussion on line monitoring, (for brevity we 
will adopt the term "line monitoring" as a convenient - though rather glib 
- phrase to reference all areas of the fields of monitoring and control of 
industrial mechanization) it is perhaps useful at this stage to catalogue 
the various factors relating to the choice of monitoring equipment. These 
are as follows:-
* Cost 
* Single supply source 
* Software/firmware programmable 
* Versatile range of input/output options 
* Good noise immunity 
* Networkable 
* Easily interfaced to computers 
* Compact, rugged construction 
* Ease of maintenance 
Cost, of course, is often the overriding factor that governs the choice 
of any equipment to be purchased. If, as in this case, the equipment may 
be duplicated many times in different sites, the total capital expenditure 
over a period of time may be very large. Conversely, for small projects 
with tight budgets, the price/performance ratio for the equipment to be 
purchased will frequently determine the scope of the project, and may tip 
the balance between success or failure. Another factor which determines 
the successful outcome is the maintainability of the equipment - which can 
become a major problem in multi-vendor situations, as indicated earlier. 
Digital or analogue signals that the monitoring equipment may need to 
process can be of many different types. For example, analogue signals may 
take the form of either currents in the range 4-20 milliamps or voltages in 
the range 0-10 volts. These are two commonly used conventions, although 
the analogue signals may not conform to either - e.g. thermocouple outputs. 
A similar situation also arises when digital signals are considered. 
- 2 -
A common method of digital signalling (for example, the output of an 
industrial optical sensor) is to interrupt a closed current loop system; 
switching devices commonly encountered may be new technology solid-state 
devices, such as Hall Effect S\vitches, or more traditional electrical 
hardware - e.g. relays or reed switches. Ideally, as well as supporting 
digital switching signals conforming to the standard industrial protocols, 
equipment should also have the ability to communicate with (possibly) 
remote computers or microprocessors. To achieve this communication, the 
equipment should be capable of supporting a number of interface protocols, 
such as RS232C, IEEE488 (HPIB), 20mA current loop and (preferably) a 
networking protocol - which would allow a number of monitoring "nodes" to 
be networked with a host computer. 
For maximum versatility of application, monitoring systems should be 
software or "firmware" based (the latter term is generally used in 
connection with EPROM as opposed to RAM storage). This allows, 
possibly, the internal program to be replaced by another program, allowing 
the equipment to perform a different task. Another possibility is that the 
user may wish to vary program parameters, while keeping the basic program 
task the same. Such an occasion arises when a device is required to scan a 
different (or extra) channel or sequence of channels. 
Perhaps the greatest single source of problems concerning purchased 
equipment is the possibility of error due to it's lack of resilience to the 
stresses imposed on it by the working environment - the major sources of 
stress frequently being mechanical vibration and electrical noise. "Noise" 
invariably takes the form of large mains born "spikes" (often, say, 40dB in 
excess of the signal levels inside the equipment), although electromagnetic 
induction can also cause problems. Manufacturers equipment, often 
demonstrated by sales staff in an office environment, can sometimes prove 
- 3 -
disastrous in performance when sited on an industrial production line, next 
to heavy electrical machines. Mechanical stress can take the form of 
prolonged vibration, or sudden, perhaps violent, jolts. Thus equipment 
must be rugged, compact and generally mechanically sound. Additionally, it 
should preferably be constructed in a modular easily maintained manner 
(such as the standard Eurocard system - which also has the advantage of 
allowing incorporation into other manufacturers racking systems). A 
modular approach further extends the range of applications, as discussed 
later in this introduction, and it also means that spare modules can be 
held on-site, whilst a complete integrated unit may be prohibitively 
expensive to hold in stock. 
Having considered all these factors outlined above, the Company examined 
the market for potential suppliers, the first choice being the approved 
manufacturer, mentioned earlier. A limited range of equipment was 
available, but it was prohibitively expensive, and required an external 
controller in the form of a desk- top type microprocessor. A networking 
system was available, but this was again very expensive, and failed to work 
when demonstrated. Thus the Company began to look elsewhere for sources of 
supply. 
Several companies were able to offer systems that partly fulfilled the 
requirements outlined above - a considerable number of companies are in the 
process control/industrial automation market, offering expensive and 
inflexible "turnkey" systems. The products of a smaller number of firms 
who manufacture rack based interface systems (typically "Eurocard" based) 
offering a (limited) range of plug- in options were examined, but the 
systems offered were either biased towards "low noise" environments or 
lacked the required networking capability. A possible hybrid system was 
considered - that is to say that it was envisaged that the total equipment 
could originate from two independent suppliers, the interface equipment 
- 4 -
being supplied from one source and the networking equipment from another. 
However, apart from defaulting on the single-source requirements, it did 
not prove to be a viable alternative economically. Those networking 
systems that possessed good noise immunity were, inevitably, amongst the 
most expensive available. 
Faced with the possibility of having to purchase multi-sourced expensive 
equipment lacking some of the features required, the Company then 
considered the possibility of developing it's own; although the Company 
lacked the facilities to manufacturer in quantity it's own equipment, it 
was felt that if a prototype design could be developed and proven in a 
pilot scheme, then the equipment could then be manufactured by an external 
contractor. The author was approached to develop the prototype equipment 
for the pilot scheme, which is described in the next chapter. The thesis 
proceeds, in further chapters, to narrate how the full Distributed 
Interfacing System was developed from this successful initial scheme. 
- 5 -
CHAPTER 2 - THE PILOT SCHEME 
The initial scheme chosen to test the viability of a subset of the 
proposed hardware was a three 'node' system used to monitor an ageing 
production line in one of the Company's North of England sites, the 
aim of the scheme being to pin-point troublesome areas within the line 
by recording fault indications. A distributed system was preferred to 
a centralized system, in order to minimize cabling to sensors, thus 
saving installation effort, and reducing the risk of noise pick-up. A 
schematic diagram is shown in Figure 2.1. The three nodes are 
represented Nl - N3, a fourth node (Nc) is also shown - this being the 
'controller', as explained later; a microprocessor node (Nm) connects 
an HP-85 (Hewlett-Packard desk-top computer) to the system. Standard 
M-70 75 Ohm coaxial cable was used as the interconnecting medium, for 
economy. 
2.1. The 8751 Single Chip Microprocessor 
To minimize size and to keep printed circuit board (PCB) 
layouts simple, a decision was taken to base the circuit design 
of the node hardware around a 'single chip' microprocessor. 
Such a device contains the central processing unit (CPU), 
memory typically erasable programmable read only memory 
(EPROM) and some random access memory (RAM) - and input/output 
hardware, in a single package. Several such devices were at 
that time available, but the chip selected, the Intel 8751, was 
unique in that it featured an on-board full duplex DART 
(Universal Asynchronous Receiver Transmitter). 
below lists the major features of the device. 
Table 2 .1. 
Reference 1 
contains a full description of the MCS-51 family, of which the 
8751 is a member. 
- 6 -
s s s 
Ni N2 N3 Nc 
T J T 
--..J S = 16 Sensor Inputs 
T = 75 Ohm Line Terminator Nm 
C = HP85 Microcomputer 
c 
Figure 2. i Pilot Scheme - Schematic 
TABLE 2 .1. 
~'r Eight-Bit CPU with hardware mult./div 
* Four Eight-Bit I/0 ports 
* 4K Bytes of EPROM 
~'r 128 Bytes of RAM 
* Full Duplex UART 
* Boolean processor 
* Two Sixteen-bit Timers 
* Multiplexed Sixteen-bit Address/Data Bus 
The Major Features of the Intel 8751 Microprocessor 
For the pilot scheme, the full capability of the chip was not 
exploited. The eight-bit internal architecture was considered 
adequate, as was the number of input/output ports; indeed only two of 
the ports were used for data transfer, as we shall see later in the 
chapter. (Chapter 3 gives details of the 8751 facilities not relevant 
to this chapter, and also provides a pin-out diagram- Figure 3.1.). 
The UART was of immeasurable value to the author in the early 
'breadboard' stages of the design work, as it allowed the connection 
of serial devices (e.g. computers, printers, visual display units 
[VDU's]) as test units. However, the fact that the UART is an 
integral part of the 8751 does have its disadvantages - mainly because 
the UART is timed from the microprocessor's on-board oscillator 
(master clock), which is referenced to an external crystal. Appendix 
1 discusses in detail aspects of the oscillator circuitry and lists 
the baud rates available from the 3.6864 MHz and 7.3728 MHz crystals. 
Early versions of the 8751 were available with a maximum clock 
frequency of 8 MHz, effectively limiting the clock frequency to a 
maximum value of 7.3728 MHz. 
The author had some in-depth discussions with the Intel support 
staff as regards the preference of oscillator components (discussed 
- 8 -
more fully in Appendix 1). The accuracy of the serial data timing is 
wholly dependent on the stability of the clock circuitry; Intel's 
recommendation of the use of the on-chip Pierce oscillator with the 
minimum of external circuits led to the requirement of purchasing 
crystals quoted for parallel resonance. These were obtainable 'off 
the shelf' from component suppliers for the 3.6864 Mhz frequency, and 
therefore · this was selected as the operating frequency for the 
hardware described in this chapter. The need for special clock 
frequencies (and non-standard crystals) is a disadvantage the 8751 
incurs by supporting the on-board serial facilities. Another 
disadvantage is the implied inability to 'hesitate' the CPU clock - a 
matter discussed in Chapter 3. 
Other features of the 8751 listed in Table 1, although of great 
value in pursuing development work (described in the later chapters of 
this thesis), were not exploited in the preliminary work. 
2.2. Design Criteria (node units) 
Having thus selected a suitable intelligent device around 
which to base the design, the author then turned to the problem 
of isolating the total design requirements, i.e. determining 
the design 'goals'. These are summarized in Table 2.2. below: 
TABLE 2.2. 
* Sixteen opto-isolated inputs per node 
* Single 5v supply 
* High noise immunity 
* Serial half-duplex data transmission 
* Minimal cost 
* Minimal software/firmware 
* Simple PCB artworks 
* Watchdog on-board 
* Rapid development 
Design goals for initial development work 
- 9 -
_, 
0 
L 
E 
N 
F1 
(Filter) (Sub-Minature Supply) 
Figure 2.2 - Power Supplies. 
.-------±i2v 
±5v 
~~ 
" 
.. N 
,.,___ 
...... 
...... 
EXTERNAL DC SUPPLY 
:-·-·-·-·-·-·-·-·-·-B-·-·-·-·-·-·-·-·-·l I . 
. I I . 
I FILTERING/ I I . I NOISE SUPPRESSION i 
. ~ I . 
I r/SMOOTH 5v DC SUPPL~ I 
I . 
. I I . 
. I I SERIAL . 
I LINE CIRCUITS < DATA ) CPU BOARD ~ 
. I I . 
. I 
I ~ . . UNE SIGNALS IL·-·-·-· . ·-·-·-·-·-·-·-·-·-·-·-·-·-·-·____; 
Figure 2.3 - Schematic Diagram of a Node. 
PADDLE I~R 
BOARD I~ 
The rest of this chapter narrates the author's attempts to 
meet these design goals for the trial system, and summarizes 
the achievements and the lessons learnt. The Thesis continues, 
in the subsequent chapters, to outline the development of the 
complete Distributed Interfacing System. 
2.3. Power supplies 
Great attention was paid from the early stages onwards, to 
the elimination of noise 'spikes' from the electronics. As 
stated earlier, the transients may be either induced or 
mains-born - in the latter case most of the transients may be 
eliminated by a conventional commercial mains filter, although 
such a filter may prove to be incapable of eliminating 
completely the largest spikes. 
The technique adopted in this prototype system was to filter 
the mains supply as described, using a Belling-Lee (model 
L2140/2L) mains filter, before converting to Sv DC using an 
inexpensive (Farnell DS-OSA) sub-miniature power supply (see 
Figure 2.2.) - and then to attenuate the remaining transients 
to an acceptable level. Figure 2.3. shows the schematic 
diagram for each (nl, n2, n3) node; the power (Sv supply) 
arrives on the board at a central location, where it is further 
smoothed by series RF chokes, a large (100 micro-Farad) 
reservoir capacitor, and finally a solid-state transient 
suppressor. It is then fed from this central point to the 
various circuits in the node. Most of the circuitry of the 
prototype nodes was located on the main printed circuit board 
(PCB), with the 8751 CPU and its associated oscillator and 
reset circuits located on a small 'Piggy-back' PCB. 
- 12 -
~.4. Line circuits 
The need to transmit a serial data stream over long 
distances (several hundred metres) in an electrically hostile 
environment requires more than a simple amplitude modulation 
system such as, say, RS232 or 'r'l'L with line drivers. 'l'he 
commercially available option that springs immediately to mind 
is the modem; the essence of this device is to generate one of 
two ·basic frequencies according to the logic state of the 
incoming (TTL) signal i.e., two-state frequency modulation 
(FM). At the receiving end of the transmission line the signal 
is demodulated (hence the name, MODulator-DEModulator), 
typically by a phase-locked-loop (PLL), to recover the original 
TTL signal. 
To design a miniature modem is not a difficult task, as 
several suitable PLL's are available, the most commonly used 
being the Signetics NE565. This chip has two disadvantages, 
firstly it requires a dual voltage power supply, and, secondly, 
it is inefficiently packaged. A suitable alternative is the 
NE567, an 8-pin device requiring only a single 5-volt supply. 
This chip is frequently used as a tone decoder, but has 
sufficient bandwidth to decode serial data transmitted at rates 
of the order of 10 kilobaud. 
The 567 has an open collector output; the output transistor 
is driven into saturation whenever a tone of the correct 
frequency is present at the input. Figure 2.4. shows the 567 
in its usual use as a PLL; the resistor-capacitor combination 
- 13 -
Cc 
4 
3 lnpu~ 
Ri, C1 
are Timing 
Components 
5 NE567 !} 
A 1 
~ 
2 7 1 
Ci C2 C3 
Output 
Filter 
Low Pass 
Filter Q-
Figure 2.4 - The N E567 configured 
As a Phase Locked Loop. 
- 14 -
+5v 
load 
,.. 
Outpu t 
determines the centre frequency, while external capacitors 
adjust the loop capture range and the output .filter response. 
With a suitable pull-up, the output is TTL compatible. The 
output is then at logic '1' state when the loop is idle, and at 
logic '0' when locked onto a tone of the correct frequency. 
Thus if we consider a transmission system that 'tone-bursts' on 
logic '0' s only, then clearly a '567 can decode the incoming 
signal into a form immediately presentable to the serial input 
of an 8751 microprocessor. This is the basis of the 
transmission system implemented. 
The 567 is a versatile chip enabling, for example, the 
independent use of the on-board voltage controlled oscillator 
(VCO) for other purposes. This versatility permitted the use 
of the VCO as an inexpensive tone burst generator, thus 
allowing the same type of chip to be used as both the encoder 
and decoder of the line signals. Figure 2.5. shows the basic 
VCO circuit, which together with the PLL circuit originates 
from the Signetics application notes (Ref. 2). These circuits 
configured for a centre frequency of approximately 200 KHz (See 
Appendix 2) are incorporated unmodified (excepting the addition 
of supply trimming potentiometers) into the circuit shown in 
Figure 2.6. The buffered serial data stream is used to pulse 
the oscillator and generate the logic 'O' tone bursts. 
The output of the VCO is a pulsed 200KHz square wave, which 
is TTL compatible, and can be buffered by a conventional TTL 
line driver, in this case the Texas 75123. The 75123 is used 
to drive a 75ohm coaxial line, terminated at the characteristic 
impedance. The serial data stream is also used to gate the 
- 15 -
line driver, floating it's open-emitter output on logic 'l's -
the normal state for an idle transmitter - and allowing other 
nodes to transmit. 
The line receiver circuit is the 567 configured as a PLL, as 
already described. The minimum values for the two external 
capacitors (input/output filters) were calculated from the 
formulae supplied with the Signetics application notes, and 
were found to give the best performance for noise rejection. 
Note that the PLL is used to detect tone bursts that occur 
during the periods corresponding to logic zeros in the original 
TTL signal; when the '567 detects a tone burst its output is 
driven LOW. The external pull-up guarantees the logic one 
state during the absence of the tone-bursts, which of course 
includes the line idle condition. 
2.5. CPU sub-board 
The 8751 CPU and its associated reset and oscillator 
circuitry, together with connectors etc., were mounted on a 
miniature pre-prepared PCB sub-board, which the author designed 
for earlier 'breadboard' tests on the 8751. The use of this 
item as a circuit component eased the development task. The 
sub-board was mounted on the main PCB by means of short 
'stand-offs', both boards being enclosed within a small 
die-cast box. The sub-board's 20-way connector allowed a 
ribbon cable connection to an external 'D' socket mounted on 
the lid of the box. This enabled data input from the 
opto-isolating 'paddle board' (see below) to be routed to the 
microprocessor input ports. Only two of the three general 
purpose ports were used on these prototype nodes as input 
- 16 -
Ri, C1 
are Timing 
Components 
vco 
Terminal 
4 
N/C 3 
5 NE567 
R1 
G 
2 7 
Ci 
Figure 2.5 - The N E567 configured 
As a Voltage Controlled Oscillator. 
- 17 -
Output 
. co 
WD 
UJlt 
(Une Gating) 
1/41LQ74 
~ 
I -
- ... 
161nput -
Unes 
(Qpto-
lslolated 
as above) J 
Paddle Board 
NOTES. 
o.47u 
--o<'LS14 
O.tu _I_ VCO 
~ 
8 1 40~ 
10k E 
16 8 
~ 
~-1 Sv o.tu + 
6751 DC_ In 
-
CEU I= 
-
(f 
!Pll 
3.6864 MHz 
20 21 
~11 II 470? 
1. CIRClJIT SHOWS PHVS!CAL POWER DlSmiSlJTlON FROM CENmAL SOURCE. 
2. cr ,. 47tlllF FEEDBACK CNJ. - SPEEDS Ul' LOOP 1...00<. 
S. R:l c 20inA CIJRReiT UMrT RESISTOR. 
m 
11_~ 
tu· 
2211 
-!1 
-
r-W 
Figure 2.6 - Circuit Diagram of a Node. 
~ 
N 
....... 
"ill:rn~ 
ll..d"'' 
t-
UNE 
9~, 750hm !~ 
:1 lc~:ex. 
DRIVER 
nhr 
Copyright (S) Glaxo Pharmaca-Jticels iSS5. 
ports, the sixteen input lines offered by each node being more 
than adequate for the pilot scheme. 
2. 6. Watchdog 
Also featured in Figure 2. 6. is a 'watchdog' circuit, a 
retriggerable mono stable circuit as found in standard 
References (Ref. 24). The watchdog is retriggered by pulses 
from the 8751' s serial port; it has a decay time of 500 
milliseconds before expiring and pulsing the reset line. Thus, 
provided the node responds to 'polling' (see below), the 
watchdog remains in a quiescent state. A watchdog circuit is 
essential in industrial applications, to recover from 
situations where the internal registers (e.g. the program 
counter) within the CPU have been corrupted. Such a situation 
can occur, for example, as the result of a mains 'brown-out'. 
2.7. Opto-input board 
This small externally mounted 'paddle board' was used to 
isolate the sensor input signals (0/20rnA) from the CPU input 
ports, for noise rejection and CPU protection purposes. Four 
Litronix quad opto-isolator packages were used for compactness. 
The paddle board PCB featured a row of rigid wire posts, which 
allowed mechanical connection to a row of DIN rail mounted 
Klippon connectors. These screw-type block terminals were used 
to terminate input sensor signal lines. 
2.8. Node firmware 
Descriptions of the firmware for the various nodes are 
included in Appendix 2. A brief outline only is given here. 
- 19 -
2. 8 .1. 
2.8.2. 
Sensor node firm\vare 
A sensor node consists of the complete circuit of 
Figure 2.3. above. The firmware (that is, the program 
held in EPROM) is identical for each node (nl, n2, n3) 
with the exception of one byte of EPROM containing the 
node number - 1,2 or 3. Each node compares this node 
number with the controlling node's current polling 
character, and if a match is found it then transmits 
four ASCII bytes, the least significant four bits of 
each byte corresponding to the nibble present at the 
input to each quad isolator on the paddle board. 
Because the characters transmitted are ASCII printing 
characters, and the polling characters are pure binary 
non-printing characters, the two types of transmission 
are easily distinguished. 
Controlling node firmware 
The controlling or polling node is simply a device 
for continuously transmitting the node polling 
sequence; although it does not require the receiver 
circuits of the sensor nodes, it was constructed using 
the same PCB, with the PLL chip omitted. The firmware 
consists of a loop of code which outputs the binary 
sequence 8, 7, .. 2,1 (a maximum of eight sensor nodes 
were allowed for, three being used initially), with a 
delay between each transmitted character of sufficient 
duration to allow the polled node to respond with the 
four ASCII characters described above. Thus the 
system is seen to be simple T .D.M. (Time Division 
Multiplexing). 
- 20 -
2.8.3. Monitoring node software 
The monitoring node uses the PLL receiver part of 
node hardware shown in Figure 2 . 6. The CPU (and 
paddle board) are not required, the serial data stream 
being ted directiy to an HP8j serial interface, 
configured for TTL. A transmission rate of 9600 baud 
was utilized. The simple software written for the 
HP85 by the author was sufficient to prove the system. 
It consisted of a small program written in BASIC, 
which displayed the state of the sensors connected to 
system as three rows of sixteen noughts or ones on the 
screen of the HP85. 
2.9. Noise tests 
During the development the system was tested for noise 
immunity by deliberately injecting noise signals into the power 
lines and saturating the boards with EM radiation. The most 
sensitive parts of the circuitry were found to be the TTL 
serial data lines. Excellent results were obtained simply by 
decoupling the lines with optimum value capacitors. Not 
surprisingly, the die cast box eliminated the pickup of EM 
radiation. The box, paddle board and power supply were all 
mounted in a standard (earthed) metal industrial enclosure 
when installed on site. 
2.10. Review 
Several useful lessons were learnt from the pilot scheme. 
The RF (radio frequency) transmission system worked well. The 
site engineers were able to run the coaxial cable (the HP85 was 
sited remote from the line being monitored) through the same 
ducting used for the fluorescent lighting circuits without 
- 21 -
problems occurring with data transmission. It was found 
necessary to trim the VCO frequency, using the supply trim 
potentiometer, to the mid-range of the PLL pass-band, to allow 
for drift due to temperature variations. Clearly a stable 
crystal oscillator to replace the 567 VCO would be an 
improvement. The die cast box was not considered a convenient 
enclosure, as it made access to the boards difficult. The unit 
was not sufficiently versatile - it could not process commonly 
encountered analog signals, nor interface standard 
communications devices such as hand-held terminals. 
Despite the criticisms above, the system has performed a 
useful function for two years with only one malfunction - a dry 
joint on a PCB. The author's simple demonstration software has 
been replaced by an elegant software package written by 
software specialists within the Company's Computer Services 
Department, which provides statistical printouts and logging 
facilities on disc files. 
After completing the pilot scheme, the author was asked to 
continue the development of the system into a versatile 
interfacing system. How this was progressed is discussed in 
the following chapters. 
- 22 -
CHAPTER 3 - THE EXPANDED SYSTEM 
The dilemma the author encountered in attempting to expand the system is 
known in Literature (Ref. 4) as Parkinson's Third Law, and is stated 
formally thus: 'Expansion means complexity, and complexity decay;. The 
inevitable increase in size and complexity is the price to be paid for 
increased flexibility. It was decided to aim at keeping the total unit 
size as small as possible whilst still retaining flexibility as a major 
requirement - though these two conflicting requirements, compactness and 
versatility, created problems from the outset. How, for instance, could 
the system have the versatility and power of a typical modular Eurocard 
system yet be compact enough to be accommodated in a standard wall mounting 
industrial enclosure? - the most common type in use on the Company's sites 
has an internal depth of only fourteen centimetres. 
A decision was taken to split the existing design into four separate 
small boards; the average chip-count per board would then for the most part 
dictate the final board size. The principal board in this initial set was 
of course the CPU board, the other boards being the Watchdog/power input 
board, the RF board, and DVI board (digital voltage input). All these 
boards are described in detail below - with the exception of the RF board, 
which is covered in Chapter 6. We will examine first the choice of the 
mechanical components for the system - the racking system, the backplane, 
the connectors and other related components. 
3.1. The Eurocard Sub-rack 
A local contractor with past associations with the Company 
was selected to produce the emerging prototype system in small 
quantities for evaluation. The major function of the 
Contractor (see Acknowledgements), was to perform assembly work 
- both electrical and mechanical. As the Contractor already 
- 23 -
Plate 3 . 1. - The Sub -miniature Rack 
Plate 3 . 2. - The DVI Board 
- 24 -
held stock items of components for other customer's systems, it 
was pertinent to consult with the Contractor's staff throughout 
the design exercise as regards circuit components, to aim for a 
design that would take full advantage of bulk purchase. The 
Schroff Eurocard racking system (Ref. 29) is a particularly 
well-designed versatile and compact system, with a professional 
appearance and low cost. This was one of the rack systems 
stocked by the Contractor. 
Another racking system held in stock and also considered was 
the ISEP system, and in fact, trial assemblies of sub-racks 
were made using both the ISEP and Schroff parts (for 
comparison), but the Schroff system was found to adapt easiest 
to the shallow depth required. Moreover, the ISEP system was 
heavier and less elegant in appearance. The Schroff system was 
therefore selected for the implementation of the sub-rack 
hardware. Plate 3.1. shows a photograph of an assembled 
sub-rack. Although most Eurocard racking systems use a 
standard nineteen inch card frame, the Schroff system allows 
the user to assemble an eight- inch frame, which is ample for 
---
most purposes. Again, although the normal depth for a Eurocard 
is 160 centimetres, the side plate pressings allow for the long 
Eurocard, or in our case the half-depth Eurocard (80 mm.). As 
the card fronts fitted are one inch wide, the sub-rack capacity 
is eight cards (using an eight-inch rack), as can be seen from 
the photograph. 
The backplane used in the prototypes was again a stock part 
from the sub-contractors, a simple printed circuit board 
designed to accept standard Eurocard DIN connectors with rows 
- 25 -
'A' and 'C' fully pinned ( 32 pins each rows) and row 'B' 
omitted. 
Figure 3.1. shows the signal names assigned to the pins. 
c A 
o--1-o GROUND 
port 0.0 0 2 o port 1.0 
B port 0.1 0 3 o port 1.1 
port 0.2 0 4 o port 1.2 
u port 0. 3 0 5 o port 1.3 
port 0.4 0 6 o port 1.4 
s port 0.5 0 7 o port 1.5 
port 0.6 0 8 o port 1.6 Peri*/memory 
port 0.7 0 9 o port 1.7 
Address 0 0 10 o RESET 
Address 1 0 llo INTERRUPT 0* 
Address 2 0 12 o Timer 1 
Address 3 ol3 o Timer 0 
Address 4 0 14 0 INTERRUPT 1* 
Address 5 0 15 o Clock 1 
Address 6 0 16 o Address Latch Enable (ALE) 
Address 7 0 17 o Prog. Store Enable (PSEN)* 
ADD. 15 Port 3.7 0 18 o Relinquish Control (REL) 
14 Port 3.6 0 19 o RESET* 
13 Port 3.5 0 20 0 Clock 2 
12 Port 3.4 0 21 0 Spare 
11 Port 3.3 0 22 0 Spare 
10 Port 3.2 0 23 0 Spare 
9 Port 3.1 0 24 0 Spare 
8 Port 3.0 0 25 0 Spare 
Serial TX 0 26 0 Spare 
Serial RX 0 27 0 Spare 
o-28-o WRITE* 
o-29-o READ* 
o-30-o +12v 
o-31-o -12v 
o-32-o +5v 
*Active LOW 
Figure 3.1. Backplane Connector Pin-out 
The backplane tracking consists of a series of parallel 
lines interconnecting like-named pins on the eight DIN 
connector sockets. Each signal track is 0.5 millimetre thick, 
with heavier tracking provided for power lines (and the 
read/write lines assigned, for utility, to spare power 
lines). The backplane, as explained, was a part 'borrowed' 
from another system; it did not feature intertrack ground 
- 26 -
lines, a desirable feature if the system should enter mass 
production at some future time, especially if the CPU clock 
rate should be increased. However, during the development work 
there was no evidence of backplane crosstalk, possibly 
aLLrlbuted to both the low CPU clock rate and the wide track 
spacing on the simple PCB. 
3.2. CPU board 
The signals present on the backplane connector pins are for 
the most part determined by the structure and design of the CPU 
Board; this in turn reflects the facilities afforded by the 
8751 which are fully exploited in this system. The 
development system (Ref. 18) used for developing test firmware 
was the Intel PDS (Personal Development System), which the 
author used to assemble, edit and run programs. Although not 
as convenient or as powerful as a standard Intel (MDS) 
microcomputer development system, this cheap portable system 
proved to be adequate. The emulation vehicle used was the 
Intel EMV51 (Ref. 19), which is a plug-in option for the PDS. 
EMV51 is essentially a device that replaces the 8751 on the CPU 
board with an electronic 'umbilical chord' linking it to the 
PDS; this allows the user to monitor the internal registers of 
the processor during the debug stage. Although this thesis 
repeatedly refers to the 8751, the author used EMV51 
exclusively for firmware debugging; for final testing of 
debugged firmware the 8751 was used and some work was also done 
with the 8052-BASIC device (see Appendix 8). 
The author opted for a 'memory mapped' I/0 (input/output) 
scheme to realize the desired flexibility in interfacing to 
external systems (Ref. 5). This system is described below in 
- 27 -
sub-section 3.2.1. Subsequent sub-sections cover the remaining 
features of the board. 
3. 2 .1. The Bus and Memory Mapped I/0 
The Bus system of the 8751 is derived from the 
Intel 8085, the successor to the still-popular Intel 
8080, whose most famous descendant is the ubiquitous 
(Zilog) Z80. The latter processors use separate 
address and data lines, while 8085-type addressing 
structures multiplex the lower 8 bits of the (16-bit) 
address lines with the 8 data lines on one 'bus' port 
usually referred to simply as 'the Bus'. The Bus on 
the 8751 is assigned to the port 0 lines, whilst the 
upper eight address lines are mapped to port 2. 
Figure 3.2. below shows the 8751 pin-out . 
• • • • • • 0 •• 0 0 •• 
port 1.0 :1 40: Vdd(5v) 
port 1.1 :2 39: port 0.0 
port 1.2 :3 38: port 0.1 
port 1.3 :4 37: port 0.2 
port 1.4 :5 36: port 0.3 
port 1.5 :6 35: port 0.4 
port 1.6 :7 34: port 0.5 
port 1.7 :8 33: port 0.6 
RESET :9 32: port 0.7 
RxD :10 31: EAjVDD 
p TxD :11 30: ALE 
0 INTO* :12 29: PSEN* 
R INTl* :13 28: port 2.7 (Add 15) 
T TO :14 27: port 2.6 (Add 14) 
Tl :15 26: port 2.5 (Add 13) 
3 WR* :16 25: port 2.4 (Add 12) 
RD* :17 24: port 2.3 (Add 11) 
XTAL 1 :18 23: port 2.2 (Add 10) 
XTAL 2 :19 22: port 2.1 (Add 9) 
Vss (GROUND) :20 21: port 2.0 (Add 8) 
•••••• 0 •••••• 
*Active LOW 
Figure 3.2. - 8751 Pin-out 
- 28 -
Although nominally designated 'ports', ports PO and 
P2 implement the address/data Bus, while P3 provides 
eight special one-line functions, described later. 
The remaining port (Pl) is reserved for use as eight 
individual I/0 lines (e.g. Pl.6 is used as a 
peripheral memory control line- see below), although 
it could also be employed as a port during firmware 
testing, as an aid to diagnostics. During a write to 
external data memory (see Figure 3.3) the 8751 
generates signals on several pins. For example, the 
signal ALE (address latch enable) is emitted on pin 
30; because of the way the 8751 fetches program memory 
bytes internally (in pairs), ALE is clocked at half 
the normal rate when external data memory is accessed. 
This issue is dealt with in more depth in Chapter 4, 
which covers the RAM (Random Access Memory) board. 
The low level state of ALE is used to latch the 
lower eight bits of the multiplexed address into an 
eight-bit latch. The latch is shown as U3 (74ALS573) 
in CPU board schematic diagram (Figure 3.4). ALE is 
also buffered to the backplane (by USc - 74LS125) to 
act as a timing/control signal for peripheral cards. 
Two other signals are also relevant to external memory 
access- RD (read- pin 15) and WR (write- pin 16), 
both active LOW. These signals are two examples of 
alternative uses of port 3 pins; thus whenever the Bus 
feature of the 8751 is utilized, use of port 3 as a 
conventional port is excluded. However, this is a 
small price to pay for the powerful facilities the Bus 
- 29 -
INTERNAL 
CLOCK 
STATE 4 
Pi I P2 
STATE 5 
Pi I P2 
STATE 6 STATE 1 
Pi I P2 Pi I P2 
STATE 2 STATE 3 STATE 4 STATE 5 l 
Pi I P2 Pi I P2 Pi I P2 Pi I P2 ! 
XTAL 2l I I I I I I I I I I I I I I I L 
{ALE RUNS AT HALF NORMAL RATE DURING MOVX EXECUTION) 
ALE __ ______. 
RD {ACTIVE L0\111) I I 
~ PO ----~~ < DPL OUT > l ~:~~l.__< _________ _ 
0 
I 
P2 
< 
-LED 
DATA POINTER HIGH BYTE OUT > 
WR (ACTIVE LOW) I I 
PO _j I I L 
P2 
____ __.I < DATA POINTER HIGH BYTE OUT > 
Figure 3.3 - Timing Diagram for External Memory Access. 
affords. The signals RD and WR are also buffered to 
the backplane by US. They are used to enable data to 
or from memory and peripheral cards. 
To enable peripheral cards to be addressed, four 
address lines (Al2-Al5) have been 'borrowed' from the 
Bus - a technique known as 'memory mapping'. This 
allows up to sixteen individual cards in the rack to 
be addressed - more than sufficient for most 
applications. The CPU sees the peripherals as sixteen 
high order address locations; there is no conflict 
between the peripheral addresses and the first 4K of 
external RAM. This was considered an adequate 
quantity of RAM at first, but at a later stage in the 
project the requirement for addressing larger 
quantities of external memory arose - possibly up to 
32K, or perhaps even 64K. To allow for these larger 
memory requirements, one line of port 1 (Pl.6 -
PERI(BAR)/MEMORY) was buffered to the backplane (a 
second, spare line- Pl.7, was similarly buffered, for 
general use). The Pl.6 signal line has been gated on 
all peripheral and memory boards with the relevant 
address decode logic to select either memory or 
peripheral accesses. A zero latched by firmware to 
Pl.6 will select peripheral devices; a one latched to 
Pl.6 will select memory access. Details of several 
other port 1 pins which provide optional facilities 
(e.g. serial handshake lines for RS232 options) for 
various peripheral cards, are given in the chapters 
which relate to the particular peripheral cards. 
- 31 -
I 
w 
N 
I 
1'~ 
.j~ 
kl 2 ~ U7b '- ,....., 
U7cl.Q 1-1-!~......( 
I-
I-
P1 ..... G 
1 
0 
RESET 
if."' Rn Ui ~2 Tn ~£! 
~ 
hO 
~ 
l(1 
xr~~D[ 
!2p ~ ~~ 
.... ~ ~~~@[ 
U6 9~q r 2 6 
NOTES 
1. lCTAL = 3.6£$4 Ol'l7.37'S MHz. 
2. Pt.6 = PERliMEM SEU:CT. 
3. REL SIGNAL IA1Gl TRISTA'TES UT. 
4. Q.OCK UNES: A.B.C.D = OIV fJ'f 2.4,9.1!. 
Lt 
8 
w I-
1-
1- BUS 
-
- 8 
- PO 
r-
32 ~F 
lll'3:1a 
291-
1-
1-
1- A 
1- 8 
- P2 -+Sv t - -21 
-
1-
~ -EA/VDO -J- 1-1-
1-
1-
Q.00<2 ;,., 
n~ 
~ ~~ WA 
ilo"' .... 
I~ MJ 
us ~ 'ALE £ ,.. ... 
~4> I~ 
...... 
~· -
( A I! I II DlR 
@=j u~ 
119 
1 
2 F@ fF I_ ,..... ~ 
1- 1r- f-4> ,_ r -1- ~ ~ @- I !8l 
- U2 1- A ~. [J 8 - 1- I' 8 - :-
-
~ f-o . iil l...@ ©I I ,_ 
'11 1\J 'iJ 1-
r-- 2 
1 19 ,.... ~ Er 1- 1- ~~-1- 1- BUS BUfFEI'l ~ TI r- U3 i- ~ TO 
A I- 1- 8 t: ~ fim 
I DlR * 
r- 1-
I- l== t:: ~ I !..... \1 ?l 12 1-
11 1 9 ~ @=.'81 I 1-
i- u !=© @ ~ ~LA'TCH r- A 1-o© (6> ~ @ 1'. U4 I-1- 7 ~ @ 1- U7a @' 
D- t: @: i 1-11) 21- (iJ I I ~>--o @ I ~ADO. BUFFER r> t;j) @ 
-, 
elk==@ : • {J5v 
~I G~ 
o-32.,.._ 
I ~i~ '~ 
I 
II , 
( 
---.-
Copyright (£) Glaxo Phmrmacautlcala i9i35. .,. 
3.2.2. 
Bus buffers are provided for ports PO and P2; these 
are U2 and U4 respectively. Both buffers are 
74LS245's - these provide the necessary increased 
output fan-out and also protect the 8751 against 
accidental damage. The control of the output enable 
by the gating provided by U7A enhances this protection 
in the case of PO - the direction being controlled by 
the WR signal. Directional control of U4 is not 
required, as the upper address lines are 
uni-directional. A control line has been allocated to 
backplane pin AlB (REL), to allow another intelligent 
device to gain control of the backplane lines. This 
could possibly be, say, a video controller card ( a 
likely future requirement) with a need for 
asynchronous access to the RAM memory board. 
Typically the device would participate in an 
interrupt/status handshake with the CPU board, before 
completing the Bus release by taking REL high, thus 
tri-stating the active control/address circuits. 
Clock circuitry 
The 8751 features an on-board crystal oscillator 
which requires a minimal set of external components, 
as shown in Figure 3.4. The oscillator circuit is in 
fact a single stage amplifier connected as a Pierce 
oscillator (Ref. 8). XTAL l (pin 19) is the input to 
the oscillator and XTAL 2 (pin 18) is the output. To 
prevent the extremely small input capacitance of the 
FETs (field effect transistors) that form the 
oscillator amplifier 'pulling' the crystal above its 
- 33 -
required operating frequency (overtone start-up is 
disastrous to the operation of the 8751 serial port, 
for example, which is referenced to the clock 
frequency), two balanced phase-shifting capacitors 
shunt each side of Lhe cr.ysLal to ground. Fisher 
(Ref.7) reports suitable values of 30 pF (obtained 
empirically) for these capacitors giving reliable 
start-up in the frequency range 500 kHz to 15 MHz, 
with pulse rounding at the latter frequency. (At the 
time of writing the 8751 is specified to 12 MHz -
although at the start of the project the part was 
limited to 8 MHz). 
Appendix 1 lists some sample serial port baud rates 
for the 3.6864 and 7.3728 MHz crystals; the baud rate 
is determined by the clock frequency and by the reload 
constant loaded into the timer register 'THl'. 
Crystal selection is not a straight-forward matter in 
this case; for most microprocessors, an approximate 
operating frequency will suffice, but the accuracy of 
the 8751 serial port timing is important for reliable 
serial data transfer. Crystals have several selection 
parameters (Ref. 8), and are quoted as for either 
series or parallel resonance oscillators. A crystal 
quoted for series resonance will work reliably in a 
parallel resonance circuit, but will oscillate at a 
frequency slightly removed from that quoted by the 
crystal manufacturer, hence it is important in this 
case to obtain the correct component. Parallel 
resonant crystals can be purchased off the shelf from 
- 34 -
component distributors for 3.6864 MHz, and so early 
development work was based on this frequency. Later 
tests were performed at 7.3728 MHz, using crystals 
made to order (Ref. 7). 
A penalty for having an on-board UART is the 
impracticality of including 'hesitate' circuitry 
r.:·. 
('freezing' the CPU by withholding clock pulses) for 
the clock oscillator; the reception of serial data 
being essentially asynchronous, clearly it would be 
unsatisfactory to disable the UART for even short time 
intervals. In a typical 8080 or 8085 system, for 
example, the 8224 clock generator (Ref. 9) would 
provide the hesitate function via the READY input. 
This line would appear as a backplane signal in such a 
system, enabling other boards in the system to pause 
the CPU - typically while awaiting external data. 
This rules out the use of some families of interface 
chips - e.g. PIA's (Ref. 16) which provide a hesitate 
signal to the host CPU - for use on the various 
interface cards that comprise the miniature rack 
system. This matter is discussed further in Chapter 
5, in the section covering the BCD interface design. 
The CPU board provides two clock lines (Clock 1, 
Clock 2) which may be utilized by other boards in the 
system, via the backplane connections. U6 is a high 
speed CMOS clock divider (HC 4024); the high input 
impedance and the CMOS logic levels of the inputs are 
an excellent match to Xl pin's low drive output 
parameters, allowing a direct connection to the 875l's 
- 35 -
3.2.3. 
3.2.4. 
Pierce oscillator. Links are provided on the board to 
enable the user to select the required clock rate(s). 
During testing the author selected the clock 1 rate to 
be 921.6 KHz; Clock 1 is used by several cards - e.g. 
ADC (Chapter 7) - whilst clock 2 is provided for 
possible future use. The jumper configuration used 
is, of course, partly dependent on the crystal 
frequency. 
Reset 
The reset signal, which provides a positive CPU 
reset pulse on power-up, is provided by the watchdog 
card (section 3.4.) on backplane pin AlO. The 
watchdog card also features a manual reset push-button 
which allows an operator to reset the system. 
External Memory Features 
Data memory external to the CPU is covered in the 
next chapter; P1.6 is used as a memory select line, 
with Pl.7 being similarly buffered (U7b, U7c) for 
possible future use. External program memory is also 
allowed for - the jumper connected to pin 31 
specifying whether the program resides on internal or 
external EPROM (Erasable Programmable Read-Only 
Memory). Up to 64K of external EPROM may be 
addressed, although the 4K on-chip is considered 
adequate for the Company's applications. PSEN 
(Program Store Enable - active LOW) is the control 
signal used to gate external PROM's, and is buffered 
to the backplane by USd. An inexpensive EPROM-less 
version (the 8031) of the 8751 is available, should 
- 36 -
3. 2. 5. 
the Company require the development of EPROM programs 
in excess of 4K in size, in which case these programs 
could reside in the external 64K memory areas, on a 
separate EPROM board. 
Miscellaneous - Timers etc. 
Two timer pins (TO and Tl) are connected directly 
to the backplane (pins Al3 and Al2 respectively), as 
are two interrupt lines (INTO and INTl - backplane 
pins All and Al4 respectively); the timer pins may be 
used (software configurable) as either event counters 
or one-bit I/0 lines (Ref. 1). The interrupt lines 
are similarly software configured as either active low 
(input) interrupt pins or general-purpose I/0 lines -
invariably they are used for interrupts. Normally a 
device (interface board) requiring attention would 
force, say, the INTO line LOW, and the CPU would 
respond by reading the status register of each card 
until the interrupting device is identified - an 
interrupt triggered serial poll sequence referred to 
herein as an 'interrupt/status handshake'. Usually 
the sequence completes with an exchange of data 
between the two boards - an entirely conventional 
method of servicing 8085 type peripheral chips such 
as, say, the 8251 USART (Refs. 21,22). An acceptable 
alternative approach to addressing peripherals 
considered during development was the use of DMA 
(Direct Memory Access) using a DMA controller chip 
such as the Intel 8237, which is designed for DMA 
implementation on 8085-type bus systems. However, 
- 37 -
this >·muld have meant a separate DMA board due to the 
size of the DMA chip (40-pin) - an unacceptable 
hardware overhead. 
The 8751 serial port pins RXD (Receive Data - pin 
10) and TXD (Transmit Data - pin 11) are also 
connected to the backplane (pins C27 and C26 
respectively), to provide serial data to the RF board 
or the Serial board - both of which are described in 
Chapter 6. (See this chapter also for details of use 
of port 1 pins - Pl.O and Pl.l - as serial data 
handshake lines). The serial port options (baud rate, 
parity checking/generation, start/stop bits etc.) are 
all firmware selectable, details of which, together 
with a sample firmware listing, are contained in 
Appendix 3. 
A small Sv reservoir (22 micro-Farad) has been 
included on the card, in common with all the other 
cards (with the exception of the watchdog card, which 
has larger capacitors associated with the various 
power lines - see 3.4. below) in the system. The 
capacitor is sited near the Sv backplane power pins 
(C/A 32) to ensure a smooth DC line for the whole 
card. As the card utilizes one single Sv supply, 
there are no connections to the +12v line (pins C/A 
30), or the -12v line (pins C/A 31). Ground 
connection to the backplane occurs on pins C/A 1. 
Gridded ground planes and similar noise rejecting PCB 
layout techniques were used in pre-production artworks 
for the CPU board (and/where space 
- 38 -
considerations permitted on other boards) in an 
attempt to minimize the pickup of noise (Ref. 17). 
3.3. The DVI Board 
The DVI (Digital Voltage Input) board was designed to 
interface digital signals (voltage or current) to the CPU 
board. Figure 3.5. shows the circuit diagram. The ·requirement 
was for an opto-isolated eight-input board, memory mapped to 
the Bus. The board can be thought of as a memory mapped 
development of the simple opto-isolator board ('paddle' board) 
described in Chapter 2. The use of the memory-map hardware and 
associated device address switches means that a greater number 
of inputs can be monitored by one node - the rack can be 
populated by several DVI cards, each with a different device 
address. 
/Continued Over 
- 39 -
LED Array I I r.r-u 
~ 
~ 
i' 
__:j 
U1 
; ~ 
8 U2 8 
-
. .-
~ 
~Ill I ~ I T 
I 
.p.. +Sv 
,, r ~~ 0 I I I I 
~ 
" ~ 
-'Sv 8 c I 
·~ 
200 
I 
,U3b 
10k 
8-Way I 
Switch Bank 1 
+Sv 
10k 
U7a 
::!:!::!. v 
C A 
ltP1 
I!) -
: I -
~ ~II :JPi.G (QJ 
@ (QJ 
@ 
@ 
0 
0 
IOl (QJ 
IOl @ 
@ \01 
_r--~u6Ffl 4 
@ 
()) 
(jJ 
@ 
+Sv 
-;-1-:-A 
10k 
- ft. 
~ 
@ 0 
@ (lJ 
@ @ 
© © 
@ @ 
@ @ 
- 0==0 
'""'! o---4:ll ' ~:i~s-J I' 
000 U7b o--@ I' 
TO o-32 ' ' I 
· nm I I 
·T1 I 22jJ , 
of the DVI Board. --- j 
Copyright (£) Glaxo Pharrnucsu~cals isa5. 
3.3.1. Memory mapping hardware 
This hardware is described in detail at this stage, 
as it is a common feature of most cards in the system. 
The memory mapping device is the LS85 comparator (U6); 
it was one of a number of circuit elements chosen 
after consultation with the Contractor's staff, with 
reference to their bulk component stock. Other 
comparator's considered were the Fairchild F521 
(8-bit) and the 'LS682 (the latter component was used 
on the watchdog card - see 3.4. below - in preference 
to cascaded '85 comparators). The comparator has two 
sets of four-bit input lines (A and B) - when the data 
present on both sets are equal then a logic one is 
output on pin 6 (the A=B output). The 'A' lines are 
connected to a four-way switch bank (switching to 
ground), pull-ups selecting logic ones when the 
switches are open-circuit. The switches define the 
card address within the rack. 
The '85 comparator features an input enable, which 
is driven high by the presence of a logic one on the 
AND-tied output of two open-collector inverters. One 
of the inverters (U7a) buffers the signal 
PERI(BAR)/MEMORY obtained from backplane pin A8 (this 
is the firmware dependent signal present on Pl.6, 
selecting either memory or peripheral accesses via the 
Bus, described earlier- see section 3.2.). Another 
'LSOS buffer (U7b) is used to invert the active LOW 
read (RD) signal. Hence the comparator provides an 
output 'one' on pin 6 when the card is correctly 
- 41 -
3.3.2. 
3.3.3. 
addressed, provided the input enable condition is 
satisfied - i.e., RD being LOW and peripheral 
addressing being enabled. The output is inverted 
(U7c) to give an active LOW output in order to drive 
the output-enable pin of an 'LS245 octal buffer (US) 
LOW under the conditions detailed above. 
Input isolation 
The '245 is used to drive data obtained from the 
outputs of two Litronix ILQ74 quad opto-isolators (Ul 
and U2) onto the Bus during the read interval. The 
opto-isolators are the same type of components as used 
for isolation of inputs in the hardware of the simple 
nodes of the pilot scheme described in Chapter 2. A 
current in the range 4-100 milliamps through a 
photodiode in Ul or U2 will drive a LOW output on the 
(collector) output of the corresponding 
phototransistor. (A series resistor, user-specified, 
is used for current limiting on each input - allowing 
input signals to be sourced from whatever DC supply is 
convenient). Pull-ups on the outputs ensure TTL 
levels; the signals are also fed to a high-gain 
(Darlington) transistor array, which is used to drive 
eight elements of a ten element bargraph array, used 
in this application as an LED front-panel signal state 
indicator. The ULN2803A (U4) incorporates internal 
base resistors that ensure TTL compatibility. 
Connector hardware 
It is useful to mention at this stage the reason 
for the choice of front-panel connector for the input 
- 42 -
3.3.4. 
signals. The connector. used is the T and B Ansley 
20-way polarized socket (Farnell Part No. 612 2004ES), 
designed to accept the corresponding polarized 
ribbon-connector plug. The socket features two 
::;ide-mounted lock/eject tabs as well as right angled 
PCB solder pins for ease of assembly. The socket is 
of the type used as a component of the Pheonix FLK-20 
20-way C-rail connector - allowing a simple one-piece 
ribbon cable connection between C-rail signal cables 
and a DVI card in a typical installation. The FLK-20 
is a compact connector, splitting the 20-way signals 
into two tiers (ten signal connections and ten return 
or ground connections) of screw-tightening cable 
clamps. Plate 3.2. shows a photograph of a prototype 
DVI card. 
Handshake Options 
The availability of two spare signal/earth pairs on 
the front panel socket (and two spare LED indicators) 
prompted the addition of two opto-isolated handshake 
lines to the card, to allow a possible alternative use 
- as an opto-isolated parallel bus interface. The 
opto-isolator (U3) used is the Litronix ILD74, a dual 
isolator similar in performance to the quad package 
(Ul, U2). Both halves of the isolator can be used as 
input lines (the isolator outputs are open-collector -
the 8751 incorporates pull-ups within the input ports) 
; the U3a output may be optionally inverted (using 
jumpers AB and DC) or connected (jumper BC) directly 
to the selected backplane line - either an interrupt 
- 43 -
line or timer input (although, of course, the line 
selected may simply be a general purpose input line, 
according to the 875l's firmware configuration of the 
port pin). A typical use of this option would be as 
an input flag line for a remote parallel interface. 
U3b allows, by means of jumpers, the implementation of 
either a second input flag line (jumper 1 and 4), or 
an output control line (jumper 2 and 3). 
As a general comment it can be stated that the 
options described above were added simply because the 
space was available on the board; most applications 
which require the use of the interface will omit U3, 
the card serving an eight-input passive isolation 
device. As the three inverters (U7d, e and f) are 
already present on the board, little extra production 
cost is incurred for the additional facilities. The 
marginal value of these extra facilities preclude the 
addition of the status register hardware found on 
other boards, so the DVI board is excluded from the 
list of serial pollable devices - i.e., it cannot take 
part in an interrupt/status handshake with the CPU. 
3.4. Watchdog card 
This card (see Figure 3.6.), is a development of two 
sections of the system described in Chapter 2 - the power input 
and transient suppression section, and the watchdog circuit. A 
third function - node identity - is added. Each section is 
described in detail below. 
- 44 -
I 
.p. 
Vl 
I 
GNO 
+12v 
-12v 
+5v 
GNO 
+12v 
""i2v 
+5v 
s, 
1u 
5v 
Trona. 
Su!Jp. 
41u 
+ 
Sv 
47U 
+ 
RESET 
RESET 
+ U6rc 
100u 
A 
101 II-::-
@ @ 
[' 
o <0> I 
~ : J'l (j) 10 
@ : I 
l()l ' 
~~)- c- I 
0 
@ 
@ 
0 
0 10 
0 
0 
o-o-(M I( 
Figure 3.6 - VVatchdog Board Circuit Diagram. 
Co;DYllgl'lt (V Glmto Pi'l~fll<l~~u~e~01 i!m5. 
3 .4.1. Power input 
Because of the presence of RS232 buffers, ADC's 
(Analog to digital converters) etc., etc., on certain 
cards in the system, the original single-supply 
requirement was relaxed. Power on this system is 
derived from an external commercial switch-mode power 
supply, which by it's nature offers further buffering 
against mains-born noise. The outputs of the pm11er 
supply (see Appendix 10 for further details) are +Sv, 
+12V, -12V and Common, which are admitted to the 
system by a cranked plug (Cannon type AXR-3-15) 
inserted into a mating 4-way socket (Cannon type 
AXR-3-32), flush-mounted on the front panel. The 
minimal depth of the plug ensures that the total depth 
of the whole assembly is not excessive with respect to 
the internal depth of common wall-mounting industrial 
enclosures. The circuit diagram of the card (Fig. 
3.6.) reveals that the Sv supply is conditioned in the 
same way as in the pilot scheme; the other supplies 
are less critical and are simply decoupled (47 
micro-Farad capacitors) before being routed to the 
backplane. 
The operation of the power supply is monitored on 
the front panel of the card by LED's (light emitting 
diodes); also present on the front panel are a 
push-button, LED and switch which are associated with 
the manual reset and watchdog enable functions, 
described later. 
- 46 -
3.h.2. \vatchdog Circuits 
This circuit (Ref. 3) is similar to the '555' timer 
circuit used in the original 'node' system (see 
Chapter 2); the same system is used- a train of 
pulses are used to retrigger the 555 (in this case 
configured as an astable) - but the source of trigger 
pulses is different. The CPU must source the pulses 
in the form of data bytes on the Bus - the watchdog 
card is memory mapped in the same manner as the DVI 
card, for example. (Rather than repeat the 
description of the '85 comparator circuitry, the 
author will refer the reader to the DVI board circuit 
description in section 3.3.1. in future). \Vhen the 
card is selected by a 'MOVX' write command within the 
CPU, the eight-bit '682 comparator (U2) compares the 
data byte on the bus with the settings on an eight-way 
switch register (note that the pull-ups for the 
switches are incorporated within the '682), and 
outputs an active LOW signal if equality is detected. 
The output pulse is buffered to the '555' (U4) 
retrigger input; active LOW output pulses from the 
'555' are diode-coupled to the RESIN input of US (see 
below).A manual push button ('RESET') is provided on 
the front panel, with LED indication; a toggle switch 
(SWl) is also provided, to disable the watchdog 
function during system testing. 
The '555' used on this board is a variant of the 
'standard' 555 timer, the Texas TCLSSSCD. This is a 
new product, a low-power CMOS type, allowing the use 
- 47 -
3.4.3. 
of smaller value timing components to achieve the 
corresponding decay periods. This adds to both the 
compactness of the circuit (the timing capacitor is 
quoted representatively in units of nano-Farads rather 
than, say, micro-Farads and hence is relatively small 
and stable) and to its timing range. 
An extra chip (US - Texas TL7705) has been included 
on the Watchdog board to monitor the SV power supply 
rail and detect 'brown-outs' or major supply 
fluctuations. The chip has a 'SENSE' input (pin 7) 
which is, in this case, connected directly to the SV 
supply line. The SENSE input will detect supply 
fluctuations and the chip will output a RESET pulse to 
reset the active devices connected to the backplane 
reset line(s), the output pulse timing being 
determined by an external (pin 3) capacitor. The chip 
provides an active LOW open - collector output via an 
internal n-p-n transistor and an active HIGH 
open-collector output via an internal p-n-p 
transistor. These outputs are provided with external 
pull-up/pull-down resistors and connect directly to 
the backplane reset lines. The reset function may 
also be triggered by an active low input pulse on pin 
2 (RESIN), which may be sourced from the watchdog 
output (described earlier) or the buffered (U7e) RESET 
push-button. 
Node Identity 
If the interfacing system is to be a 'node' in a 
- 48 -
3.5. Review 
distributed system, the node identity (it's number in 
the system) needs to be accessible to the CPU 
firmware. For the pilot scheme, the node number was 
stored as a constant in EPROM inside the 8751, but 
this is inconvenient for the user, as it is necessary 
to 'blow' (i.e., EPROM program) different versions of 
the firmware according to the node's identity. 
To cater for convenient access to the node number, 
and ease of visual discrimination, the comparator 
switches also double as node 'identity' switches; when 
the CPU firmware uses a MOVX instruction to 'read' 
from the card memory-mapped address location, the 
address decode logic will enable - via a '245 buffer 
(U3) - the data onto the bus. The 8751 firmware would 
perform this access as part of its initial RESET 
sequence during start-up, and incorporate the node 
number into its self-test calculations; at a later 
stage the regenerated node number would be written 
back to the watchdog card to service the watchdog 
timer. 
After an initial DC check-out, the three boards described in 
this chapter were tested in combination, plugged into the 
backplane of the sub-rack. The PDS system's EMV51 emulator was 
used in lieu of the 8751 to enable rapid de-bugging. Most of 
the testing was performed using the emulator's high-level macro 
language, which enabled a convenient and thorough system test. 
- 49 -
3. 5 .1. 
3. 5. 2. 
CPU board 
The CPU board was tested with both the 3.6864 MHz 
crystal and the 7.3728 MHz crystal. No problems were 
experienced at either speed with signal crosstalk. 
~articularly pleasing were the CLOCK 1 and CLOCK 2 
signals, which exhibited a clean square waveform when 
viewed on an oscilloscope (Phillips PM3215). The 
waveform (see Appendix 1) displayed a 50% duty cycle 
with minimal ringing. The author tested the 875l's 
response to interrupts using the DVI board's options 
(see 3.5.2. below). Response to reset etc. is dealt 
with under 3.5.3. 
The DVI Board 
Problems were experienced with this board 
concerning the values of the pull-ups; the board did, 
in fact, perform satisfactorily from the user's point 
of view - i.e., it functioned correctly as a system 
component as originally designed. However, a logic 
probe placed on the US inputs indicated an invalid 
signal logic level for the theoretical logic '1' state 
- an effect caused by the pull-down action of the 
current flowing into U4's internal base resistors. 
Substituting 3.3k or 4.7k resistors for the lOk 
pull-ups solved the problem. 
The introduction of lower value pull-ups also 
speeded up the rise-time of pulses associated with 
open-collector ('LS05) gates - although the 
exponentially rising waveforms observed during testing 
- 50 -
3.5.3. 
had no detrimental effect on the operation of the 
logic. Later (production) versions of the board used 
SlL and DlL resistor networks to minimize the 
component population and improve reliability; this is 
true also ot other boards in the system, which is why 
the reader will sometimes encounter, for example, a 
pair of series resistors (e.g. Figure 3.6) in a 
circuit where a single larger-valued component would 
suffice. 
Watchdog Board 
This board was tested in several 'breadboard' 
versions and at the time of writing a production 
design has yet to be finalized, although the version 
shown in Figure 3.6. performed satisfactorily. Tests 
were made with the CPU board to check the correct 
operation of the reset, node identity and watchdog 
functions. Although the watchdog circuit was found to 
function correctly, the author was unhappy about the 
large number of discrete components associated with 
the watchdog circuit, giving a cluttered PCB layout 
compared with other boards in the system. Also, the 
presence of many discrete components on a PCB 
increases assembly effort/cost and reduces 
reliability. 
The author has experimented in replacing the 555 
circuit with a second TL705 chip - configured similar 
to US but used as a watchdog timer. To use a TL7705 
as a watchdog requires the use of the RESIN input as 
the input of the retrigger pulses; in this mode the 
- 51 -
TL705 is pulsed into the reset mode and held there -
an absence of pulses causes the device to revert to 
its quiescent state, causing an output pulse on pins 5 
and 6. This unconventional use of the TL7705 is still 
experimental, but offers clear advantages in circuit 
layout. 
- 52 -
CHAPTER 4 MEMORY EXPANSION 
Although the 875l's 4k of EPROM and 128 bytes of RAM are sufficient for 
many applications, the small quantity of RAM (in particular) will be too 
limited for some of the Company's applications. I L ls a common need to 
buffer slow peripherals - especially devices such as serial printers - with 
large (e.g. 2k) RAM buffers. On the other hand, any local 
'nl@ber-crunching' tasks that the system may be called upon to perform may 
prove demanding as regards EPROM space. The 8751 's address architecture 
allows for both data and program memory to be expanded externally, each to 
64k maximum. 
This chapter describes the RAM board in detail and discusses EPROM 
memory expansion; as the Company does not require the development of an 
EPROM board at the time of writing, the author has limited his activities 
to providing the necessary backplane signals, thus allowing the addition of 
the board at a later date. As there are obvious similarities between the 
two memory systems, many points concerning circuit design that are covered 
in the description of the RAM board apply also to the design of an EPROM 
board. 
4.1. The RAM Memory Board 
Memory systems for microprocessor data storage are normally 
based on one of two types of memory: 'static' RAM's or 
'dynamic' RAM's (often referred to as SRAM's or DRAM's). 
SRAM' s are usually preferred for small (up to 64k) memory 
stacks, as they are totally self-contained. They are however, 
more expensive to manufacture per storage element than DRAM's. 
The major drawback with DRAM memory is the need to 'refresh' 
the memory - i.e., read (and write back) every bit in the 
memory at the 'refresh rate' quoted by the I.C. manufacturer. 
- 53 -
Refresh control is a task unsuitable for a busy CPU, and is 
often implemented with special refresh and 'arbiter' (it is 
necessary to resolve the conflicts that arise from simultaneous 
refresh and data requests) circuits. The overheads in cost and 
size that the circuitry incurs prohiLits Lhe economic use of 
DRAM memory in small systems. 
choice for 
alternative 
many 
has 
systems 
recently 
Thus, SRAM' s are the obvious 
designers. However, another 
become available IRAM's 
('integrated' RAM's also known as 'pseudostatic' RAM's), 
which offer a cheaper alternative to SRAM's. 
IRAM's are DRAM memories included on the same chip together 
with the necessary refresh and arbiter circuits. To the user 
the external characteristics make IRAM'S appear to be 
compatible with SRAM' S - that is, they occupy the same JEDEC 
(Reference 10) International Memory Site for 'byte-wide' 
memories as SRAM' s, and share the same ease of application. 
The major difference between the two products lies in the 
interpretation of one all-important parameter - Access Time. 
When the 8751 issues a 'MOVX' instruction for the purpose of 
reading data from external RAM memory, the read timing profiles 
shown in Figure 3. 3. apply. ALE (which runs at half normal 
speed during a MOVX instruction) is used as the main timing 
pulse, the memory (SRAM or IRAM) being enabled by (and, 
therefore, timed from) either the rising or falling edge. In 
the case of the Intel 2186 asynchronous IRAM, the falling edge 
is used. (The 2186 will be used as a convenient model for 
discussion, for the time being). The RD signal is used to gate 
the IRAM's output buffers onto the Bus; although the data need 
not be available from the RAM at this point, it must arrive 
- 54 -
before the 875l's read sampling interval, which occurs during 
the eleventh clock period after ALE goes LOW, as shown in the 
diagram. Thus, the critical timing (Tc) for the 2186 is the 
time between the falling edge of ALE and the start of the 
sampling period (SP); this represents ten complete clock 
cycles. Table 4 .1. below shows the timing figures for Tc at 
three different clock frequencies, and the access times for 
three different versions of the 2186 (- 25,-30,-35 indicates 
250nS, 300nS and 350nS respectively. These are the access 
times without refresh contention). 
Clock freq. Tc Access Time with refresh 
(MHz) (nS) 2186-25 2186-30 2186-35 (nS) 
3.6864 1898.9 675 800 950 
7. 3728 949.4 II II II 
11.0592 632.9 II II II 
Table 4.1 - Access Time (with refresh) for the 2186 !RAM. 
From the table above, for example, it can be seen that the 350nS 
part is (marginally) too slow for the 7.3728 MHz clock rate, so the 
300nS version would be the correct choice. The 350nS part is suitable 
for the slower (3.6864 MHz) rate, and, of course, is cheapest. The 
author experimented during development with both of these versions of 
the !RAM, and also with an 8k x 8 bit SRAM's, (e.g., the Hitachi 
HM6264 See Appendix 11). The latter part was found to be 
satisfactory (the access time of 150nS made it a possible contender 
for use as a program memory store), but was significantly more 
expensive than the 2186, which was therefore preferred for data 
storage. 
Figure 4.1. shows the circuit for the RAM memory board, based on 
the 2186-30 part. It is expected by the author (as a result of 
enquiries) that Intel will double the size of the !RAM within the next 
- 55 -
12 months (the first of the current series of Intel IRAM' s was 
released as a 4k x 8 bit part, which was subsequently replaced by the 
8k x 8 bit part); to allow for this links have been incorporated into 
the design to cater for the anticipated upgrade. The circuit is based 
on a stack of four IRNi's (U3, U4, US and U6), giving a total memory 
capability of 32k x 8 bit board. The memory may be mapped into either 
the 0-32k or 32k-64k address range, using further links. Thus, if 64k 
of memory is needed, then it is necessary to use two boards, until the 
upgraded IRAM becomes available. 
detail. 
The circuit is now described in 
4.1.1. Chip enable Gating 
A 2186 memory cycle commences when Chip Enable (CE 
- pin 20) is driven LOW. The signal that provides the 
transition is, as indicated earlier, ALE - but Lt is 
necessary to gate the signal with others (Reference 
11) to prevent illicit access, particularly during 
power-up. The IRAM is self-resetting when the 5 volt 
supply is applied, provided CE, OE (output enable -
active LOW) and WE (write enable - active LOW) are 
inactive. This is certainly true in the case of the 
last two named signals, but ALE needs to be gated out, 
as it commences clocking immediately the 8751 is 
initialized. Pulsing CE before the 2186 has 
terminated its internal reset procedure would result 
in incorrect operation of the device, so ALE is gated 
with RESET to prevent this occurrence. The signal is 
also gated with the memory/peripheral select line, to 
inhibit access during peripheral transfers via the Bus 
(see the previous chapter). Table 1 below shows the 
- 56 -
truth table for the chip enable gating, v1hich is 
implemented with NAND gates (Figure 4.1.- Ula, b and 
c). 
MRA Q 
0 0 0 1 
0 0 1 1 
0 1 0 1 M=Memory Enable 
0 1 1 1 R=(NOT) Reset 
1 0 0 0 A=(NOT) ALE 
1 0 1 1 
1 1 0 1 
1 1 1 1 
Table 4.2. - The Truth Table for Gating ALE 
A two-to-four line decoder (U2) is used to select 
the individual 2186's. The open collector version 
( 'LS156) is used to allow the versatility in IRAM 
component choice mentioned earlier. When the 8k RAM's 
are used the Sl and Sh inputs of the '156 select the 
0-32k or 32k-64k range; wire links are employed to 
configure the inputs to the '156. Only the 'A' 
section of the '156 would be used with the 16k 
devices, and only one half of the '156 is ever 
enabled, according to the option selected the 
appropriate link combinations are shown on the circuit 
diagram. 
- 57 -
I 
\J1 
CXl 
I 
1]1 
oe? 
5v 
...---------------;)~ ~ 
" 
' 
r-' 5v 
* 
4 
I ~CE 
Q DO 
/{13 
..&: 
c 
8~ 
Lt{ 
slt oo 
'Jl' Jp 
.... E 
_a:: 
13 13 
tl 
tt 
t: 
1]1 
~we oe 
<lA13 TRACK - SEE TEXT 
Figure 4.1 - R.t\M Board Circuit Diagram. 
~ 
IH--1---"""·J 
IH--+--=n'C ... ~ 
l .. j i 
,, !...111 ( "' 
0=1~=~-.....,.,1 
0 ~ 
10 
(l) 
l!lJ 
()) 
Rl':l'MI':M 
OJ 
@ 
@ AU! 
~
@ 
A7 A15!21 0 
10 
10 
10 
10 
0 
0 
10 
Uic 
~: l 
~y 
Copyright (£) Glaxo PhormaCiilutlcoiG 1sa5. 
-=-
4.1. 2. 
4.1.3. 
When the card is linked for the 0··32k range, Al3 
and Al4 are connected to the AO and Al inputs to the 
decoder; AlS is connected to the Sl input of the 'B' 
section of the '156 the 'A' section being disabled, 
with Sh held LOW. The gating of the enable to the 
decoder us deferred until Ula pulses LOW on the 
falling edge of ALE, whereupon the selected CE is 
driven LOW, and the memory cycle for the chip 
commences. 
Reading from data memory 
A data memory read cycle commences with a 
negative-going CE transition as outlined above. The 
address information on lines A0-Al2 is latched into 
the IRAM at this time. The IRAM then accesses the 
addressed data byte as part of a standard 
'read-modify-write' cycle, as is common with other 
types of read/write memories. Within the time-period 
detailed above, the data is present in the RAM's 
output buffer, to be gated to the Bus by RD (which is 
connected to OE pin 22). The rest of the 
read-modify-write cycle is internal to the 2186 
consisting of writing the unmodified data back into 
the memory location. This part of the cycle is most 
relevant to WRITE transfers, described below. 
Writing to Data Memory 
The write timing is less critical than the read 
timing (see above), the data being latched into the 
IRAM on the falling edge of WR. The standard R-M-W 
- 59 -
cycle commences as for READ transfers (described 
above), on a negative CE pulse. The latched (by WR) 
data byte from the Bus is written to the addressed 
memory location in lieu of the previously fetched byte 
(hence the 'modify'). Once the data byte has been 
sampled by the !RAM, the timing of the remainder of 
the write cycle is in general unimportant to the 
operation of the host CPU, and it is therefore true to 
say that the read timing is generally the more 
limiting factor in the application of RAMs. Further 
details on the operating conditions of the 2186 and 
other memories discussed herein can be found in 
Appendix 11. 
4.2. External EPROM Facilities 
The author has allowed for the addition of external EPROM by 
providing the relevant buffered signals (PSEN, together with 
the existing set of signal lines) on the backplane. Clearly, 
the design of a separate EPROM board is not a major 
undertaking; indeed, it is possible to extend the existing RAM 
board design to so that the board accepts either RAM or EPROM -
the use of 16k x 8 bit EPROM's would allow the modified board 
to accommodate external (to the 8751) firmware programs 
extending up to 64k in size. The author's development brief 
from the Company does not allow for such work, so the provision 
of external EPROM facilities remain a future development. 
4. 3. Review 
The RAM board was soak-tested by repeatedly writing and 
reading back chequerboard patterns (patterns of alternate 
noughts and ones) throughout the address range of the memory 
- 60 -
array (four 2186's). The circuit \vas tested in 'breadboard' 
form, and the board was tested in the rack in conjunction with 
the CPU (using the EMVSl emulator) and watchdog boards. 
Although the circuit components all performed satisfactorily 
under test, it will probably be necessary to substitute 8k x 8 
bit SRAM' s (See Appendix 11) for the 2186's in production 
boards. At the time of writing the 2186 is suffering 
unfavourable price competition from the SRAM' s (See project 
Review Chapter 9); the 2186 is otherwise the preferable 
component - being fast enough for data memory and having in its 
DRAM structure an inherent low power consumption. Production 
artworks for the RAM board are under preparation and 
incorporate the techniques recommended by Intel (Ref. 10) for 
address/ground/power line tracking e.g., gridded ground 
planes and show an acceptable component/track density, 
suggesting the board will be suitable for volume production. 
During the course of the development of the RAM board the 
author experimented with a memory-mapped version of the RAM 
board with an on-board page register which could be loaded via 
the Bus; this design was discarded after consultation with the 
users of the system, due to the inconvenience of the 2K paging 
system adopted in the circuit. The design did have some 
potential application, though, especially for use as a video 
data store, as several RAM boards (using different memory map 
addresses) could be referenced within the same rack. The 
memory mapping hardware for such a board in basically the 
familiar 'LS85 comparator circuitry introduced in the previous 
chapter. 
- 61 -
Of relevance to the possible future development of RAM 
boards for the system is the recent introduction (Reference 30) 
of hybrid 32k x 8 bit (and also 128 x 8 bit) RAM chips. These 
parts use surface mounted components (notably four 8k x 8 
SRAM's) on a DIL carrier, giving a pin-out conforming to JEDEC 
standards, and offer the possibility of designing a page 
addressable RAM board with an 128k x 8 bit (or greater) 
capacity. 
- 62 -
CHAPTER 5 COMMUNICATIONS INTERFACES 
To interface to a variety of commercial devices, a number of boards were 
designed to support standard protocols. For example, a typical device to 
be found on or near one of the Company's production lines is a small 
industrial balance (for testing the weights of samples of specific 
products) - invariably fitted with either a 'current loop' (CL) interface 
or a BCD (binary coded decimal) interface. A typical device requiring 
two-way data transfers is a small (e.g. desk-top) microprocessor, such as 
the H.P. (Hewlett Packard) 80 Series - possibly used as a local 'host' for 
a data logging application. This device would be interfaced to the system 
using an HPIB (Hewlett Packard Interface Bus) interface as first choice, as 
the HPIB is an integral (HP86) interface, as it is with some other 
manufacturer's computers. 
Probably the commonest communications interface protocol is RS232 (Ref. 
12), the only protocol supported on many types of microprocessor; it was 
therefore essential to develop a board to interface to RS232. Each of the 
boards designed to enable the user of the system to interface to the 
protocols outlined above are now described at length. 
5.1. HPIB Board 
It would be inappropriate to attempt in this thesis to 
describe HPIB in detail; the complexity and depth of 
specification of HPIB can be grasped by examining the 
International Standard IEEE488 (Ref. 13). The author has 
included· (Appendix 4) a brief overview, together with details 
of the Bus Adapter chip (Ref. 14,15) 
The advent of a number of Bus Adapter chips has of late 
considerably eased the engineer's task when faced with an HPIB 
- 63 -
interface design. Several chip-sets are available (e.g. from 
Texas Instruments, Motorola, Intel, etc.), but the Fairchild 
96LS488 has the unique advantage of not requiring a dedicated 
host microprocessor the device has enough on-board 
intelligence to handle the Bus protocol asynchronously. This 
allows the user to address the HPIB Bus via the Adapter chip 
using a simple set of handshake lines, facilitating read/write 
and status interfacing. 
The 96LS488 has the further advantage of in-built 48 rnA Bus 
buffers for the Management/Data Bus logic. This means that the 
single Fairchild chip provides a direct interface to the HPIB 
Bus that is equivalent to the three-chip solutions provided by 
other vendors yielding advantages in size, cost and 
complexity. Indeed, as regards size, the 96LS488 solution was 
probably the only viable design option for the board area 
available. A disadvantage of the 96LS488 is its inability to 
handle the controller function i.e. it is restricted to 
talker/listener functions. As the talker/listener mode is the 
expected operating mode in the applications foreseen for the 
equipment, this is not seen as a major disadvantage; the design 
of a separate HPIB controller card is not a difficult task, but 
such a card is not required by the Company at the present time. 
Figure 5 .1. shows the circuit of the interface. The full 
facilities (Appendix 4) of the 96LS488 (Ul) have not been 
exploited, due to in part to the size restriction of the 
half-Eurocard board, but also because of the fact that they are 
in excess of the Company's requirements. The mode inputs have 
been preset to the 'fast talker/listener option', which is the 
- 64 -
I 
0' 
\.11 
I 
r-----~ffi 
(SF.E TABLE 5.1 FOR KEY 
TO SIGNAL A8BREV1AT10NSI. 
u~ 
[ "'i; 
~ Q.2k ~ S.ZI 
XTAl. 
IPOAT 1 JUMPE'R OFT:OrJSl 
~ 
.. 
'L---------<1 
Figure 5.1- HPIB Board Circuit Diagram. 
Copyright G) Glaxo Pharmaceuticals 11:!85. 
USa1 
!U:ID.. 
U5d 
~ 
correct choice for the tri-state Data Bus drivers used 
externally. These are implemented with the 74F240 (U2) 
package, which has the required 48mA capability as specified in 
IEEE488. This provides the buffering for data bytes presented 
to the HPIB when the Talker function is being implemented. The 
bytes are held in the '574 octal latch (U3) until the HPIB is 
ready to accept; this is achieved via the triple-wire handshake 
(Appendix 4), which is handled by the 96LS488 (Ul) - the DRB 
(active LOW) signal enabling the data onto the HPIB. Extra 
gating has been used (Ref: 14, 15) to eliminate the extra DRB 
pulses that the '488 emits during serial poll response; these 
are active LOW pulses used to multiplex status bytes (if 
required) onto the HPIB, but the author has preferred to 
implement the simpler IEEE488 option - that is to drive DI07 in 
response to serial poll, which the '488 achieves using its RQS 
output (pin 23). 
Circuit Signal Signal 
Abbreviation Group Name 
Dl - DB HPIB Data Bus DIOl - DI08 
E HPIB Man. Bus EOl 
DV II DAV 
ND II NRFD 
NC II NDAC 
I II IFC 
s II SRQ 
A II ATN 
R II REN 
RS Poll response option RQS 
D Status multiplex D/S/E 
DB Data enable DRB 
RD Handshake RXRDY 
RT II II RXST 
TD II II TXRD 
TT II II TXST 
SD II II STRD 
ST II II STST 
IT II II IST 
T Control Trigger 
c II Clear 
RV SRQ Prompt RSV 
Table 5.1. - Key to Signal Abbreviations 
- 66 -
The transmit handshake pair (TXReady and TXStrobe) 
set/reset the transmit handshake latch U4a (74LS74), the other 
half of the D-type flip-flop (U4b) being used to implement the 
corresponding receive handshake latch. Open-collector 'LSOS 
buffers (USa, USb) are used to drive the backplane interrupt 
lines INTO and INTl; the jumper set provided allows the 
required combination to be selected. The card is memory mapped 
(U7/U8c) using the '85 comparator circuit common to the other 
memory mapped cards already described (see Chapter 3). Gating 
of WRITE and the '85 output derives the (rising edge) latching 
pulse for the '574 latch enable input, allowing the data bytes 
from the backplane Bus to be admitted to the interface. 
The data held in the (U3) latch is enabled to the HPIB Bus 
by U2 when DRB pulses LOW (this occurs when Ul sees the 
listening device signalling that it is ready for data - via 
NRFD). As indicated above, extra gating is used (U8d) to 
inhibit DRB enabling U2 during poll response. A two input OR 
gate was used on the prototype version of the card to gate DRB 
and D/S/E, but this required an extra package, and the card is 
already highly populated. Hence a spare function in the LS125 
package has been pressed into service as a logic gate as a 
pre-production experiment to attempt to ease circuit tracking 
problems. (Another section of the package - U8c - has been 
similarly experimentally used as a logic gate to gate RD with 
the U7 output signal). 
The card receives bytes from the HPIB when in Listener mode. 
A 74LS540 inverting buffer is used to accept bytes from the Bus 
- it is unnecessary in this case to latch the byte, as it is 
- 67 -
the responsibility of the Talker device on the Bus to hold the 
byte on the Bus until the triple handshake is complete. This 
will be the case when the 8751 takes the data byte via a 
backplane READ, which also drives the RXStrobe handshake line; 
the '4B8 takes its cue from the RXStrobe (active HIGH) pulse, 
and completes the HPIB handshake with the Talker device. 
The receive and transmit status bits latched by the '74 are 
,-
enabled onto the bus during a status read operation via a '125 
tri-state buffer. The READ signal is gated with AO, thus 
mapping data (NXXO - where N is the card address) and status 
(NXXl) into adjacent memory addresses; using contiguous memory 
map areas for related peripheral functions is a recurring 
technique used on several cards in the system, including the 
BCD and UART cards, whose descriptions follow. 
Plate 5 .1. shows a photograph of a prototype HPIB board. 
The visible components on the front panel are the 24-way IEEE 
488 connector and the rotary hexadecimal switch used for HPIB 
address selection. Early prototype boards used discrete 
transistors to accomplish the open collector interrupt 
functions implemented by USa and U5b in figure 5.1. - this is 
generally true to most boards in the system. The 
pre-production designs published in this thesis are the 
embodiment of a consistent philosophy - elimination of discrete 
circuit components wherever possible, minimization of circuit 
components, and optimization of tracking densities on all 
production PCB's. 
5.2. BCD Board 
The BCD board (Plate 5. 2.) features it's own single-chip 
- 68 -
micr.oprocessor, an Intel 8748. The author decided on this 
design approach after considering and rejecting various other 
circuit configurations involving 'semi-intelligent' chips such 
as PIA's (Ref. 16) and suchlike. The requirement was for an 
interface capable of handling the variety of BCD output devices 
that are currently manufactured. These items of equipment 
often feature thirty or more signal output lines which can 
release their data simultaneously consider, for example, 
eight BCD digits requiring four lines per digit - a total of 
thirty-two output lines. Alternatively, the equipment may have 
been designed to emit the data in 'bit-parallel-byte-serial' 
form, in which event the number of signal lines would be 
relatively small. 
Every BCD device is equipped with handshake lines; often 
there is a 'flag' line (sometimes more than one) to indicate to 
the 'host' that the data is available on the data lines. The 
flag line may be either active HIGH or LOW, pulsed, or held at 
a logic state for the data duration also the flag line 
transition may occur before or during the period the data is 
valid. A handshake line operating in the reverse direction (an 
output from the host) - usually termed a 'control' line - may 
also be required, to tell the device to perform a function 
and/or release data. The control line may drive an active HIGH 
or LOW signal, and it's timing requirements may be as varied as 
those of the flag line. To allow for all permutations of logic 
levels etc., the interface needs the uncommitted logic of a 
microprocessor, which also can handle the buffering of the data 
and the data exchange with the 8751. 
- 69 -
Plpte 5.1. (above) 
The HPIB Board 
Plate 5 . 2 . (right) 
The BCD Board 
. 
.. 
70 
• 0 
. .. 
~ . 
• • 
~ . 
. . 
~ 0 
.. ~ 
.. 
~ 
• 
f3C O 
The 8748, the forerunner of the 8751, remains an important 
single-chip microprocessor in its own right - being still the 
first choice of many designers for small low-cost systems. 
This is mainly due to the second- sourcing of the device 
bringing the unit price down to less than fifteen pounds 
(1984). The microprocessor (Appendix 5) has similar (but less 
comprehensive) features to those of the 8751 - the most obvious 
differences being the amount of EPROM (lK), number of ports (3) 
and lack of serial I/0. The ability to extend the device's I/0 
facilities using the associated 8243 I/0 expander greatly 
enhances the 8748's range of application. The 8748 uses part 
of one of its ports (port 2) as an expander Bus; the four-bit 
Expansion Bus allows 8243 's to be addressed using special 
instructions within the 8748 which make the 8243's appear as a 
transparent extension of the 8748's I/0. 
Figure 5.2. shows the circuit design of the BCD board. Each 
8243 has four four-bit ports which may be individually 
addressed by firmware within the 8748. Two (U2, U3) 8243's 
have been assigned to the 8748 (Ul) in this application, 
allowing a range of eight BCD dig~ts to be read simultaneously 
- if required. The chip enables for the 8243 's are driven by 
8748 port pins, timing signals being emitted automatically on 
the PROG pin. The front panel of the BCD card houses a 
thirty-seven way 'D' -type socket, thirty-two pins of which are 
the input connections for the expander chips; two of the 
remainder are connected to Ground and the 5v line, the rest 
being handshake signal lines. Two buffered (input) flag lines 
(U7e, U7f) are provided, and one buffered (output) control line 
(U7d). 
- 71 -
I 
-...J 
N 
I 
n~ 
... 
... 
o---
0-=-
o--
o--
o--
o---
~f~ 
13 
tr-1 
Sv 
cs 
b 
U2 
II ~ 
FOG I I I I I P2.5 
P2.6 
P1.5 
m 
~ ~ 
~~,, ' ~~ U1 .. :PORT ~ ~ I r-~ 
~'I I no , E 
P2.3 ~ ~ P2.3 PROG 
U4 
T1 Pl.1 
"'7.1 jf>1.2 u 
~ ~ 
INTO 
RESET 
LATCH 
g 
DATA 
a: A I @=-1~ 
[;!) @ ":" 
! 0 
I 0 
() 
0 
0 
t>7 t: ~ 
c--
o---
c--
o-
o---
QH~ . § ~ f&~~.....--..~ I.A.. L ~~2211 
U5 
~ -:u~=--~!rr~~:_jl ~' 
~r: ~ 
0 (ll 
()) I!) 
@ 0 
@ @ 
@ @ 
0>-----
c--
u 
o--
-
Sv 
=31 
HANDSHAKE BUFFERS 
~ 
_A 
E 
U3 
4-7 
PROG 
~-r )ti 
I!) 
I!) 
c: 
0 
0 
0 0 
© 0 
0 0 La --1 ~~~ USc 4 
!Ilk 
Sv 
~ 
I 
o-32 II 
Figure 5.2 --- The BCD Board Circuit ~JL Diagram. 
Copyright (£) Glraxo Pharmsceutlcals 1S85. 
I 
The Bus port of the 8748 (port 0) is used as an output port 
(NOT as a Bus, but in its alternative usage as a conventional 
port) to drive data into the two '574's, which are employed as 
latches (U4, US) for status and data bytes. Data to be latched 
is first loaded into the port 0 output latches within the 8748, 
before the appropriate latch enable is taken through a 
low-to-high transition; the latch enables are driven via spare 
port pins, as for the 8243's. The eight-bit latches are 
preferred to four-bit latches so that BCD digits may be passed 
to the 8751 in pairs rather than singly, thus minimizing the 
burden on the 8751 interrupt handling firmware; the BCD 
interface forces an interrupt of the 8751 after it has updated 
the data in the latches. The status latch is used to pass the 
byte count to the 8751 and to indicate (status bit seven) that 
it was the device originating the interrupt. The interrupt is 
driven by an 8748 port pin, which is buffered by an 
open-collector inverter (U7c) to the INTO interrupt line on the 
backplane, lack of board space inhibiting the use of jumpers 
to allow the user a choice of interrupt lines. 
When the 8751 is interrupted by the 8748 it polls the status 
registers (serial poll) of the devices within the rack until it 
locates the device that originated the interrupt. In the case 
of the BCD interface, the 875l's next action would be to read 
the data byte; as the output of U8b (Status add. decode) is 
also wired to the interrupt pin of the 8748, this initiates an 
8748 interrupt, thus informing the device that it is time to 
update the latches, i.e. set up the next status byte. A 
description testing of the firmware for the 8748 can be found 
- 73 -
in Appendix 6, together with a description and flow diagram 
relating to 8748/8751 interaction. 
5.3. The DART Board 
The DART uuaru is one of three serial interfaces developed 
for the system (descriptions of the RF Board and the Serial 
board can be found in Chapter 6; the latter interfaces are both 
slaves to the serial port). It allows the user to address a 
number of serial devices other than the single device 
addressable via the serial port. With the aid of a number of 
DART cards the system user can conveniently implement, for 
example, a serial multiplexer. A circuit diagram of the DART 
card is shown in Figure 5.3; the interface supports both RS232 
and 20 rnA current loop, the latter being fully configurable to 
either active or passive loop on both transmit and receive 
lines. Appendix 9 details how the various options may be 
selected on the card. 
5. 3 .1. The 8251A USART 
The 8251A device is an indus try standard 
8085-Bus-type serial device originally developed by 
Intel, but now second-sourced by several companies -
NEC parts were used for the prototype tests. Although 
the 8251 is officially designated a USART (Universal 
Synchronous/Asynchronous Receiver-Transmitter), the 
author, after discussions with staff in the Company's 
Computer Services Department, reached the conclusion 
that the synchronous facilities offered by the device 
were not required; therefore this part of the USART 
remains unused within the interface design, and the 
- 74 -
device is referred to as a UART for simplicity. The 
8251A is designated Ul in the circuit diagram; being a 
standard 8085-type peripheral, it is a simple matter 
to interface the UART to the system Bus. 
Unlike, for example, the 6402, the DART is a 
software configurable device, the configuration being 
achieved by loading its internal Bus-addressable 
command registers via a series of commands from the 
host processor (8751) - full details of these commands 
and other aspects of the operation of the DART, and 
facilities available, can be found in the device's 
data sheets (Ref. 21) and the Intel Application Note 
(Ref. 22). The status registers inside the DART may 
be read by the host's firmware at any time, to 
determine the current state of the device. A control 
line, assigned to address line AO, is used to select 
transfers of data or status/commands (according to the 
state of the read/write lines) as shown in Table 5.2. 
below: 
AO R w Interpretation 
0 0 1 Read data 
0 1 0 Write data 
1 0 1 Read status 
1 1 0 Write Command 
Table 5 .1. - Showing the use of AO to select registers within 
the 8251A 
5.3.2. 8251A-8751 Bus interface 
The interfacing of the device to the 8751 is, in 
truth, a straight-forward implementation of the 
- 75 -
I 
...... 
0' 
I 
20mAFill 
20mAFblum 
13 & 0 
o-- us 
0 0 ..---il-+----1 
0 
0 0 
DTR 0 0 
~~~ 
0 
0 
0 
0 
~8b 
_,., 
:l o I U8 
t 
•r---------oo---~~~Zv 
2k~ $ 
BC477 
~~ 
I I 
9.2v T o.tu 
---b-JJBCWJ' 
2k ~ :> 15() -1Zv l___i___j 
_pESEJ 
~-------------@A ~ 
.c 
~~ ~ C A RESET 
CH ~>-~-~~ 1--{--o.l.l-
0 U7a @ 
U7c 
J\J:lll~FOR 
RS232/CURRENT 1..00P 
o-
r----, 
.---~--, 
0 
g 
<0 
o-t--1f-+--! 
I()) 
~f--'1 
0 ~ 
0 @ 
0 g 
iC)) o---
0 ~1 
lO 10 
@ 
<OJ 
@ 
@ 
0 
iC)) 
@ ()) 
@ 0 
0 0 
([ll ~U4~~~1 ~ r , 's.!~Y"' 
22JJY 
.JL 
Copyright (S) G!wto PhG1"1!1eCl!l.Jtlcsls 1SS5. 
Application Note listed above, the 8751 having the 
8085 Bus structure as related earlier in this thesis. 
The same '85 (U3/U2c) comparator circuits 
(covered in the DVI Board description, Chapter 3) as 
used on other memory-mapped boards are used to select 
the UART, when addressed. Also, in common with 
circuitry on other boards, the backplane signal on 
Pl.6 (peripheral/memory select) is inverted (U2d) and 
used to enable the comparator. Transmit/Receive Ready 
pins drive the backplane interrupt lines (INTO/INT1 -
selected by jumpers) via open collector buffers 
(U2a/U2b). 
5.3.3. Baud rate generation 
The board rate is selected via a switch bank (see 
Table 5.3. below) connected to an industry-standard 
4702 baud rate generator (U4), allowing the user to 
operate in asynchronous full-duplex mode at rates up 
to 9600 Kilobaud. 
S3 S2 S1 so Baud rate 
0 0 0 0 I 
0 0 0 1 I 
0 0 1 0 so 
0 0 1 1 75 
0 1 0 0 134.5 
0 1 0 1 200 
0 1 1 0 600 
0 1 1 1 2400 
1 0 0 0 9600 
1 0 0 1 4800 
1 0 1 0 1800 
1 0 1 1 1200 
1 1 0 0 2400 
1 1 0 1 300 
1 1 1 0 150 
1 1 1 1 110 
Table 5.2. - Baud rate selection 
- 77 -
5.3.4. 
The baud rate generator's (16x) output is used 
clock both the transmit and the receive circuits of 
the UART - lack of board space prohibiting independent 
clock circuits. Thus the UART board cannot be used 
for applications where differing clock rates are 
required on the receive and transmit lines. This is a 
rare requirement, 
limitation. 
and is not seen as a major 
Handshake lines 
The UART supports the primary (CTS/RTS) and 
secondary (DTR/DSR) handshake signals associated with 
RS232; these I/0 lines may be examined or modified 
(where appropriate) via the 8251A's internal 
status/command registers. Details of these registers 
are given in Appendix 9 - which also deals with the 
initialization of the device. The Company's use for 
the UART board on projects requiring serial 
interfacing with handshaking are confined to RS232 -
hence the handshake lines have not been provided with 
current loop options. The options are allowed for 
only on the serial data lines, the common use being to 
communicate with a small (e.g. Mettler PL200) 
industrial balance via current loop (current loop has 
a superior noise immunity relative to RS232), such a 
balance either requiring no handshaking whatsoever, or 
providing a 'software handshake' with control 
characters (such as XON/XOFF) in the data stream. 
- 78 -
5.3.5. 
5 .4. Review 
RS232/Current Loop Drivers 
As explained earlier, the interface can support 
both current loop and RS232 protocols. The driver 
circuits are common to both the UART and the Serial 
Boards and are covered in detail in the next chapter, 
which deals with the Serial Board (section 6 .1) and 
the RF Board. The Serial board lacks the ability to 
support the RS232 secondary handshake (DTR/DSR), 
although it does support the primary handshake 
(CTS/RTS). Hence the 8251A's secondary handshake 
lines are also provided with RS232 buffers; the 
buffers used are Fairchild ul488 (U8) and ul489 (U9) 
types (Ref: 23), which are industry-standard parts 
available from a number of alterative sources. The 
current loop transmitter (US, HCPL-4100) and receiver 
(U6, HCPL-4200) circuits are covered in the next 
chapter, section 6.1.2. 
All the communications boards were tested in prototype form 
in combination with the CPU and watchdog boards, using the 
PDS's emulator to monitor the testing. Some use was also made 
of the serial Board (Chapter 6) as detailed below. All boards 
were given a DC check-out before system testing commenced. 
5 .4.1. HPIB Board 
An HP85 desk top computer was used as a host device 
for the HPIB tests, being capable of supporting the 
controller/talker/listener modes of operation. Figure 
5. 4. shows the physical connections of the various 
devices used for testing. The HPIB board was tested 
- 79 -
0 
00 
0 
0 
~ 
SUB-MIN. RACK 0 
0 
v ~ I CPU I I HI=IIS I 
[DOl I I ~ 
P.O.S SYSTEM D = HP~5 
J 
.\ida \\ I h ..il r _) 
Figure 5.4 - Schematic Diagram showing HPIB Board Testing. 
for its talker/listener functions and for its handling 
of clear, trigger and SRQ options. 
5.4.1.1. Talker/listener tests 
Because of the efficient triple handshake 
that is the heart of HPIB (Appendix 4), 
testing of bidirectional data transfer on 
the HPIB was relatively straight-forward. 
To transfer data to the HP85, a small PDS 
emulator routine was written (using the 
high-level macro-language); a PBYTE command 
was used to write a data byte to the HPIB 
card and the status register was examined 
using a second PBYTE command. The routine 
repeatedly wrote data bytes to the HPIB on 
detection of the 'Tx Ready' state by 
performing an infinite loop. The HP85 BASIC 
program consisted of a simple ENTER - and -
DISPLAY loop. A compare statement was added 
to this simple loop at a later stage, to 
allow soak testing of the board. The 
modified program checked that consecutive 
data bytes were identical and counted any 
errors. Repeated tests used different data 
patterns designed to check-out all the Bus 
lines. 
Testing of the Listener function of the 
HPIB interface was essentially the reverse 
of the above procedure; the HP85 's simple 
- 81 -
BASIC program consisted of an OUTPUT 
statement within an infinite loop. (The 
HP85's participation in the Bus handshake is 
to the high-level BASIC transparent 
language). The emulator's program loop 
consisted of instructions to read the 
status register (to check for the arrival of 
characters from the HP85) and to transfer 
data bytes as they arrived (as indicated by 
the status bits), displaying the bytes on 
the screen of the PDS they were received. 
The only problem with the testing of the 
Talker/Listener functions concerned the 
power-on state of the interface; after 
power-on the U8ajU8b status bits are 
incorrect - a problem that could be remedied 
by applying a power-on reset to the U4, or 
by issuing a dummy data read in the 8751 
host firmware. Othe~-wise, no logic errors 
were detected during testing. 
5.4.1.2. Miscellaneous 
A small assembler routine was written to 
check the operation of the INTO and INTl 
lines, which are driven by USa and USb. 
Interrupt vectors were used to vector the 
interrupts to memory traps. The HP85 was 
used to drive the trigger and clear option 
lines remotely, and also to test the 
operation of the SRQ line via the RSV option 
- 82 -
5.4.2. BCD Board 
on port 1. 
satisfactory. 
All the above tests proved 
As TRIGGER and CLEAR are 
pulsed signals, they are of marginal value -
R/L would be a better choice to either, as a 
fixed logic level is maintained. SRQ is a 
very useful HPIB signal, and well worth 
implementing; it affords a means by which 
the 8751 may interrupt the host computer. 
Despite the efficient operation of the 
interface, it remains too complex (i.e., the 
chip density is 
production and 
rationalization 
too high) for mass 
some 
is 
further 
desirable. 
circuit 
One 
possibility is to replace U2 and U3 with a 
single component; several CMOS latches are 
made with high-drive open-collector bipolar 
output stages which may be suitable. 
Lack of an 8748 assembler for the PDS limited the 
testing of the BCD interface to a check-out of the 
various logic elements that are present on the board -
the 8243's, the 8748, the 574 latches etc. as outlined 
in Appendix 6. These logical tests allowed the 
integrity of the interface design to be established. 
More sophisticated firmware routines for the 8748 will 
be written at a later date by the staff of Company's 
Computer Services Department. 
- 83 -
5.4.3. 
The physical layout of the board is dominated by 
the three major chips (Ul, U2 and U3) , which means 
that only minor improvements can be made to component 
densities, which are high on this board. The simple 
U4/U5 latch system used to conununicate with the 8751 
host is effective in operation but suffers from two 
drawbacks: firstly, it is unidirectional, and secondly 
it is redundant in component utilization. A possible 
improvement in the design would be to replace the data 
latch with a bidirectional buffer, allowing both 
reading and writing (with modified gating) to be 
performed. The data latch is not strictly required as 
the Ul port 0 latches can perform the latch function 
for the data byte. 
UART Board 
The 8251 UART, as stated earlier, is a standard 
Intel Bus part, and as such presented few problems to 
interface to the 8751. Testing the device consisted 
of initialization of the 8251 (setting up options in 
it 1 s internal register) and checking out the serial 
data flow through the UART. 
covered in Appendix 9). 
(Initialization is 
Checking the device 1 s serial data handling was 
achieved using a similar test arrangement to that 
shown in Figure 5. 4. , with the UART board replacing 
the HPIB board in the rack. The HP85 (using the 
HP85 1 s serial interface) monitored transmitted data 
and sourced the data for the 8251 1 s receiver tests in 
a similar manner as for HPIB tests. Tests were made 
- 84 -
at several different baud rates to a maximum rate of 
9600 band without any difficulties being encountered. 
The above tests were made with the current loop and 
RS232 options in turn (the '85's serial interface 
supports both options). The active and passive 
options on the current loop interface were both 
tested. When testing (either RS232 or C.L.) without 
handshake lines, it was necessary to hold the CTS line 
high (pin 5 of the 25 way connector) - clearly the 
provision of +/- 12v supplies on the 'D' connector 
would be useful. The action of the various handshake 
lines was checked by means of the HP85's 
control/status registers, and the corresponding 
control/status registers within the 8251. 
Compared with the BCD board the UART board has a 
relatively low density of chips per unit area of board 
and is therefore a suitable device for mass 
production. Some of the discrete devices 
(transistors, diodes, resistors) may be replaced by 
SIL or DIL parts; suitable transistors arrays are ,......._ __ 
discussed in Chapter 6. DIL or SIL resistors arrays 
are used on all boards for pull-ups etc., the aim 
being to produce boards composed of SIL or DIL 
components aligned parallel to the 32-way DIN 
connector, permitting the board to be flow soldered. 
- 85 -
CHAPTER 6 - THE SERIAL PORT INTERFACES 
Earlier in the thesis (Chapter 3) the 875l's on-board UART was briefly 
discussed. This chapter discusses the device more fully (below), and gives 
details of the two slave interfaces designed to service the serial port. 
The serial port of the 8751 is serviced by on-board full-duplex USART -
which will be treated in this thesis as a UART, as the system does not 
utilize the synchronous facilities at present. The baud rate (See 
Appendix 1), which is generated using an internal counter, is a function of 
the crystal frequency; the upper limit is 9.6 Kb for the 3.6864 MHz 
crystal, and 19.2 Kb for the 7.3728 Mhz crystal. 
The serial I/0 is routed through a single buffer (SBUF) whose state is 
monitored by a serial control register (SCON), which also allows the user 
to configure some of the many options available - such as 8/9 data bits, 
interrupts etc., etc. These and other registers (see Reference 1) are used 
to generate functions associated with parity checking, receiver/transmitter 
disabling and so forth. When operated in 9-bit UART mode, the 8751 has a 
most useful master-slave mode of operation which is ideal for polling 
devices in a multi-drop communications environment. Further details of the 
various modes of operation of the serial port are contained in Appendix 3. 
6.1. The Serial Board 
Externally (See Plate 6 .1.), the board resembles the UART 
board described in the previous chapter - i.e., it has the same 
25-way 'D' type socket on the front panel, and supports the 
same protocols (RS232 and current loop). However, the 
interface is, unlike the UART board, a simple buffer-type 
interface with no inherent intelligence. The lack of an 
intelligent device with internal command/status registers on 
- 86 -
Plate 6 .1. The Serial Board 
Plate 6.2 . The RF Board 
- 87 -
the board has certain drawbacks, and the interface supports 
RS232 handshaking with difficulty - see section 6.1.1.2. below. 
Another design problem that the author encountered was the 
means of baud rate ::;elet;Liun - Lo make Lhe baud rate switch 
selectable on the board would have meant the introduction of 
memory mapping hardware, as used on other boards (e.g., the DVI 
board, described in Chapter 3) , resulting in a hybrid board, 
with data being accessed directly via the serial port, and the 
baud rate being read from a memory-mapped buffered switch bank 
an inelegant solution. Because of the rather limited 
deployment that the serial board will experience (for most 
applications the RF Board will be preferred) the author decided 
that it was sufficient to allow the Baud rate to remain simply 
as a firmware selectable parameter. 
6 .1.1. RS232 Facilities 
The ubiquitous RS232C protocol (Ref: 12) is the 
standard protocol for a profusion of applications, 
originating from data transmission (modem) standards 
(CCITT V24 Ref. 33) but now commonly used for 
computers, printers, terminals and many other devices. 
It utilizes transmission signals with a wide voltage 
swing (typically, the range -12v to +12v is 
implemented), data signals having reverse polarity 
with respect to handshake signals. The operating 
range as defined is limited to 50 foot of transmission 
line, although RS232 signals are often transmitted 
over significantly longer distances at modest baud 
rates - low frequency signals are less 
- 88 -
6.1.1. 
affected by the dispersive properties (Ref. 25) of the 
line. 
RS232 Data Signals 
The 8751 serial port pins are directly connected 
(see Chapter 3) to the backplane (pin C26 = Txdata, 
pin C27 = Rxdata), and support TTL level signals. The 
serial board buffers these signals using either RS232 
buffers or current loop drivers/receivers (see 6.1.2. 
below); a jumper is provided on the receive line to 
allow selection of the option required. The circuit 
diagram of the serial board is shown in Figure 6.1; 
the transmit data line is buffered to pin 2 of the 'D' 
socket by Ula (RS232 quad line driver Fairchild 
ul489). Data received on pin 3 is buffered to 
backplane pin C27 by U2a (RS232 quad line receiver -
Fairchild ul488). The sensitivity of the line 
receiver can be adjusted by varying the voltage on pin 
3 of the package, but on the prototype board the pin 
was connected to the supply rail via a pull-up 
resistor. This proved an adequate system for 
short-range communication, which is the mode in which 
the board will operate. A potentiometer acting as a 
potential divider could be added to the production 
versions of the board as a sensitivity control later, 
if required. 
6.1.1.1. RS232 Handshake Signals 
The possibility of using memory mapping 
hardware to read baud rate selection via a 
- 89 -
a 
\0 
0 
a 
eao 
0 
0 
tll 
0 
0 
0 0 
0 0 
'I'll~ 0 02, 
o o-:-
o CTS 
0 - RT8 
0 ~fbi 
0 ~ ~0 .... 
I ~ 
-
Wll7 
fbi 
R:lilan 120;:-.AI 
I 
~ 
J 
II 
II 
Wum~DGr for h6lndshakG o[Gtlons) 
::~--~==="0 ~·$ 
~a 
______!/1_____ -····· __ l __ 
I I 
r-----, 
~ I o~ 
@ @ 1>1.1 
(l) @ 
I!)) @ 
@ @ 
@ @ 
0 @ 
@ @ 
@ 
© 
·@ 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
© 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
@ 
~1 ~ ~ ¥ l-~,..C.-L.-~4~"""'~::! 
~~ U3 1 @---@-x!\1 
·------- ~~ 
" 1 o--+-o--~ ! , I @-1124li ~ 
~ 
U4 I 
~ 
-~I 
£ttll'l' 
Figure 6.1 - Circuit Diagram of the Serial Board. 
CoPYl'lght ® Glwto Pntilrmoczuilccla ~~5.. 
buffered switch bank further suggested to 
the author the possibility of using memory 
mapping hardware for reading the state 
(using a '245 buffer as a status buffer) of 
the RS232 input handshake lines and 
controlling the RS232 output handshake lines 
(using a '~74 latch as a control register). 
Again, this approach was rejected, because 
(as stated before) of the rather clumsy and 
inelegant hybrid solution that would result, 
and also because of cost - the memory 
mapping hardware and status/control 
circuits, baud rate switches and buffers 
would result in a design requiring a 
relatively expensive double-sided PCB 
artwork. The author was advised by 
potential users of the system of the 
strictly limited applications that were 
foreseen for the serial board, and that a 
fairly unsophisticated design was required. 
As a result of these comments, the author 
decided on an inexpensive solution - to 
buffer the RTS and CTS handshake lines (as 
for the data lines above) with RS232 buffers 
and to jumper the buffered signals to the 
backplane. Ulb (ul488) is the output 
handshake buffer, which drives RTS on pin 4 
of the 'D' connector, while CTS (pin 5) is 
buffered by U2b. The two bits of port 1 are 
- 91 -
6 .1. 2. 
'borrowed' when the handshake option is 
implemented (Pl.O and Pl.l). For the 
reasons given in the previous chapter, 
(section 5.4 - the UART board) no attempt 
has been made to provide handshake 
facilities for the current loop options. 
Current Loop Facilities 
The need for current loop options on the serial 
// 
interfaces was explained in ~he Chapter 5.Current loop 
I 
protocol is simple to comprehend, being derived from 
the original telegraph signalling system: a logic 
'one' is indicated by the presence of a 20 rnA current 
in a closed loop - hence the name. The absence of 
loop current (open circuit condition) indicates the 
logic 'zero' state; these signals states are often 
referred to as 'marks' or 'spaces' - common terms in 
serial protocol parlance. The equivalent of the 
telegraph Morse key in modern current loop interfaces 
is the bipolar transistor which is usually 
conveniently incorporated in an opto- isolator, thus 
implementing the dual functions of isolation and 
switching in a single device. 
Two chips recently introduced (by Hewlett-Packard) 
enable engineers to design current loop Rx/Tx hardware 
with the minimum number of circuit components. These 
items are the current loop transmitter (HCPL-4100, U4) 
and receiver (HCPL-4200, U3) which have TTL 
compatibility as an in-built feature. The TTL data 
stream entering pin 6 of U4 is converted into an 
- 92 -
isolated switched output without the need for further 
external components. Similarly, current loop data 
passing through U4's isolation diode is converted into 
a TTL data stream which is presented the output (pin 
i) . The receiver chip contains buffers with 0. 8mA of 
input threshold hysteresis incorporated into their 
input circuits; both chips are much more sophisticated 
than simple opto- isolators and are specifically 
designed for 20 mA current loop circuits. The 
internal circuits of the devices contain buffers which 
provide a metered current feed to the isolation LED's 
providing compensation for LED light output 
degradation, thereby improving reliability. 
The Txdata signal from the backplane is fed 
simultaneously to both the RS232 buffers and the 
current loop circuits. Received data from either 
source is connected to the Rxdata backplane signal 
line by means of a two-way jumper, as shown in Figure 
6 .1. Options (See Appendix 9) are provided for both 
passive and active current loops in the receive and 
transmit circuits. The current loop sources (BC477 
circuit) and sinks (BC107 circuit) are conventional 
base-referenced bipolar circuits; decoupling is 
provided on the base of each transistor in an attempt 
to minimize destablization of the reference voltages 
by environmental noise. 
6.2. R.F. Board 
The purpose of this board (See Plate 6. 2.) is to allow 
serial communication over long distances (e.g. 500 metres); it 
- 93 -
is derived from the R.F. transmit/receive hardware used on the 
original scheme. The two halves of the circuit are described 
separately below. The circuit diagram is shown in Figure 6.2. 
6. 2 .1. R.F. Transmitter 
This section of the circuit is similar to the 
original version described in Chapter 2, the major 
difference being the choice of oscillator. The use of 
the 567 as a VCO in the original system resulted in a 
cheap simple design, but the 567 lacked the necessary 
temperature stability, requiring the oscillator to be 
trimmed when the temperature inside the die-cast box 
had stabilized; this was unimportant for the pilot 
scheme, as the equipment was left running permanently, 
and therefore required no further adjustment. It 
should be stressed that drift was expected - in fact 
it is specified in the data sheet for the '567 (Ref. 
2) and not excessive. However, the use of trim 
potentiometers is clearly undesirable, so a quartz 
oscillator module (PX0-1000) was used instead. The 
oscillator frequency chosen (200 KHz) was sufficiently 
close to the original frequency as to allow the 
majority of the component values of the receive 
circuitry (see below) to remain the same. The 
oscillator allows dynamic frequency shifting by means 
of external programming pins (unused pins are held LOW 
by internal pull-downs); data logic zeros present on 
pin 2 (see Figure 6. 2) drive the oscillator to a 
frequency outside the pass-band of the PLL's (see 
below), thus reducing cross-talk risks, as discussed 
- 94 -
I 
\0 
\J1 
g 
75 Ohm 
Coax. Line 
,-
1 I ; -L~; ~r~e~- - - - - ~ ~ 
U2 
6=~-=-=----...!1 
m.?' ! n n-,. 311 I 
5v 
UP; 
~ 
~ 
Wlli! 
Line Gating 
--
517 
0 I l3 n n n II ?"""'! 
( A 
ltP~ 
101 ;~co (!)! 
0 @ ll 
0 @ 
@ @ 
@ @ 
@ @ 
@ 0 
@ 0 AESI!T 
@ 0 
@ @ 
@ @ 
@ © 
@ @ 
@ @ 
© @ 
@ @ 
@ @ 
@ @ 
@ © 
@ @ 
@ @ 
@ © 
@ @ 
© 
I II 0 
~ 
~rr i .Sv 
@-@ 
C===© 
@-32 
""' 
Figure 6.2 - RF Board Circuit Diagram. 
CoWJ!glrt €) G!wto Fi'tlilm!G:I:Cl.!i!c':.!o 1!rn5. 
6.2.2. 
in Chapter 2. The line driver circuitry is the same 
as described in that chapter, except for the 
additional gating of RESET, to eliminate start-up 
noise. 
Receiver 
The receiver uses the successful '567 PLL circuit 
used in the original system, but with one major 
difference - two identical PLL's are used in tandem. 
One of the undesirable characteristics of the 567 
circuit was it' s tendency to ' spike' to logic ones 
within the start-bit interval. This somewhat rare yet 
annoying habit was attributed to charge build-up 
during the line idle state. The effect could be 
easily monitored on an oscilloscope by repeatedly 
transmitting the binary character 01010101 (ASCII 
'U'). The author's first attempts to eliminate the 
effect using analogue filters proved more cumbersome 
and less effective than the technique finally adopted 
- two tandem PLL's forming a 'statistical filter'. 
The basis of the technique hinges on the open 
collector output characteristics of the circuit. 
Tying the two outputs to a common collector load has 
one important implication - the feedback conditions of 
the two loops are inter-linked; thus, because the 
logic LOW state predominates, a loop attempting to 
break out of lock will be restrained by the other. 
This is so because no two loops have exactly the same 
characteristics, because of minor variations during 
- 96 -
6.3. Review 
manufacture. Thus, because the rogue transients are 
so narrow, and because they occur during different 
time intervals (in fact, usually only one loop 
'spikes' during any particular start-bit interval), 
the output of the receiver PLL's is a clean noise-free 
serial data stream. Spare Schmitt trigger functions 
are used to square up the pulses. 
To prevent the loops responding to RF noise from 
the transmitter's line driver circuitry, the 
oscillator and the driver were enclosed in a screening 
can. (The (earthed) can is shown as a chained line in 
Figure 6.2.). 
Both the serial and RF boards were tested with the PDS 
Emulator/Rack/HP85 arrangement used in previous tests (see 
below). Both boards operate using data transmitted from the 
serial port, and so the same 8751 firmware (see Appendix 3) was 
utilized to test both boards. 
6. 3 .1. Serial Board 
The test arrangement used for checking-out the UART 
board (see chapter 5) was utilized for testing the 
serial board. The HP85 serial interface (Type 82939A 
Option 001) was initially configured for RS232 and 
used to test RS232 data transfer to and from the rack 
system, without handshaking. The handshake options 
were then tested in turn using the CTS option (port 
pin Pl.O) to control data transmission from the 8751 
- 97 -
and the RTS option (port pin Pl.l) to control data 
reception from the HP85. 
For the tests described above, the emulator's 
high-level macro language was used; for a true 
simulation of real-time data a small assembler routine 
(listed in Appendix 3) was used to soak-test the board 
at 9600 baud. For this test the HP85 was disconnected 
from the 25-way 'D' connector and replaced by a link 
joining pins 2 and 3. The HP85's serial interface was 
then modified to receive TTL signals (this is a simple 
modification to the circuit board of the device, 
involving connecting a spare cable lead directly into 
the board's DART input, thus by-passing the RS232 
buffer) and used to monitor the output of U2a (Figure 
6 .1.). For this purpose the RS232/CL jumper was 
removed, and the U2a jumper post used as a monitor 
point. Using this system the board was soak-tested to 
check-out the circuit buffers and the serial port 
stability. A simple program within the HP85 was used 
to confirm data consistency - the character 'U' being 
used as the test character for transmission. 
After these tests were completed the current loop 
circuits were tested. For this purpose the HP85's 
serial interface was configured for active current 
loop(s) (transmit/receive - the option 001 interface 
/ 
is a versatile interface supporting R<l332 and 
/ 
active/passive current loop) and the Serial Board 
(Rack) was configured for passive current loop(s). 
The current loop (jumper) option was selected and the 
- 98 -
HP85's serial interface was plugged back into the 
front panel socket. Data was exchanged in both 
directions between the 8751 and the HP85 and the tests 
repeated with the active and passive roles reversed. 
Several further tests were carried out with 
different current loop devices (e.g., industrial 
balances) substituting for the HP85. For these tests 
the emulator's high-level command language was used to 
control data exchange. The instruments with current 
loop interfaces in common use within the Company in 
general have generous (e.g. 15-25 rnA) margins on the 
line marking current specification, and current 
measurements showed the line currents to be well 
within specification for all cases. 
In general, the serial board proved to be a simple 
trouble-free interface, and should prove useful for 
many applications. Tests using the 8052-BASIC CPU 
(Chapter 8) showed that as well as acting as the 
console interface, the board could be simply modified 
to enable a printer to be interfaced to the system. 
This suggests that an extra jumper option would be 
worth adding; it is quite feasible to drive serial 
data in and out of spare part 1 pins using software 
timing loops - indeed, this is a technique commonly 
used to facilitate serial data transfer on 
microprocessors not equipped with a serial port (Ref. 
32 offers suitable algorithms for the MCS-48 family). 
The switch-bank used for passive/active current loop 
selections (See Appendix 9) was an item selected from 
- 99 -
6.3.2. 
the Contractor's stock (after discussions with the 
Contractor) and was used because it is a low-cost 
well-stocked item. However, it allows the user to 
make switch selections that are undesirable, and the 
options would be better selected by a fool-proof 
jumper nest, similar to the system used to select DVI 
board options (Chapter 3). 
The current loop sources and sinks (the UART board 
uses the same circuitry) being based on discrete 
devices, would be better implemented with DIL packages 
for ease of mass production. RCA, for example, 
manufacture several useful transistor arrays, e.g. the 
CA3096 and the CA3097 - the latter part being of 
particular interest as it incorporates suitable 
transistors and also a zener diode. 
RF Board 
Figure 6.3. shows schematically the system used for 
testing RF Boards. Two boards were used within the 
same rack. Each board was fitted with a BNC 'T' 
connector - each of which was fitted with a 75 Ohm 
line terminator. The two connectors were joined 
together by means of a short length of 75 Ohm coaxial 
cable, each end of which was terminated with a BNC 
socket. One of the boards (1) was connected to the 
backplane serial port lines, while the other (2) was 
isolated from the lines by removing the jumpers (See 
Figure 6.2.) from the board . 
- 100 -
~ ~ 0 ....... I 
~ 
m l2l 
SUB-MIN. RACK 
~ y 
/ ~ I CPU I ~ ~ 
[DOl I r- I I 
P.D.S SYSTEM D = HP85 
j a~ f ~ J\ !J I 
-J 
Figure 6.3 - Schematic Diagram showing RF Board Testing. 
The HP85's serial interface was modified for 
receiving TTL data signals (see previous sections) and 
used to monitor signals from the board's (2) PLL 
output. The receiver line jumper pin and ground 
provided the signal connection points. Using this 
system and the program listed in Appendix 3, the HP85 
was used to monitor the serial data and confirm 
validity, in the same manner as for the soak-tests of 
serial boards. During soak tests the RF boards worked 
well, without data corruption or spurious outputs. 
Long-line (300 metres) tests were performed which 
confirmed the operation of the tone-burst decoding 
over extended distances. 
The replacement of the original VCO (Chapter 2) 
circuit with a crystal oscillator module corrected 
problems associated with temperature dependent 
frequency variations (See Appendix 2). Further 
testing of the RF board, however, revealed that the 
875l's UART was more critical to the PLL output pulse 
width than the UART on the HP85's serial interface. 
This caused problems with incorrect data reception on 
some batches of prototype boards. Appendix 2 shows 
the effect of pulse narrowing, observed on an 
oscilloscope monitoring the PLL's output. Clearly 
this reduction in duty cycle is a function of loop 
lock speed, which suggests that a faster loop (the 567 
is normally used for tone decoding applications at 
relatively low frequencies) might be used to improve 
performance. The NE565 (the original choice - see 
- 102 -
Chapter 2 .. rejected because of the lack of split 12v 
supplies for the pilot scheme hardware) is a suitable 
candidate for substitution, but several other loops 
recently introduced have excellent specifications. 
- 103 -
CHAPTER 7 - THE ANALOGUE BOARD 
Frequently there is a need to monitor and record analogue measurements 
associated with production equipment on the Company's manufacturing lines -
e.g., conveyer speeds, temperatures, pressures etc.. Such measurements are 
typically obtained via transducers which output signals in the range 0-lOv, 
or 4-20 rnA. (The latter system is often considered 'superior' as it has an 
'active zero', which in theory allows an open-circuit (OmA) condition to be 
recognized; in reality, the equivalent performance can be obtained using, 
say, 0-0.2v as the guard band, and 0.2-lOv as the signal range). 
The following design goals were set for the Analogue (Input) Board, 
which would fulfil the Company's needs for current projects: 
* 8-bit ADC 
* On-board reference voltages 
* 8 input channels 
* Single-ended inputs 
* On-board memory 
These requirements were met using a design based on the AD7581 - a 
unique 8-channel ADC (Analogue to Digital Converter - Ref. 26) from Analog 
Devices. The design is based on the application notes that accompany the 
device's specification, and the application information supplied in 
'Electronic Design' (Ref. 27). 
7.1. The AD758l 
The ADC employed in the design is a special hybrid device -
it is both an ADC and a 8x8 bit memory in a single package. 
These can be thought of as two independent devices, with 
separate functions; the ADC section performs the tasks 
associated with a multi-channel ADC, while the memory and the 
digital logic circuits provide a clean, convenient interface to 
- 104 -
the (8751) host. Each mechanism is covered briefly in the two 
sub-sections below; the reader is referred to the references 
listed above for further details. 
7.1.1. The 8-channel ADC 
The eight analogue inputs are scanned by an 
analogue multiplexer at a rate determined by the 
frequency of an external clock. An output is 
available to indicate the channel currently being 
scanned, but this generally is irrelevant to the host 
- see 7.1.2. below. The output of the multiplexer is 
fed to a conventional successive approximation type 
ADC; the speed of conversion is proportional to the 
external clock rate. At the end of the conversion the 
result is passed from the SAR (successive 
approximation register) to the memory stack. 
The ADC features single ended inputs and a common 
analogue ground, which may be tied to the digital 
ground if desired (depending on the application). The 
manufacturer's specification states that the AGND-DGND 
voltage must not exceed the supply voltage, which 
indicates that for some applications a proprietary 
external signal conditioning unit will be needed. 
The reference for the ADC (VREF) must be supplied 
off-chip, and the same observation applies to the 
offset (BOFS) for the internal comparator; the 
external circuitry (see 7.2. below) required is 
minimal, and allows the designer to implement a wide 
range of custom designs. 
- 105 -
7 .1. 2. The Digital Logic 
The '7581 contains it's own internal address 
latches, and needs no further external circuitry for 
interfacing to 8085-type Buses. The signal 
connections that comprise the Bus interface are ALE 
(See Chapter 3), three address lines, and the eight 
Bus lines. The address lines (AO-A2) are used to 
address the eight memory locations within the '7581 
that contain the conversion results for the 
corresponding analogue channels. The clock input is, 
in general, not relevant to the timing of the digital 
interface, with the exception of the channel 
identification output (STAT- not required). 
The designer is not usually interested in 
identifying the channel currently being scanned by the 
analogue multiplexer within the 7581; normally an ADC 
would interrupt the host CPU to prompt for attention 
after completing a conversion - but the 7581 removes 
the burden of ADC interrupt servicing from the host by 
storing the conversion result in its internal RAM 
array. The user extracts the result at any convenient 
time; to the host, the ADC simply appears to be a 8x8 
bit external RAM (c. f. Chapter 4). The 7581 deals 
with any contention problems associated with the RAM, 
and the fast access time specified for this section of 
the device (200 ns) means that there are no timing 
problems. The data is latched (when valid) on the Bus 
for the duration of the chip select pulse. 
- 106 -
PLATE 7.1. - THE ANALOGUE BOARD 
- 107 -
7.2. The ADC interface design 
Figure 7.1. shows the design of the ADC board; it can be 
seen to be a relatively straightforward implementation of the 
A.D. application notes (Refs. 26 and 27). The ADC's Bus and 
address lines connect direct to the backplane, as does ALE, 
without the necessity for further external components. Chip 
select (active LOW) is achieved using the familiar (see 
previous chapters) '85 comparator logic, the comparator itself 
being enabled by the presence of both PERI (Peripheral Select -
active LOW) and RD (Read - active LOW), both signals being 
buffered by '05 (U3a, U3c) inverters with AND-tied outputs. A 
further buffer (U3b) is used to invert the logic high signal 
from the comparator (U2) to enable the 7581 (Ul) via the chip 
select pin (CS - active LOW). The backplane clock (Clock 1) 
signal (see Chapter 3) is used as the source for the clock 
input (CLK - pin 15) to the ADC. 
Provision is made for an on-board reference or a reference 
taken from external supplies; the reference voltage determines 
the range of the internal comparator. The voltage is taken 
from a -lOv stabilized LH0070 reference chip, which is fed from 
a -12v supply referred to analogue ground. The offset (BOFS) -
pin 1) voltage is supplied from a potential divider network 
(between 5v and -lOv) buffered by an ADOP07 operational 
amplifier configured as a voltage follower (U4). The choice of 
using on-board supplies (the penalty is the loss of isolation) 
or external supplies is made via jumpers Jl to J7. 
The use of the (27k) offset-trim potentiometer, together 
with (2k) trim potentiometers in series with the analogue 
- 108 -
I 
~ 
0 
1.0 
a 
f Jt, 
n 
6 
a 
ANO 21< 
:'!l 
·a 
5C1) 
-'121" 0 
NOTES. 
"="IT 'J1 j_ 1lllt 
1. 500 Ohm Input shunts on HOmA version onlY. 
2. Jumper J1 - J4 tor on-board references. 
Jumper J5 - J7 tor extem&l references. 
Figure 7.1 - Analog Board Circuit Diagram. 
Copyright (£) Glfl)(o Phsrmacsutlcols 1S05. 
~1~tJL 
o II -=-
1!) 
0 
@ 
© 
0 
Pl.IS 
0 
(IJ 
0 
0 
0 0 
0 
10 
0 
@ 
0 
() 
0 
0 
0 
; ~ : :- J • - . ~ •• : i 
! . ~ ...... ..: j 
I 
...... 
...... 
...... 
I 
~ 
/ 
~ 
~ 
SUB-MIN. RACK 500 
,... 
~ ~ @] 
[~Dl 
P.D.S SYSTEM 
~ II 
Figure 7.3 - Test Rig for ADC evaluation. 
-........... ), 
p 
j 
I 
CONSTANT 
CURRENT 
SOURCE 
inputs allows the user to trim for optimum span and zero set 
conditions. The circuit is designed primarily to cater for 
0-lOv input signals, but optional 500 ohm shunts allow for 4-20 
rnA signals to be accepted. There is no isolation comparable to 
that provided on the DVI board (Chapter 3), due to lack of 
space; opto-isolators would be inappropriate, due to the 
non-linearity inherent in such devices. The author feels that 
such isolation would be better provided by an external 
isolation panel, many excellent units being available on the 
market at present. 
7 .3. Review 
The AD 7581LN chip was used for the circuit check-out; this 
is the most accurate part available, with a quoted accuracy of 
± 1/2 LSB. The interface's offset null and gain adjustments 
were made in accordance with the manufacturers data sheet 
directions to give an input range of 0-lOv. In order to check 
out the current response (4-20mA transducers are preferred to 
0-lOv by the Company's Instrumentation Engineers) the test 
configuration shown in Figure 7. 3. was used. A pre-settable 
constant current source (Time Electronics Model 505) was used 
to supply current to an external 500 Ohm (0 .1% wire-wound) 
shunt resistor; a series ammeter (Beckman TlOOB Industrial 
Multimeter 0-20mA range) was used to monitor the input 
current (Channel 7 was used for the tests). 
Table 7.1. below summarizes the results obtained. The ADC 
output was monitored via the PDS display, using EMVSl's REPEAT 
and 'PBYTE' commands to set up a monitoring loop, displaying 
the readings on the screen of the PDS. 
- 112 -
Input Current (rnA) ADC 0/P Theoretical 0/P 
0.00 + 0.005 0 0 
1.00 II 13 12.7 
2.00 II 26(5) 25.4 
3.00 II 38 38.1 
4.00 II 51(2) 50.8 
5.00 II 64 63.5 
6.00 II 76 76.2 
7.00 II 89 88.9 
8.00 II 102 101.6 
9.00 II 114 114.1 
10.00 II 127 127.0 
11.00 140 139.7 
12.00 152 152.4 
13.00 165 165.1 
14.00 178 177.8 
15.00 190 190.5 
16.00 203 203.2 
17.00 216 215.9 
18.00 228(7) 228.6 
19.00 241 241.3 
20.00 254(5) 254.0 
TABLE 2 .1. ADC TEST 
It can be seen from the above results that, within the 
limitations of instrumentation accuracy and • flicker' on ADC 
LSB, that the ADC chip performed within the manufacturer's 
accuracy specification. The chip is impressively linear in its 
operation as can be seen from the graph of these results 
(Figure 7.2.); tests on the remaining channels produced 
comparable results. 
Physically, the board design was good, a limited number of 
components being used to realize the interface. This resulted 
in an uncluttered PCB layout on a board employing single-sided 
tracking. The interface will be suitable for future 
mass-production, with a low assembly cost. 
- 113 -
CHAPTER 8 - RUNNING MCS BASIC-52 ON THE SYSTEM 
Developing programs whose source code is written in assembly language is 
tim~-consuming task .. An alternative is to write programs in a high-level 
language such as rascal, FORTP~ or BASIC. As an option, Intel provides 
the user with PLM-51, a PLl-like language which may be compiled using a 
disc-based compiler residing on a development system. The user still has 
to contend with the tedium of the familiar edit/compile/link/run cycle 
inherent in debugging programs. 
The ubiquitous BASIC language is familiar to many people outside the 
programming fraternity and is a boon to many engineers, scientists and, 
indeed, laymen; this popularity is in part due to the simple structure of 
the language, although it is for the most part a result of the fact that 
the language is usually implemented as an interpreter rather than a 
compiler - allowing the user to enter the program and type 'RUN' to begin 
immediate execution. Intel have catered for users who wish to run BASIC on 
MCS-51 family systems by offering a novel variant of the 8052AH processor -
the 8052AH - BASIC chip. 
8.1. The 8052AH-BASIC Microprocessor 
The 8052 single-chip microprocessor is a recent addition to 
the MCS-51 family (see Ref. 1). It is a ROM-based part with 8k 
of ROM available to the user. There are other significant 
enhancements to the 8031/8051/8751 specification, but these 
need not concern us in this chapter. Intel have themselves 
(Ref. 20) developed a stand-alone BASIC system consisting of a 
BASIC interpreter, library routines and EPROM blowing logic all 
of which is contained in the 8k ROM space of 8052AH-BASIC. The 
BASIC supported by the system is known as 'MCS BASIC-52'. 
- 114 -
Plate 8 .1. shm11s the 8052AH-BASIC chip side-by-side \ITith an 
8751 chip, for comparison. The number of pins, layout of 
ports, etc. is the same for each processor. The BASIC chip 
uses the 8052 's serial port as a dedicated TTL-level console 
interface; it also uses the eight bits of PORT 1 (see Section 
8. 2) for special functions. Because it is a member of the 
MCS-51 family, the BASIC chip may be substituted directly for 
the 8751 on the CPU board of the system described in this 
thesis. 
MCS BASIC-52 has much to offer the user - Table 2.1. below 
lists some of the features. 
* Full BASIC interpreter in ROM 
* Floating-point maths 
* EPROM .file commands 
* Interrupts handlable by BASIC/Assembler 
* Linkage with assembler programs 
* Programs may reside in RAM or EPROM 
TABLE 2.1. - FEATURES OF MCS BASIC-52 
The chip supports a remarkably comprehensive BASIC language 
- far superior to the 'TINY BASICs' offered on other ROM-based 
systems. In order to function, the chip requires, as a 
minimum, an address latch, lk or more of external RAM memory, 
timing components, and a suitable serial console device. After 
RESET or power-up, the system expects the operator to press the 
space bar on the console, whereupon it automatically determines 
the baud rate of the console device and signs on with the 
message 
* MCS-51 (tm) BASIC Vx.x* 
READY 
> 
- 115 -
PLATE 8.1 - ALTERNATIVE CPU CHIPS 
PLATE 8.2 THE 'BASIC' SYSTEM CONFIGURATION 
116 
The final character in the sign-on sequence is a prompt to 
the operator to begin entering BASIC commands. More details 
concerning the system facilities, memory configurations and 
other features can be found in Appendix 8. 
8.2. Initial Check-Out 
The author was able to check-out the BASIC system using a 
miniature sub-rack and a number of the boards described 
elsewhere in this thesis. The required boards were:-
(i) CPU board with 8052-BASIC CPU installed. 
(ii) RAM board with 8K IRAM installed in lower address space. 
(iii) Watchdog/power board with watchdog disabled. 
(iv) DVI board with select code set to 8. 
(v) Serial board for console device interface. 
(vi) Serial board (modified - see below) for use as 
printer interface. 
(vii) Port 1 monitor board (see below). 
Plate 8.2. shows the cards installed in the sub-rack, ready 
for testing. Some minor modifications to the boards were 
needed before the system could be run; Port 1 is used by the 
BASIC chip for special purposes, purposes which clash with the 
use of some of the Port 1 pins on various boards in the system. 
In the case of the board configuration outlined above, the only 
port pin affected is Pl. 6, which is used on RAM/peripheral 
boards to distinguish between memory and peripheral accesses 
via the data bus. To test out the system it was necessary to 
isolate the control signal on the RAM and DVI boards, and tie 
the signal to the appropriate enable level (ground or Sv), in 
either case, using discrete resistors. In the case of the 
- 117 -
watchdog card, it was sufficient to remove the relevant chips 
on the card, as it was needed only as a power supply link. The 
DVI select code was set to '8' - i.e., Bus address 8000H, in 
order to avoid conflict with the RAM chip's address range. 
MCS BASIC-52 uses port pin Pl.7 to support an optional list 
device - i.e. it treats the pin as a serial output channel. 
The user selects the baud rate with the BAUD command in BASIC. 
A standard serial card was modified by disconnecting the TTL 
serial lines from the backplane connector pins on the card and 
connecting the Pl. 7 pin on the connector to the RS232 output 
buffer on the card. This converted the card to a makeshift 
printer interface to a standard EPSON FX-100 printer. 
The author used as a convenient console device a small 
'TRANSTERM' portable terminal; this was configured to operate 
at 110 baud, to enable the listing of programs to be observed. 
The TRANSTERM was connected to the system via a standard serial 
interface board. After power-up the space bar on the console 
was pressed, whereupon the sign-on message (described 
previously in this chapter) immediately appeared on the 
terminal's small LCD monitor. 
After receipt of the 'READY' prompt, the author was able to 
enter BASIC statements into the RAM memory via the console. 
The system uses the first lk of RAM for program stacks, the 
rest of memory being available to the user. As well as at the 
3.6864 MHz clock rate, the system was tested using the 7.3728 
and 11.0592 MHz (using faster memory see Appendix 11) 
crystals, and found to function correctly. Plate 8. 3 shows 
BASIC running on the system. 
- 118 -
119 
PLATE 8.3. MCS BASIC - 52 
RUNNING ON THE SYSTEM 
PLATE 8.4. (BELOW) 
THE PORT 1 MONITOR 
BREADBOARD 
8.2. Port 1 Functions 
The BASIC system has a 'command' mode of operation which was 
used initially to confirm the system operation. The author 
used the 'PORT 1' commands to drive the port 1 lines on the 
backplane. A simple PORT 1 monitor card, shom1 in Plate 8.4., 
was used to display the state of the logic levels on the lines 
on LED's. Figure 8.1. shows the circuit of the breadboard. 
Executing the commands 
PORT 1 0 
PORT 1 OOFFH 
via the console confirmed that all eight Port 1 lines were 
being driven. 
To check-out program sequencing, the following program was 
entered and run: 
10 REM DRIVE EACH PORT 1 LINE 
20 P= 1 
30 FOR I=l TO 8 
40 FOR J = 1 TO 100 
50 REM DRIVE PORT PIN 
60 PORT l=P 
70 NEXT J 
80 REM SELECT NEXT PIN 
90 P = 2*P 
100 NEXT I 
110 STOP 
The program's function is to drive each port 1 pin in turn, 
holding the pin in an active state for the duration of the FOR 
loop occurring between statements 40 - 70. In practice, when 
the program was run the LED's were seen to energize in rapid 
sequence, confirming CPU operation and program execution. 
The Port 1 functions (see Appendix 8) relevant to the current 
configuration tested were the PWM command and the LIST= 
- 120 -
command. The function of the PWM command is described in 
section 8. 3; the LIST= command directs listing to a printer 
rather than the console device - port pin Pl.7 is used by MCS 
BASIC-52 as a serial channel for the listings. 
The command BAUD 1200 was issued via the printer to configure 
the printer port to match a 1200 baud Epson FX-100 serial 
printer attached via a cable to the serial port interface. A 
small BASIC program was entered via the console and the command 
LIST% 
was issued, which confirmed the operation of the printer 
channel. The printer port facility was found to be most useful 
for taking quick listings of the programs under test, as the 
two line console used by the author \V"as not convenient for 
listing programs. Later the author borrowed a standard HP2392A 
terminal from the Company's mainframe installation, which 
proved to be a very acceptable device for program debugging. 
8.3. Sensor Interfacing 
Having tested out the program sequencing, the author 
proceeded to investigate the accessing of sensor data via the 
DVI card. The system admits two possible ways of achieving 
access to the card: 
i) By an assembler routine called from BASIC. 
ii) By a special BASIC-52 'XBY' command, which allows the user 
to access external memory locations directly from a BASIC 
program. 
The first option requires the development of a small 
assembler subroutine, which would then be assembled into object 
code and stored in an external EPROM. The rather exacting 
- 121 -
requirements of the external memory layout (see Appendix 8) 
precluded further investigation by the author. Possibly this 
work will be pursued at a later date (see Section 8.4). The 
use of the 'XBY' command was investigated by means of the BASIC 
program listed below: 
10 REM PROGRAM READS DVI CARD 
20 REM GIVING AN AUDIO FEEDBACK 
30 A = 8000H 
40 X = XBY(A) 
50 PRINT X 
60 H = X + 20 L H 
70 N = 100 
80 PWM H, L, N 
90 REM OUTPUT TO DGO CARD 
100 XBY(A) = X 
110 GOTO 40 
Before running the program a prototype 'DGO' card (a digital 
output card was added to the list a cards required by the 
potential system users, towards the end of the work covered by 
this thesis. It performs the opposite function to the DVI card, 
i.e. it provides eight isolated output lines, the state of 
which are monitored by front panel LED's) was inserted in the 
spare slot in the rack (see Plate 8.1). The card address was 
set to 8, but no conflict occurs as the DVI card is an input 
only device, while the DGO card provides the complementary 
function . 
The program transfers data from the DVI card by means of the 
XBY command in statement 40. The parameter 'A' is the external 
memory address of the DVI (and DGO) card. The decimal value of 
the eight-bit data byte ('X') is logged on the console. The PWM 
(pulse width modulate) statement at location 80 causes the 
output of a square wave pulses on special function pin Pl.2. 
The program selects the pulse high time (H) and pulse low time 
(L) at statement 60; the number of cycles (N) to be output is 
- 122 -
selected by statement 70. An amplifier (a simple audio signal 
tracer) was coupled to the output of the Pl.2 buffer on the 
monitor card as shown in Figure 8. 1, to monitor the audio 
output. The minimum specified values of the high and low 
parameters are both 20; hence it is necessary to add 20 to the 
value X read from the DVI input lines. The program copies the 
input data out to the DGO card at statement 100, before looping 
back to statement 40 to fetch fresh data. 
A simple DIL switch-bank arrangement was used to connect the 
positive (DVI) inputs to an external +Sv supply, the negative 
inputs all being commoned to the supply's ground. 330 ohm 
series resistors were used for current limiting. The program 
performed as expected with this arrangement, reading the values 
from the DIL switches, logging the value on the console, 
producing an audio output dependent on the value read and 
copying the input value to the DGO output latch (the value was 
monitored on the front panel display). 
8.4. Enhancements 
To verify the system further the author experimented with 
simple modifications to the above program to check-out the 
DO-WHILE and DO-UNTIL statements as alternatives to the simple 
GOTO loop. The author found the BASIC-52 version of BASIC in 
general both powerful and flexible. The EPROM file handling 
and related extensions to standard BASIC were not investigated 
as the author did not have the appropriate hardware 
configuration. The necessary modifications to the CPU board 
design and other aspects of the system were considered outside 
the scope of the author's design brief. 
- 123 -
.---I ------I ----------~ 
I I 5v 
I 
I SZLED 
I 
I 
I 
560 
I 
I 
I 
I 
I 
I 
I 
• I f'--, 
I 
* 
I 
I 
I 
I 
I 
I 
I 
! ----f>o--_j I I I 
I 
l v 
I 
[A F. Signal 
...... 
1-[) 
I 
N 
Tracer 
~ 
~~ 1 : • 
I 
Lit-ES FROM \{I '>o------J 
BACKPLANE 1 I ~ I ~ 
I * 
I 
.:--c i >---1-- I I --
I 
I "'- * I 
I 
I 
I 
:PLO-t>--* I -I __j I * L 
I 
1 (, I ED Circuit L--_?~_Buffers) i as for Pi. /Y 
---- I 
_________ J 
Figure 8.1- Port1 Monitor Breadboard & Audio Monitor. 
8.5. Review 
The 8052AH-BASIC microprocessor appeared on the commercial 
market towards the end of the author's work on the system, when 
most of the design decisions had been taken. Had it entered 
the market a year or so earlier, it would have been feasible to 
have designed the system around the device's specialized 
external memory requirements (Appendix 8) . However, despite 
the limited amount of testing the author was able to perform, 
the BASIC-52 system impressed in its ease of use and range of 
facilities. 
Clearly it would be useful to have such a system as an 
alternative to an assembler-based system, as it requires no 
expensive support hardware and is easily reconfigured in the 
field by service engineers. It was, for example, a simple 
matter to add a series of 'IF' statements to the BASIC program 
described in Section 8.3. to produce a specific message on the 
printer log for each sensor input change detected - creating, 
in essence, an instant alarm logging system. To create an 
equivalent system using the standard cards in the system and 
assembler-based 8751 firmware requires considerably more 
equipment and effort. 
Thus it may be concluded that the BASIC system has clear · 
advantages for ease of use and rapid development. The penalty 
paid for these facilities is, of course, speed - an interpreted 
system runs much more slowly than the system based on compiled 
or assembled programs. So it can be seen that each processor, 
the 8751 and the 8052AH-BASIC has its own advantages and 
drawbacks. 
- 125 -
The selection of Pl.6 as the memory/peripheral control line 
of the system fits in well with any future integration of the 
8052 chip into the system; BASIC-52 uses Pl.6 as a DMA 
acknowledge line, as part of the 'fake DMA' offered by the 
system. This • DMA' is in fact a low- speed interrupt-based 
system that is too slow to be compatible with some of the 
(relatively) high-speed data transfers required by some 
interfaces - e.g., HPIB - that the system supports . As all of 
the other port 1 lines (see Appendix 8) are of potential use, 
then this is probably the best line to retain for the purpose. 
BASIC-52's ability to communicate with assembler subroutines 
means that a small peripheral service routine may be written in 
assembler which could perform the same functions as the 'XBY' 
command, but additionally would manipulate the Pl. 6 signal 
line. However, special BASIC-52 CPU and RAM cards would also 
have to be designed, with careful thought given to the 
avoidance of address decode conflicts. 
- 126 -
CHAPTER 9 - PROJECT REVIEW 
Looking back on the work described in this thesis, it can be said that 
the project as a whole was of benefit to the Company, and provided a firm 
foundation for future developments. The pilot scheme described in Chapter 
2 was in itself an interesting and rewarding project ~ a duplicate system 
was in fact installed in another of the Company's sites to meet an urgent 
requirement for an alarm monitoring system for remote areas. The RF 
coaxial line communications system used in this installation was found to 
perform well over distances of the order of five hundred metres. 
Possibly it might be worth developing the original node system used in 
the pilot scheme into a small single-board device as a cheap alternative to 
the sub-miniature rack system, i.e., a device compatible with the rack 
system as regards the RF communication link, but offering a cheaper 
alternative for situations that require the monitoring of ON/OFF sensor 
devices. Clearly, the T. D .M. (Time Division Multiplexing) protocol used 
for the evaluation system would be unsuitable for more sophisticated 
applications involving a large number of nodes. The obvious solution would 
be to impress a standard protocol on the system using one of the 
commercially available chips-sets. Two common protocols that spring to 
mind are Ethernet and S.D.L.C. (Synchronous Data Link Control); despite the 
implications of acronym, S.D. L. C. is frequently used as the protocol for 
asynchronous systems - PLL' s being employed to recover a clock from an 
asynchronous data stream, N.R.T.Z. (Non Return To Zero) encoding (see 
Reference 28) being used to guarantee the necessary level transitions on 
the incoming data signals. 
A recently introduced variant of the 8751, the 8744, offers 
possibilities in this direction. This chip is in essence, on a single die, 
an S.D.L.C. protocol controller, buffer memory, and 8751; externally, the 
- 127 -
device is pin-compatible with the 8751, except that the serial port is used 
purely for the reception/transmission of S.D.L.C. data. Thus the 
introduction of S.D.L.C., for example, need not require major modifications 
in hardware. 
The 8744 is, of course, an ideal choice as an alternative CPU for the 
CPU board is the rack system itself, and with the addition of a protocol 
such as S.D.L.C., the system assumes a new power. The 8751 and 8744 are 
both relatively expensive chips, because of the EPROM content. If the user 
is prepared to hold programs in external EPROM, then the CPU chip price 
drops significantly. For example, the ROM-less equivalent of the 8751 is 
the 8031 microprocessor, which is identical in function to the former but 
relies on external EPROM for program storage. The chip may be fitted to 
the existing CPU board without the need for major design modifications. 
Addition of external EPROM facilities is one way in which the system 
may be improved. The CPU architecture allows for the addressing of up to 
64K of external EPROM; it is a simple matter to alter. the existing RAM 
board design to allow for the fitting of EPROM chips - the pin-out of both 
RAM and EPROM chips conform to international (JEDEC) standards. 
It was felt that the design of the RAM board was acceptable, although 
the design will almost certainly be rationalized in the future as higher 
density memories become available. The IRAM's, originally cost effective 
against other memory devices, were only marginally so in relation to some 
of the 8K SRAM' s available on the market as the project work approached 
completion. Some of the Japanese 8Kx8K parts tested (see Appendix 11) were 
acceptable replacements, and offered faster operating speeds. It was felt 
that the IRAM was, in concept, a promising device 
unfavourable competition from the cheap SRAM's. 
despite the 
The DVI board performed well under test, and several site 
- 128 -
installations using prototype boards are operating satisfactorily at the 
time of writing. The parallel bus handshake options have not, as yet, been 
utilized, but as there is no cost penalty in manufacturing the boards 
without the extra components, it is felt that the (potential) extra 
flexibility the options afford make their inclusion in the design 
worthwhile. As indicated in the previous chapter, a complementary 'DGO' 
Board has been designed as a future enhancement to the system, to allow 
eight digital outputs to be driven. 
The bargraph display on the front panel of the DVI (and DGO) boards /" 
provided an elegant and efficient monitor of the digital inputs, but it had 
several drawbacks. Firstly, the ten-element modules were difficult to 
connect to the board, as standard right-angled DIL sockets were available 
only as sixteen-pin items; the thick, rectangular leads of these sockets 
caused problems with the pad sizes on the PCB artworks. Also, the front 
panel cut-out, hand cut on the prototypes, would have been expensive to 
die-press in production. Somewhat reluctantly, it was decided to switch to 
standard Schroff right-angled stacking LED's for final production. The hole 
matrix in the front panel could be easily produced by the Contractors using 
standard stock tools. 
The Watchdog Board design was considered to be satisfactory, with the 
exception of the original Cannon connector, which was replaced by a SIL 
Weidmuller part (Type GZ8) , as shown in Figure 3. 6. The Cannon part was 
found to be satisfactorily for installations where the whole rack system 
was bolted to a backplate of a standard industrial enclosure, but it proved 
unsuitable to those applications of the system where the rack was housed in 
a free-standing instrument case e.g. for bench use. In the latter 
example, the power supply was usually housed in the back of the instrument 
case, causing problems in cabling to the plug and socket arrangement on the 
front panel. The proposed production system features an extra board-mounted 
- 129 -
Weidmuller (straight) socket, in addition to the Weidmuller (right-angled) 
socket for the front panel. This allows the cable to be inserted into a 
socket enclosed within the rack, thus avoiding an unsightly cable loop on 
the Watchdog Board front panel. 
Of the communications interfaces covered in Chapter 5, the UART board 
was the most satisfactory design, as it featured the most acceptable 
component layout with a passable track density. Both the BCD and HPIB Board 
layouts were considered too cramped, and although the boards functioned 
correctly, it was felt that these two boards were the ones in the system 
with unacceptably high track densities. This should not be a problem for 
small-scale production runs, but would pose problems on 9rt' large volume 
/ 
manufacturing involving wave soldering methods. It is difficult to foresee 
how these problems might be eased, considering the size of the major chips 
on each board, and the high chip density. 
In the case of the HPIB Board, the board supports only the Talker and 
Listener functions; this is a limitation of the 96LS488 chip, an otherwise 
excellent part. The implementation of the Controller function requires the 
employment of a chip-set from another source - Texas, Motorola and Intel, 
for example, all offer suitable devices, but, unlike the Fairchild part, 
they require external buffers to connect to the HPIB. This involves, 
typically, three major chips - making an acceptable board layout difficult 
to achieve. 
The Analogue and Serial Boards were both fairly straight-forward 
design implementations, and both should be suitable for volume production. 
The RF Board caused problems during development, and a major re-design 
around a PLL with faster response characteristics is desirable, as 
explained in Chapter 6 and the related Appendices. The lessons learnt from 
- 130 -
the development of the prototype board should prove useful in the future 
re-design work. 
Each individual board in the system is at a different stage of its 
development at the time of writing this Review. For example, an early 
prototype of the BCD board had its own reset components on-board, as it has 
an active LOW reset requirement, and at that time the Watchdog Board 
provided only a single (active HIGH) signal on the backplane. The addition 
of the voltage supervisor chip to the watchdog board provided the active 
LOW signal, prompting the removal of the reset circuitry from the BCD 
Board. This has further implications for the Watchdog Board, whose timing 
components have to cater for the reset pulse specifications of all the 
boards in the system. The final development of the system in therefore seen 
to be cyclical in nature, as changes in any one board in the system are 
seen to impinge on the other boards. Changes to the CPU clock rate, for 
example, also affects the related backplane clock signals, which time the 
UART card and determine the scanning rate of the ADC on the Analog Board. 
In summary, the development work described in this project has 
progressed a long way towards achieving the design goals set at the 
commencement of the work. A prototype distributed interfacing system has 
been developed, tested and installed on several of the Company's UK sites. 
The test systems installed perform useful tasks monitoring a variety of 
analog and digital signals on a number of projects. Although the work has 
still some way to progress before full-scale production can be 
contemp~d, 
~---
it can be said that the work performed throughout this 
project has laid the foundations for the future production of a flexible, 
reliable and useful production monitoring system. 
- 131 -
REFERENCES 
1. Intel Corp., The MCS-51 Family of Single Chip Microcomputers User's 
Manual, July 1981. 
2. Signetics Corp., The Linear Components Databook, June 1980. 
3. STC Electronic Services, 'A Watchdog For Microcomputer Systems', 
'Distribution', Issue 21, p. 15, September 1984. 
4. Parkinson, C.N., 'In-Laws and Outlaws', p. 102, John Murray, Oct. 1952. 
5. Intel Corp., The Peripheral Design Handbook, August 1980. 
6. Lese a, A. & Zaks, R. , 'Microprocessor Interfacing Techniques' , Sybex 
Inc., 2nd Edition, 1978. 
7. Fisher, J.B., 'Report on the Characterization of the Crystal Oscillator 
On Board the Intel 8031/8051/8751 Microcontroller', Standard Crystal Corp. 
Design Note 2F, undated. \,)(, 
"l\ 
8. Williamson, T., 'Oscillators for Microcontrollers', Intel Application 
Note AP-155, June 1983. 
9. Intel Corp., The Component Data Catalog, January 1981 
10. Intel Corp., The Memory Components Handbook, 1983 
11. Fallin, J.J., & Righter, W.H., 'Designing Memory Systems with the 8Kx8 
iRAM', Intel Application Note AP-132, June 1982 
12. Seyer M.D., 'RS232 Made Easy', Prentice Hall Inc., 1984. 
13. Institute of Electrical and Electronic Engineers Inc., IEEE Standard 
Digital Interface for Programmable Instrumentation (ANSI/IEEE Std 
488-1978), IEEE Inc., November 1978. 
14. Fairchild Camera and Inst. Corp., 96LS488 Data Sheet, June 1981. 
15. Summers, J., 'Microprocessor GPIB Interfacing With the 96LS488', 
Fairchild Application Note 351, June 1981. 
16. Intersil Datel (UK), Ltd., Intersil Data Book, Ch. 8,1981. 
17. Intel Corp., 'Designing Microcontroller Systems for Noisy 
Environments', Intel Application Note AFN-02131A, 1983. 
- 132 -
18. Intel Gorp., iPDS Personal Development System User's Guide, 1983. 
19. Intel Gorp., EMV-51 Emulation Vehicle User's Guide, 1982 
20. Katausky, J. , MGS BASIC-52 User's Manual, Intel Gorp., Pub. No. 
270010-001 (1984). 
21. Intel Corp., 8251A/S2657 :Programmable Communications lnterface Data, 
Application Note AFN-01573A, 1980. 
22. Intel Gorp., 'Using the 8251A Universal Synchronous/Asynchronous 
Receiver-Transmitter', Application Note AFN-00600A, 1980. 
23. Fairchild Camera and Inst. Gorp., Linear Interface Data Book, , 1978. 
24. Lancaster, D., 'The TTL Cookbook', The Howard W. Sams & Go. Inc. ,1974. 
25. Garter, G.W. & Richardson, A., 'Techniques of Circuit Analysis', p 
46lff., Cambridge University Press, 1972. 
26. Analog devices, AD7581 Data Sheet, Analog Devices Inc., (Undated). 
27. Tucholski, H. & Wynne, J., 'DAS Packs Memory for Easy Microprocessor 
Interface', Electronic Design, September 13th, 1980. 
28. IBM, SDLG General Information, GA27-3093-2, 3rd Ed., March 1979. 
29. Schroff Equipment Catalogue, 1985. 
30. Electronic Designs Inc., EDH8832G-12/15/20 Data Sheet, 1986. 
31. Intel Gorp., MGS 48 Family Single Chip User's Handbook, Sept. 1981. 
32. Intel Gorp., 8048 Family Applications Handbook, January 1980. 
33. International Telecoms. Union,GGITT White Book, Vol. 8, 1969. 
- 133 -
Appendix 1 - Crystals/Oscillator Components 
The author is indebted to Intel Technical support for in-depth 
discussions concerning the MCS-51 Family oscillator components, and for 
providing the two excellent references (Fisher - Ref. 7 and Williamson -
Ref. 8). The information given below is a summary of the practical 
experience gained from the experimental application of the theoretical data 
gleaned from the References. 
The experimental circuit used by Fisher (Ref.7) gave values of 30pF for 
the Xl, X2 shunt capacitors, but 22pf values were used in the CPU Board 
circuit implementation, as these are standard items from the Contractor's 
stock. These capacitors are needed to prevent the extremely small input 
capacitance of the internal F.E.T. 's of the 875l's Pierce Oscillator 
"pulling" the crystal up beyond its quoted frequency of oscillation. If 
required, the oscillator frequency may be "tweaked" by adding asymmetric 
(e.g. SpF) trimming capacitors. Reference 7 contains all the details needed 
by the circuit designer in order to specify crystals to a 
manufacturer,including ESR (Equivalent Series Resistance) and Shunt 
Capacity graphs. Note that the oscillator tolerates quite large valued 
shunt capacitors - e.g. 100 pF, whilst still maintaining operation. 
Best operation and stability (especially temperature stability) is 
obtained using the on-board oscillator. Reference 8 offers a number of 
alternative ways of obtaining a clock signal from the oscillator to drive 
external devices. Three of these options were tested ; two of the options 
(Ref. 8, p. 7, Fig. 9) used discrete components, notably npn transistors 
loosely coupled to Xl or X2. The circuit working off the Xl pin was found 
to operate reliably using a BC107 as the test transistor, whilst the 
alternative design malfunctioned under test. A third solution proposed in 
the Reference - a simple buffer used to provide the necessary drive for 
- 134 -
I 
t-' 
w 
\J1 
a 
Frequency Counter 1 16 
Q JL 
'!I 14 t-----1 
!Roootl r J 
HC4024 
GND INP. 8751 
(12 MHz) 
,-
B 
X2 
19 Ho-~=n ~ . 
II ~ 2o 1-
-'- -~ 
22p -r- 22p 
~ 
Figure At! - CPU Oscillator Tests 
+5v 
------
40 
31 
,--, 
Ov 
Ov 
Ov 
Ov 
Ov 
i 
···-
. i ""'-::j 
__ :; -- L j 
the backplane signal lines - is not without problems; TTL buffers provide 
excessive loading on Xl or X2 , whilst 'B' series CMOS parts are too slow 
and have appreciable input capacitance. 
An ideal emerging logic family with the required parameters (high speed 
coupled with low loading properties) for this type of application is HCMOS. 
This logic family (the range of components is not, as yet , extensive) 
compares favourably with TTL as regards speed, and has the minimal current 
consumption and high noise immunity attributes associated with CMOS 
parts. Figure Al.l shows the test circuit used to evaluate the operation of 
the device. 
A precursory examination of the Xl, X2 clock waveforms with an 
oscilloscope (50 MHz Phillips PM3215) showed that at 3. 6864 MHz the Xl 
output was a pure sine wave slightly in excess of 5v peak-to-peak. The X2 
output was seen as a signal of reduced amplitude 180 degrees out of phase 
with the Xl signal; an examination of each cycle of the waveform showed 
that the positive-going half-cycle was sinusoidal, whilst the 
negative- going half cycle was a linear ramp. (The signal resembled a 
distorted square wave). Both the Xl and X2 signals were attenuated at 
higher frequencies , and the X2 output was unable to drive the '4024 part 
(HCMOS clock divider) at 7.3728 MHz - the inputs require 3.15v minimum to 
guarantee recognition of the logic one state. 
Figure Al.2 shows the observed outputs using the Xl signal. At all test 
frequencies the Ql output of the '4024 was a clean 50% duty cycle square 
wave exhibiting minimal ringing. The 3.6864, 7.3728 MHz tests were 
performed for the 8751, whilst the 11.0592 MHz tests related to the 
8052-BASIC chip. (Chapter 8). It was obvious that at higher frequencies the 
Xl signal amplitude was affected was affected by the capacitance of the 
'scope leads. Figure Al.2 shows the Xl amplitude as marginal for the '4024 
- 137 -
input , but this is almost certainly a loading effect ·· the Ql output was 
stable. Possibly a light pull-up (e.g. lOOk) could be used on production 
boards operating at this frequency. 
The 3.6864 MHz crystal was purchased off-the-shelf from a major 
component supplier and was quoted for parallel resonance. The other 
crystals were made to order by S.E.I. (Salford Electrical Instruments), to 
the following specifications: 
Style: 
Frequency: 
Accuracy: 
Shunt C.: 
Mode: 
ATQC1622 
7.3728/11.0592 MHz 
+/- 50p.p.m. at 25deg. C. 
22pF 
Parallel Resonance 
The table below summarizes the results of frequency measurements taken 
with a Phillips PM6670 frequency meter. 
Quoted Xtal Frequency 
3.6864 
7. 3728 
11.0592 
Ql (Theoretical) 
1. 8432 
3.6864 
5. 5296 
Ql (Measured) 
1. 84363 
3.68640 
5.52960 
(Measurements of the ALE frequency confirmed the inaccuracy of the 
3.6864 MHz crystal frequency; possibly the part was misquoted for parallel 
resonance). 
The oscillator frequency is one of the controlling parameters for the 
generation of the baud rate of the 875l's on-board UART. Enclosed with this 
Appendix is a list of theoretical baud rates obtainable using each of the 
(three) crystals mentioned previously; data concerning other useful or 
common crystal selections is also included. A listing of the HP86 program 
used to generate the data is enclosed with Appendix 3; the latter also 
provides details of the 8751 serial port. 
- 138 -
CONST. 
-1 
.:.:_. 
-4 
-5 
-6 
-7 
-8 
-9 
-10 
-11 
-12 
-13 
-14 
-15 
-16 
-17 
-18 
-19 
-20 
-21 
-24 
-.c-
-..::_._) 
-26 
-27 
-28 
-29 
-30 
-31 
'":"'7 
·-··-· 
-34 
-36 
~~ 
--..:•1 
-38 
-39 
-40 
-A1 
-42 
-43 
-44 
-45 
-46 
-47 
-48 
-4C) 
-50 
-51 
-52 
c:""':"" 
-....J . ..:• 
-54 
-55 
-56 
-.57 
-58 
-59 
-60 
-61 
-62 
-63 
-64 
BAUD 
9600 
4800 
3200 
2400 
1920 
1600 
1371 
1200 
1067 
960 
873 
800 
738 
686 
640 
600 
565 
C"77 w .... .::o . ..:• 
505 
480 
457 
436 
417 
400 
384 
369 
356 
343 
331 
320 
310 
300 
291 
282 
274 
267 
259 
246 
240 
234 
229 
223 
218 
213 
209 
204 
200 
196 
192 
188 
185 
181 
178 
175 
171 
168 
166 
163 
160 
157 
155 
152 
150 
CONST. 
-65 
-66 
-67 
-68 
-69 
-70 
-71 
-72 
-73 
-74 
-75 
-76 
-77 
-78 
-79 
-80 
-81 
-82 
-83 
-84 
-85 
-86 
-87 
-88 
-89 
-9•) 
-91 
-92 
-93 
-94 
-95 
-96 
-97 
-98 
-99 
-100 
-101 
-102 
-103 
-104 
-105 
-106 
-107 
-108 
-109 
-11 (I 
-111 
-112 
-11::. 
-114 
-115 
-116 
-117 
-118 
-119 
-120 
-121 
-122 
-123 
-124 
-125 
-126 
-127 
-128 
BAUD 
148 
145 
143 
141 
139 
137 
135 
133 
132 
130 
128 
126 
125 
123 
1?':' 
120 
119 
117 
116 
114 
113 
112 
110 
109 
108 
107 
105 
104 
103 
102 
101 
100 
99 
98 
97 
96 
95 
94 
93 
92 
91 
91 
90 
89 
88 
87 
86 
86 
85 
84 
83 
83 
82 
81 
81 
80 
79 
79 
78 
77 
77 
76 
76 
75 
CONST. 
-129 
-130 
-131 
-132 
-133 
-134 
-135 
-136 
-137 
-138 
-139 
-140 
-141 
-142 
-143 
-144 
-145 
-146 
-147 
-148 
-149 
-150 
-151 
-152 
-153 
-154 
-155 
-156 
-157 
-158 
-159 
-160 
-161 
-162 
-163 
-164 
-165 
-166 
-167 
-168 
-169 
-170 
-171 
-172 
-173 
-174 
-175 
-176 
-177 
-178 
-179 
-180 
-181 
-182 
-183 
-184 
-185 
-186 
-187 
-188 
-189 
-190 
-191 
-192 
BAUD 
74 
74 
73 
73 
72 
72 
71 
71 
70 
70 
69 
69 
68 
68 
67 
67 
66 
66 
65 
65 
64 
64 
64 
63 
63 
62 
62 
62 
61 
61 
60 
60 
60 
59 
59 
59 
58 
58 
57 
57 
57 
56 
56 
56 
"'"" ..J.,J 
55 
55 
54 
54 
54 
.,..,.. 
........ ) 
53 
.,..,.. 
._I._;. 
"'~ 
._}..::.. 
52 
52 
52 
51 
51 
51 
51 
50 
50 
CONST. 
-193 
-194 
-195 
-196 
-len 
-198 
-199 
-200 
-201 
-202 
-203 
-204 
-205 
-206 
-207 
-208 
-209 
-210 
-211 
-212 
-213 
-214 
-215 
-216 
-217 
-218 
-219 
-220 
-221 
...... ,,...., ....... , 
~--
-223 
-224 
-226 
,-,.-,....,. 
-..:...::./ 
-228 
-229 
-230 
-231 
.-.-:o-,.., 
.._._._ 
.-.-:r-:r 
-..::.. .... .:.......:• 
-234 
'17c:-
-..:.. . ..:•.J 
-236 
-237 
-238 
-239 
-240 
-241 
-242 
-243 
-244 
-245 
-246 
-247 
-248 
-249 
-250 
-251 
1"'"").::;::--;r 
-..::_....,._:. 
-254 
-256 
TABLE OF RELOAD CONSTANTS/BAUD RATES FOR 3.6864MHz XTAL 
******************************************************* 
- 139 -
BAUD 
50 
49 
49 
49 
49 
48 
48 
48 
48 
48 
47 
47 
47 
47 
46 
46 
46 
46 
45 
45 
45 
45 
45 
44 
44 
44 
44 
44 
43 
43 
43 
43 
43 
42 
42 
42 
42 
42 
42 
41 
41 
41 
41 
41 
41 
40 
40 
40 
40 
40 
40 
39 
39 
39 
7J. 
. ..:•7 
39 
..,..,, 
. .:.•7 
38 
38 
38 
38 
38 
38 
COI·lST. 
-1 
-2 
-3 
-4 
-5 
-6 
-7 
-8 
-9 
-10 
-11 
-12 
-13 
-14 
-15 
-16 
-17 
-18 
-19 
-20 
-21 
-23 
~.= 
-..:.:_._) 
-26 
-27 
-28 
-29 
-3(1 
-31 
._: .. ..;. 
-34 
-36 
-37 
-38 
-39 
-4(1 
-IH 
-42 
-43 
-44 
-45 
-46 
-47 
-48 
-49 
-50 
-51 
-53 
-54 
-55 
-56 
-57 
-58 
-59 
-6(1 
-61 
-62 
-63 
-64 
BAUD 
14400 
7200 
4800 
3600 
2880 
2400 
2057 
1800 
1600 
144(1 
1309 
1200 
1108 
1029 
960 
9(1(1 
847 
800 
758 
720 
686 
655 
626 
600 
576 
554 
514 
497 
480 
465 
450 
436 
424 
411 
400 
38'7' 
379 
369 
360 
351 
343 
?~C:O 
• ..:• .... .:O..J 
327 
320 
313 
306 
300 
294 
288 
282 
277 
267 
262 
257 
248 
244 
240 
·07 .' 
..::,.._:.a 
232 
225 
CONST. 
-65 
-66 
-67 
-68 
-69 
-70 
-71 
-72 
-73 
-74 
-75 
-76 
-77 
-78 
-79 
-80 
-81 
-82 
-83 
-84 
-85 
-86 
-87 
-88 
-8'7' 
-90 
-91 
-92 
-93 
-94 
-95 
-96 
-97 
-98 
-99 
-1 (ll) 
-1 (1 1 
-1(!2 
-103 
-104 
-105 
-106 
-107 
-108 
-109 
-110 
-111 
-112 
-113 
-114 
-115 
-116 
-117 
-118 
-119 
-120 
-121 
-122 
-123 
-124 
-125 
-126 
-127 
-128 
BAUD 
218 
215 
212 
209 
206 
203 
200 
197 
195 
1 '7'2 
189 
187 
185 
182 
180 
178 
176 
173 
171 
169 
167 
166 
164 
162 
160 
158 
157 
155 
153 
152 
150 
148 
147 
145 
144 
143 
141 
140 
138 
137 
136 
135 
133 
132 
131 
130 
129 
127 
126 
125 
124 
123 
122 
121 
120 
119 
118 
117 
116 
115 
114 
113 
113 
CONST. 
-129 
-130 
-131 
-132 
-133 
-134 
-135 
-136 
-137 
-138 
-139 
-140 
-141 
-142 
-143 
-144 
-145 
-146 
-147 
-148 
-149 
-1 ~·0 
-151 
-152 
-153 
-154 
-155 
-156 
-157 
-158 
-159 
-160 
-161 
-162 
-163 
-164 
-165 
-166 
-167 
-168 
-169 
-170 
-171 
-172 
-173 
-174 
-175 
-176 
-177 
-178 
-179 
-180 
-181 
-182 
-183 
-184 
-185 
-186 
-187 
-188 
-189 
-190 
-191 
-192 
BAUD 
112 
111 
110 
109 
108 
107 
107 
106 
105 
104 
104 
103 
102 
101 
101 
100 
99 
99 
98 
97 
97 
96 
95 
95 
94 
94 
93 
92 
92 
91 
91 
90 
89 
89 
88 
88 
87 
87 
86 
86 
85 
85 
84 
84 
83 
83 
82 
82 
81 
81 
80 
80 
80 
79 
79 
78 
78 
77 
77 
77 
76 
76 
75 
75 
CONST. 
-193 
-194 
-195 
-196 
-197 
-198 
-199 
-200 
-201 
-202 
-203 
-204 
-205 
-206 
-207 
-208 
-209 
-210 
-211 
-212 
-213 
-214 
-215 
-216 
-217 
-218 
-219 
-220 
-221 
-223 
-224 
-226 
-227 
-228 
-229 
-230 
-231 
-233 
-234 
-236 
.-.-:o--r 
-,.:: . ..:•/ 
-238 
.-,--:rn 
-....::_._:,-, 
-·240 
-241 
-242 
-243 
-244 
-245 
-246 
-247 
-248 
-249 
-250 
-251 
-252 
-254 
-255 
-2~·6 
TABLE OF RELOAD CONSTANTS/BAUD RATES FOR 5.5296MHz XTAL 
******************************************************* 
- 140 -
BAUD 
...,.,. 
/ ._I 
74 
74 
73 
/ . ..:.:. 
73 
-, .-. 
/~ 
,,...., 
.1..::... 
71 
71 
71 
70 
70 
70 
69 
69 
69 
68 
68 
68 
67 
67 
67 
66 
66 
66 
65 
65 
65 
65 
64 
64 
64 
63 
63 
63 
63 
62 
62 
62 
62 
61 
61 
61 
61 
60 
60 
60 
60 
59 
59 
59 
59 
58 
58 
58 
5E: 
57 
57 
"'"""' ~1/ 
56 
56 
CONST. 
-1 
-4 
-5 
-6 
-7 
-8 
-9 
-10 
-11 
-12 
-13 
-14 
-15 
-16 
-17 
-18 
-l9 
-20 
-21 
-22 
-24 
-26 
...,.., 
-..:~I 
-28 
-29 
-30 
-31 
~ ..... 
-·~ 
-34 
-35 
-36 
-37 
-38 
-39 
-40 
-41 
-42 
-43 
-44 
-45 
-46 
-47 
-48 
-49 
-50 
-51 
-55 
-56 
-57 
-58 
-59 
-60 
-61 
-62 
-63 
-64 
BAUD 
19200 
9600 
6400 
4800 
3840 
3200 
2743 
2400 
2133 
1920 
1745 
1600 
1477 
1371 
1280 
1200 
1129 
1067 
1011 
960 
914 
873 
835 
BOO 
768 
738 
711 
686 
662 
640 
619 
600 
582 
565 
549 
533 
519 
~~05 
492 
480 
468 
457 
447 
436 
427 
417 
409 
400 
::'.92 
384 
376 
369 
362 
356 
::'.49 
343 
337 
331 
325 
320 
315 
310 
305 
300 
Cot..JST. 
-65 
-66 
-67 
-68 
-69 
-70 
-71 
-72 
-73 
-74 
-75 
-76 
-77 
-78 
-79 
-80 
-81 
-82 
-83 
-84 
-85 
-86 
-87 
-88 
-89 
-90 
-91 
-92 
-93 
-94 
-95 
-96 
-97 
-98 
-99 
-100 
-101 
-102 
-103 
-104 
-105 
-106 
-l.07 
-108 
-109 
-110 
-111 
-112 
-113 
-114 
-115 
-116 
-117 
-118 
-119 
-120 
-121 
-122 
-123 
-124 
-125 
-126 
-127 
-128 
BAUD 
295 
291 
287 
282 
278 
274 
270 
267 
~I"":"' 
LO-..:• 
256 
"""C"7 .::.,~._;. 
249 
246 
243 
240 
2::'·7 
234 
231 
229 
226 
223 
221 
218 
216 
213 
211 
20<;· 
206 
204 
202 
200 
198 
196 
194 
l'i'2 
19(! 
188 
186 
185 
183 
181 
179 
178 
176 
175 
173 
171 
170 
168 
167 
166 
164 
163 
161 
160 
159 
157 
156 
155 
154 
152 
151 
150 
CONST. 
-129 
-130 
-131 
-132 
-133 
-134 
-135 
-136 
-137 
-138 
-139 
-140 
-141 
-142 
-143 
-144 
-145 
-146 
-147 
-148 
-149 
-150 
-151 
-152 
-153 
-154 
-155 
-156 
-157 
-158 
-159 
-160 
-161 
-162 
-163 
-164 
-165 
-166 
-167 
-168 
-169 
-170 
-171 
-172 
-173 
-174 
-175 
-176 
-177 
-178 
-179 
-180 
-181 
-182 
-183 
-184 
-185 
-186 
-187 
-188 
-189 
-190 
-191 
-192 
BAUD 
149 
148 
147 
145 
144 
143 
142 
141 
140 
139 
138 
137 
136 
135 
134 
133 
132 
132 
131 
130 
129 
128 
127 
126 
125 
125 
124 
123 
122 
122 
121 
120 
119 
119 
118 
117 
116 
116 
115 
114 
114 
113 
112 
112 
111 
11 (l 
110 
109 
108 
108 
107 
107 
106 
105 
105 
104 
104 
103 
103 
102 
102 
1(11 
101 
100 
CONST. 
-193 
-194 
-195 
-196 
-197 
-198 
-199 
-200 
-201 
-202 
-204 
-205 
-206 
-207 
-208 
-209 
-210 
-211 
-212 
-213 
-214 
-215 
-216 
-217 
-218 
-219 
-220 
-221 
-222 
-223 
-224 
-2~5 
-226 
-227 
-228 
-229 
-230 
-231 
-232 
-233 
-234 
-236 
-237 
-238 
-240 
-241 
-242 
-243 
-244 
-245 
-246 
-247 
-248 
-249 
-250 
-25l 
IJC'"7 
-L.....J·....:· 
-254 
-255 
-256 
TABLE OF RELOAD CONSTANTS/BAUD RATES FOR 7.3728MHz XTAL 
******************************************************* 
- 141 -
B~iUD 
99 
99 
98 
98 
97 
97 
96 
96 
96 
95 
95 
94 
94 
9::'· 
93 
92 
92 
91 
91 
91 
90 
90 
89 
89 
88 
88 
88 
87 
87 
86 
86 
86 
85 
85 
85 
84 
84 
83 
83 
83 
82 
82 
82 
81 
81 
81 
80 
8(1 
80 
79 
79 
79 
78 
78 
78 
77 
77 
77 
76 
76 
76 
76 
75 
""'"' /...! 
CONST. 
-1 
-..:· 
-4 
-5 
-6 
-7 
-8 
-9 
-10 
-11 
-12 
-13 
-14 
-15 
-16 
-17 
-18 
-19 
-20 
,..,, 
-,.;:.J, 
-25 
-26 
-28 
-29 
-30 
-31. 
33 
-34 
-35 
-36 
-37 
-38 
-39 
-40 
-41 
-42 
-43 
-44 
-45 
-46 
-47 
-48 
-49 
-50 
-51 
-52 
.,..,. 
-...J-..:• 
-5l.J. 
-55 
-56 
-57 
-58 
-59 
-60 
-61 
-62 
-63 
-64 
BAUD 
20833 
10417 
6944 
5208 
4167 
3472 
2976 
2604 
2315 
2083 
1894 
1736 
1603 
1488 
1389 
1302 
1225 
1157 
1096 
1042 
992 
947 
906 
868 
833 
801 
772 
744 
718 
694 
672 
651 
631 
613 
595 
579 
563 
548 
534 
521 
508 
496 
484 
473 
463 
453 
443 
434 
425 
417 
408 
401 
393 
::::.86 
37'7' 
365 
359 
347 
342 
336 
331 
7'"'i/ 
-...:•.LO 
COt~ST. 
-65 
-66 
-67 
-68 
-69 
-70 
-71 
-72 
-73 
-74 
-75 
-76 
-77 
-78 
-79 
-80 
-81 
-82 
-83 
-84 
-85 
-86 
-87 
-88 
-89 
-90 
-91 
-92 
-93 
-94 
-95 
-96 
-97 
-98 
-99 
-100 
-101 
-102 
-103 
-104 
-105 
-106 
-107 
-108 
-109 
-110 
-111 
-112 
-113 
-114 
-115' 
-116 
-117 
-118 
-119 
-120 
-121 
-122 
-123 
-124 
-125 
-126 
-127 
-128 
BAUD 
321 
316 
311 
306 
302 
298 
293 
289 
285 
282 
278 
274 
271 
267 
264 
260 
257 
254 
251 
248 
245 
242 
239 
237 
234 
231 
229 
226 
224 
222 
219 
217 
215 
213 
210 
208 
206 
204 
202 
200 
198 
197 
195 
193 
191 
189 
188 
186 
184 
183 
181 
180 
178 
177 
175 
174 
172 
171 
169 
168 
167 
165 
164 
163 
CONST. 
-129 
-130 
-131 
-132 
-133 
-134 
-135 
-136 
-137 
-138 
-139 
-140 
-141 
-142 
-143 
-144 
-145 
-146 
-147 
-148 
-149 
-150 
-151 
-152 
-153 
-154 
-155 
-156 
-157 
-158 
-159 
-160 
-161 
-162 
-163 
-164 
-165 
-166 
-167 
-168 
-169 
-170 
-171 
-172 
-173 
-174 
-175 
-176 
-177 
-178 
-179 
-180 
-181 
-182 
-183 
-184 
-185 
-186 
-187 
-188 
-189 
-190 
-191 
-192 
BAUD 
161 
160 
159 
158 
157 
155 
154 
153 
152 
151 
150 
149 
148 
147 
146 
145 
144 
143 
142 
141 
140 
139 
138 
137 
136 
135 
134 
134 
133 
132 
131 
130 
129 
129 
128 
127 
126 
126 
125 
124 
123 
123 
122 
121 
120 
120 
119 
118 
118 
117 
116 
116 
115 
114 
114 
113 
113 
112 
111 
111 
110 
110 
109 
109 
CONST. 
-193 
-194 
-195 
-196 
-197 
-198 
-19Cf 
-200 
-201 
-202 
-203 
-204 
-205 
-206 
-207 
-208 
-209 
-210 
-211 
-212 
-213 
-214 
-215 
-216 
-217 
-218 
-219 
-220 
-221 
.-,,"":"' 
~ ..... _. 
-224 
~.,...,c· 
-..;:...::.._t 
-226 
-228 
-229 
-230 
-231 
1""\~-:r 
--·-· 
-234 
-236 
-237 
-238 
-239 
-240 
-241 
-242 
-243 
-244 
-245 
-246 
-247 
-248 
-249 
-250 
-~51 
-254 
-255 
TABLE OF RELOAD CONSTANTS/BAUD RATES FOR BMHz XTAL 
************************************************** 
- 142 -
BAUD 
108 
107 
107 
106 
106 
105 
105 
104 
104 
103 
103 
102 
102 
101 
101 
100 
100 
'7'9 
99 
98 
98 
97 
97 
96 
96 
96 
95 
95 
94 
'7'4 
93 
93 
93 
92 
92 
91 
91 
91 
9(1 
90 
89 
89 
89 
88 
88 
88 
87 
87 
86 
86 
86 
85 
85 
85 
84 
84 
84 
83 
83 
83 
82 
82 
82 
81 
cmmT. 
-1 
-4 
-5 
-6 
-7 
-8 
-9 
-10 
-11 
-12 
-13 
-14 
-15 
-16 
-17 
-18 
-19 
-20 
-21 
...,7 
.._._. 
-24 
-~5 
-26 
-27 
-28 
-29 
-::.o 
-31 
-34 
-36 
7~ 
- . ..:•/ 
-38 
-39 
-40 
-41 
-42 
-43 
-44 
-,(15 
-46 
-47 
-48 
-49 
-50 
-51 
<:"7 
-,_J._:, 
-54 
-56 
-57 
-58 
-59 
-60 
-61 
-62 
-63 
-64 
BAUD 
24000 
12000 
8000 
6000 
480(1 
4(h)(l 
3429 
3000 
2667 
2400 
2182 
2000 
1846 
1714 
1600 
1500 
1412 
1333 
1263 
1200 
114::'. 
1091 
1043 
1000 
960 
923 
889 
857 
828 
BOO 
774 
750 
727 
706 
686 
667 
649 
632 
615 
600 
585 
571 
558 
545 
511 
500 
490 
480 
471 
462 
453 
444 
436 
429 
421 
414 
407 
400 
393 
387 
::.81 
CONST. 
-65 
-t..6 
-67 
-68 
-69 
-70 
-71 
-72 
-73 
-74 
-75 
-76 
-77 
-78 
-79 
-80 
-81 
-82 
-83 
-84 
-85 
-86 
-87 
-88 
-89 
-90 
-91 
-92 
-93 
-94 
-95 
-96 
-97 
-98 
-99 
-1(1i) 
-101 
-1(!2 
-103 
-104 
-105 
--106 
-107 
-108 
-109 
-110 
-111 
-112 
-113 
-114 
-115 
-116 
-117 
-118 
-119 
-120 
-121 
-122 
-12::. 
-124 
-125 
-126 
-127 
-128 
BAUD 
369 
364 
358 
348 
:~.4-~· 
338 
333 
32S' 
324 
320 
316 
312 
308 
304 
300 
296 
293 
289 
286 
282 
279 
276 
273 
270 
267 
264 
261 
258 
255 
250 
247 
245 
242 
240 
238 
'17'7 
,..::.._: .. _:. 
231 
229 
226 
224 
222 
220 
218 
216 
214 
212 
211 
209 
207 
205 
203 
202 
200 
198 
197 
195 
194 
192 
190 
189 
188 
CONST. 
-129 
-130 
-131 
-132 
-133 
-12.4 
-135 
-136 
-137 
-138 
-139 
-140 
-141 
-142 
-143 
-144 
-145 
-146 
-147 
-148 
-149 
-150 
-151 
-152 
-153 
-154 
-155 
-156 
-157 
-158 
-159 
-160 
-161 
-162 
-163 
-164 
-165 
-166 
-167 
-168 
-169 
-170 
-171 
-172 
-173 
-174 
-175 
-176 
-177 
-178 
-179 
-180 
-181 
-182 
-183 
-184 
-185 
-186 
-187 
-188 
-189 
-190 
-191 
-192 
BAUD 
186 
185 
183 
182 
180 
1~9 
178 
176 
175 
174 
173 
171 
170 
169 
168 
167 
166 
164 
163 
162 
161 
160 
159 
158 
157 
156 
155 
154 
153 
152 
151 
1 ~~o 
149 
148 
147 
146 
145 
145 
144 
143 
142 
141 
140 
140 
139 
138 
137 
136 
136 
135 
134 
133 
133 
132 
131 
130 
130 
129 
128 
128 
127 
126 
126 
125 
COI"·lST. 
-193 
-194 
-195 
-196 
-197 
-198 
-199 
-200 
-201 
-202 
-203 
-204 
-205 
-206 
-207 
-208 
-209 
-210 
-211 
-212 
-213 
-214 
-215 
-216 
-217 
-218 
-219 
-220 
-221 
'"'"\'"'"\~ 
---· 
-224 
-226 
-227 
-228 
-229 
-230 
-231 
-232 
'""'l"":"""":"" 
..... -· -· 
-234 
'1-:rc:::-
-.::,._·.u 
-236 
-237 
-238 
-239 
-240 
-241 
-242 
-243 
-244 
-245 
-246 
-247 
-248 
-249 
-250 
-251 
.-,c:--:w-
-,.,;; . ...J . ..:• 
-254 
,....,t::;-c:-
-..::. ..... l,_j 
-256 
TABLE OF RELOAD CONSTANTS/BAUD RATES FOR 9.216MHz XTAL 
****************************************************** 
- 143 -
124 
124 
123 
122 
122 
i21 
121 
120 
119 
11 c;· 
118 
118 
117 
117 
116 
115 
115 
114 
114 
113 
113 
112 
112 
11 1 
111 
110 
11 (I 
1(1<;• 
1(•9 
108 
108 
107 
107 
106 
106 
105 
11)5 
104 
104 
103 
103 
1 o::-. 
102 
102 
101 
101 
100 
100 
100 
99 
99 
98 
c;·s 
98 
97 
97 
96 
96 
96 
95 
95 
94 
94 
94 
Cm·lST. 
-1 
3 
-4 
-5 
-6 
-7 
-8 
-9 
-10 
-11 
-12 
-13 
-14 
-15 
-16 
-17 
-1El 
-19 
-20 
-21 
-:23 
-24 
'""'"' -..;:_.._J 
-26 
-27 
-28 
-29 
-30 
-31 
-34 
-?.5 
-36 
7~ 
",/ 
-=·8 
-39 
-40 
-41 
-42 
-43 
-44 
-45 
-46 
-47 
-48 
-49 
-50 
-51 
<C7 
-..J . ..:• 
-54 
-55 
-56 
-57 
-58 
-59 
-60 
-61 
-62 
-63 
-64 
BAUD 
28646 
14323 
9549 
7161 
5729 
4774 
4092 
3581 
:::.183 
2865 
2604 
2387 
2204 
2046 
1910 
1790 
1685 
1591 
1508 
1432 
1364 
1302 
1245 
1194 
1146 
1102 
1061 
1023 
988 
955 
924 
895 
868 
843 
818 
7C:,'6 
774 
754 
735 
716 
699 
682 
666 
651 
637 
623 
609 
597 
585 
573 
~~62 
551 
540 
5.30 
521 
512 
503 
494 
486 
477 
470 
462 
455 
44B 
CONST. 
-65 
-66 
-67 
-68 
-69 
-70 
-71 
-72 
-73 
-74 
-75 
-76 
-77 
-78 
-79 
-80 
-81 
-82 
-83 
-84 
-85 
-86 
-87 
-88 
-89 
-90 
-91 
-'7'2 
-93 
-94 
-95 
-96 
-97 
-98 
-99 
-100 
-101 
-102 
-103 
-104 
-105 
-106 
-107 
-108 
-1(19 
-110 
-111 
-112 
-113 
-114 
-115 
-116 
-117 
-118 
-119 
-120 
-121 
-122 
-123 
-124 
-125 
-126 
-127 
-128 
BAUD 
4•+1 
434 
428 
421 
415 
409 
403 
398 
392 
-:o"lt'r 
·..:•0/ 
382 
377 
372 
367 
363 
358 
354 
349 
345 
:'".41 
337 
333 
329 
326 
322 
318 
315 
311 
308 
305 
302 
27'8 
295 
29:? 
289 
224 
281 
278 
275 
273 
270 
268 
265 
263 
260 
258 
254 
251 
249 
247 
245 
243 
241 
239 
237 
233 
231 
;-,..-,,-, 
k.L7 
r:'l,....,....., 
.L..:.:.l 
226 
224 
CONST. 
-129 
-130 
-131 
-132 
-133 
.. ..,..11 
-J. . ..::·"""f· 
-135 
-136 
-137 
-138 
-139 
-140 
-141 
-142 
-143 
-144 
-145 
-146 
-147 
-148 
-149 
-150 
-151 
-152 
-153 
-154 
-155 
-156 
-157 
-158 
-159 
-160 
-161 
-162 
-163 
-164 
-165 
-166 
-167 
-168 
-169 
-170 
-171 
-172 
-173 
-174 
-175 
-176 
-177 
-178 
-179 
-180 
-181 
-182 
-183 
-184 
-185 
-186 
-187 
-188 
-18'7' 
-190 
-191 
-192 
BAUD 
220 
219 
217 
215 
::::14 
212 
211 
209 
208 
206 
205 
203 
202 
200 
199 
198 
196 
195 
194 
192 
191 
190 
188 
187 
186 
185 
184 
182 
181 
180 
179 
178 
177 
176 
175 
174 
173 
172 
171 
170 
169 
168 
167 
166 
165 
164 
163 
162 
161 
160 
159 
158 
157 
157 
156 
155 
154 
153 
152 
152 
151 
150 
149 
cm~sT. 
-193 
-194 
-195 
-196 
-197 
-198 
-199 
-200 
-201 
-202 
-2(13 
-204 
-205 
-206 
-207 
-208 
-209 
-210 
-211 
-212 
-213 
-214 
-215 
-216 
-217 
-218 
-219 
-220 
-221 
.--,,..., ...... 
..:... ........ _, 
-224 
-226 
-228 
-229 
-230 
-231 
-232 
-234 
-235 
-236 
.-,-;o-~ 
- ..::..-..:• / 
-238 
-239 
-240 
-241 
-242 
-243 
-244 
-245 
-24-6 
-247 
--248 
-24'7' 
-:?50 
-251 
'ft="r"'"; 
-..::....J.L 
,...,.::-"?" 
-..::._,_1 . ..:• 
.-. .::-.::-
- ..::_,_1,_1 
-256 
TABLE OF RELOAD CONSTANTS/BAUD RATES FOR 11MHz XTAL 
*************************************************** 
- 144 -
BAUD 
148 
148 
147 
146 
145 
145 
144 
143 
143 
142 
141 
140 
140 
139 
138 
1 :::.s 
137 
136 
136 
135 
134 
134 
133 
133 
132 
L:.1 
1:::.1 
130 
13•) 
129 
128 
128 
127 
127 
126 
126 
125 
125 
124 
123 
123 
122 
122 
121 
121 
120 
120 
119 
119 
118 
118 
117 
117 
116 
116 
116 
115 
115 
114 
114 
113 
113 
112 
112 
CONST. 
-1 
...,. 
·-· 
-4 
-5 
-6 
-7 
-8 
-9 
-10 
-11 
-12 
-13 
-14 
-15 
-16 
-17 
-18 
-19 
-20 
-21 
-24 
-25 
-26 
-27 
-28 
-29 
-30 
-31 
-34 
-36 
-37 
...,.,... 
--...:•C:• 
-39 
-40 
-41 
-42 
-43 
-44 
-45 
-46 
-47 
-48 
-49 
-50 
-51 
-52 
.,..,. 
-~ .. J..:.o 
-54 
-55 
-56 
-57 
-58 
-59 
-60 
-61 
-62 
-63 
-64 
BAUD 
28800 
14400 
9600 
7200 
5760 
4800 
4114 
3600 
3200 
2880 
2618 
2400 
2215 
2057 
1920 
1800 
1694 
1600 
1516 
1440 
1371 
1309 
1252 
1200 
1152 
1108 
1067 
1029 
993 
960 
929 
900 
873 
847 
823 
BOO 
778 
758 
738 
720 
702 
686 
670 
655 
640 
626 
613 
600 
588 
576 
565 
554 
543 
524 
514 
505 
497 
488 
480 
472 
465 
457 
450 
CONST. 
-65 
-66 
-67 
-68 
-69 
-70 
-71 
-72 
-73 
-74 
-75 
-76 
-77 
-78 
-79 
-80 
-81 
-82 
-83 
-84 
-85 
-86 
-87 
-88 
-89 
-9t) 
-91 
-92 
-93 
-94 
-95 
-96 
-97 
-98 
-99 
-100 
-101 
-102 
-103 
-104 
-105 
-106 
-107 
-108 
-109 
-110 
-111 
-112 
-113 
-114 
-115 
-116 
-117 
-118 
-119 
-120 
-121 
-122 
-123 
-124 
-125 
-126 
-127 
-128 
BAUD 
443 
436 
430 
424 
417 
411 
406 
400 
395 
389 
384 
379 
374 
369 
365 
360 
356 
351 
347 
343 
339 
3::.1 
327 
324 
::.20 
316 
313 
310 
306 
303 
300 
297 
2'7'4 
291 
288 
•I ott::"' 
.0::.0·.....) 
282 
2E!O 
277 
274 
272 
267 
264 
262 
259 
257 
255 
.-.r=....,. 
.&::.J·~· 
250 
248 
246 
244 
242 
240 
238 
236 
234 
232 
230 
229 
227 
225 
CDNST. 
-129 
-130 
-131 
-132 
-133 
-134 
-135 
-136 
-137 
-138 
-139 
-140 
-141 
-142 
-143 
-144 
-145 
-146 
-147 
-148 
-149 
-150 
-151 
-152 
-153 
-154 
-155 
-156 
-157 
-158 
-159 
-160 
-161 
-162 
-163 
-164 
-165 
-166 
-167 
-168 
-169 
-170 
-171 
-172 
-173 
-174 
-175 
-176 
-177 
-178 
-179 
-180 
-181 
-182 
-183 
-184 
-185 
-186 
-187 
-188 
-189 
-190 
-191 
-192 
BAUD 
223 
220 
218 
217 
215 
213 
212 
210 
209 
207 
206 
204 
203 
201 
200 
199 
197 
196 
195 
193 
192 
191 
189 
188 
187 
186 
185 
183 
182 
181 
180 
179 
178 
177 
176 
175 
173 
172 
171 
170 
169 
168 
167 
166 
166 
165 
164 
163 
162 
161 
160 
159 
158 
157 
157 
156 
155 
154 
153 
152 
152 
151 
150 
CONST. 
-193 
-1 <:;·4 
-195 
-196 
-197 
-1 '7'8 
-199 
-200 
-201 
-202 
-203 
-204 
-205 
-206 
-207 
-208 
-209 
-210 
-211 
-212 
-213 
-214 
-215 
-216 
-217 
-218 
-219 
-220 
-221 
IJ'I?' 
.._...._._. 
-224 
-226 
'"'""1·1""7 
-.L.LI 
-228 
-229 
-230 
-231 
-232 
-234 
-236 
-2::.7 
-238 
-239 
-240 
-241 
-242 
-243 
-244 
-245 
-246 
-247 
-248 
-249 
-250 
-251 
-253 
-254 
"'"""" - ..::.._!~ 
-256 
TABLE OF RELOAD CONSTANTS/BAUD RATES FOR 11.0592MHz XTAL 
*************'****************************************** 
- 145 -
BAUD 
149 
148 
148 
1-':P 
146 
145 
145 
144 
143 
143 
142 
141 
140 
140 
139 
138 
138 
137 
136 
136 
135 
135 
134 
133 
133 
132 
132 
131 
130 
130 
129 
129 
128 
127 
127 
126 
126 
125 
125 
124 
124 
123 
123 
122 
1'?'"J 
121 
121 
120 
120 
119 
119 
118 
118 
117 
117 
116 
116 
115 
i 15 
114 
114 
113 
113 
113 
CONST. 
-1 
~ 
_. 
-4 
-5 
-h 
-7 
-8 
-9 
-10 
-ll 
-12 
-13 
-14 
-15 
-16 
-17 
-18 
-19 
-20 
-21 
-23 
-24 
-25 
-26 
-27 
-28 
-29 
-30 
-31 
~, 
·-•..;.. 
._: .. _:. 
-34 
-35 
-::.6 
-37 
-38 
-3''7 
-40 
-41 
-42 
-43 
-44 
-45 
-46 
-47 
-48 
-49 
-50 
-51 
-52 
""~ -.J . .:.• 
-5•+ 
-55 
-56 
-57 
-58 
-59 
-60 
-61 
-62 
-63 
-64 
BAUD 
31250 
15625 
10417 
7813 
6250 
5208 
4464 
3906 
3472 
3125 
2841 
2604 
2404 
2232 
2083 
1953 
1838 
1736 
1645 
1563 
1488 
1420 
1359 
1302 
1250 
1202 
1157 
1116 
1078 
1042 
1(108 
977 
947 
91 c;· 
893 
868 
845 
822 
801 
781 
762 
744 
727 
710 
694 
679 
665 
651 
638 
625 
613 
601 
590 
579 
568 
558 
548 
539 
530 
521 
512 
504 
496 
488 
CDNST. 
-65 
-66 
-67 
-68 
-69 
-70 
-71 
-72 
-73 
-74 
-75 
-76 
-77 
-78 
-79 
-8(1 
-81 
-82 
-8::. 
-84 
-85 
-86 
-87 
-88 
-89 
-90 
-91 
-92 
-93 
-94 
-95 
-96 
-97 
-98 
-99 
-100 
-1(11 
-102 
-1 o::. 
-104 
-105 
-106 
-107 
-108 
-109 
-11.:1 
-111 
-112 
-113 
-114 
-115 
-116 
-117 
-118 
-119 
-120 
-121 
-122 
-123 
-124 
-125 
-126 
-127 
-128 
BAUD 
481 
473 
466 
460 
453 
446 
440 
434 
428 
422 
417 
411 
406 
401 
396 
391 
386 
381 
377 
372 
368 
363 
359 
355 
351 
347 
::.43 
340 
336 
"":""-:"' ...... 
._: .. _: . ...,;;. 
329 
:.26 
322 
319 
316 
313 
309 
306 
303 
300 
298 
295 
292 
289 
287 
284 
282 
279 
277 
274 
272 
269 
267 
265 
263 
260 
258 
256 
254 
252 
250 
248 
246 
244 
CONST. 
-129 
-130 
-131 
-132 
-133 
-134 
-135 
-136 
-137 
-138 
-139 
-140 
-141 
-142 
-143 
-144 
-145 
-146 
-147 
-148 
-149 
-150 
-151 
-152 
-153 
-154 
-155 
-156 
-157 
-158 
-159 
-160 
-161 
-162 
-163 
-164 
-165 
-166 
-167 
-168 
-169 
-170 
-171 
-172 
-173 
-174 
-175 
-176 
-177 
-178 
-179 
-180 
-181 
-182 
-183 
-18ll 
-185 
-186 
-187 
-188 
-189 
-190 
-191 
-192 
BAUD 
242 
240 
239 
235 
233 
231 
230 
228 
226 
223 
220 
219 
217 
216 
214 
213 
211 
210 
208 
207 
206 
204 
203 
202 
200 
199 
198 
197 
195 
194 
193 
192 
191 
189 
188 
187 
186 
185 
184 
183 
182 
181 
180 
179 
178 
177 
176 
175 
174 
173 
172 
171 
170 
169 
168 
167 
166 
165 
164 
164 
163 
CONST. 
-193 
-194 
-195 
-196 
-197 
-198 
-199 
-200 
-201 
-202 
-203 
-204 
-205 
-206 
-207 
-208 
-209 
-210 
-211 
-212 
-213 
-214 
-215 
-216 
-217 
-218 
-219 
-220 
-221 
-224 
'""''""'"" -..::...::...J 
-226 
-227 
-228 
-229 
-230 
-231 
-233 
-234 
-235 
-236 
-237 
-2::.8 
-239 
-240 
-241 
-242 
-243 
-244 
-245 
-246 
-247 
-248 
-249 
-250 
-25l 
-252 
-253 
-254 
-255 
-256 
TABLE OF RELOAD CONSTANTS/BAUD RATES FOR 12MHz XTAL 
*************************************************** 
- 146 -
BAUD 
162 
161 
160 
159 
159 
158 
157 
156 
155 
155 
154 
153 
152 
152 
151 
150 
150 
149 
148 
147 
147 
146 
145 
145 
144 
143 
143 
142 
141 
141 
140 
140 
139 
138 
138 
1:'.7 
136 
136 
135 
135 
134 
134 
13::. 
132 
132 
131 
131 
130 
1 3(1 
1::-!9 
1~0 
128 
128 
127 
127 
126 
126 
125 
125 
124 
124 
123 
123 
122 
Appendix 2 - Pilot Scheme Data 
This Appendix includes further details of performances of RF circuits 
relating to both the Pilot Scheme (Chapter 2) and the RF Board (Section 
6.2), and also provide~ ueLails of the firmware used in the Pilot Scheme. 
VCO Performance 
Figure A2.1 shows a plot of output frequency versus modulation voltage 
for the VCO circuit used in the Pilot Scheme, obtained from the 
experimental results listed in Table A2.1 below. 
Vmod(volts) Freq. (KHz) Vmod(volts) Freg(KHz) 
0.0 0.0 2.6 187.1 
0.2 0.0 2.8 187.1 
0.4 0.0 3.0 187.1 
0.6 0.0 3.2 187.1 
0.8 185.0 3.4 187.1 
1.0 187.0 3.6 187.1 
1.2 187.1 3.8 180.2 
1.4 187.2 4.0 166.7 
1.6 187.2 4.2 165.1 
1.8 187.2 4.4 165.0 
2.0 187.1 4.6 165.0 
2.2 187.1 4.8 165.0 
2.4 187.1 5.0 165.0 
Table A2.1 - vco Frequency variation with modulation voltage. 
The readings were obtained from a CSC Model 5001 frequency meter which 
was connected to the output of the VCO (see Figures 2.5 and 2.6), while the 
modulation voltage was applied to the input using a variable output power 
supply. It can be seen from Figure A2.1 that there is a relatively stable 
output (187.1 KHz) around the Voh point (typically 2.4v for the 'LS14), 
with large frequency variations at voltages on either side. The cut-off at 
the 0.6v mark indicates that the 'LS14 quenches the oscillator when in the 
- 147 -
'• 
) 
Vol state, theoretically making the making the line gating signal for the 
75123 line driver redundant; in practice, the absence of a gating signal 
was found to affect the accuracy of the data transmission - an effect 
probably attributable to turn-off transients. 
Other factors which affect the VCO output frequency are temperature and 
supply voltage. Several components in the VCO circuit (as well as the '567 
itself) , such as trim potentiometers, timing components etc. , are also 
temperature sensitive, and changes to the nominal values of these 
components due to temperature fluctuations also affect operation. 
PLL Performance 
Figure A4.2 shows the observed and theoretical waveforms for the serial 
data stream recovered by the PLL's on the RF Board. The observations were 
taken using a Phillips PM3215 oscilloscope during testing of the RF Board 
circuit (see Chapter 6). Clearly the PLL's were too slow in responding to 
the termination of the tone bursts, and this is reflected in the narrowing 
of the logic '1' pulses in the recovered serial data stream This is 
probably attributable to the use of feedback capacitors to speed up loop 
lock, causing the loop to retain 
termination of the tone burst. 
lock for a short period after the 
The timing of serial data reception is, with devices such as UART's, in 
relation to the occurrence of the start bit. In Figure A2.2 the start bit 
(ii) terminates the line idle state (i) and precedes the first data bit 
(iii) . UARTs usually time the reception of data bits from the centre of 
the start bit, which, in theory, in this case predicts problems with the 
reception of serial data, as the rising edges of the logic '1' pulses are 
close to the theoretical pulse centre positions, which correspond to the 
centres of the data sampling periods. (The data sampling period for the 
8751 UART, for example, is defined by three samples taken at clock 
- 149 -
i.. 
. ' 
··-··-·------------- ---·-- -----~-
.--t--
-----,-~--:-,- '---~--__:____:___:_;_..:._...:.~-i--'---'--.l..:.:..:.:..:..C:~_:___:_+-~ +-_:__--+_:__:_'-l.-.:..:..:.:-:-'-i---'-:-:-:+-'--,-'i 
i· 
' 
. - . -t- ·-j. 
' r· 
·------ :....._.......:..~-- --+----
intervals 7, 8 and 9 of a clock running at sixteen times the baud rate . 
The data is accepted on the basis of a best from three poll). 
The 875l's UART was found to be more sensitive to problems associated 
with pulse narrowing and pulse jitter than the HP85' s serial interface 
UART. Clearly further development work will be necessary before a 
production board can be manufactured; the choice originally of the '567 as 
the PLL was determined by the single-rail power supply constraint (for the 
Pilot Scheme) and by the specification given for an earlier phase of the 
project originally the Pilot Scheme was conceived as a 300 Baud 
single-node system. (The '567 is well-suited for utilization in 
relatively slow-speed data transfer systems). With the power supply 
restriction removed, the choice of PLL's is greatly increased, and it is 
felt that if further development work on the board design is to be 
undertaken, then it would be prudent to substitute the '567 with a PLL with 
a faster lock characteristic and better high frequency specification. It 
can be seen from the information given in Appendix 3 that the 8751 serial 
port has some useful high data rate optl.ons. 
Firmware. 
Included with this Appendix is a set of flow diagrams relating to the 
firmware for the Pilot Scheme. Each flow diagram is described separately 
below. 
Polling Fl.rmware. 
This firmware consists of s simple closed loop which transmits the 
'polling sequence'. The polling sequence comprises the sequence 8,7,6, .... 1 
repeated indefinitely. Before entering the loop the program initializes the 
875l's serial port (see Appendix 3). The program polls eight devices, to 
allow for future expansion beyond the original three-node system. 
- 151 -
To begin the polling sequence the program selects the first device by 
loading the constant eight into the accumulator. The subroutine 'OUCH' is 
used to output the binary character; after calling • OUCH' the program 
pauses for twelve milliseconds (this delay is to allow the polled device to 
respond and transmit two bytes of sensor data) before decrementing the 
accumulator and jumping back to repeat the loop for the other seven 
characters in the polling sequence. The sequence is then repeated. 
Monitoring firmware. 
After initializing the serial port the monitoring node program inputs a 
polling character by calling subroutine 'INCH'. The polling character is 
compared with the node address (held as a constant in EPROM). If the 
polling character does not match the node address, then the next character 
is input from the serial port via 'INCH'. 
On detecting equality the sensor data (eight bits indicating the state 
of eight sensors) is read from Port 0 and output to the coaxial line using 
subroutine • NOUT' . This process is repeated for Port 1, after which the 
program jumps to the start of the loop and reads the next polling 
character. 
Subroutine NOUT 
This subroutine splits the eight-bit sensor data into two nibbles and 
adds the constant forty-eight to each nibble. This allows the HP85 (which 
• eavesdrops' on the line via a non- intelligent node - see Chapter 2) to 
differentiate between polling characters (pure binary) and data characters 
(printing ASCII characters). Each byte (modified nibble) is output to the 
line using subroutine 'OUCH'. 
N.b. It was found necessary to write one's (hexadecimal FF) to either port 
before reading the data. (Nowhere in the firmware is port 0 or 1 used for 
the outputting of data). 
- 152 -
Subroutines OUCH and INCH 
These two subroutines output or input characters respectively to or 
from the serial port. The buffer 'SBUF' is used to transfer data bytes, 
and is common to both processes, but the ready (or interrupt) flags - RI 
and TI are individual to each function. The serial port sets the 
appropriate flag when the I/0 transfer is complete and the flag is reset by 
software before the next byte is input or output. Both subroutines 
incorporate wait loops which test the state of the relevant flag line 
while the I/0 function is in progress. 
- 153 -
0 
....... 
\J1 
+'-
0 
POLL 
INITIALISE 
ACCUM.=8 
CALL S/R 
OUCH 
WAIT 12 mS ACCUM.= ACCUM.-1 
Figure A2.3 - Flowchart of Polling Firmware (Controller Node) 
I 
..... 
\.J'I 
\.J'I 
I 
MON. NODE 
I L INITIALISE 
CALL S/R 
INCH 
MOVE PORT 0 
TO ACCUM. 
CALL~:l 
Noufn II 
MOVE PORT 1 
TO ACCUM. 
CALL S/R 
NOUT 
Figure A2.4 - Flowchart of (Monitoring) Node Firmware 
I 
1-' 
\J1 
C1' 
I 
Figure A2.5 - Subroutine 11 NOUT 11 
I 
1-' 
\J1 
-...J 
I 
INCH 
CLEAR AI 
MOVE SBUF 
TO ACCUM. 
RETURN 
OUCH 
CLEAR TI 
MOVE ACCUM. 
TO SBUF 
RETURN 
Fig. A2. 6a - Subroutine "INCH II Fig. A2. 6b - Subroutine ~~OUCH IJ 
Appendix 3 - The 8751 Serial Port. 
The 8751' s serial port is a firmware-configurable device capable of 
supporting full-duplex data transfer . The device can operate in one of 
four alternative modes, selected by bits six and seven of SCON, the serial 
port control register. 
Mode 0 
Mode 0 configures the port as a synchronous data transfer device. The 
data rate is fixed at one twelfth of the crystal's operating frequency, 
i.e. 1 MBaud for a 12 MHz crystal. The Rxd pin is used for bidirectional 
data transfer and the Txd Pin is used as a clock output for 
synchronization. Although this mode of operation clearly has applications -
e.g. I/0 expansion using shifts registers, point-to-point interprocessor 
communications, high speed datalink implementation etc., etc. - it is not 
directly relevant to the work outlined in this thesis. 
Mode 1 
In this mode the serial port functions as a conventional eight-bit UART, 
with the Rxd, Txd pins being used for full-duplex data transfer. The 
receiver/transmitter ready/interrupt flags (RI, TI) are located in bits 
zero and one of SCON, and are used in conjunction with the serial port 
buffer (SBUF) to receive/transmit data. To utilize this mode of operation 
the user must configure Timer 1 as an auto-reload timer(i.e. set TMOD the 
timer mode register, equal to hexadecimal twenty) and load the appropriate 
constant into the high-order byte (THl) of the timer's register. Baud rate 
generation commences when the Timer Run control bit (TRl) is set in TCON, 
the Timer Control Register. Enclosed with this Appendix is a listing of the 
Assembly language program used for the soak-testing of RF Boards - serial 
port dependent interfaces. This listing shows the reader how the serial 
port may be configured to transmit at 9600 Baud. 
- 158 -
Also enclosed with this Appendix is a listing of the HP86 program used 
to generate lists of timer constants/baud rates (Appendix 1). The baud rate 
generated is a function of the THl constant and the oscillator frequency, 
and is given by the equation 
Baud Rate= -(Oscillator frequency)/(12x32xR) 
where R is the (negative) reload constant. 
Thus, the highest baud rates are obtained using the reload constants 
with the smallest modulii - e.g. a reload constant of minus one gives the 
highest baud rate (9600 baud for the 3. 6864 MHz) as it causes timer 
register overflow on the initial incrementation. The HP86 program lists the 
reload constants as negative two's complement integers; the constant minus 
one, for example, would be loaded into Thl as hexadecimal FF. 
Mode 2 
In this mode the port is configured as a 9-bit UART operating at a fixed 
baud rate given by 
Baud rate (Oscillator frequency)/64 
At 12 MHz the calculated baud rate is 187.5 KB, which is fast enough 
for efficient asynchronous interprocessor communications e.g. for 
datalinks or multi-CPU configurations using bussed serial ports. Because 
the baud rate is fixed, Timer 1 is available to the user for 
general-purpose use. The ninth bit of the serial frame is used as part of a 
useful master/slave protocol implemented by hardware within the 8751. The 
protocol has much to recommend it, mainly because it allows the user to 
implement a simple processor-to-processor communications system with a 
minimised software overhead. A full description (which is beyond the scope 
of this thesis) of the master/slave protocol can be found in Reference 1. 
- 159 -
Mode 3 
Mode 3 operation is similar to mode l operation in that Timer l is again 
utilized as a baud rate generator, but a nine-bit frame is employed, as 
for mode 2. This mode of operation has much to recommend it for 
general-purpose multi-processor communications, although data rates are of 
course limited compared with, say, mode 2. 
- 160 -
;**************************************************************~·*** 
0· , PROGRAM FOR SOAk- TEST OF RF BOARDS-
;THIS PROGRAM TRANSMITS THE CHARACTER 55H <U> VIA THE SERIAL PORT 
.-- ---- ~HARDI.oJARE REQtJIR€5g--c-··- -~----- .. · ··- ------- ~·------- -- · 
0 -· ,_-
0-, 
RAC~:: 
POWER <WATCHDOG} CARD .c-=:. 
2 X RF- CARDS----- ----- · ------ ----· · ---- -- ··-· 
CPU CARD-.--:--~-- ----- --- ---------- ----- - - ·--::c-:.:--·-
HP85/86 WITH OPTION 1 SERIAL I/F CONFIG'D FOR-TT~ 
ADAPTOR <FEM. 25-WAY DEE TO BOARD· PLUG)··- -
;***************************************************************** 
0.----!l- --
~-, 
0 -----, 
TX EQU 
AUTO EQU 
B9600- EQU 
ENABLE EQU 
u-- EG!U 
DT It1E EQU 
ORG 100H 
DEFINITIONS· 
42H 
20H 
OFFH-
OFFH·. 
55H 
OFH 
;TRANSMITTER ENABLE 
; AUTO RELOAD TIMER --
; 9600 BAUD---- --· ---- - ······ 
;; ENABLE (FOR- F'3 ,_. -::-c ·-
; 01 01 01 01- "FOFc BESr TEST·· 
~CONSTANT FOR DELA~ TIME 
. . . 
CONFIG SER; PT o FOR 9600 BAuo----·-------·--
l'lOV 
MDV 
MDV 
Mov--
P3,£ENABLE 
SCON 9 £TX ··· 
TMOD,£AUTO 
TH1 9 £BI7600-
·; STAHT- BAUD RATE=-GEN~---c--· 
···· SETB- TF\1 
;LOAD CHARACTER-··'U' INTO ACC;; 
SELF: 
MDV 
JNB 
CLR 
MDV 
DELAY~- MDV 
DEL~ DJNZ 
- ---..::--· DJ Nz-
-A 9 £U 
TI, SELF 
TI 
· SBUF 9 A--
R09£DTIME 
RO, DEL.:'-·· 
R 1 9 DE:t.:AY · ---- -
SELF · ---
;WRITE ONE's----
!l ENABLE· TX -
;AUTO-RELOAD MODE-~­
; 9600 BAUD:c 
; OUTPUT CHAR.-= 
;WAIT-- <HPB5~IS SLOW) 
------- --- --------- --- -
- -- -
; NEXT" CHAR.- --- --- --- · 
. -- .. -- -- -- - - - - - -
- . -
-
-·-------- -------
-------- -------------- ----------~---- -~--------------------
- --- - -
. -
---- ------- ------·- -
10 ************************************************** 
20 1 PROGRAM TO LTRT BAUD RATES FOR 8751 MICROPROCESSOR 
30 AUTHOR P.GRAY SEPT. 1984 
40 USES HP86 WITH P.P. AND A.P. ROMS 
50 1 AND 829058 PRINTER 
60 I ************************************************** 
70 
80 1 DEFINE 82905B PRINTER AS OUTPUT DEVICE 
90 PRINTER IS 702 
100 I REQUEST XTAL. FREQUENCY 
110 LINPUT "XTAL FRED. IN MHz?", X$ 
120 1 CONVERT TO Hz 
130 X=VAL IX$1*1000000 
140 1 PRINT HEADER 
15(; PR ll'lT " CONST. BAUD CONST. BAUD 
UD " 
160 PF:INT 
170 1 PRINT IN 8 COLUMN FORMAT ON A4 
180 FOR 1=1 TO 64 
190 ! CALULATE RELOAD CONSTANTS 
200 RO=-I 
210 R1=-II+641 
220 R2=-II+1281 
230 R3=-II+192l 
240 1 CALCULATE BAUD RATES 
250 BO=X/112*32*Il 
260 81=X/112*32*1I+64ll 
270 B2=X/112*32*1I+128)) 
280 B3=X/112*32*1I+19211 
290 PRINT USING 300 ; RO,BO,R1,B1,R2,B2,R3,B3 
CONST. BAUD 
300 IMAGE 4X,S3D,4X,5D,5X,S3D,4X,5D,5X,S3D,4X,5D,5X,S3D,4X,5D 
310 NEXT I 
320 1 PRINT CAPTION 
330 PRINT 
340 F'RINT 
CONST. 
350 PRINT " TABLE OF RELOAD CONSTANTS/BAUD RATES FOF: ";X$; "1'1H:: XTAL" 
360 ' UNDERSCORE WITH ASTERISKS 
370 FOR 1=1 TO 60+LEN IX$1 
380 IF 1<12 THEN PRINT " "; 
::::90 IF I> 11 THEN PRINT "*"; 
400 NEXT I 
410 F'RINT 
420 1 RELEASE PRINTER 
430 PRINTER IS 1 
440 END 
-162-
BA 
Appendix 4 - HPIB Overview 
This brief overview of HPIB (Hewlett-Packard Interface Bus) is included 
for the reader who is unfamiliar with HPIB and requires an explanation of 
some of the technical terms used in Chapter 5. In 1978 the protocol was 
formally adopted by ANSI/IEEE as the Standard IEEE-488, a standard which is 
also referred to as GPIB (General Purpose Interface Bus). The protocol is 
referenced throughout this thesis as HPIB rather than IEEE-488 or GPIB; 
this is appropriate, as the Company does use exclusively HP computers, and 
therefore the equipment will be interfacing to HP' s implementation of 
IEEE-488 rather than any other. 
HPIB is a parallel bus system originally developed by HP to interlink 
laboratory equipment; a typical modern-day example of it's application 
might be, say, a system in which a desk-top computer is used to monitor the 
output of a complex piece of chemical analysis equipment and log the 
results on a dot-matrix printer in the form of a report. The three pieces 
of equipment - computer, analyser and printer would be linked together by a 
series of cables in a simple 'daisy-chain' manner. HPIB cables feature 
convenient stacking connectors to make the daisy-chaining a fool-proof 
operation. In this example the computer would (almost certainly) assume the 
role of the HPIB Controller (see below), but this would probably be a 
function performed transparent to the user. Despite its depth of 
specification, the beauty of HPIB is its simplicity of use compared with, 
say, a relatively crude protocol such as RS232, which is notorious for 
causing connector pin-out misunderstandings. This simplicity of application 
possibly accounts for HPIB's lasting popularity in Industry. 
Figure A4-l offers an illustration of the HPIB concept An HP86 
desk-top computer is shown as the Bus Controller which controls the 
transfer of data between the other devices which may be either Talkers, 
- 163 -
I 
f-1 
"' .p. I 
TO OTHER 
DEVICES 
{Talker) (Talker/Ustener} 
(Ustener) 
1 .J .....•.......•........ L •• J. •••••••••.••••••.•••• Ls •• J ••••••••.••••••••••••• -•• ~ <==·.·.·.·.·.·.· . .'........................... MANAG.~~.~N.J .~V ........................... ·---,.../" "''-~ 
HP86 
Figure A4.i - HPIB Schematic. (Bus Controller} 
Listeners, or both (Talker/Listeners). A typical Talker device (shown) 
might be the analyser quoted as an example previously. A Talker can 
transfer data via the Bus (HPIB) to one or more Listeners - in this case, 
perhaps the 2361 printer (illustrated) or, even the HP86 (a device which 
acts as a Bus Controller may also, additionally, perform Talker/Listener 
functions; this app 1 ies to the HP8 6 with its built- in HPIB interface) . 
Another example of a Talker/Listener device (shown) might be a data capture 
terminal; such a device could have its own keyboard and display in addition 
to a slot reader and light-pen wand (devices for reading bar codes). Bar 
codes are used increasingly, for example, in the Pharmaceutical Industry 
for identifying batches of bulk material. The terminal would, typically, 
transfer data before logging it on the printer (the HP86 now acting as a 
Talker while the printer Listens) and the terminal's screen (the terminal 
is now a Listener). 
To achieve this flexibility the HPIB Bus is organized into two sets of 
eight lines (each) known as the 'Data Bus' and the 'Management Bus'. The 
remaining lines of the HPIB (there are 24 in total) are earth lines 
associated with screening or grounds for signal logic. The Data Bus is 
simply eight lines (DIOl - DI08) used, as the name implies, to transfer 
data bytes (and also command bytes) between devices in a bit-parallel 
byte-serial manner. The Management Bus consists of eight control lines used 
for handshaking or other purposes. 
The single most important control line is ATN which is asserted (HPIB 
uses negative-true logic) by the controlling device when it wishes to 
transfer commmand bytes onto the Data Bus. Talkers and Listeners respond to 
ATN by ceasing data transfer and responding to subsequent commands bytes 
from the controller. 
- 165 -
A typical sequence of events is: 
ATN LOW 
UNT (Untalk) 
UNL (Unlisten) 
LISTEN 1 
TALK 2 
ATN = HIGH 
The UNT, UNL commands are used to remove current Talkers and Listeners 
from the Data Bus. The result of the sequence above is to cause data to be 
transmitted from device Two to device One. There may be up to sixteen 
devices on the Bus, each with its own unique address. 
When a Listener is ready to accept data it indicates this to the active 
Talker via the handshake line NRFD (Not Ready For Data) . (All Listeners 
will take NRFD HIGH when they are ready; thus the slowest device governs 
the speed of data exchange). On seeing NRFD HIGH the Talker takes DAV (Data 
Valid) LOW to indicate that a data byte is on the Data Bus. (Only one 
Talker may be active on the HPIB, so this signal condition is of immediate 
effect). The Listener takes the data byte and sets NDAC high (Not Data 
Accepted) - again the slowest Listener determines when the signal condition 
is established. The Talking device sets DAV high on seeing NDAC HIGH , and 
the Listeners respond by taking NDAC back to the LOW state. This completes 
the handshake sequence. 
The NRFD/DAV/NDAC triple-wire handshake ensures that the data is 
reliably transferred at the speed of the slowest Listener. Other 
single-wire control lines not covered so far are SRQ, REN, IFC, and EOI. 
SRQ (Service Request) is an active LOW signal that may be asserted by 
any device to request attention from the controller - which then polls the 
devices (see below) to determine the source of the request. REN (Remote 
- 166 -
Enable) is a special signal that is used by the controller to switch all 
the Listeners into remote mode, while IFC is used as a general reset signal 
for Bus devices. EOI (End Or Identify) is a signal used by the controller 
to elicit a parallel poll response (see later). 
For simplicity, the signal wires have been grouped into two data buses 
as shown in Figure A4.1. A more strict convention for the signal groupings 
is the following: 
(i) An eight-line 'Data Bus' (DIOl - DI08). 
(ii) A 3-line 'Data Byte Transfer Control Bus' (NRFD, DAV, NDAC). 
(iii) A 5-line 'I/F Management Bus' (ATN, SRQ, REN, IFC, EOI 
The Bus adapter chip (96LS488) used in the HPIB Board design responds to 
REN with a LOW output on the R/L pin; the chip also responds to both serial 
and parallel poll. Serial poll is performed by the controller sending the 
SPE (Serial Poll Enable) command on the data Bus followed by the talk 
address of each device in turn. In the implementation chosen by the author, 
the RQS (Requested Service Output) will drive DI07 LOW if an SRQ request 
has been made via the interface. 
The IST pin of the 96LS488 is the parallel poll input pin; the chip 
responds to a parallel poll request (initiated by the controller taking EOI 
and ATN LOW simultaneously) by comparing a defined Data Bus line with the 
current IST logic level (see Ref. 14), and driving another (defined) Bus 
line LOW. For the prototype HPIB Board design, the IST pin has been wired 
LOW, as certain facilities have been dropped to improve the track layout -
the board is heavily populated. It is true to say that many HPIB devices 
that are manufactured are designed to respond to only a subset of the HPIB 
commands, and it is the author's experience that parallel poll is a feature 
that is rarely implemented. There is little point in implementing the 
feature if the majority of the devices in common use (printers, balances, 
etc.) do not support parallel poll. 
- 167 -
Appendix 5 - Features of the 8748 
The 8748 single-chip microprocessor (as used on the BCD Board - see Chapter 
5) is a member of the MCS -48 family (Refs. 31, 32), the precursor to the 
!-1CS-51 family. The major features of the 8748 are: 
* Eight-bit CPU 
* Three eight-bit I/0 ports 
* lK Bytes of EPROM 
* 64 Bytes of RAM 
* Eight-bit timer 
* Multiplexed Twelve-bit Address/Data Bus 
Although, if compared with the 8751' s facilities (Chapter 2), these 
features appear to make the 8748 to be the 'poor relation', the 8748 has 
several useful 'extras' not implemented by Intel within the 875l's 
hardware. For example, the user may debug small programs held in the 8748's 
EPROM by using the single step pin (pin 5); only a small amount of external 
hardware is needed to provide the function (see Reference 31 Figure 2-13). 
Two test inputs are provided (but only one interrupt pin) which may be 
directly tested by dedicated instructions (JTO, JNTO, JTl, JNTl). Probably 
the biggest 'extra' the 8748 offers, however, is its ability to expand its 
l/0 using 8243 port expander chips. A timing signal (PROG) and 4 bits of 
port 2 are used for this purpose. The 8748' s instruction set contains 
instructions allowing the programmer to address the 8243's as though they 
were an integral part of the 8748. By bussing several 8243 's and using 
spare 8748 (port 2) pins to drive their chip selects, a very powerful I/0 
structure can be quickly designed. Thus the 8748 is an ideal choice of 
microprocessor for the BCD Board application described in Chapter 5. 
It is beyond the scope of this thesis to include full details of the 
8748 's instruction set, which is fully described in Reference 31. This 
reference, and Reference 32, offers much application detail for the 8748. 
- 168 -
Appendix 6 - BCD Board (Testing/Firmware) 
As indicated in Chapter 5, testing of firmware for the 8748 was strictly 
limited by the lack of development facilities (the PDS system used for 
te~ting the 8751 supported neither an MCS-48 family assembler, nor an 8748 
emulator). The testing, therefore, consisted of writing small blocks of 
8748 machine code to check sections of the BCD board circuitry. This 
testing was to some extent trivial, as the author has had previous 
experience of the MCS-48 family in similar work unrelated to this project; 
also, the BCD interface design is not complex. 
Figure A6 .1 shows a simple schematic arrangement for data exchange 
between the BCD Board (8748) and the CPU Board (8751). The 8748 firmware 
accesses data from the 8243 I/0 expanders (see Figure A6. 2), writes the 
data to the data latch, and sets the status to 'ready' within the status 
latch. The 8751 then accepts the data and status bytes (reading the status 
register causes an 8748 interrupt, which indicates that the status has been 
read), stores the valid data byte and loops while testing the status 
register until the next byte is valid . The sequence then repeats. The 
simple sequence shown in Figure A6.1 will be replaced by more sophisticated 
software routines written by software specialists within the Company's 
Computer Service Department. 
The BCD Board has the facility to interrupt the 8751 to initiate serial 
poll; thus the Board will be a member of the set of boards capable of 
taking part in the interrupt/status handshake system. 
Testing of the 8748-8243 circuitry was achieved using switches 
(switching to ground with an open-circuit pull-up) to simulate the BCD data 
lines from a BCD device. Further switches were used to switch the two flag 
lines, and the status of the control line was monitored with a logic probe. 
- 169 -
I 
'""' -....! 
0 
I 
GET 
VALID DATA 
WRITE DATA 
BYTE TO LATCH 
SET 
STATUS=READY 
CLEAR STATUS 
FINISH 
START 
(8751) 
STORE 
DATA BYTE 
FINISH 
Figure A6.1- Schematic of 8748/8751 Interaction 
I 
t-' 
....... 
t-' 
I 
START 
SET 
CONTROL 
LINE 
SELECT 
1ST 8243 
READ 
ALL FOUR 
PORTS 
SELECT 
2ND 8243 
READ 
ALL FOUR 
PORTS 
CLEAR 
CONTROL 
LINE 
FINISH 
Figure A6.2- Schematic of 8748/8243 Firmware" 
A small modifiable machine-code routine was written to read data from 
adjacent pairs of selected expander ports (specified by the state of the 
flag lines 00, 01, 10, 11) and latch the data byte to the Bus Port. A 
further machine code routine was written to latch bytes into the two '574 
latches from the 8748, and the PDS was used to check that the 8751 could 
read the data bytes via the backplane lines, thus the confirming the 
validity of the address decode logic on the BCD Board. 
- 172 -
Appendix 7 - HPIB - RS232 Converter 
In Chapter 5 the testing of the HPIB Board and the DART Board were 
described in detail, while Chapter 6 gave details of the Serial Board 
check-out. During later stages of the tests, the various boards of the 
system were checked in combination - some of these combinations suggesting 
an immediate use as working systems for specific applications. 
An example of of a potentially useful combination of boards is the set: 
Board 
CPU 
Watchdog 
HPIB 
Serial/DART 
Use 
Control 
Power input/monitor 
Data Input 
Data Output 
which, in the example shown in Figure A7. 1, can be used to create a 
basic HPIB to RS232 converter. 
The convertor shown schematically in the Figure A7. 1 flow diagram can 
work with either a Serial or DART board as the output interface. The 
initialization of the serial device (see flowchart) in the case of the 
Serial Board consists of setting up the 875l's on-board DART registers as 
described in Appendix 3 and elsewhere, while the UART Board (if used) is 
set up by initializing the 8251 DART as discussed in Appendix 9. The HPIB 
interface requires a dummy read to set up its status registers correctly, 
as indicated in Chapter 5. 
Once both devices are set up, the HPIB status register is examined to 
see if a byte has been received; the interface will not accept another byte 
from the HPIB until the 8751 takes the current one. As soon as the 8751 has 
taken the byte it sets the output handshake (RTS) line to the remote serial 
device acting as the data sink. This tells the remote receiver that a byte 
is pending, and the receiver responds by taking the input handshake 
- 173 -
D 
...... 
..... 
_;,... 
D 
NO 
HPIB/RS232 
INIT. 
HPIB BOARD 
OUTPUT 
BYTE 
NO 
CLEAR OUTPUT 
> <.1 I HANDSHAKE 
READ BYTE 
SET OUTPUT 
HANDSHAKE ~ 
LINE 
LINE 
Figure A7.1- Schematic of HPIB to RS232 Converter 
line (CTS) high, prompting the 8751 to output a character via its serial 
channel. Once the character has been transmitted, the 8751 clears the 
output handshake latch and returns to the commencement of the main loop and 
awaits the arrival of the next character from the (HPIB device) data 
source. This is in theory, the complete firmware requirement for a simple 
HPIB to RS232 converter. In practice, the program probably would be 
enhanced in a number of ways - e.g. on-board buffering (RAM Board) would 
give the unit a 'spooler' feature which would enable the transmitting 
device to dump blocks on data into the unit, without being limited by the 
speed of the (slow) serial device. Also, there is no reason why the 
firmware should not be written in 
bidirectional data transfer. 
a general purpose way to support 
- 175 -
Appendix 8 - The 8052-BASIC CPU 
This Appendix gives further details of the hardware configuration 
required to support the 8052-BASIC chip described in Chapter 8. Figure A8.1 
shows a typical minimum configuration for a system supporting RAM and 
EPROM. 
Memory Configuration 
The BASIC chip is programmed to expect a specific configuration of the 
external memory; the required partitioning is as follows: 
0-32K RAM Memory (Controlled by RD and WR) 
0-32K EPROM 
32K-64K RAM/EPROM 
" ( " " " PSEN) 
" ( " " " [PSEN ANDed 
and WR) 
with RD] 
The syseem allows for the programming of EPROM's resident in the upper 
address range. Because PSEN and RD are ANDed during access to this memory 
area, both BASIC and assembler programs stored in these locations can be 
executed. 
During EPROM programming the system uses the ALE DISABLE (Pl.3) line to 
override ALE, thus allowing the lower address byte to be held in the ('573) 
latch for a prolonged period; by using this technique the CPU is able to 
use port 0 as an I/0 port (this port is open-drain in structure - it is 
necessary to use external lOk pull-ups) and use the port latches to hold 
data bytes for EPROM programming data. (A similar double-latch system is 
utilized in the BCD Board design). The programming pulses (PULSE AND 
ENABLE) provided to control the programming are TTL level signals, hence 
the user must provide the necessary level shifters to increase the voltages 
to those specified by the EPROM manufacturer. The system supports a 
- 176 -
BUS /I RAM 1\. BUS /I EPROM 
~ > I AO-A7 u I I~ H (f) 
I <! f-0 I ~y YOE ....., CD ....., 
I _..... I .573 Pi.7 :r: LATCH 
<( 
LINE PmN1ER 0/P I ru LD 
Q1leJL£ ~em I 0 (!) I ALE ' <?I.E 
v- I ~INPUT ~~ 
-
RD 
-
PSEN 
-
PULSE 
--
I I ENABLE I ~>l ~Viall stu~~~ 
~sic ci.r"\:ull.trv -
a. g. osc. compomn~Cs -
omitted ~or clmrity) Fig AB.i- Schematic of a Typical BASIC-52 System. 
conventional programming algorithm (via the • PROG' command) and also 
Intel's fast programming algorithm (FPROG). To use the latter it is 
mandatory to increase Vee for the EPROM to 6v throughout the programming 
interval. 
The MCS BASIC-52 system has a unique EPROM filing system for storing 
BASIC programs. Issuing the 'PROG' command, for example, causes the 
currently selected BASIC program, resident in RAM, to be stored in an EPROM 
file. The system maintains a file index automatically, allowing the user to 
recall programs back into RAM memory at will, via the 'XFER' command. 
Alternatively, the programs may be executed directly from EPROM memory. 
'RAM' and 'ROM' commands are provided to allow the user to switch between 
the two memory areas. 
It should be born in mind that 8K of the usable object code memory space 
is already occupied by the 8052's on-board ROM (used to implement the BASIC 
interpreter and other elements of the system). Also, the system needs lK of 
external RAM for system variables, so the first lK of external data memory 
is also unavailable to the user. 
Statements 
Reference 20 lists (Section 1.4) commands/statements/operators that are 
supported by BASIC-52. Typical commands that may be executed via the 
console are RUN, LIST, LIST=, etc. There are fourteen defined commands, 
forty-four statements such as DO-WHILE, DO-UNTIL, FOR-TO-STEP, 
IF-THEN-ELSE, etc. ,etc., and forty-five operators. The operators available 
include the standard set of mathematical instructions associated with 
BASIC, as well as many other useful and powerful operators unique to 
BASIC-52. 
- 178 -
Assembly Language Interface 
MCS BASIC-52 allows the user to interface to an object program (held in 
EPROM) by means of the 'CALL' instruction. 'PUSH' and 'POP' instructions 
allow programs, subroutines or assembly language routines to exchange 
parameters via the stack. For example, 
PUSH A,B 
CALL 5000H 
calls the assembly language subroutine at location 5000H. The 
parameters A and B are passed via the argument stack; assembly language 
programs can retrieve the parameters with calls to defined BASIC 
subroutines. These same subroutines (with specific parameter values) allow 
the user to make use of the BASIC facilities from assembly language 
programs. The user can thus write a program in assembly language - which is 
faster running than interpreted BASIC and make use of the on-chip 
'library' of powerful functions when required. Full details of the 
functions available are given in Reference 20. 
Port 1 Functions 
BASIC-52 provides the 'PORTl' operator (see Chapter 8) to read/write 
data to port 1. All eight port lines have special functions associated with 
them, as listed below: 
Port 1 Pin Function Meaning 
0 T2 Timer 2 Trigger Input 
1 T2EX Timer 2 Input 
2 PWM 0/P Pulse Width Mod. 0/P 
3 ALE DISABLE (used during EPROMing) 
4 PROGRAM PULSE ( " " " ) 
5 PROGRAM ENABLE ( " " " ) 
6 DMA ACK Fake DMA Acknowledge 
7 L.P. 0/P Line Printer Output 
- 179 -
The timer functions (Pl.O, Pl.l)are standard 8032/8052 functions, and 
the reader is referred to the respective data sheets. The PWM (Pulse Width 
Modulate) signal, whose use is described in Chapter 8, is output on pin 
Pl.2. The ALE DISABLE, PROGRAM PULSE and PROGRAM ENABLE are all 
EPROM- related signals, as discussed earlier in this Appendix. The DMA 
facilities that use pin Pl. 6 as an acknowledge output are reviewed in 
detail below; the L. P. output (pin 1. 7) has been mentioned already in 
Chapter 8 - it is a TTL compatible output that is used as a channel for 
listings and other outputs invoked by the LIST= and PRINT= commands. A 
statement (BAUD) is provided to allow the user to tailor the transmission 
rate to match the speed of the printer employed. 
Fake DMA 
Although the MCS-51 family architecture does not support DMA with 
dedicated on-chip hardware the BASIC variant offers a type of 'DMA' 
known as 'Fake DMA' , which is implemented using the INTO pin as a DMA 
Request input and Pl. 6 as a DMA Acknowledge signal. To use the Fake DMA 
facilities the user must: 
(i) Provide tri-state buffers for port 0 and port 2 and also a 
tri-state address latch, and control the tri-stating of these chips with 
the DMA Acknowledge signal. 
(ii) Using BASIC statements, enable Fake DMA by setting three bits 
associated with the facility (one of these bits is located in the 
8052's internal memory, the other two are held in the Special Function 
Register). 
Although at first sight the functioning of the Fake DMA system appears 
similar to a conventional DMA system, operation is much slower, as the 
system is interrupt driven. During the operation of the DMA access, the 
- 180 -
8052 idles, testing the state of INTO. The full Fake DMA operation sequence 
is: 
(Initially, DMA Request (INTO) and DMA ACK (Pl.6) are HIGH). 
1. The requesting device takes INTO LOW and waits for DMA ACK to eo T,OW, 
2. The 8052 interrupts its processing, takes DMA ACK LOW and waits for 
INTO to return HIGH. 
3. The requesting device performs the memory access and then takes INTO 
HIGH. (The device waits for DMA ACK to return HIGH before making further 
DMA requests). 
4. The 8052 sees INTO return HIGH, takes DMA ACK HIGH, and continues 
normal execution. 
Obviously, this method of memory access is inefficient compared with 
'cycle stealing' systems, but is a useful feature for those users who 
require a DMA-like memory access system, and are not constrained by 
high-speed requirements. 
- 181 -
Appendix 9 - Serial/UART Board Functions & Options 
Current Loop Configurations 
The activejpassive current loop configurations shown in Figure A9 .1 
apply to both the Serial and UART Boards, as the current loop circuitry is 
identical in design for both boards. By means of the eight-way DIL switch 
that is incorporated in the prototype designs, the system user may select 
active/passive combinations for both the receiver and transmitter 
circuits. For example, the passive options shown in Figure A9 .1 may be 
selected may by closing switches one through four and opening switches five 
through eight, while the active options may be configured by utilizing the 
complementary switch settings. 
The instruments with current loop interfaces that the Company have used 
in the past have, although possessing full duplex facilities, not been used 
for simultaneous bidirectional data transfers. Hence the prototype units 
described in this thesis are designed to support a three-wire cabling 
system that is frequently used within the Company to connect to small 
industrial balances. This is not good practice for long cable runs which 
should feature twin twisted-pair cables with separate signal returns; it 
would be better therefore, on production boards, if the passive loop 
options featured independent return lines, to minimize cross-talk and offer 
improved noise immunity. 
UART Board - Configuration 
The 8251A USART is a software-configured device. Two sections of the 
USART, the synchronous and asynchronous sections, can be thought of as two 
independent devices sharing the same package. As there is no foreseen 
requirement for the synchronous facilities the part offers, this option has 
been ignored in the development work. Obviously, should the need arise in 
- 182 -
(Pln i2l (20mA RJll 
(25-WAV D-TYPE CONNECTOR) 
(Pin 19) I'Pln 10) 
(20mA Common Return) 
(PASSIVE} 
(20mA Txl 
(Pln 12) (20mA Ax) 
(25-WAY D-TYPE CONNECTOR) 
rPin19) (Pin7) 
l_ 
(20 rnA 
CURRENT 
SOURCE) 
(ACTIVE) {HCPL-4100 
OUTPUT 
TRANSISTOR) 
C20mA Txl 
(HCPL-4100 
OUTPUT 
(HCPL-4200 
INPUT 
---'r- DIODE) 
" ;1-
TRANSISTOR) 
(HCPL-4200 
INPUT 
DIODE) 
C20 rnA 
CURRENT 
SINK) 
-1211 
Figure A9.1 - Current Loop Configurations. 
-183-
START 
~ 
SEND 
3 SYNC CHARS. 
SEND 
INTERNAL RESET 
COMMAND 
SET MODE -1:: 
rt>-
/), 
DISABLE 
ALL FUNCTIONS 
ENABLE RECEIVER 
AND 
PURGE BUFFER 
SELECT OPTIONS 
ITX AX H/S) 
* 
FINISH 
Figure A9a2 - UART Initialisation Sequence" 
the future, then the system could easily support synchronous devices with 
the minimum of circuit modification. 
To use the USART correctly, it must be initialized in accordance with 
the manufacturer's specification; the reader is referred for full details 
to the 8251A data sheets and to Reference 5, which contains much useful 
application data. After correct initialization, the user passes/accepts 
data to/from the USART via its internal data buffers. Internal registers 
are also provided for command/status bytes, which the 8751 accesses via 
the data bus as described in Chapter 5. 
Figure A9. 2 shows schematically a typical system for initializing the 
USART, which is a simplification of the diagrams/notes contained in the 
Intel application data. The initialization scheme starts with the 
transmission of three dummy SYNC characters (binary zero), which is a 
necessary precursor to issuing an internal reset command (hexadecimal 
forty) to the USART, in order to put the chip into a known state. The dummy 
SYNC characters are required as a result of the USART' s dual function, 
explained earlier. (The reader should note that delays are needed in the 
initialization firmware between writes to the USART in order to meet the 
various recovery/response 
sheets). 
times specified in the manufacturer's data 
After the reset state has been successfully achieved, the user writes 
the mode byte to the USART, which selects the various options - parity, 
character length, etc. . After these mandatory operations, the user may 
perform a number of different commands according to his specific 
requirements. Typically, for a full duplex data transfer, the user will 
inhibit all options by writing zeros into the command register, before 
purging the 825l's input buffer as required by the manufacturer's 
specifications, as the 8251 can supply erroneous data upon start-up. (This 
- 185 -
is a similar condition to the one encountered during the HPIB interface 
initialization). The user can now safely set-up any required options by 
writing the appropriate command word to the 8251. The command word options, 
mode instruction and status register formats are all detailed in the 8251A 
data sheets to which the user is referred for further information. 
- 186 -
Appendix 10 - Power Sup~ 
Several different power supplies were used during the course of the 
Project; the specifications of the various units are listed below. 
Farnell D5-05A 
This was the sub-miniature 500mA supply used for the Pilot Scheme. It 
was a mass produced economically priced unit, primarily intended for 
powering a digital panel meter. It had a regulated Sv output, and also an 
unregulated 12v output which proved useful in the Pilot Scheme for 
powering instrumentation external to the nodes. 
Parameter 
Mains Input 
0/P Voltages 
Load Regulation 
Line Regulation 
Ripple 
Specification 
214-255v and 108-128v, 50-400Hz 
Sv +/- 0.2v (3-terminal regulator) 
12v +/- 4v (unregulated) 
Less than SOmV 
II II 
II II pk to pk 
Some use was also made of the Farnell 6/SOOP sub-miniature supply ( a 
single output supply with a superior specification to the DS-05), and the 
related 15/15/lOOP unit, which featured split supplies suitable for 
powering RS232 buffers, OP amps, etc. All units were enclosed in robust 
cases formed from extruded aluminium sections, and had clip on covers to 
protect the connections. 
VMS 2000 
This switch-mode power supply was used for powering the rack system and 
proved to be a most reliable and economical unit incorporating an integral 
mains filter. 
- 187 -
Parameter Specification 
Total Maximum 0/P 60 Watts 
Input Voltage Range 175 to 265v AC @ 50/60Hz 
90 to 130v AC @ 50/60Hz 
DC Output 
Line Regulation 
Load Regulation 
Ripple 
+5v DC @ 6.0 Amps (adjustable) 
+12v DC @ 1.0 Amps 
-12v DC @ 1.0 Amps 
-5v DC @ 1.0 Amps 
Less than 0.25% over the input voltage range 
II II II for a 20% to 80% load change 
II II 50mV pk to pk 
The above regulation figures apply to the 5v line only. The other supply 
lines are regulated by standard three terminal regulators (see the D5-05 
figures). The unit was of open-frame construction, and was, naturally, 
considerably bulkier than the supplies used for the Pilot Scheme. 
- 188 -
Appendix 11 - Details of RAM Memory Devices 
This Appendix gives further information on the various RAM chips 
mentioned in Chapter 5, especially the 2186 !RAM used on the RAM Board. 
The 2186 !RAM 
The 2186 and 2187 pseudostatic (or 'integrated') RAM's are two 
'byte-wide' memories introduced by Intel in an attempt to fill the gap 
between small-scale static RAM memories and complex DRAM systems. The 
2186/2187 RAM's have the following features: 
* On Chip Refresh 
* External Refresh Option (2187) 
* Microprocessor Handshake Option(2186) 
* TTL Pin Compatibility 
The 2187 is a synchronous device requiring more complex external 
circuitry than the 2186 asynchronous part, the latter being a natural 
choice for the RAM Board design, resembling a conventional SRAM in its 
external electrical characteristics. The 2186 has a 'Ready' output on pin 
one, which can, optionally, be used as a microprocessor handshake line to 
time memory accesses, thereby avoiding contention delays and achieving 
faster response. This feature was not, however, utilized in the RAM Board 
design. 
The simple 'R-M-W' treatment used by way of illustration in Chapter 4 is 
not strictly correct for the 2186; it is certainly an accurate overview for 
the some modes of operation of DRAM memories such as the 2118, but the 2186 
is a much more sophisticated chip embodying not only DRAM arrays but also 
refresh timers, counters, arbiters, address multiplexers, etc., etc .. The 
various modes of operation of the 2186 are reviewed briefly below, but for 
- 189 -
a fuller treatment of the 2186 architecture the reader should consult 
References 10 and 11. 
There are 'pulsed' and 'long' mode options for both read and write 
operations. Both operations are subject to contention delays, but otherwise 
the contention resolution processes are transparent to the device's 
functioning. 
Pulsed Mode Read 
If CE (Chip Enable - active LOW) returns HIGH before OE (Output Enable) 
returns HIGH, then a pulsed mode read occurs, provided .the 2186 timing 
specifications are observed. This is a useful mode of operation for designs 
where the chip enable is not gated for, say, the duration of ALE or a 
similar long pulse. In the case of the RAM Board design, ALE is used as the 
main enable pulse, so this mode of operation is not relevant to the project 
application. 
Long Mode Read 
This mode applies to designs with a protracted CE pulse; the minimum 
time for CE to be held LOW after OE goes LOW is given in the 2186 data 
sheet. Failure to observe the timing specifications results in an FMC (see 
below). 
Pulsed Mode Write 
A pulse mode write occurs if CE returns high before WE (Write Enable), 
within the device's timing specifications. 
Long mode Write 
As for long mode read, this mode of operation is applicable to the RAM 
Board design in that it requires a protracted CE pulse; failure to observe 
the timing specifications results in an FMC. 
- 190 -
False Memory Cycle 
An FMC (False Memory Cycle) occurs when CE goes LOW without either WE or 
OE being active, or when a read/write violation takes place. This is in 
itself a valid mode of operation, causing a refresh of the row within the 
2186 which is selected by the seven external row addresses. 
Other Memory Chips 
Both the Hitachi HM6264 and the Toshiba TC5564P 8Kx8 SRAM's were sampled 
for evaluation (see main text). Pin 26 on either device is used as an extra 
chip select (active HIGH), which is a useful facility for designers wishing 
to minimize select logic. The parts are available with a variety of 
options, with access times as fast as lOOnS. Other memories of interest 
include the family of Hybrid RAM's from Electronic Designs Inc. (Ref. 30), 
whose family of components include static RAM-based parts from 32Kx8 bits 
upwards, and hybrid components - 80C31 (CMOS version of the 8031) CPU's 
combined with SRAM arrays, surface-mounted on 40-pin headers - obviating 
the need for further external RAM. 
- 191 -
