Feasibility study of microprocessor systems suitable for use in developing a real-time for the 4.75 GHz scatterometer by unknown
General Disclaimer 
One or more of the Following Statements may affect this Document 
 
 This document has been reproduced from the best copy furnished by the 
organizational source. It is being released in the interest of making available as 
much information as possible. 
 
 This document may contain data, which exceeds the sheet parameters. It was 
furnished in this condition by the organizational source and is the best copy 
available. 
 
 This document may contain tone-on-tone or color graphs, charts and/or pictures, 
which have been reproduced in black and white. 
 
 This document is paginated as submitted by the original source. 
 
 Portions of this document are not fully legible due to the historical nature of some 
of the material. However, it is the best reproduction available from the original 
submission. 
 
 
 
 
 
 
 
Produced by the NASA Center for Aerospace Information (CASI) 
https://ntrs.nasa.gov/search.jsp?R=19770026642 2020-03-22T08:06:31+00:00Z

L_,
TABLE OF CONTENTS
Section	 Page
INTRODUCTION.	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 1 1
' SYSTEM ARCHITECTURE	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . 2 a
ANALOG SYSTEM	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 5
DIGITAL	 SYSTEM	 .	 .	 ..	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 9
d	 Architecture	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 9
I/O	 Structure	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 11
c	 Memory	 Structure	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 12
F
Power Requirements 	 .	 .	 .	 .	 .	 . 13
Operating Modes	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 13
Reset	 and Initialization	 .	 .	 .	 .	 .	 .	 :	 .	 . .	 .	 13
Execution .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 14
SOFTWARE.	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . is
Variation-of Efficiency. 	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 15
Conditional Control Transfer . 	 .	 .	 .	 .	 . ...	 .	 17
Subroutine Linkage 	 .	 .	 .	 ..	 .	 .	 .	 .	 .	 . .	 .	 .	 18
Subroutine	 Design .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 19
8-Bit Arithmetic and Logic Functions . 	 . .	 .	 .	 21
Memory Size and Usage 	 .	 . .	 .	 22
Speed	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 23
M
i
v
a
^
'	 Section page
ADDRESSING MODES.	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 .	 24
Extended Addressing.
	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 .	 24
Direct Addressing.
	 .	 .	 .	 .	 . .	 .	 24
Indexed Addressing
	 .	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 25
F	 Relative Addressing.
	 .	 .	 .	 . .	 .	 .	 .	 26
f'	 Immediate Addressing 27
Inherent Addressing.
j
.
Comparisons.	 .	 .	 .	 . 29
UTILIZATION OF COMMERCIALLY
AVAILABLE MAINFRAMES
	
.	 .	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 .	 ..30
THE TRADEOFF WITH AND WITHOUT
'j
I
UTILIZING ,A FIRST LEVEL MAINFRAME.
	 . .	 .	 32
f	 CONCLUSIONS	 .	 .	 .	 .	 .	 . .	 .	 34
RECOMMENDATIONS 35
i REFERENCES.	 .	 .	 .	 .	 .	 .	 .	 . .	 .	 36
APPENDIX
3
j
l
x
.
-
t^
INTRODUCTION
A class of signal processors has been developed
at the Remote Sensing Center, Texas A&M University,
suitable for the reduction of radar scatterometer data
in real-time.	 The developed systems are applied to the
reduction of single polarized 13.3 GHz scatterometer data
and provide a real-time output of radar scattering
r
coefficient as a function of incident angle.
It has been proposed that a system for pro-
cessing of C-band (4.75 GHz) radar data be constructed
to support the scatterometer system currently under
development.
	
It is the purpose of this report to establish
feasible design approaches to the development of this
processor system utilizing microprocessor technology.
Two major microprocessor systems, the Motorola
M6800 and the Intel 8080, are contrasted and considered"
for possible use in the development of a processor system.
The purchase of a microprocessor system at the chip level
is also considered.
	 Recommendations are made as to the
most suitable approach in the development of the processor
system. xi
R
-	 -	 -
This report is developed into sections considering
System Architecture, Trade-Off Considerations, and Recommenda-
tions.
SYSTEM ARCHITECTURE
The overall processor system architecture is
dictated by the functions it is required to perform.	 The
basic functions are: }
3
1) Sign-sense,
Z) Sample power spectra,
3) Obtain aircraft flight parameters,
4) Calculate scattering coefficient,
5) Align coefficients for a single cell, and
6) Output data to recorders.
It was determined from past development that these pro-
cessing functions can be best accomplished by a hybrid
analog/digital processing system. 	 It has also been
shown that these functions can be accomplished in real-
time under certain processing constraints on cell size and
sample frequency.
A system function block diagram for the processor'
is shown in Figure 1.	 This system includes analog signal
conditioning and sign -sensing, analog spectral sampling and
analog-to-digital conversion for use by the digital micro-
processor section.
Z;
m ,,
r s•L_
APPLICATION	 REVISIONS
NEXT ASSY	 USED ON	 LTRI	 DESCRIPTION	 I DATE	 JAPPROVED c ;
- V Sign	 Spectral
Linear	 Filter, &Sense	 Integrate
MUX
ADC
Sign	 Spectral
FilterCross	 Sense	 Integrate
a
ADAS	
Declode	
Microprocessor	 Analog Out
PCM Encode
x
Memory
Figure 1
System Function Diagram
_	 g
TOLERANCES:	 CONTRACT NO	 REMOTE SENSING CENTER
DEC.1.006	 TEXAS A&M UNIVERSITY
FRACTIONS—* 1/64 DATE
	
COLLEGE STATION, TEXAS
u	 ANGLESt.50 E NGR.
CK.
'	 APRVO
SIZE ICODE IDENT. NO, DRAINING NO.
SCALE	 ISHEET`^
i9
i
The digital section consists of a microprocessor,
memory and I/O ports. Also included in the system are PCM
decoders for input of ADAS aircraft data andPCM encoders
for output of processed data to recorders. The fundamental
differences considered for the C-band processor are:
1) The type of microprocessor chip,
Z) Parallel filtering of spectral data, j
3) Dual polarization,
4) Fixed incident angles, and
5) Commercially constructed microprocessor
mainframes.
Each subsystem is considered in the following sections.
4
i'
i
i s
Y ^
ANALOG SYSTEM
The Analog subsystem of the processor accomplishes
the sign-sense and the Doppler filter functions. Two approaches 	
r
to implementation of the Doppler filtering in this subsystem
are considered.
The first approach is sequential filtering. The
Doppler spectrum of the sign-sensed data is sampled by a
process which mixes the signal with a voltage controlled
oscillator sinusoidal signal. The frequency of this oscillator
is selected by the digital processing subsystem so that the
desired Doppler information is within a low-pass filter.
The filter output is RMS converted, integrated, and analog-
to-digital converted for input to the microprocessor system.
Multiple Doppler slices are acquired sequentially in a
determined pattern to 'obtain the necessary angle related
data. Signals from each of the required angles are measured
under the direct control of the system software. Changes in
frequencies to select proper angles are readily computed,
and changes in the angle selection are software controlled..
The two principal parameters in this process are the filter
bandpass and the signal integration time
Doppler filtering can also he accomplished using
a parallel filter configuration. Sign-sensed data are fil-
tered by a multiple filter bank where each filter is set
Ir	
-
Y
5
i
F
to extract the data from a single scatterometer incident
angle. Each signal is RMS converted and integrated. The
integrated signals are multiplexed to an analog-to-digital
converter which converts the data and provides the results
to the digital processor. The principal parameters in this
situation are also bandwidth and integration time.
1
A disadvantage of the parallel filter scheme is that
the filter frequencies are fixed, consequently only angles
related to these frequencies can be processed. The dupli-
cation of filter hardware causes an increase in the construc-
tion cost of the 'parallel filter system over a sequential
system, however the implementation is straightforward and
maintenance is less complicated.
`
	
	
A relationship which is pertinent to this dis-
cussion is the change in incident angle (0) for a fixed fil-
1.
ter frequency as a function of the change in aircraft veloc-
ity (V). This relationship is
AO tanO (V )
Normal aircraft velocities experiences during data acquisi-
tion vary within ± 1.5 knots or about 3o	 This converts
to a ± 1.5 degrees at a 45 degree incident angle. This is
not appreciable formost data gathering situations. Thus,
angle variations as a result of different aircraft veloci-.
ties for different flight lines are small and can be tolera-
6	
w
I
i
1
r	 ted for the parallel filter configuration.
The number of independent samples of data acquired
from a single ground cell is important since the confidence
in the estimate of the measurement is related to this number.
The normalized standard deviation of the estimated mean
Wn) is
T = 1 _ 1
T)
	
N	 -A—jT
The number of independent samples N is equal to the Band-
width--integration time product (AfT).
Another significant relationship is the length
of the ground cell as limited by the Doppler contours
corresponding to the bandwidth of the Doppler filter.
This relationship is
h	 AX =	 hXAf
vcos 0
where
	
h = altitude
v = 'velocity
X = wavelength
Table 1 shows the relationship between
the independent samples, data variation for worst case
standard deviation changes, and ground cell lengths
The table is constructed for an angle of 45 degrees,
the filter Q is 100, and integration.times are 0.1 seconds
for the sequential samples, and 1.0 seconds for parallel
samples.`
Sequential
Parallel
r
	 A
X
i
DIGITAL SYSTEM
Many microprocessors have some of the desirable
features which make them attractive for the intended appli-
cation, but none of them has a complete and consistent set.
To be able to evaluate the relative merits of each processor,
the advantages provided by each must be examined in detail.
<i
p
	 Architecture
Designing a computer architecture can be defined
as "determining the needs of the user of the structure
and then designing to meet those needs as effectively
as possible within economic and technological constraints." [1]
Every manufacturer therefore bases the design of his processor
on an independently determined set of user needs, and thus
produces a processor with a unique if similar implementation.
In the case of the Motorola M6800 and Intel 8080,
t
the similarities are these:
40 pin dual-in-line package
I	 NMOS technology
16-bit 3 state address lines
1	
8 -bit 3 state data lines
I	 stack addressing
L
interrupt
Both the 8080 and the 6800 make a stack available
to the user. A stack is an area of memory used as a last-in,
first-out store. On' the'8080 the user may insert on or
9
remove from the stack any of four 16-bit register pair
combinations, while on the 6800 the user may select
either 3-bit accumulator, or in the case of interrupts,
the condition code, both accumulators, the index register,
and the program counter. 	 The 8080 and the 6800 also use r-
the stack for containing the return address when a sub-
routine is called to provide almost unlimited subroutine
nesting.
The 6800 accepts two independent interrupt in-'
3
puts which cause program execution to be suspended, the1
current status of the processor to be saved on the stack,
'	 and execution to proceed form a specially designated interrupt
service routine location. 	 The 8080 has a single interrupt in- a
put.	 The recognition of an interrupt by the 8080 causes t
program execution to be suspended and execution to continue
with the instruction supplied by the interrupting device.
The M6800 and the 8080 A have the following differences:
M6800	 8080A
Instructions	 72	 78
8-bit registers	 2	 7
8-bit accumulators	 2	 1
16-bit registers	 2	 5
v	 Index registers	 1	 0
Address modes	 8	 7
:I
I/O addresses	 all addresses	 256
10 3
I
1
__	
a
M6800	 8080A
Flag bits	 6	 5
I/O structure	 memory mapped	 isolated or
memory mapped
These statistics are given with the understanding that
	
[t
tables such as this do not completely characterize the
differences in the processors because of the simplifications
which are made
Better characterization comes from careful exami-
nation of the attributes of each processor. Some of the
attributes are;
(1) _L/0 structure
(Z) _memory structure
(3) power requirements
(4) operating modes
I/O Structure
The 8080 has two modes for input and output (1/0):
isolated and memory mapped 1/0. Isolated I/O uses the IN
and OUT instructions in conjunction with ,control information
and the decoded peripheral address to transmit to or
receive data from an external device. - This type of -I/0
{ architecture separates the memory address space from the
I/O address space and uses a conceptually simple'transfer
y to or from the'accumulator. Also, because o^ the isolation
t
-	 11;
7	
A
I
4	 ^^
I
v
of program memory and I/0, the full 65K address space is
unaffected by I/O addressing.
	 Memory mapped I/O assigns
an area of memory space as I/O space.
	 This allows the
manipulation of I/O using the same instructions that are r
used to manipulate memory. 	 Instead of the accumulator as the
only transfer medium, any of the internal registers may be
t
used for I/0.	 It is conceptually more difficult to under-
stand than isolated I/O and limits address space, but it
can mean a significant increase in overall speed and a
reduction in the required program memory area.- The 6800
uses memory mapped i/0 for communication with peripheral devices.
Memory Structure
3
7
The 6800 addresses memory using the 16-bit address bus
and two controlsignals which are interpreted to determine
a valid read or write. 	 Some applications require additional
time for addressing.	 In these cases, the processor may
be directed to extend the period during which the address r
is stable on the address bus for up to 4.5 microseconds.
The 8080 addresses memory in the same way, using the 16-bit
address bus and two control signals.
	 Operations which
require additional address time may inject as many, WAIT- ,r	 '
states as necessary, where a WAIT state is normally 0.5
microseconds long.
12 i
y
I;
Power Requirements
i
The 8080A requires +5, -5, and +12 volt power
supplies.	 The clocks on the 8080_ are not TTL-compatible,'
and must be 8.1 volts in magnitude_, assymetrical, and
non-overlapping.
	 The 6800 requires a single +5 volt power
supply and two phases of TTL compatible clocks which
must likewise be assymetrical'; and 'non-overlapping. 	 The 6800
r
and the 8080 read/write memory device requires a single +5
K	
supply.	 The 6800 and the 8080 serial interface and parallel
interface devices both require +5 supplies.
Operating Modes y,
Both the 6800 and the 8080 are chacterized by
their operating modes.	 For convenience, these may be - -
grouped into three categories: x
r _	 (1)	 reset and initialization
(2) execution
(3)	 interrupt;
Item (3) has been discussed above; the remainder of this
section will investigate items (1) and (2).
Reset and Initialization
Reset on the 8080 causes the contents of the
program counter to be set to zero; thus, at the end of A
reset, _program execution begins at location zero.
	 On -
13
rr
the 6800, reset causes the byte at address FFFE (in
hexadecimal) to be loaded into the most significant
byte of the program counter and the byte at location
FFFE to be loaded into the least significant byte of
the program counter. Thus, at the end of reset, program
execution begins at the location contained in the
16-bit number beginning at FFFE. It can be seen that
while the RESET function on the 8080 and the 6800 is
implemented differently, they may be functionally
equivalent.
Execution
Both the 6800 and the 8080 execute a program by
repetitively fetching instructions from memory, then
controlling the internal and external circuits in accordance
with the information coded into the respective instructions.
Instructions may consist of one, two, or three bytes of
information, and are fetched from the memory addressed by
the current contents of the program counter (PC).
3.The first byte contains sufficient information to define 	 -;
how many additional bytes are required as well as which
operation is to be performed. The 6800 has a 1 MHz
i
r clock rate yielding an effective data transfer rate of }
1 Mbit/sec., while the 8080 has a 2 MHz clock with an
effective data transfer rate of 840 kbit/sec.,[2].
14
+lam	 -.	 ..n
is
4
SOFTWARE
Differences in the characteristics of the 6800
and 8080 software which affect the performance of the
required processing are	 I
(1) variation of coding and execution
efficiencies for typical operations
(2) lack of conditional absolute branch
instructions and conditional sub •-
R	
routine call and return instructions
on the 6800
(3) variation in subroutine linkage con-
ventions
(4) variation in typical subroutine design
Variation of Efficiency
C 	 ^
A typical arithmetic operation used in the flight
program is a_16-bit addition. The implementation for the
8080 and the 6800 is given below:
8080:
bytes	 time (us)	 instruction
3	 $	 LHLD OPI	 1
1	 2	 XCHG
3	 8	 LHLD OP2
1	 5	 DAD	 D
R	 3	 8	 SHLD RES
11 bytes	 31 us
15
f
3	
,
r;
__|
60DO:
bytes.	 time	 (ps)	 instruction
18 bytes	 26 ps
These codings assume that the operands are in memory
and that the results are stored in memory. 	 The 8080
is assumed to have a characteristic 2MHz clock rate and
the 6800 a characteristic lMHz clock rate.	 The memory
efficiency of the 8080 is 39% greater than 6800, while
the execution efficiency at the 6800 is 16% greater than
the 8080.	 The memory efficiency of the 8080 is due to
its 16-bit load and store instructions, and the execution
efficiency of the 6800 is due to its capability to add to
an accumulator from memory.
If the assumption is made that one operand is
already in register pair D,in the 8080 or in-the accumulators
:	 . -^^-	 (which	 typically	 '	 programs'^^	 ^0	 ^^	 i	 be	 ^]	 the	 ab ove
^.
Iti
^'	 ^^
	 \	 °^^^
3	 8	 LHLD OP2
1	 5	 DAD D
r
3	 8	 SHLD ,RES
7 bytes	 21 us
6800.
bytes	 time	 instruction
3	 4	 ADAA Op?+ 1
3	 5	 STAA RES+1
3	 4	 ACDB OP2
3	 5	 STAB RES
12 bytes	 18 us
In this case,the coding efficiency of the 8080 is 420
greater than that of the 6800, while the execution
efficiency of the 6800 is 14% greater than the 8080.
Conditional Control Transfer
The 8080 provides 8 conditional jump instruc-
tions. These execute in5 us and require 3 bytes of
memory for the instruction and a_,16-bit branch address.
The 6800 provides 14 conditional jump instructions,
each of which use the relative addressing mode and
require 2 bytes and execute in 2 us. However, if a condi-
tional branch is required to an address outside of program
w counter relative range, the operation must be recoiled as
17
a relative branch and an absolute jump, requiring 5 bytes
and 11 us. Studies have shown that 80% of all conditional
branch addresses lie within relative addressing range [1],
so the net difference due to conditional jumps in overall
execution time between the 8080 and the 6800 is insignifi-
cant
The 8080 also has conditional subroutine call }
and return instructions.	 The 6800 does not.	 Again,
these must be coded as a relative branch and a call or k
return, requiring-5 bytes and 11 'us for a call and 3 bytes
and 7 us for return.	 The 8080 performs an equivalent r
operation in 3 bytes and 8.5 ps for a call and 1 byte and
5.5 us for a return.
Subroutine Linkage
K
When a subroutine is called on the 8080, the h
arguments are passed in the registers.	 The 6800 has too
few registers t6 use this convention, and an alternate
r,{
method must be used.	 One method is to use an area of
memory to contain arguments and results.	 The relative
efficiencies of the two methods are compared below:
8080:
bytes	 time (u s )	 instruction
- 3	 8	 LHA	 OPl
- Y
1	 2	 XCHG 3
18
FIWk'1+abi.'.vMkLt.W l3•d ..a t': . 	 ro: z.w..	 y:rt	 z.w ;::'.: 	 .. .	 Y.	 ,..	 «: <,.	 ^,.; ..	 .	 ..Y.,.
	
"•	 :'`.	 w	 ly	 *i..	
..	 _^..._.	 _w_._	 _	
_$,"::.
{
3	 8	 LHLD OP2
1	 2.5	 MOV	 B,H
.1	 2.5	 MOV
	
C,L
9 bytes	 23 us
'	 6800:
bytes	 time (us)	 instruction
.!	 3	 5	 LDX OP1
3	 6	 STX SAVE1
3	 5	 LDX OP2
3	 6	 STX SAVE2
12 bytes	 22 us
The memory efficiency of the 8080 is 75% greater than
that of the 6800 while the execution efficiency of
7y
the 6800 is 4% greater than the 8080.
Subroutine Design
In the 8080 mathematics subroutines, the H
register pair is used as an index into the tables, making
computation of the effective table address a single DAD.
The 6800 does not allow a 16-bit add, so for an equiva-
lent operation the look-up procedure must be recorded.,
Representative codings for the 8080 and the 6800 are
given below:
8080:
bytes	 time
3	 5	 LXI
	
H,TAB
2	 3.5	 MVI	 B4O
r
19
i0 
r	 __	 e
41 2 ADD
M
A
3 5 JNC NC
1 2.5 INR B
1 2.5 NC MOV C,A	 i
1 5 DAD B
`	 1 3.5 MOV E, M
1 2.5 INX H
1 3.5 MOV D,M
15 bytes 35 us
6800:
bytes tim
3 4 LDAB TAB+1
1 2 ABA
3 4 LDAB TAB
2 4 BCC NC
1 2 INCB
3 5.NC STAA SAVES
r
3 5 STAB SAVE3+1
3 5 LDX SAVES
2 _	 5 LDAA 0,X	 ;-
2 5; LDAB 1,X
3 5 STAA SAVES,
3 5	 - STAB SAVE3+1
29 bytes 51 us
20
^^M
8-Bit Arithmetic and Logic Functions
The 8080 and the 6800 have equivalent 8-bit
arithmetic and logic functions. In addition, the 6800
allows arithmetic shifts which the 8080 does not. The
6800 also has an overflow flag bit to detect two's
complement overflow.
Both the 6800 and the 8080 require one byte
and 2 Vs for the execution of a register-to-register
operation.
The 8080 register-to-memory operations take
one byte (two using immediate addressing) and execute
in 3.5 us.	 The 6800 register-to-memory operations take
i
three bytes- (two using immediate addressing) and execute
w
in 2 to 4 us.
The 6800 rotate instructions are 9-bit (including
'	 carry) and may operate on either accumulator or on memory.
The 8080 has 8- and 9-bit rotates for the accumulator only. a
The 6800 allows arithmetic shifts for the
accumulators and memory. 	 In a right shift, the MSB (sign)
z^
f,
big is propagated.	 In a left shift, zero is propagaged
into the LSB.
Execution time of both 6800 and 8080 register
shifts and rotates is 2 us, 	 A 6800 memory shift or ro-
tate requires 6 to 7 us. -
I
21
i
rMemory Size and Usage
The 8080, with its separate I/O systems allows
the full 64K memory addressing range to be used or program
F	 storage. The 6800, with its memory mapped architecture,
must split its range between I/O and program storage. The
_ 6800 tends to use more memory for programs, and more memory
ij! accessing takes place d due to the lack of program registers.
:a
The 8080's multi-register architecture allows
more usage of register-to-register instructions. 	 More
memory may be devoted to EPROM because of this occurrence.
m, Since the 6800 must use more register-to-memory instruc-
tions, more memory must be devoted to RAM,
A tabulation of the instructions used in the 8080
implementation of the program reveals that the instruction
CALL was used 330 times.	 If only 50% of these involveM, y
argument setup as described above, then the 6800 requires
2`60 more bytes than the 8080.	 Also, the 8080 uses 148 re-
l
turn instructions of various types. 	 If half of these involve
subroutines with arguments, then the 6800 requires 1036 more
Y bytes than the 8080,. making the additional memory required
about 1300 bytes over the 8080. 	 Coupled with this fact
is a time cost overhead of 16 additional microseconds with
every subroutine call.	 If all of the subroutines with
I arguments were called only once, then the 6800 would re-
22
quire an additional 1.2 milliseconds of time simply to
invoke the subroutines. In reality, subroutines are called
many more times than they are coded in the program, making
the actual time cost of the 6800 much higher than the 8080.
Speed
The 6800, although it uses a slower cycle time,
has an execution speed that is approximately the same as
the 8080. The 8080 uses more machine cycles for its oper-
ations, in spite of its register-to-register capabilities.
x
`f
F
€E.'
-
4
r
ADDRESSING MODES
Extended Addressing
The Extended Addressing mode permits the MPU
to refer to any memory location within the 65,536 bytes
which the MPU can directly access. Instructions using
the extended addressing mode consists of three bytes,
the first of which is the instruction operation code.
The second byte contains the most significant eight bits
of the operand address and the third contains the least
significant eight bits ofthe operand address.
The operation code for instructions with the
extended addressing mode has the form, rrllxxxx, where
'
	
	 rr	 00. In other words, the hexadecimal representation 	 9
of the operation code has the first digit of 7,-B, or F.
The following instructions may be used with the extended
addressing mode
ADC,ADD,AND,ASL,ASR,BIT,CLR,CMP,COM,
CPX, DEC,FOR,INC,JMP,JSR,LDA,LDS,LDX,LSR,
NEG,ORA,ROL,ROR,SBC,STA,STS,STX,SUB,TST
Direct Addressing
The Direct addressing mode permits the MPU to
access any memory location withinthe first 256 _bytes,
which is also known as "PageO." Instructions using the
Direct addressing mode consist of two bytes, the second
I
24
3
4	 ~
. rt
F.
byte of which is the location cn page 0, or the least
significant eight bits of the operand address; the most
significant eight bits of the operand address is impli-
citly zero.
The operation code for the instructions which use
rs
the direct addressing mode has the form, lrOlxxxx, where r
designates the second operand (A or B,s or X). 	 The hexa-
decimal representation of the operation code has the first
I. digit of 9 or D.
s The following 	 Yinstructions may be used with the
direct addressing mode:
{ ADC,ADD,AND,BIT,CMP,CPX,EOR,LDA,LDS,
LDX,ORA,SBC,STA,STS,STX,SUB
y
Indexed Addressing
The Indexed addressing mode permits the`MPU
3
to access a memory location relative to the contents of
a 16-bit index register. 	 This is actually a "base dis-
s:
placement" form of addressing, in that a one byte offset
is added to the value in the index register to form the
A : true memory address.	 The index register is not altered
by this addressing mode.	 Instructions using the indexed
i
addressing mode consist of two bytes, the 'second of which
defines an offset or displacement of between zero and 255,
inclusive.
z
-= 25(
L^ ^
The operation code for instruction using the
indexed addressing mods has the form, rrl0xxxx, rr = 00.
L
The hexadecimal representation of the operation code has
the first digit of 6, A, or E. The following instructions
may be used with indexed addressing mode:
ADC,ADD,AND,ASL,ASR,BIT,CLR,CMP,COM,
CPX,DEC,EOR,INC,JMP,JSR,LDA,LDS,LDXLSR,
NET MA ROL ROR SRC STA STS STY SUB TST
When the indexed addressing mode is used with
instructions which operate on the index register (LDX,STX,
CPX), the address is formed from the initial contents of }
the index register, and is not affected by any changes
to the index register during the course of the instruction
execution.
Relative Addressing
The Relative Addressing mode permits the MPU to
access`a memory location relative to the current contents
of the Program Counter.- This addressing mode is used for
i	 the branch instructions only, and is the only addressing
mode used for the branch instructions, all of which are
two bytes in length.	 The effective address, which becomes
the location of the next instruction (by being loaded
into the program counter), consists of the algebraic sum
of the contents of the program counter {containing
26
rthe address of the instruction following the branch) and
F the second byte of the instruction, treated as a signed,•
two's complement number in the range +127,	 -.128.	 Thus the
MPU can branch forward to an instruction 129 locations
from the beginning of the branch instruction, backward
to an instruction 126 locations from the beginning of
the branch instruction, or anywhere in between, for a
total range of 256 locations.
The operand code for the branch instructions is
either of the form, OOOlOxxxx, or of the form, 10001101.
That is, either hexadecimal 8D or a first digit in hexa-
decimal of 2.	 The following instructions use the relative
addressing mode:
BCC,BCS,BEQ,BGE,BGT,BHI,BLE,BLE,BLT
BMI,BNE,BPL,BRA,BSR,BVC,BVS
Immediate Addressing
The Immediate Addressing mode permits the oper-
and of an instruction to be included with the instruction
:-
itself.	 Most of these relate to eight-bit registers,
and require one-byte operands, making the immediate-addressed
.`
instruction two bytes long.	 Three instructions, however, re-
x:
late to one of the two 16-bit registers (Index register ortt.
Stack pointer), so that two-byte operands are required; these
r;
27
-	 s^^
yA
are LDS, LDS, and CPX, and require three bytes in the
immediate addressing mode.	 The first byte in either case
is the operation code; the remaining one or two bytes
are the operand data. 	 If there are two bytes of operand, f
the first of the two is the most significant eight bits, 3`
{	 and the second is the least significant eight bits.
The operand code for the instructions using the
immediate addressing mode has the form, lr00xxxx, where r
selects the second operand (destination of the data). 	 The
y
following instructions may be used with the immediate
addressing mode:
ADC,ADD,AND,BIT,CMP,CPX,EOR,LDA,LDS,
t°
LDX,ORA,SBC,SUB
Inherent Addressing
All of the instructions which are not specifi-
cally defined to have a memory addressing mode defined
above are considered to have the Inherent Addressing mode,
and consist of one byte only, with the addressing mode
inherent in the operation code byte. 	 These may be subdi-
vided into the following' categories: 	 No Operand, Stack
Addressing, and Register Addressing, which may itself be
subdivided into Accumulator Reference, and Other Register
Reference.	 There is no consistent pattern for-the-opera-
tion codes of the instructions which use the inherent
28
addressing mode, except that they all have the first
Ithexadecimal digit of 0,1,3,4, or 5.
k
Comparisons
1.	 The 8080 and 6800 Immediate modes are equivalent.
2.	 The 8080 Direct and 6800 Extended modes are equivalent.
3.	 The 8080 Register Indirect is similar to the 6800 xij
Indexed mode in that an "index register" is used, but
no relative offset is available.	 The 8080 has 3
register pairs to be used (BC,DE,HL), while the
6800 has one Index Register.
4.	 The 8080 has no "page zero" addressing.
S.	 The 8080 has no relative addressing for either
operand fetch or branching.	 The relative addressing
feature is useful for relocation of code segments.
The size of a program also decreased.
t
_
a
t
v
29
Y	 i
UTILIZATION OF COMMERCIALLY AVAILABLE MAINFRAMES
Both processing families have been found to con-
tain four levels of system complexity.
Chip level systems and the support IC's supplied
with them were the first level introduced for market pene-
tration. Generally unusable at this level, the chip kits
require extensive additional interface support to bring
them up to a operational plane.
Level two is now defined as the card level micro-
processor. The card always contains a small amount of scratch
pad with positions supplied for E-PROM or ROM. 	 RS-232-C
and/or teletype interface is supplied for entry.
The card level system is usually supplied with a
small package of operating software which aids the user in
program construction and debug. 	 Physical interface is made
through card edge connectors and/or flat cable which facili-
tates access to address and data buss along with the existing
interrupt and control flags.	 Utilization of the card is
accomplished through interface with keyboard or CRT, after
having supplied chassis, card-cage, power supplies, inter-
face cables and the support software. 	 Based on the system`
procured, additional card level components are available
as options.
The next step up, or level three, can be defined J`
as the basic operational processor.
30
_t
r,
The fundamental processor card is supported by
all the required physical interface. Chassis, card cage,
power, cables and a small amount of memory are supplied
with any number of add-ons or options available. With
the addition of an entry device, it is at this level that
the systems become attractive for immediate use.
Level four steps into the micro/mini system stage.
Large software packages are available along with finished 	 R
v
mainframes and operator panels. Some of the systems at this
level included CRT terminals, keyboards or at least an opera-
tor switch register for conversation with the CPU.
Price ranges for these various levels may be
defined by:
1.	 Chip level system	 $100-200
2.	 Card level system	 ti $500-1000
=a
3.	 First level mainframe	 ti $2500-4000
4.	 Second level mainframe
ru(mini)	 $4000-10000
In this particular application, level three, or
the first level mainframe, is thought to be the most ap-
plicable.
	
Investigation has shown that both families con-
i'	 tain the ,required hardware, software, and expansion capa-
bilities to facilitate the additional NASA ,special purpose`
components.	 Price,_ manufacturing, reliability, maintain-
ability and the other tradeoffs required, all appear to be
equitable at this level.
31
j
F
^'	 1
G
i
k
f	
THE TRADEOFF WITH AND WITHOUT UTILIZING A FIRST LEVEL MAINFRAME
The primary areas of savings when employing a main-
frame system are in time and commonality.
	 Assuming that a
first level mainframe is procured,, savings are predicted in
the areas of:
" 1. Mainframe, design and fabrication
2. Motherboard design and fabrication
3. Interconnect design and fabrication
4. CPU design and fabrication
S. Memory design and fabrication
b. Power source design and fabrication
7. Interface design and fabrication
8. System integration
9. Lead time
10. -Component commonality with existing systems'
The parts procured at this level are generally pro-
duced"to a "best commercial practices" specification.
	
Flexi-
bility of design, reliability, and quality all are approximately
equal-family-to- family and although not military-grade, possess j
the potential for being upgraded to engineering model flight
worthiness. Costs involved in the tradeoff when considering
board level components as listed above, are usually lessy
for the procured subassemblies because of fabrication and
j	 checkout time for inhouse boards run two or three to one.
_ 32
Investigation has indicated that the "make or
buy" breakpoint for cost exists above the first level main-	
f
frame. Siginificant`savings are experienced in the areas
of common mechanical and electronic fabrication, lead-time,
debug, commonality, and interface, while the system does not
require the general purpose features of the second level, or
micro/mini system. 	
4
A
Y
i
1
A
33
k v	 -	 -	 -<
h
a
CONCLUSIONS
The following conclusions are made from this study:
1. Intel 8080 and Motorola M6800 microprocessors
are for all practical purposes equivalent in their present
hardware configuration, speed, and reliability.
2.. The 8080 series has an architecture which lends
7
itself to further development and projections point to
more sophisticated 16-bit microprocessors which are com-
patable to the 8080 architecture.
3. The M6800 architecture limits the further develop-
ment of this series of microprocessor and probably is the last
major development in the series.
4. Development software support for the Intel 8080
significantly exceeds that of any other available micro-
processor and vendor support in this area is excellent.
S. Commercially available microprocessor systems
are adequate.for the developmentof processor systems. Special
purpose subsystems can be added, in a straightforward fashion
using vendor built mechanical hardware.
6. Parallel analog filtering represents a straight-
forward approach to Doppler filtering of scatterometer signals.
E	 However, it is more expensive to construct and has no angle`
selection flexibility. This method exhibits a greater noise
-	
immunity than a sequential filter approach with a consequent
decrease in ground cell resolution.
34
_	
^i
tRECOMMENDATIONS
As a result of this study, recommendations based
i
on the stated conclusions are:
1) An Intel 8080 series microprocessor be used to
implement the C-band processor system,
2) A first level Intel mainframe be purchased for
N	 the implementation, and that additional functions required
for processing be added to the mainframe,
3) A second-mainframe chassis be purchased to house
the analog portion of the processor, and
4) That a parallel approach to Doppler filtering
j be used rather than the sequential approach.
a
r
k
A
-
s	
_ 35
-T	 71111
REFERENCE S
[1] F.P. Brooks, Jr., "Architectural Philosophy," in
Planning a Computer System-Project STRETCH, W. Buchholz,
ed., McGraw-Hill, 1962, p.5.
[2] Bala Parasuraman, "High-Performance Microprocessor
Architectures," Proc. IEEE, Vol_. 64, No.. 6, June 1976,
t
y
J
I=
--w
--^-- ►-	 .

F7
7
1
S I_GfV FILTER 8
LIKE
,....^
v
SENSE
I EJT:EG APPAL
k^	 a
MUX OUT 4k
FY
& !,;
A^
r---i>l PCM
SIGH! FILTER ENCODE
CROSS
&A SENSE
I NTEG 8
, 8
ADAS — — PCM MICROPROCESSOR
i,..
DECODE
SYSTEM FWNCTION

20 45 1,75 10 61 2,38 5 86 3.21
200 115 .54 10 130 0,83 50 156 1,15
SEQUENTIAL
PARALLEL
A
M6800 INTEL 8080A
INSTRUCTIONS 72 78
8-BIT REGISTERS 2 7
$-BIT ACCUMULATORS 2 1
16-BIT REGISTERS 2 5
INDEX REGISTERS 1 0
ADDRESS MODES $
I/O ADDRESSES ALL ADDRESSES 256
FLAG BITS 6 5
I/O STRUCTURE MEMORY MAPPED ISOLATED OR
	 ,.
MEMORY MAPPED i
ADDRESS RANGE 64K BYTES 64K BYTES
CLOCKS 1 'MHF-,- 2 6 2 MHz, 2
A-6
_ `I vi"x
INTERNAL
DATA IUS
CONDITION
' INTERNAL CODE
REGISTER
.,!, .............
_
'
AOOAESS
NISIL01k
Iltl allAlU
•	 II1ITSI	 A
SUY ^r- (
13^ 001
*-w–.* 01
i
.
1^ 07
Tel STATE Ila 07
_. ACCUMULATORS OAtA. IMP 01
A IUFfER 1)11
-.. ACCUMULATOR M^ 07 I.,
-	
ADDRESS B
AUS NI •11111S)
INDEX REGISTER
11 NITS NII	 11 BITS L01 INSTRUCTION
REGISTER
AtU 111	 rttt. REGISTER
CONTROL
LINES
1=11 ONO
—
 GOOD
,..... STACK POINTERI INSTRUCTION 
(IBITSNII
	 IIIITSLO) i DECODER AND
}
CTRL LOGIC
INTERRUPT 119 R^SfT .i
AND RESTART 161	 Rwi j
M.
LOGIC	 1— ;N	 111 :,
PROGRAM COUNTER
TIMING.
GENERATOR
-
oI
1771 02
'.; fl-BITS NU	 (I BITS L01
).	 _
I
(711	
RfW
INCREMENTERIOECREMENTER /US CONTROL (5) YMA
- 11 BITS HI)	 11 BITS LO) AND HALTLOGIC. (1)
_..
..DISABLE ..171.	 N^
f 1]91	 TSC
TEMPt)RARr t!1110).	 AOt, flECtSTEfl Al
p 11 ZITS) 1111ADDRESS 1127	 ].
11 BITS LO) AIF117
(151	 AS
Lj (16)	 A6
A7All
nli A9
n 1191 AID 
ADDRESS 1701 All X.
... WfiER 1771(I BITS NII' 17]1	 AI)
.1711, AI]
1)91	 A14AIS
ATA BUS r
)
^	 a
I ACCA ACCB FLAGS
-
-
f .
INDEX
x ALU CONTROL
REG I S`CEj .
If
6800 ARCHITECTURE	 16
1	 t
' ADDRESS BUS	 CONTROL
w
A-7
ii
D? 
-Do	 BI-DIRECTIONALDATA BUS
DATA BUS
-	 BUFFER/LATCH
(B BIT)
	
IS BIT)
INTERNAL DATA BUS
	 INTERNAL DATA BUS 	 w
ACCUMULATORR r TEMP. REG.
	
INSTRUCTION	 MULTIPLEXERlel	 181	 REGISTER lel
FLAG-..151
FLIP.FLOPS.ACCUMULATOR
LATCH le)
ARITHMETIC INSTRUCTION
LOGIC
DECODER
UNIT ANDMACHINE(ALU) CYCLE181 ENCODING
-W	 18) Z	 In
TEMP REG. TEMP REG.
u
B	 Ie! C	 (8)
REG. REG.
w D	 181 E	 181
a REG. REG.
H	 181 L	 leiui
N REG, REG.
u Itela STACK POINTER
(telPROGRAM COUNTER
DECIMAL_	 INCREMENTER/DECREMENTERADJUST	 -	 ADDRESS LATCH	 It81
TIMING
	
-----	 AND
CONTROL	
1
	POWER^+ ^12V	 ADDRESS BUFFER	 Itel
	
SUPPLIES -r ♦5V	 DATABUS INTERRUPT HOLD 	 WAIT
L—^.SV 1 WRITECONTROL CONTROL CONTROL CONTROL SYNC .CLOCKS. 	 -	 -:
	--^ GND	 ]
VM	 DBIN INTE INT HOLDHOLDWAIT I SYNC 01 62' RESET
ACK	 READY
A1e.Ae
ADDRESS BUS
f
^	 DATA BUS
H
AL
ACC	 FLAGS	 j
B_	 C
L D	 E
ALU 4	 CONTROL
	 01 H
	 L
REGISTERS  8080 ARCHITECTUR 16
CONTROL
	 ADDRESS BUS
A- 8
fi
B C
D E
H L
x
DATA BUS
{
w nn	 1	 r^ w nn -
COMMERCIAL SYSTIEM
COQ ML-*ITS
SBC 30/10/fIG08111101 CPU
HEIM
1/0
D/A
S YS 30/10/MI CROP OD ADASBIO-L
CD ANALOG (1&2)
IATELLEC/EXORCISOR
.A
PS
CPU R I/O
OPERATOR
HEM	 %SOFT11ARE
1/0
1/0 FLIGHT SOFT!•IARE
CHASSIS.
MOTHER BOARD
ADDITIONAL COMP071ENTS RLE-1 U I RED
MA I NFRAME
POIVIER SUPPLY
INTERCO)' RECT
C011.1,1011
CARD CAGE
0030/6300
SUBSETS
iq
SYSTEM DEVELOPMENT TRADE-OFF
WITH COMMON COMMERCIALLY ALL FAB AND DEVELOPMENT
I
AVAILABLE COMPONENTS PROCURED - ACCOMPLISHED IN-HOUSE
^ 01234567991011_12 012345678910111213
STUDY C7 C7	 i
j	 D/D + FAB^;
t
INTEGRATION C	 L C_._^
I
INTERFACE TESTING O D
COST x'.
FAB LABOR X12 X
aSHOP FAB X/10 Y
MATERIAL
I
TOTAL 1/Z
)ESIGN FLEXIBILITY.
ZELIABILIITY/QUALITY COMMONALITY WITH
ASSURANCE EXISTING COMMERCIAL
I;
COMPONENTS
BEST COMMERCIAL i!	
-
PRACTICES
k.
,
39 SOFTWARE TRADE-OFF
UTILIZING SUBSETS OF EXISTING FLIGHT PROGRAM
TABLE LOOKUP
IN THE 8080 MATHEMATICS SUBROUTINES, THE H REGISTER PAIR IS USED AS AN INDEX INTO
THE TABLES, MAKING COMPUTATION OF-THE EFFECTIVE TABLE ADDRESS A SINGLE DAD, THE 6800
ti
DOES NOT ALLOW A 16-BIT ADD, SO FOR AN EQUIVALENT OPERATION THE ,LOOK-UP PROCEDURE MUST
BE'RECODED.
8080 6800
BYTES TIME BYTES TIME
N	 3 5	 LXI H, TAB	 3 4 LDAB TAB+1
2
1.
3,5	 MVI B4O	 1 2 ABA
1 2	 ADD A	 3 4 LDAB TAB
3 5	 JNC NC	 2 4 BCC NC
1 2.5	 INR B	 1 2 INN
t{5
	
t	 1 2.5 NC	
_ 
M6V. C. A
	 3 5. NC	 --_ STAA SAVES. .	
..
6	 1 5	 DAD B	 3 5 STAB SAVE3+1 E	 f
1 3,5	 M6V E,M	 3 5 LDX, SAVES
p
1 2.5
	 I NX H	 2 5 LDAA 0, X
3.5	 MoV DA	 2 5 LDAB 1,X r,15
35 ps 3 5 STAA SAVE3
_
STAB SAVE?+1
29 51 ps
Usage, percent	 -
0 	 1 2	 3 4	 5	 6 7	 8 9 10	 11 12	 13	 14	 1s	 16
AiOV
CALL
LXI
PUSH Instructions Making Up
& POP
More than 50% of Program;.
MVI a
RET
a
W
L DA
i
Time, uS
0	 4 8	 12 16	 20	 24 28	 32 36 40 8	 52	 56	 60
6500
TIME
8080'
6800 1
BYTES<
8080 i
0	 2 4	 6 8	 10	 12 14	 16 18 20	 22 24	 26	 28	 30
Effect of CALL. on Bytesthe program
...:.ii	 <:.
:^....3w...avdd.,diJ,^me...vL.'d.e.n;..v •,....:.:.	 ^,_ ^	 ,.,-wiwi^u.S^:^:Y....rsJw..ti,J.erwLL..'e.x^3:va.a.d..ar„^_a....e.w- r: -r.r^eWU[uuW^e,_^['.'. .^'+.:,...u...^	 ._.-......,,.,	 .a ....^e.......	 .M	 ..	 _,.,?1.....^,^_,u..w.,.
I	 1
-4
i3
u
•
CONCLUSIONS
l
I;
INTEL SOHO AND MOTOROLA M6800 SERIES MICROPROCESSORS EQUIVALENT
FOR PRESENT TASK$
Q 8080 SERIES LEADS INTO FURTHER MICROPROCESSOR DEVELOPMENT, 	 6800
a SERIES	 IS LIMITED WITH RESPECT TO FURTHER DEVELOPMENT.
I ,
Q 8030 DEVELOPMENT SOFTWARE AND VENDOR SUPPORT EXCELLS SIGNIFICANTLY.
} ® AVAILABLE MICROPROCESSOR MAINFRAMES ARE ACCEPTABLE AND CAN BE
READILY MODIFIED.
PARALLEL DOPPLER FILTERING IS STRAIGHT FORWARD, LESS FLEXIBLE,
MORE EXPENSIVE TO COMSTRUCT AND EASIER TO MAINTAIN THAN SEQUENTED
a
FILTERING,
I
I
 
Fr
w
I
cS 
^ A-14
fRECOMMENDATIONS
© AN INTEL 8080 SERIES MICROPROCESSOR BE USED TO
IMPLEMENT THE C —BAND PROCESSOR SYSTEM,
® A FIRST LEVEL INTEL MAINFRAME BE PURCHASED
•
FOR THE IMPLEMENTATION, AND THAT ADDITIONAL
FUNCTIONS REQUIRED FOR PROCESSING BE ADDED
TO THE MAINFRAME,
SECOND MAINFRAME CHASSIS BE PURCHASED TO
HOUSE THE ANALOG PORTION OF THE PROCESSOR,
AND
}
THAT A PARALLEL APPROACH TO DOPPLER FILTERING
BE USED RATHER THAN THE SEQUENTIAL APPROACH.
l
—a
C
A-15
