An Extensible, scalable microprocessor architecture by Dinmore, Matthew
Rochester Institute of Technology
RIT Scholar Works
Theses Thesis/Dissertation Collections
11-1-1993
An Extensible, scalable microprocessor architecture
Matthew Dinmore
Follow this and additional works at: http://scholarworks.rit.edu/theses
This Thesis is brought to you for free and open access by the Thesis/Dissertation Collections at RIT Scholar Works. It has been accepted for inclusion
in Theses by an authorized administrator of RIT Scholar Works. For more information, please contact ritscholarworks@rit.edu.
Recommended Citation
Dinmore, Matthew, "An Extensible, scalable microprocessor architecture" (1993). Thesis. Rochester Institute of Technology. Accessed
from
An
Extensible, Scalable
Microprocessor Architecture
by
Matthew Dinmore
A Thesis Submitted
ill
Partial Fulfillment of the
Requirements for the Degree of
MASTER OF SCIENCE
in
Computer Engineering
Approved by:
Thesis Advisor
Dr. Tony Chang
Department Head
Dr. Roy Czemikowski
Committee Member
Prof. George Brown
DEPARTMENT OF COMPUTER ENGINEERING
COLLEGE OF ENGINEERING
ROCHESTER INSTITUTE OF TECHNOLOGY
ROCHESTER, NEW YORK
NOVEMBER, 1993
Thesis Release Permission Form
ROCHESTER INSTITUTE OF TECHNOLOGY
College of Engineering
Title of Thesis: An Extensible, Scalable Microprocessor Architecture
I, Matthew D. Dinmore, hereby grant permission to the Wallace Memorial Library
of the Rochester Institute of Technology to reproduce my thesis in whole or in
part.
Abstract
An extensible, scalable stack-based microprocessor architecture is developed and
discussed. Several unique features of the architecture, including its non-memory
oriented interface, and its use of a stack for holding and executing code, are
detailed. A programmed model is used to verify the architecture, and a hardware
implementation of a small-scale version of the architecture is constructed and
tested. Notes for future implementations are provides. Possible applications based
on the latest technological trends are discussed, and topics for further research
into the architecture are listed.
Contents
Abstract i
List ofDiagrams v
List of Tables vi
List of Acronyms & Abbreviations vii
1 Introduction 1
1.1.0 Background & Goals 1
1.2.0 Definitions 2
1.3.0 Overview 3
2 Design Issues 4
2.0.0 Basic Services 4
2.1.0 Input/Output Performance 6
2.2.0 System Interfaces 8
2.3.0 Program Execution Model 10
2.4.0 Additional Architectural Issues 14
2.4.1 Stack Sizes 14
2.4.2 Interrupts 16
2.4.3 Levels of Implementation 19
2.5.0 Instruction Set Design 22
2.5.1 Arithmetic & Logic Instructions 23
2.5.2 StackManipulation Operations 28
2.5.3 Input/Output Instructions 32
2.5.4 Control Operations 33
2.5.5 Program Execution Instructions 35
2.5.6 Extended Instructions 37
2.5.7 Instruction Encoding 38
2.6.0 InstructionMandates for Each Implementation Level 45
3 Implementation & Testing 47
3.0.0 Overview 47
3.1.0 VHDLModel 48
3.1.1 Entity Definition 49
3.1.2 Model Internals 50
3.1.3 VHDL Test Bench 51
3.2.0 FPGA Implementation 53
3.2.1 FPGA Technology 53
3.2.2 The Processor Design 54
3.2.3 Overall Design 56
3.2.4 Arithmetic/Logic Unit (ALU) 57
3.2.5 Input/OutputUnit (IOU) 60
3.2.6 Data Stack (DS) 61
3.2.7 Control Register Block (CRB) 62
3.2.8 Control Unit (CU) 64
3.2.9 Additional DesignNotes 69
3.2.10 Design Testing 69
3.2.11 FPGA Test Bench 72
3.3.0 General ImplementationNotes 74
4 Discussion 80
4.0.0 Overview 80
4.1.0 IXA& RISC 80
4.2.0 IXA & Stack Machines 82
4.2.1 IXA and the Transputer 83
4.3.0 Applications 84
4.3.1 Uniprocessor Applications 85
4.3.2 Multiprocessor Applications 86
4.4.0 Issues for Further Research 87
5 Conclusions 90
References 91
Appendix A - Architectural Definition
Appendix B - Condition Code Results
Appendix C - VHDL Source Code
Appendix D - Test Programs
Appendix E - VHDLModel Test Results
Appendix F - FPGA Logic Diagrams
Appendix G - Test Results for the FPGA System
Appendix H - FPGA Place & Route Results
Appendix I - MC68008-based ProgramController
List of Diagrams
2.1 I/O Protocol 9
2.2 Architectural Levels 20
2.3 Architectural Layers of Definition 21
3.1 VHDL Model Design 49
3.2 System Layout 57
3.3 Arithmetic/Logic Bit Slice 58
3.4 Input Handshake Timing 60
3.5 Output Handshake Timing 61
3.6 Cycle Timing 65
3.7 Processor Pin Placement 72
3.8 Processor/Switch Board Test Bench 73
3.9 Processor/MC68008 Test Bench 74
3.10 Dynamic Power Consumption 78
List of Tables
2.1 Instruction Set 43-44
3.1 ALU Internal Control Signals 59
3.2 Control Signal Generation 66
3.3 Pin Requirements for Various Processor Scales 76
List of Acronyms & Abbreviations
ALU Arithmetic and Logic Unit
ASCII American Standard Code for Information Interchange
ASIC Application-Specific Integrated Circuit
CISC Complex Instruction Set Computer
CRB Control Register Block
CU Control Unit
DS Data Stack
DSP Data Stack Pointer
FPGA Field Programmable Gate Array
I/O Input/Output
IB Instruction Bit
IOCR Input/Output Control Register
IOU Input/Output Unit
IS Instruction Stack
ISP Instruction Stack Pointer
IXA Implementation Extensible Architecture
LIFO Last-In, FirstOut (a stack)
LSB Least-Significant Bit
MIPS Millions of Instructions Per Second
MSB Most-Significant Bit
PC Program Controller
PDA Personal Digital Assistant
RISC Reduced Instruction SetComputer
RPN Reverse PolishNotation
SIMD Single Instruction,Multiple Data
SMI StandardMemory Interface
SP Stack Pointer
SR Status Register
SW Status Word
TOS Top Of Stack
VHDL VHSIC Hardware Description Language
VHSIC Very High Speed Integrated Circuit
VLSI Very Large Scale Integration
1 Introduction
1.1.0 Background & Goals
The proliferation of low-cost microprocessors has made the task of selecting a
processor for a particular application more complicated. System implementers
may choose a general-purpose processor which provides the functionality
necessary for the application, or they can design a custom processor. By selecting
an off-the-shelf system, costs are kept low, time is saved, and a certain level of
compatibility is established. However, the processor is not necessarily optimized
for the application, and there may be features which go completely unused.
Developing a custom processor would alleviate these problems, but would be
expensive in terms of time and money, and would lack compatibilitywith existing
systems and tools. A better solution would be to base a new system on a simple,
standard processor which provides a core set of computing services and excellent
scalability and extensibility. This thesis develops and demonstrates an architecture
which incorporates these basic goals.
Additionally, the architecture has been designed such that it is fabrication
technology independent. In modern microprocessor design, there are two
approaches to improving performance; the fabrication technology used to produce
the processor can be improved, or the internal, logical architecture of the processor
can be changed. Certainly, the two approaches can be used in conjunction to
An Extensible, ScalableMicroprocessor Architecture
further performance, but doing so ties logical features of the architecture to the
technology, a situation which could impede implementation of the architecture
in other technologies. The architecture developed here is implementation-
technology independent to allow its fabrication in any technology, a feature which
is demonstrated.
1.2.0 Definitions
In this context, scalability refers to the fact that design variables such as the word
size, amount of internal storage or buffering, and portion of the defined instruction
set which is implemented in the processor are not rigidly set by the architecture.
Instead, these variables would be determined by the processor or system
implementer to meet the needs of the application.
Extensibility refers to the architecture's ability to support implementation-specific
extensions to the instruction set or supporting hardware. This allows the system
designer to take the basic architecture and add capabilities supporting the specific
application.
An Extensible, ScalableMicroprocessorArchitecture
1.3.0 Overview
In order to provide a basis for the development of the architecture, several issues
of processor design are discussed relative to current solutions. From this discussion,
various aspects of the architecture are introduced. A detailed discussion of the
architecture follows. To put the architecture in perspective, it is compared to
some similar systems.
A VHDL model of one possible implementation of the architecture has been
created and used to test various aspects of the architecture. A different
implementation has been performed in hardware to demonstrate the architecture's
implementation flexibility. Both of these implementations are detailed and
discussed.
Finally, the unique nature of the architecture requires that topics such as
programming (and the software tools to support development), external interfacing
and implementation will be discussed. Applications for the architecture will be
briefly outlined.
An Extensible, ScalableMicroprocessor Architecture
2 Design Issues
2.0.0 Basic Services
The purpose of developing a new architecture is to provide solutions to computing
problems. As discussed above, an application-specific solution has the drawback
of being limited to just one purpose, a restriction whichmay not prove economical
against the high cost of producing a new processor. Since the goal of this architecture
is to provide basic computing services while not imposing the restrictions on
design found in either general-purpose or application-specific processors, it is
necessary to define what these basic services are.
All computing units must be able to accept data and instructions, apply the
instructions to the data, and produce results. To be able to accept input and
produce output, the processor must have an interface between its internal and
external environment. The specification of this interface is critical to the systems
implementer, because it determineswhat types of external devices canbe connected
to the processor, and what protocol they will use to communicate. To make the
architecture as extensible as possible, a simple protocol and interface scheme is
required.
The selection of instructions for data processing will determine what types of
computational problems the processor can efficiently handle. Early in computer
An Extensible, ScalableMicroprocessorArchitecture
development, complex instruction set computers (CISC) provided instructions to
handle a wide variety of computing tasks. The belief was that by providing
powerful and flexible instructions in hardware, programmers would be able to
spend more time writing applications, and less timewriting subroutines to perform
basic tasks. CISC machines provided this capability at the expense of complex
decoding and instruction execution mechanisms. As programmers became more
reliant on compilers than hand assembly, fewer of the complex instructions were
used, since the compiler tends to convert source code in the most genericmanner
to improve efficiency. As such, if the programmer wrote a routine in a high-level
language to perform the same function as an existing processor instruction, the
compiler would assemble it from simpler instructions rather than use the single,
more complex instruction.
The realization of this fact lead computer architects to devise reduced instruction
set computers (RISC), an architectural paradigm inwhich only basic instructions
with few addressing modes are provided. The task of creating more complex
instructions is left to the compiler. The instruction sets of these computers provide
a goodmodel for the development of a basic instruction set.
An Extensible, ScalableMicroprocessorArchitecture
2.1.0 Input/Output Performance
The first task is for the processor to be able to input data and instructions. The
optimal way to do this is to be able to process a continuous stream of data and
instructionswhile producing a continuous output stream of results. Some systems
which attempt to do this include systolic arrays and certain digital signal processors.
Both of these rely on the regularity of the data and consistency of the instruction
execution cyde to achieve high performance. However, this is generally not possible
since instruction execution is often conditional, and data may reside in the
processor's internal or the system's externalmemory in an almost random order.
Systolic arrays are able to achieve high performance by repeatedly executing an
instruction sequence on datawhich is continuously shifted through each processor
in the array [3, 2.18]. In this mode of operation, the instruction sequence is either
hard-wired into the processor, or loaded before data processing begins (assuming
a reconfigurable array, of course). Once processing begins, no special instructions
are required to read or write data; it simply
'flows' in and out of the processor.
This is, in a sense, an implicit addressing scheme. This model does not allow for
conditional code execution or any change in the code sequence during execution,
thereby reducing the number of applications for which the array is useful to a
very few. However, it does demonstrate the power of implicit addressing. In
An Extensible, ScalableMicroprocessorArchitecture
order to make the process more generic, it is necessary to provide a means of
loading and internally storing data, and then operating on the data with instruction
sequences which are not necessarily static for the duration of the computing task.
This can be accomplished by using a stack. This is a last-in, first-out (LIFO) data
structure which requires no addressing or special instructions for loading data
(unlike the register-basedmodel commonly found in CISC and RISC processors).
Instead, it is only necessary for the input system to be able to differentiate data
and instructions, so that they can share the same input/output (I/O) pathways,
an important consideration both in terms of logical integration and the physical
limitations of implementation. All that is required to do this is a single bit. If we
consider this bit to be set when representing an instruction and cleared when
representing data, then it is possible to load data and process it from a single
stream of words from an external source; the nature of this source is irrelevant to
the function of the processor. Any word arriving at the input with a cleared
instruction bit (the formal name for the flag bit) is implicitly pushed onto the
stack, while a word arriving with a set instruction bit is directed to the execution
unit.
An Extensible, ScalableMicroprocessorArchitecture
2.2.0 System Interfaces
The goal in designing the interface to the processor is to provide the lowest
common denominator upon which more powerful interfaces can be constructed.
Two elements are required; a data path and a means of providing control
information, i.e. handshaking between the components.
The data path may be either serial or parallel. Serial systems provide simplicity
in terms of interconnection, but are slower than parallel systems. Additionally,
since processors generally handle data in parallel mode internally, less hardware
is required to implement the interface.
To provide handshaking between systems, a standard arrangement requiring
handshake input and output signals on both devices can be used. The protocol
for handling communications is the important consideration, and needs to be
verified for proper operation. A Petri diagram with initial markings for the reset
(no I/O occurring) state is presented below (Diagram 2.1):
An Extensible, ScalableMicroprocessorArchitecture
Dack
IHift)
OHi
IHi (+)
Outdata
OHo)
Diagram 2.1- I/O Protocol
Symbols
I H i Input handshake (for input, from sender, arrows denote edges)
IHo Output handshake (for input, from processor)
OHo Output handshake (for output, from processor)
OHi Input handshake (for output, from sender)
Outdata Processor internal signal to send data
Dav Processor internal signal to indicate data available
Dack Processor internal signal to acknowledge acceptance of data at port
The protocol calls for the sender to raise its output handshake (IHi) and hold it
while the data on the bus is valid (the data should actually be valid prior to the
assertion of the handshake so that the receiver can use the handshake to latch the
data into an input buffer, if necessary). The sender must continue to hold its
handshake until the receiver replies with its own handshake (IHo). The receiver
then holds its acknowledgment handshake until the sender drops its handshake,
after which the receiver can drop its own.
An Extensible, ScalableMicroprocessorArchitecture
This protocol can be used on both uni- and bidirectional busses. With a
unidirectional bus, there is no possibility of collision, so the protocol need not
address collisions. In the event the bus is bidirectional, some type of collision
detection is required. In keeping with the goal of providing only the most basic
definition in the architecture, no collision detection or handling protocol will be
specified. If an implementation requires a more robust system, one can be
implemented externally. To mandate a protocol would increase complexity for
all cases, even those forwhcih collisions are not a possibility.
Note that the protocol is not deadlock-free. If either party fails to respond to a
handshake, the system will freeze. Again, defining a protocol to handle lock-up
increases complexity for all implementations, even those where deadlock is not
an issue. Instead, deadlock should be considered a system error condition.
2.3.0 Program Execution Model
As discussed above, data and instructions can be loaded into the processor using
the same protocols. Using a stack, data can first be loaded and then processed by
instructions from the same incoming stream of words. This format for expression
handling is known as Reverse Polish Notation (RPN), and is the most efficient
way to evaluate arbitrarily complex expressions. The question of how the
instructions are added to the data stream remains to be discussed.
An Extensible, Scalable MicroprocessorArchitecture 10
Standard processors begin fetching instructions from memory when they are
started. These instructions are located in blocks in memory, and the instructions
in each block are sequential. The processor is able to branch or jump within and
between blocks by executing specific branching operations, often based on the
current state of the processor. Since no memory interface has been defined in this
architecture, this process is not directly possible. Instead, this architecture relies
on an external program controller (PC) to feed instructions and data to the processor
in an executable stream. The nature of this controller is not specified, since itwill
define what the system does. However, the interface to the processor for the
controller is clearly defined and standard, so that processors and controllers can
be interchanged.
With such a controller, a standardmemory interface could be created and programs
inmemory could be executed as with any other processor. The controller would
handle reading and writing data to memory, and would be able to perform
branches and jumps. This is made possible by allowing additional instructions to
be defined (the architecture's extensibility), and by providing the processor's
internal status to the PC though a set of dedicated signals.
Building a system in this way has no clear benefits over a traditional processor;
in fact, if the processor and the PC are physically separated, performance would
certainly be much less efficient than a traditional
system. The main reason for
An Extensible, ScalableMicroprocessor Architecture 1 1
this is the time required to execute branches. This is one of the largest problems
in any architecture, but even more so here due to the extra time required to
communicate the processor's status before a conditional branch.
Recent processors often address this issue through the use of branch prediction.
A prediction about the outcome of the branch is made, often with the help of
information encoded in the instruction which indicates the most-often taken path
(this is the method used in processors such as the IBM/Motorola PowerPC [7,
1.4.1]). If the prediction succeeds, nothing is lost in execution, while if it fails,
the processor's pipeline often needs to be flushed causing a decrease in performance.
This architecture does not allow for easy pipelining because of the inherent data
dependency caused by the use of a stack. However, conditional branches will
still lower performance. To improve the situation, it would be useful to move
code fetch and execution inside the processor under certain circumstances. This
can be accomplished by providing a means of loading a code segment, which
will possibly be repeatedly executed, into the processor, and then executing it
without interaction from the external controller.
Since there is no addressing scheme built into the processor, it makes sense to
implement a second stack which will be used to hold the code as it is loaded. A
special instruction is required to begin the load process (otherwise incoming
An Extensible, ScalableMicroprocessorArchitecture 12
instructions are immediately executed); execution of this instruction places the
processor into a mode which directs incoming instructions to the second stack
(the Instruction Stack or IS) until an escape instruction is executed to return the
processor to normal mode. Note that incoming instructions are still tagged with
the instruction bit and that data can still be loaded concurrentlywith instructions,
since itwill be directed to the Data Stack (DS).
Once the IS has been loaded, instruction execution can be switched from the I/O
ports to the IS. Instructions are then executed from the IS until an instruction is
reached which stops IS-based execution. During execution, the IS behaves like a
stack only in that the stack pointer is used to locate the next instruction. Instructions
formodifying the stack pointer, and thereby allowing branching and looping, are
necessary.
Instructions executed from the IS act upon the DS in the same manner as instructions
coming from the I/O system. Data can also still be loaded implicitly during
stack-based execution by passing it to the I/O system as during normal execution;
an arriving word is treated as the top-of-stack (TOS) item, as it would be if it
were pushed onto the DS. This allows continuous data processing without any
explicit data-load instructions being executed, a clear advantage over standard
processors for certain applications. However, an instruction to perform an explicit
data-load operations is also required for programmed reading of data.
An Extensible, Scalable MicroprocessorArchitecture 13
2.4.0 Additional Architectural Issues
The above discussion provides a core definition for an extensible, scalable, stack-
based architecture for which the name Implementation Extensible Architecture
(IXA) has been chosen.
The remainder of this section discusses some other aspects of the architecture
which are less critical to the overall definition, yet require some discussion. A
complete, stand-alone definition for the architecture is provided in Appendix A.
2.4.1 Stack Sizes
The size of either of the internal stacks is not dictated by the architecture. Instead,
it should be based on the requirements of the application.
Stack usage for an implementation of this architecture falls into one of two classes.
First is that of single frame usage. In this class, it is used as a traditional LIFO
stack, which requires only a small amount of space. Extensive tests have been
performed to determine the optimal size of a Data Stack [5, 6.4.1]. These tests
show that a stack size of 32 elements is sufficient for all but the most deeply
recursive programs.
An Extensible, ScalableMicroprocessorArchitecture 14
The second class of usage is withmultiple, simultaneous stack frames on-chip (it
is also possible to have a single small stack and swap its contents to an off-chip
memory). The stack should be large enough to support the required number of
frames. The external program controller (or a program running from the instruction
stack) must keep a set of stack pointers to reference the frames. These may either
be stored externally or on the DS, so a master pointer space may also be required.
The size of the Instruction Stack is entirely dependent upon what applications
will be run and how the stack will be used by them. If the entire program is to be
loaded, the stack may need to be large; 32 kilobytes has been found to be a very
reasonable size for programs encoded in eight bits [5, 4.1.1] when run from
external memories. Alternately, the IS could be used to store often repeated
subroutines to gain a performance boost. Finally, it may only need to execute a
small, very simple operation (as in a systolic array application), requiring aminimal
stack size.
Another issue affecting the size of both stacks is the word size selected for the
implementation, since this determines the maximum number of elements on the
stack which can be directly addressed. Instructions must be provided to access
elements on the stack other than TOS, since only being able to access the first
element limits the complexity a program is able to achieve. Just as with a
machine
An Extensible, ScalableMicroprocessorArchitecture 15
organized around a memory subsystem, the amount of memory which can be
accessed is limited by the width of the address storage and transport system,
which is the stack in this architecture.
The word width of the IS is also related to the word-size issue. The DS must
support the full word width to handle data, but the IS only needs to hold
instructions, which are only 8-bits wide. The only cases where a wider IS is
necessary are when the IS will be used to store data or constants inside a code
module for repeated use during execution, or when the implementation uses an
extended instruction format to support instructions outside the definition. To
handle all cases, it is recommended that the IS beword-width.
2.4.2 Interrupts
Many applications require the ability to interrupt processor activity to perform
special, usually time-sensitive operations. This is particularly important when
external, asynchronous devices are involved which are running slower than the
internal speed of the processor; it is more efficient to continue normal operations
than to wait for the device to become ready.
Normally, interrupt handling is a matter of stopping the normal instruction fetch
cycle, saving the state of the processor (so the interrupting process has complete
An Extensible, ScalableMicroprocessorArchitecture 16
use of the processor, and the interrupted process can be completely restored
afterward), and beginning execution of the interrupt handling code. With out a
standard instruction fetch cycle, IXA requires a different approach.
Interrupts are handled through a priority-based request system. When an interrupt
is signalled, the processor stops it current activity and signals to all external
program controllers that an interrupt has occurred at a particular level. Four
interrupt levels are directly supported; three are maskable using an interrupt
mask code stored in the processor's status register. An interupt request succeeds
if its level is greater-than or equal to the mask level. This means that level 0 is
non-maskable.
Once the interrupt is accepted, the processor pushes the status word onto the DS.
This is the only item pushed as a matter of maintaining high-performance and
simplicity. If the interrupting process modifies any other system varibles such as
the stack pointers, IO Mode information, or either of the stacks, it is responsible
for properly restoring them, if necessary. The basic restoration process is to clear
the interrupt and then restore that status word.
The current interrupt level is communicated to external processors through a set
of dedicated signal lines; the information is not stored in the status word. As
soon as the interrupt is accepted, external devices should stop sending information
An Extensible, ScalableMicroprocessorArchitecture 1 7
to the processor until the interrupt condition is cleared. This prevents data loss
and gives the interrupting device complete access to the processor.
When the interrupting device is through with the processor, it should restore the
state and clear the interrupt status. Note that state restoration is left to the
interrupting device. This is because an interrupt is handled more as an indefinite
transfer of control to another device than one which has some expectation of
ending.
An interrupted process can itself be interrupted. The same process as above is
performed in such a case. Note that care needs to be taken not to clear the
interrupt status under these circumstances as this will preclude proper nesting of
interrupts. Instead, a process interrupting another interrupt process should first
determine whether an interrupt condition already exists, and, if it does, either
wait for the interrupt to complete, or not clear the interrupt status upon exiting
its routine.
Interrupt handling at the processor may not be as efficient as handling it at the
program controller when the processor is not executing from the stack, since it is
the program controller which is sending the instruction stream to the processor
and needs to be interrupted. Even if the processor is executing instructions from
An Extensible, ScalableMicroprocessorArchitecture 18
the stack it is possible to handle interrupts at the PC since instructions arriving at
the ports have a higher priority than those coming from the stack (in other
words, this can be used as another form of interrupt mechanism).
2.4.3 Levels of Implementation
The development of the computer industry over the past ten years has demonstrated
that no one computer system is correct for all applications. However, there are
many instances where one architecture can be applied to a variety of situations
on different scales. To address this issue, the IXA has been divided into three
levels of standard implementation. Each of these supports a subset of the features
defined by the architecture, and, in doing so, a subset of the instruction set.
The first level, Level 0, supports only the most basic set of instructions. It has
only a minimal Data Stack. Without an Instruction Stack, there is no need to
support any of the stack-based execution instructions or modes. Interrupts also
need not be supported, since such an implementation would rely entirely on an
external program controller for direction, so the controller would be required to
deal with interrupts. Applications for such a designwould be primarily found in
array processing where the data-passing capabilities of the processor could be
coupled with a shared instruction-feed mechanism, as is found in many Single
Instruction,Multiple Data (SIMD) machines.
An Extensible, ScalableMicroprocessorArchitecture 19
A Level 1 systemmight be applied where some amount of autonomous instruction
execution is required, for example in a reconfigurable array inwhich each processor
may perform a different operation.
Level 2 represents the complete architectural definition. All aspects of IXA and
its instruction set must be present in such an implementation. A full implementation
with large Data and Instruction Stacks could be used as a stand-alone computing
system, or as a powerful coprocessor.
The three levels form a layered model of the architecture:
;'J
Xit
'
::,'
m __
Level 0
i :Level 1
TTnnnTl
Level 2
*_! 1 11 1 1 irrc**
Extensions to Level 0
Extensions to Level 1
Extensions to Level 2
Diagram 2.2 - Architectural Levels
This model does not directly depict the fact that each layer is also extensible, so
An Extensible, Scalable MicroprocessorArchitecture 20
an implementation may support either some instructions of the layer above, or
some extended instructions unique to the implementation. This can be graphically
shown in a similar manner:
:Defined:;
Extensible
Diagram 2.3 - Architectural Layers of Definition
The three layers shown in Diagram 2.3 apply to each level defined above. The
Mandated area represents the instructions and architectural features required for
a particular implementation to be compliant with one of the levels. The Defined
region contains features not required by a particular level, but defined for higher
levels, which can be implemented if necessary (a design may use some features
of a higher level without meeting all of the mandated requirements of that level).
Finally, the Extensible region covers all features not provided for by the architectural
definition at any level; these are features added by the systems developer.
An Extensible, ScalableMicroprocessorArchitecture 21
When these two views of the architecture are combined, it becomes clear how
flexible it iswith respect to implementation. It also shows howmuch responsibility
is placed on the system implementer to integrate the processor into the total
system.
The concept of developing an architecture in many levels is not new. A similar
approach was used in the design of the Intel 80960 architecture [8, p. 2]. This
architecture directly supports three layers representing core, numeric and protected
functions. A fourth layer, the extended architecture, is reserved by Intel for its
own extensions. Limiting extended features in thismanner reduces the processor's
appeal as a generic solution to a specific problem.
2.5.0 Instruction Set Design
With the important features of the architecture defined, an instruction set can be
developed. Since the architecture is based on that of a stackmachine, many of the
instructions will naturally be similar to those found in stack-based computers.
The major differences are that (1) the I/O interface is significantly different, and
(2) the lack of a code fetch mechanism and the use of a stack for the internal
execution of code require special consideration.
An Extensible, ScalableMicroprocessorArchitecture 22
The basic functional areas whichmust be addressed for this architecture are:
Arithmetic & Logic - basic logical functions, shifts, and arithmetic operations.
I/O - providing ability to read and write data under programmed control.
Control - handle setting and reading of processor status information.
Program Execution - allow for conditional execution of code, branching.
These operations are similar in many cases to Forth language primitives. The
Forth language was developed to provide efficient execution of code based on a
stack machine model. The core set of operations performed on stacks can can be
easily described in terms of Forth operations, which provide a point of reference.
Also, since Forth maps directly to a stack machine, it should not be difficult to
develop a compiler to translate Forth to this architecture. The references throughout
this document to Forth are aimed at showing this inherent level of compatability.
For more information on the Forth language as it relates to stack machines, see
[5, 3.3].
An Extensible, ScalableMicroprocessorArchitecture 23
2.5.1 Arithmetic & Logic Instructions
The selection of which arithmetic and logic operations to implement is based
primarily upon the examples set by many architectures. The Arithmetic & Logic
Unit (ALU) does most of the useful work in the processor, and there are several
basic operations which are universal. Additionally, some consideration needs to
be given to the types of applications the processor may be used for, namely data
processing in which logical and shift operations are useful. The following
instructions were selectedwith this inmind:
NOT bit inversion
AND bit disjunction
OR bit conjunction
XOR bit inequality
SLL shift left, logical
SRL shift right, logical
SLA shift left, arithmetic
SRA shift right, arithmetic (sign extend)
SLR shift left, bit rotation
SRR shift right, bit rotation
ADD signed addition
SUB signed subtraction
MUL signed multiplication
DIV signed division
An Extensible, ScalableMicroprocessorArchitecture
24
A few notes about instruction selection:
a. All arithmetic operations take signed (two's complement) values as
operands.
b. XOR was selected as an independent operation even though it can be
performed through a combination of lower-order operations because it is
useful in performing operations such as the Cyclic Redundancy Check
(CRC) found in data communications.
c. The MUL and DIV operations will not return values outside the defined
single-word range of the implementation. This means that not all possible
inputs generate results in range. This is in keeping with the minimal
approach. Requiring a complete answer to be produced requires the ability
to handle double-words, which in turn requires more hardware just to
support two instructions. Further, since no other instructions handle double-
word values, a programmer making use of the entire double-word result
will have write additional code to use inwith addition or logical operations,
or even store or manipulate it on the stack. It seems better, then, if additioanl
code is required anyway, to provide basic multiply and divide operations
which can then be extended by the programmer to handle double-word
results.
An Extensible, ScalableMicroprocessorArchitecture 25
As a stack machine, the ALU will take its operands from the top of stack (TOS)
(one or two operands, as appropriate), and return a result to the TOS; the
operands are destroyed in the process. In cases where there are two operands, it
may be useful to keep one for additional calculations, like a constant function on
a hand calculator. In many applications a constant is often applied to an entire
data set. To facilitate this, operations which take two operands have two modes
of operation: normal and constant mode. To denote constant mode, a 'C will be
appended to the standardmnemonic. The operations supporting constants are:
ANDC
ORC
XORC
ADDC
SUBC
MULC
DIVC
A final operationwhich can be classified as an arithmetic operation is a comparison
operation. Generally, comparison operations are simply subtractions in which no
result is stored. In a stack machine, the disposition of the operands is in question.
The program may require that both operands be destroyed, that one be saved (as
An Extensible, ScalableMicroprocessorArchitecture 26
in constant mode above), or that both be saved so that an additional, conditional
operation be performed on them after the comparison. As such, three compare
operations are provided:
CMP compare, destroying both operands
CMPC compare, destroying only the operand at the TOS
CMPN compare, preserving all of the operands.
To flag the result of an operation, a standard set of flags is used:
N (Negative Hag) - result was negative
C (Carry Flag) - a carry occurred
V (Overflow Hag) - arithmetic overflow occurred
Z (Zero Hag) - result was zero
The N flag is set when the most-significant bit (MSB) of the internal word-size
(i.e. after the external instruction flag bit is discarded) is set, as it is for all negative
two's complement numbers. The C flag is setwhen an arithmetic operation causes
a carry-out to occur, or when a bit which is set is shifted out during a shift
operation. The V flag is set on and add or subtract when the last two carries are
not the same (indicating the result was out of the representable range), on a
divide if the resulting quotient is outside the representable range, or on an arithmetic
An Extensible, ScalableMicroprocessorArchitecture 27
left shift if the shifted-out bit is not equal to the resulting MSB. Zero is indicated
when all bits of the result are zero. The flags are only set by ALU operations or
direct manipulation of the status register; other operations which simply
manipulate items on the stack do not affect the previous settings of the flags.
2.5.2 Stack Manipulation Operations
Just as register-based processors have operations to move data to, from and
among registers, a stack machine has instructions which move data to, from and
within the stack. For this architecture, only a very basic set of operations is
provided, from which many standard stack manipulation operations can be
derived.
The most basic operation on a stack is to push items onto it, and pop them off.
This is handled essentially transparently by the processor, which automatically
pushes data items, and pops operands to instructions as necessary. The READ
instruction, a programmedmethod of pushing data, aswell as thewrit instruction
for outputting data, are discussed in section 2.5.3.
Another way to remove data from the stack is to adjust the stack
pointer such
that it points to the second item in the stack, thereby moving the top of stack.
Doing this does not actually delete the old item; it simply becomes invisible to
An Extensible, ScalableMicroprocessorArchitecture 28
the next operation. In Forth, this operation is DROP (in Forth's virtual machine
environment, the item is destroyed). By allowing the stack pointer to be changed
by two positions, Forth's DR0P2 can be executed. This leads to the development
of the ADJ instruction, arguably the most powerful instruction provided by the
architecture.
Since there is no defined stack size, how adj is used is relative to the
implementation's stack size. Using the ADJ instruction, it should be possible to
move the stack pointer by any offset, allowing any number of items to be dropped.
On a small stack, adjusting can be used to simulate a register-based system by
relatively addressing the various stack elements. On a large stack buffer (several
hundreds or thousands of bytes), this addressing can be extended to allow multiple
simultaneous stack frames, each of which could be accessed by adjusting the
stack pointer. The effect of this is to allow multiple processes or separate data
storage areas to use the stack memory without having to flush one processes
stack frame prior to another's activation, as is common with other stack machines.
The ADJ instruction applied to the IS (using the mnemonic ADJI) provides the
capability to perform relative branches or jumps in the executing code. As with
the DS, multiple active frames, in this case containing executable code, can be
loaded. These frames may contain only subroutines used by one program, or
complete processes, depending on the size of the stack and the application.
An Extensible, ScalableMicroprocessorArchitecture 29
In standard architectures, branches are usually made conditionally. To facilitate
this (as well as allow adjusts made on the DS to occur conditionally), a condition
codemay be spedfiedwith the adjust. See section 2.5.7 for a discussion of conditional
operations.
Two other stack manipulation operations provide the ability to move data on the
stack. Unlike a register-based machine inwhich all valid data items are available
to an operation, only the items at the TOS are available in a stack machine. The
ADJ operations can be used to change the location of the TOS, but not affect the
ordering of items relative to each other. A common operation required to do this
is the SWAP function which exchanges the top two items on the stack. Note that
this operation requires that two items be written to the stack in one processor
cycle; no other instruction requires this, and special hardware may be required to
implement the instruction. However, SWAP was found to be among the ten most-
common instructions in Forth programs [5, 6.3.1].
Another common instruction in Forth is the dup operation which makes a copy
of the TOS and then pushes it. This is generally used to maintain a data item
whichwould be destroyed by a later operation. This functionality is partly provided
by the constant mode provided for arithmetic operations, but not for other
instructions taking operands from the DS. Related to DUP are the SECOND, THIRD
and successive instructions which take their respective stack elements and push
An Extensible, ScalableMicroprocessorArchitecture 30
new copies onto the stack. The generic form of these instructions is the PICK
instruction which takes an operand naming a particular element on the stack to
copy.
To provide this capability, the architecture has the GET instruction. The basic GET
instruction takes an offset encoded within the instruction from the TOS, allowing
one of the top 16 stack elements to be copied to the TOS with a single instruction.
LGET takes the offset as an operand from the DS, allowing access to
2word-size
elements. GET 0 provides the DUP operation, as does LGET 0 (for LGET, the
offset is calculated after the operand containing the offset information is popped
from the stack so that GET and LGET operate interchangeably for the top 16 stack
elements). Note that by using the GET operations, operands can be fetched from
anywhere in the stack to the TOS, and, after a non-constant mode operation is
executed on them, the only change to the stack is the result of the operation
which is at the TOS. This allows several operations against a data set stored on
the stack to be performed (albeit inefficiently).
Two additional instructions which operate on the stacks are PUSH and PUSHI.
These allow data from one stack to be transferred to the other. PUSH pops the
next item on the IS and pushes onto the DS. PUSHI Performs the reverse operation.
PUSH is useful for allowing constants to be placed inside a code module that will
be loaded into the IS so that they may be pushed onto the DS at the appropriate
An Extensible, ScalableMicroprocessorArchitecture 3 1
time (or multiple times) during program execution. PUSHI allows the IS to be
used for storage of results (which can be recovered with PUSH or written with
WRITI). Note that executing PUSHI from the instruction stack has the possibly
deleterious effect of causing the PUSHI instruction on the IS to be overwritten
with the pushed data, which will then be executed as the next instruction. The
instruction's ability to be executed under these conditions is of questionable value.
2.5.3 Input/Output Instructions
In addition to the implicit push operation performed when data arrives at a port,
it is also useful to be able to read data from a port under programmed control,
particularlywhen the default prioritization of the data does not meet the program's
requirements. To allow this, there is a READ instruction which allows a single
data item to be read from a specified port and stored on the DS. A read will
cause the processor to halt until data is available at the specified port.
To output data, the WRIT instructions are provided. The basic instruction pops
the top element of the DS and sends it to the named port. As with arithmetic
instructions, a constant mode of operation is provided (WRITC) so that only a
copy of the data item is written; the original remains on the stack. Finally, the
WRITI instruction is used to write the next element in the IS to a port. Note that
there is no constant mode of operation available for the IS, since to execute such
An Extensible, ScalableMicroprocessor Architecture 32
an operationwould cause thewritten data item then to be executed as an instruction.
The purpose of the instruction is to provide the ability to encode constant data as
an instruction (so that it can be read directly to the IS) which can then be written
directly to a port during IS-based execution.
2.5.4 Control Operations
Control operations provide an interface between the state of the processor and
the program executing on the processor by allowing that state to be read and
modified directly. Several registers are provided to do this. There are two stack
pointer registers: one for the Data Stack Pointer (DSP), and one for the Instruction
Stack Pointer (ISP). These registers are at most word-sized, butmay be smaller as
required by the implementation. The Input/Output Control Register (IOCR) has
at most eight bits. The even-numbered bits (0,2,4,6) represent the setting of the
word-size-plus-one bit of the output ports, normally the instruction bit. Itmay be
used to pass instructions to other processors or as a separate signalling line. The
odd-numbered bits represent the lock-out status of each port; the bit is set for the
port if the port is locked (meaning no input is possible on the port, although
output is still possible). Finally, the Status Register (SR) contains the processor's
Status Word (SW). The eight bits in this register represent the following (from
LSB to MSB): Zero flag (Z), Overflow flag (V), Carry flag (C), Negative flag (N),
Interrupt Mask bits 0 and 1 (MO,Ml), and the internal status bits 0 and 1 (SO, Sl).
An Extensible, ScalableMicroprocessorArchitecture 33
Access to all of these registers is provided through a group of control instructions.
When a register is read, its contents are pushed onto the DS. The instructions to
do this are:
PSW Push StatusWord Register
PIO Push I/O Control Register
PSP Push Stack Pointer (DS)
PSPI Push Stack Pointer (IS)
When PSP is executed, the value of the stack pointer which gets pushed is the
value prior to the push operation (since the DSP is decrementedwhen the value it
pushed). If PSPI is executed from the IS, then the value of the ISP which is
pushed is that after the PSPI instruction has been popped.
Once a value has been pushed, it may be modified and then used to set the
register (or a new value may be loaded and used to set the register). The instructions
to set the control registers are:
An Extensible, ScalableMicroprocessorArchitecture 34
SSW Set Status Word Register
S IO Set I/O Control Register
SSP Set Data Stack Pointer
SSPI Set Instruction Stack Pointer
SSP and SSPI are different from the other register-setting instructions in that
they can be executed conditionally. This is because, like adj, they can be used to
modify program flowwhen applied to the IS.
Another control instruction which does not access any user-register is Clear
Interrupt (CLRINT), which sets the interrupt status to normal. The copy of the
status word pushed onto the DS when the interrupt occurred is not restored by
this instruction; this must be done programmatically. Also, since this instruction
simply clears the interrupt status, an interrupt process whichwas itself interrupted
is not restored properly if the interrupting process executes CLRINT. If this is a
problem, then either the SSW instruction should be used to set the interrupt mask
to lock out further interrupts, or a semaphore system should be established.
An Extensible, ScalableMicroprocessor Architecture 35
2.5.5 Program Execution Instructions
To load, enter and exit programs executing internally (using the IS), several
instructions are available. They are:
LOAD Enter loading mode; pass incoming instructions to the IS
RESUME Return to normal mode from loadingmode
EXEC Begin stack-based execution
HALT Stop stack-based execution
LOAD places the processor in loading mode so that incoming data tagged as
instructions are pushed onto the IS instead of being executed. This continues
until the RESUME instruction is encountered, which causes loading to cease. Note
that the RESUME instruction is not pushed onto the IS, and, further, it would
never be executed from the IS even if it were pushed there using PUSHI (LOAD
can be executed from the IS causing a mode shift from executing to loading
which would be terminated by an incoming RESUME).
EXEC causes instruction execution from the IS to begin. This can be executed
conditionally (allowing for conditional subroutine calls, assuming the subroutine
An Extensible, ScalableMicroprocessorArchitecture 36
is stored on the IS). Note that an EXEC canbe simulated by using the SSW instruction
to change the processor mode to executing (or to loading or normal, for that
matter). This would not be conditional and would modify the DS. Stack-based
execution continues until the HALT instruction is successfully executed. This is
also conditional, allowing conditional exit from a subroutine.
Two further program-execution commands, NOP and TTRA are defined. NOP, or
No Operation, does nothing except require one cycle to execute. This may be
useful for providing delayswhen I/O between the processor and another processor
or program controller is slower than the processor's speed. TTRA, or Toggle Trace
Mode, toggles the processor's trace mode bit. When this bit is set and the processor
is in executing mode, execution stops after each instruction (the mode is forced
back to normal mode, a change which is visible in the status word). Execution
may be resumed with the EXEC instruction. This allows for program tracing
during debugging. It could also be used to allow explicit control or synchronization
with an external controller during stack-based execution.
2.5.6 Extended Instructions
Room is left in the basic instruction encoding for additional instructions to be
defined (see section 2.5.7). To eliminate the inherent limitation on the number of
instructions that can be defined based on the default instruction size, an escape
An Extensible, ScalableMicroprocessorArchitecture 37
instruction, EXTOP, has been defined. This causes the entire next word to be
interpreted as an instruction. EXTOP takes its operand from the IS, so that the
next word is either the next word tagged as an instruction arriving at an I/O
port, or the nextword on the IS during stack-based execution .
An implementation may choose not to use EXTOP, butmight instead use a wider
instruction field for all instructions. This allows extended instructions to use the
additional codes provided by the wider word size.
2.5.7 Instruction Encoding
With the instructions defined, it is possible to encode them. There are two goals
to be met with the encoding. First, the instructions should be kept as small as
possible. A single-word instruction can be loaded in one cycle,where asmulti-word
instructions require more time to load and more space to store. The second goal
is to also provide as much pre-decoded information as possible in the instruction
format to reduce the amount of hardware required to decode the instruction.
To meet the first goal, a word size must be chosen. It may be argued that eight
bits is the smallest useful word size, as it is commonly found in analog/digital
applications (although a larger word size may need to be supported internally to
effectively work with such data). Sixteen-bit operations can be simulated fairly
An Extensible, ScalableMicroprocessorArchitecture 38
easily with eight-bit words, and eight-bit words can be conveniently stored in
memory (in the case of this architecture, although a ninth bit is required to mark
instructions, this is not a problem since 9-bit memory modules are common for
use in parity-checking systems).
Using an 8-bit word for an instruction allows a possible 256 instructions to be
encoded. The architecture only calls for 54 instructions (plus a certain number to
be set aside for extended operations). Since there are extra opcodes available, it is
possible to provide some horizontal encoding, that is, some pre-decoded
information in the instruction field.
After some intial experimentation with encoding schemes, an encoding method
was selected. It calls for the first two or three bits of the instruction word (not
including the instruction bit) to be used to determine the group to which the
instruction belongs. These group prefixes are:
OOxxxxxx
OlOxxxxx
Ollxxxxx
lOxxxxxx
llxxxxxx
Extensible Architecture Group
Arithmetic Group
Control Group
Stack & IO Group
Stack Pointer Adjust Group
An Extensible, ScalableMicroprocessorArchitecture 39
By reserving the 00- prefix for extended instructions, a total of 64 opcodes are left
for instructions in the same compact format as the rest of the instruction set (the
first opcode, 00000000, is reserved as an escape to indicate that the entire next
word is an extended instruction).
The Arithmetic and Control Groups (see Table 2.1) are the most straight-forward
in that they are fully encoded with no variable subfields. The 10- prefix is used
with nine instructions which generally have some variable information encoded
into the lower bits of the instruction (the exceptions being the PUSH, PUSHI and
SWAP instructions which are fully encoded). One of the 10- group instructions is
GET, which has a four-bit operand field to allow single-instruction access to 16
words on the stack; LGET is provided to access any element of the stack.
The 11- group instructions all contain a three-bit condition field (as do the HALT
and EXEC instructions in the 011- group). As discussed above, these instructions
can be executed conditionally as a means of providing control over program
execution. Only three bits could be provided for encoding conditions, so it was
important to decide which conditions should be allowed. The starting point for
the selection process was the condition set provided by the Motorola MC68000
family ofmicroprocessors [6, Table A-2]. For that architecture (a CISC architecture),
sixteen conditions are available. To determine the static frequency of usage of
these conditions in actual applications, code resources in several Macintosh
An Extensible, ScalableMicroprocessorArchitecture 40
applicationswere lexically scanned for branch statements and the results compiled.
The abbreviated results are given below (complete results are listed in Appendix
B):
Condition (operation) Total Found Percent of Total
Any (BRA) 257 31
Equal (BEQ) 205 25
Not Equal (BNE) 178 21.7
Greater or Equal (BGE) 37 4.5
Less or Equal (BLE) 37 4.5
Less Than (BLT) 28 3.4
Greater Than (BGT) 23 2.8
Plus (BPL) 16 1.9
Carry Set (BCS) 10 1.2
Minus (BMI) 10 1.2
Carry Clear (BCC) 6 0.73
High (BHI) 5 0.6
Overflow Set (BVS) 5 0.6
Low or Same (BLS) 3 0.37
Overflow Clear (BVC) _0_
820
_0_
100%
An Extensible, ScalableMicroprocessor
Architecture 41
Based on these results, as well as a need to provide relatively complete coverage
of possible situations (in other words, itwas necessary to provide some capability
to test certain flags, even though usage of such tests is rare), the following condition
codes were selected:
Condition Mnemonic Boolean Code
Any ANY 1 000
Equal EQ Z 001
Not Equal NE Z 010
Negative NEG N 011
Carry Set CY C 100
Overflow Set OV V 101
Greater Than or Equal GE NV+NV 110
Less Than or Ea;ual LE Z +NV +NV 111
Table 2.1 provides a complete listing of the instruction set:
An Extensible, ScalableMicroprocessor
Architecture 42
7 6 h_J 4 3| 2| 1 o Next Word
Extensible Arch. GrouD 0 Q instruction ?
EXTOP 0 0 0 0 0 0 | 0 0 instruction
Arithmetic Group 0 0 subf roup operation v:'V :'. -. -^7
Logical Subgroup 0 0 0 0 operation con -
NOT 0 0 0 0 0 0 1 _
AND 0 0 0 0 0 1 0 -
ANDC 0 0 0 0 0 1 1 _
CR 0 0 0 0 1 0 0 -
CFC 0 0 0 0 1 0 1 -
XCR 0 0 0 0 1 1 0 .
XOFC 0 0 0 0 1 1 1 -
Shifter Subgroup 0 0 0 fill du - ,
SLL 0 0 0 0 0 el _
SRL 0 0 0 0 0 1 -
SLA 0 0 0 0 1 0 _
SRA 0 0 0 0 1 1 -
SLR 0 0 0 1 0 0 -
SRR 0 0 0 1 0 1 -
Operations Subarouo 0 0 0 operation con -
ADD 0 0 0 0 0 0 -
ADDC 0 0 0 0 0 1 .
SUB 0 0 0 0 1 0 -
SUBC 0 0 0 0 1 1 -
MUL 0 0 0 1 0 0 -
MULC 0 0 0 1 0 1 -
DIV 0 0 0 1 1 0 -
DIVC 0 0 0 1 1 1 -
Compare Subgroup 0 0 1 operation -
CMP 0 0 1 0 0 0 -
CMPC 0 0 1 0 0 1 -
CMPN 0 0 1 1 0 1 0 -
Control Group (Direct) 0 0 operation -
PSW 0 0 0 0 0 0 -
SSW 0 0 0 0 0 1 DS
PSP 0 0 0 0 1 0 -
PSPI 0 0 0 0 1 1 -
PIO 0 0 0 1 0 0 -
SIO 0 0 0 1 0 1 DS
LOAD 0 0 0 1 1 0 -
RESUME 0 0 0 1 1 1 -
NOP 0 0 1 0 0 0 -
TTRA 0 0 1 0 0 1 -
CLRINT
r
0 0 1 0 1 0
Table 2.1 - Instruction Set
An Extensible, ScalableMicroprocessorArchitecture 43
Control (Conditional) 0 1 1 1 cp condition -
HALT 0 1 1 1 0 condition .
EXEC 0 1 1 1 1 condition -
Stack & IO Group 0 subgroup operation ?
IO Subqroup 0 0 0 operation port *
READ 0 0 0 0 0 port -
WRIT 0 0 0 0 1 port DS
WRITC 0 0 0 1 0 port DS
WRITI 0 0 0 1 1 port IS
Direct Stack Subgroup 0 0 1 operation ?
PUSH 0 0 1 0 0 0 0 IS
PUSHI 0 0 1 0 0 0 1 DS
SWAP 0 0 1 0 0 1 0 .
Indirect Stack Subqroup 0 1 operation -
GET 0 1 0 offset -
LGET 0 1 1 0 0 | 0 0 DS
Stack Ptr. Adjust Grp operation condition -
Relative Adi. Subqroup rrd stK cp condition <
7'
v
ADJ 0 0 off condition -
LADJ 1 0 0 condition DS
ADJI 0 1 off condition -
LADJ I 1 1 0 condition DS
Absolute Adj. Subgroup 1 stk 1 condition
SSP 1 0 1 condition DS
SSPI 1 1 1 condition DS
Table 2.1 (continued) - Instruction Set
An Extensible, ScalableMicroprocessorArchitecture 44
2.6.0 InstructionMandates for Each Implementation Level
The three implementation levels discussed above each have a set of mandated
instructions from the complete instruction set definition which are required to
make an implementation compliantwith a particular level. Note that instructions
which are implemented beyond these mandates are part of the Defined features
set for a level (except for Level 2, where all instructions are required so that any
further instructions supported by the implmentation are Extended).
The basic criterion for omission of an instruction from Level 0 is whether or not it
can be emulatedwith any other instructions in a reasonable way. To some extent,
implementation difficulty was also evaluated, based on experience in developing
the two demonstration systems discussed later in this document.
The instructions required for a Level 0 design are:
EXTOP (if used) PSP
NOT NOP
AND, ANDC READ
OR, ORC WRIT, WRITC
XOR, XORC PUSH
SLL, SRL, SLA, SRA, SLR, SRR GET
ADD, ADDC SWAP
PSW, SSW ADJ, ladj (if stack sizewarrant^
PIO, SIO SSP
An Extensible, ScalableMicroprocessor Architecture 45
Several of these instructions are only required if the size of the stack makes it
appropriate to implement them. For example, LGET is only necessary if the stack
is outside the range of GET (sixteen elements). Similarly, ladj is required if a
point in the stack cannot be reached with two ADJ instructions (since ADJ will, at
most, require the equivalent of two instruction cycles due to the need to preload
the operand).
Level 1 builds on Level 0 by adding an Instruction Stack and the instructions
necessary to use it. Again, instructions which are dependent upon the size of the
stacks are implemented as appropriate. Also, instructions which can be emulated
are omitted. The list of required instructions for Level 1 (beyond those for Level
0) is as follows:
LOAD
RESUME
EXEC
HALT
PSPI
TTRA
WRITI
PUSHI
ADJI, ladji (ifiadcazewarrant^
SSPI
An Extensible, ScalableMicroprocessorArchitecture 46
3 Implementation & Testing
3.0.0 Overview
Since the architecture developed above is so flexible in terms of the configuration
of the actual processor implementation, choosing a particular implementation
limits what types of tests can be performed on the processor. If a minimal design
is chosen, then more complex features of the architecture are unavailable for
evaluation. Alternately, if a complex implementation is done, the architecture's
performance inminimal systems can not be judged.
In an attempt to demonstrate the architecture in a number of environments, two
implementations have been performed as part of this work. The first is a VHDL
(VHSIC (Very High Speed Integrated Circuit) Hardware Description Language)
model of a two-port, Level 2 implementation of the architecture. This model is a
behavioralmodel,meaning that only the functionality of the processor is addressed,
not how that functionality is internally achieved (i.e. a black boxmodel).
The second implementation is a logic design targeted at a Field Programmable
Gate Array (FPGA). This implementation is minimal, providing 1 port and Level
0 compatibility with the architectural
definition. The purpose of this
implementation is to demonstrate a physical fabrication, as well as show that
there are many target technologies capable of supporting
the architecture.
An Extensible, ScalableMicroprocessorArchitecture 47
3.1.0 VHDL Model
The purpose of creating a VHDL model is two-fold. First, it provides a platform
for simulation, and thereby verification of the architecture. Although the
architecture is completely defined on paper, without a verification model, there
is no way to know whether the given functionality is enough or too much to
solve actual problems; the VHDL model provides a means to test this. Second, it
provides coded documentation of the architecture's behavior. Initially, the effect
of this was to help clarify certain issues in the architecture which were under-
defined in the specification. In its completed state, the code provides a working,
tested definition of the architecture for future reference.
As a behavioral model, little thought was giving to accurately simulating the
exact means by which an instruction is executed, or the timing issues associated
with a particular implementation. Instead, the model was designed to be
implementation-technology independent. This allowed for a more accurate test
of the architecture separate from any special capabilities or problems associated
with a particular implementation technology. As such, any timings or operations
seen in the code are entirely arbitrary.
An Extensible, ScalableMicroprocessorArchitecture 48
The code was written, compiled and tested under Mentor Graphics version 8.2
design tools, including the Design Architect, VHDL Editor, System-1076 VHDL
Compiler, and QuickSim II logic simulator /debugger. A complete listing of the
source code is provided in Appendix C.
3.1.1 Entity Definition
The entity definition at the top of the code defines the processor's interface. This
definition provides a black-box style interface in that several different architectural
modeling styles could use the same interface, and the compiled object could be
integrated with other components which are not necessarily compiled VHDL
objects themselves. Diagram 3.1 shows this interface and other system components.
I/O Handlers
Port 0 in
^
Port 0 out *
fc.
Port 1 out -
w
tKescr
Execution Unit,
Stacks,
Control Registers
-? Status Word
^ Interrupt
Acknowledgements
Diagram 3.1 - VHDL Model Design
An Extensible, ScalableMicroprocessor Architecture 49
The model has two logical ports, each of which is physically divided into input
and output ports. Two ports is enough to demonstrate the handling and
prioritization of simultaneous inputs. The model could easily be extended to
allow more ports (up to the maximum of four supported by the architecture) for
testing applications requiring more than two ports. Each physical port has its
associated input and output handshake signals.
The ports have been defined as type INTEGER for several reasons. Internally, the
model emulates an 8-bit machine. For this, a ninth bit is required at the I/O
ports. By using integers (16-bits), no special types need to be defined. Also, since
the model is designed to be used in test bench not only for the architecture, but
also for the software that will be executed on that hardware, using integers
makes itmuch easier to define an external object that can be used to read instructions
and data from a file and pass them to the processor model for simulation.
Also defined are two interrupt request and acknowledge signals, the status word
output (also an integer), and the processor reset signal.
3.1.2 Model Internals
The architecture block of the model contains several processes. The two ports are
modeled as separate processes which interactwith the rest of the processor through
An Extensible, ScalableMicroprocessorArchitecture 50
a series of handshake signals in much the same way as is done in the FPGA
implementation (see section 3.2.5).
The main body of the architecture is the execution process which is called when
data becomes available at either of the ports. This data is decoded and then acted
upon either as an instruction or pushed onto the stack. In terms of simultaneous
data handling, This model supports the ability to push two data words onto the
stack in one cycle, or to execute an instruction on an incoming data word in one
cycle.
Internally, most of the process of decoding the instruction is done mathematically;
that is, there is no conversion to bit vectors to perform instruction decoding.
Conversions to and from bit vectors are used to handle boolean operations since
VHDL defines these operation onbit vectors. The setting of status flags by arithmetic
and logic operations is handled mathematically using closed-form expressions.
3.1.3 VHDL Test Bench
To test the VHDLmodel, a second VHDL object was created whichwould simulate
an external program controller. To define how this system would provide an
interface to a memory, as well as demonstrate the extensibility of the architecture,
a Standard Memory Interface (SMI) extension to the architecture was created.
An Extensible, ScalableMicroprocessor Architecture 51
Note that this extension was not central to the thesis topic, but rather was a tool
for testing and experimentation. As a result, it is by no means complete or optimal.
See Section 4.4.0 for a further discussion of some issueswhich need to be researched
about such interfaces.
The interface module reads a program from a file; the file is a series of ASCII
base-ten integers representing instructions and data. Upon receiving the LOAD
signal, the program controller (PC) reads the file from disk into a simulated
memory, and then begins execution. Words are read from memory and tested to
see whether they are SMI instructions or simply instructions and data for the
processor. SMI instructions are executed in the PC, while everything else is passed
to the processor. The entire program can be monitored during simulation to
check for proper operation.
The Level 0 test program was executed on the model (this is listed in Appendix
D), and the expected results were achieved (provided in Appendix E). A very
simple program to execute off the stack is also listed in this Appendix. As discussed
in section 4.4.0, it should be a goal of future research to use such a model to
further test different types of algorithms on the architecture.
An Extensible, ScalableMicroprocessorArchitecture 52
3.2.0 FPGA Implementation
Whereas a VHDL model can be used to demonstrate and test the architecture's
capabilities, a physical implementation demonstrates that it can be constructed.
This architecture leaves much of the physical implementation undefined, allowing
great flexibility. To demonstrate this flexibility, a very basic (Level 0) version of
the architecture has been implemented using Field Programmable Gate Array
(FPGA) technology. The simplest possible implementationwas chosen to provide
a benchmark for the lower limit of the architecture's specifications and to see
whether or not this limit provides enough power to create a useful processor.
The purpose behind this approach is to show that inexpensive technology can be
used to implement a processor conforming to the architecture. Using the FPGA,
not only is the development cycle manageable (this processor was designed,
fabricated and testedwithin a three-month period by the author), but the resulting
device can be rapidly reproduced. Additionally, since FPGA development software
is fairly flexible, the design can be extended in the future, or used as a
"core" for
larger systems.
3.2.1 FPGA Technology
Actel FPGA components and development tools were used in the production of
the processor [11]. The Actel 1020A FPGA used provides 547 logic modules,
An Extensible, ScalableMicroprocessorArchitecture 53
which are simply four-input, one-output logic blocks which can be programmed
into a variety of logic configurations through a set of burn-once fuses. These
blocks can then be connected together using an internal interconnect network
which also uses fuses to permanently set the logic design into the chip. This
permanent-burn system tends to allow for simpler FPGA's, which are therefore
cheaper and provide more logic blocks. Additionally, they are faster than
reprogrammable FPGA's (such as FPGA's manufactured by Xilinx) which rely on
static gates to configure the chip.
The schematic capture for the processor was done initially on a Macintosh using
LogicWorks 2.5.1, and then transferred to the Apollo systems using Mentor
Graphic's NETED v7 tool. The resulting netlist was then used by Actel's Action
Logic System (ALS) version 2.11 tools to automatically place and route the chip.
The resulting file was used to program the chip, which could then be used
immediately .
3.2.2 The Processor Design
The implementation done here is compliant with the architecture's Level 0
specifications. Specifically, it has one logical port (physically separated into input
and output ports), a four-element data stack, and an 8-bit data path. This processor
An Extensible, ScalableMicroprocessorArchitecture 54
was designated IXAipl08 (the 'V refers to the single port, the
'08' is the size of a
data word). A single letter is postfixed to this to indicate design revisions.
The limitations placed on the implementation by the FPGA technology drove
many aspects of the design, most notably the minimalistic approach. Each logic
block in the array can support up to four inputs and one output, although not all
four-input logic functions can be generated with a single block. Actel's logic
chips also require that only bi-state logic be used; this rules out the use of tri-state
buses internally, so that multiplexers must be used. These are expensive in terms
of logic blocks since at least eight blocks are required for each multiplexer on the
bus. The same argument can be made about every element of the data path, so
that increasing the data path size proportionally increases the number of blocks
for the processor.
The number of I/O ports was limited mainly to make the processor simpler to
route (since it appeared that it was going to be densely populated already). An
additional port would have required even more logic to support not only the
port hardware, but the architecture's capability to handle multiple data items
simultaneously.
Speed was also not an issue in the design. The FPGA is not the fastest technology
available and would not be the technology of choice for performance-critical
An Extensible, ScalableMicroprocessorArchitecture 55
applications. However, the Actel FPGA does offer enough performance that 20 to
30 MHz clock speeds are not uncommon for some applications. The goal of this
implementation was simply to break the one million instructions per second
(MIPS) barrier, a reasonable performance expectation for such a implementation.
The remainder of this section details the logic of the processor and its components.
3.2.3 Overall Design
The processor is constructed of five major subsystems: the Arithmetic and Logic
Unit (ALU), the Input/OutputUnit (IOU), the Data Stack (DS), the Control Registers
Block (CRB), and the Control Unit (CU). Each of these systems is detailed below.
The overall arrangement of these pieces in the processor is shown in diagram 3.2.
Also shown are the main internal buses, as well as the primary external interface
connections.
An Extensible, ScalableMicroprocessor Architecture 56
Bus
Port 0 in
Port 0 out*
IOU
CU
Status
Word
DS
CRB
DO Bus
Dl Bus
ALU
YBus
Diagram 3.2 - System Layout
3.2.4 Arithmetic/Logic Unit (ALU)
Nearly half of the instructions provided by a Level 0 implementation are arithmetic
or logic operations. The ALU handles 8-bit, signed integers and provides three
classes of operations: boolean, shifts, and arithmetic. To do this, the ALU has be
broken into two sections: the arithmetic/logical section, and the shifter. Data and
the current operation are applied to both sections simultaneously, with the result
being selected by an output multiplexer.
The arithmetic/logic section consists of eight arithmetic/logic bit-operation
modules, each of which performs all operations upon the input data. The
appropriate result is selected by a 4-to-l multiplexer at the output of eachmodule.
With the exception of addition, each module operates independently. For addition,
An Extensible, ScalableMicroprocessorArchitecture 57
a carry-in and carry-out bit are used. Combining modules in this way creates a
ripple-through adder. Although this is not the most efficient design (a carry-
look-ahead designwould be somewhat faster), it is more conservative in terms of
logicmodule requirements, and the performance loss in an 8-bit system is minimal.
The logic for a single module is shown in Diagram 3.3.
EnaB-
Diagram 3.3 - Arithmetic/Logic Bit Slice
The shifter is an array of AND gates which, given a shift direction (encoded in bit
0 of the instruction), selects the appropriate neighboring bit to transfer to the
output. The shifter can be set for three modes of operation: logical shift, arithmetic
shift, and rotate. In logical shifting, the bits are simply shifted in the selected
direction ; a set bit shifted out in either direction causes a the carry flag (C) to
become set, and zeros are always shifted in to fill the emptied bit position. In
arithmetic shifting, the sign of the operand is preserved. For an arithmetic right
An Extensible, ScalableMicroprocessorArchitecture 58
shift (SRA), this means setting the MSB of the result if the MSB of the operand
was set. For an arithmetic left shift (SLA), the sign is preserved by the nature of
the operation, unless an overflow occurs, which is reported with the overflow
flag (V). For the rotate operation, the bit shifted out of one side of the shifter is
shifted in the opposite side.
The operation to be performed is fed directly to the ALU from the CU in the form
of the lower five bits of the instruction; all decoding is performed within the
ALU. The decoding logic inside the ALU generates several control signals; these
are listed alongwith their generation logic in Table 3.1.
Function Signal Logic
Invert A InvA (11 XNOR 14) AND (NOT 12)
Enable B EnaB I10RI2 0RI4 !
Enable Shifter ShEna 13 AND (NOT 14)
Enable Arithmetic/Logic A/LEna N0T(I3AND(N0TI4))
Carry In Ci I1ANDI4
Function Select 0 SO 11 AND (NOT 14)
Function Select 1 S1 l2AND(NOTI4)
Table 3.1 - ALU Internal Control Signals
The ALU is a combinational circuit; it processes the inputs as they become available,
and the time it takes to produce a stable result is the main factor determining the
maximum speed of the processor.
An Extensible, ScalableMicroprocessorArchitecture 59
3.2.5 Input/Output Unit (IOU)
To provide the asynchronous interface required by the architecture, the IOU uses
input and output buffers to latch data and provide handshaking between the
processor and external devices.
The input side of the IOU waits for the input handshake signal (IHi) to latch
data. It will only be able to latch the data if the Lockout (LO) bit for Port 0 is
cleared in the Input/Output Control Register (IOCR). Note that setting this bit
effectively stops the processor until a reset is performed since there is only one
port and therefore only one way to feed instructions to the processor. When the
data is latched, the IOU passes the data to the I bus and sets the Data Available
(Dav) signal to the CU. When the CU accepts the data, it responds with the Data
Acknowledge (Dack) signal,which causes the IOU to drop its Dav signal, and set
the output handshake (IHo) signal. When the external device drops its input
handshake, the IOU drops the output handshake. Diagram 3.4 shows the timing
of this sequence of events.
IHi
IHo
DAv
DAck
.1 i_
Diagram 3.4 - Input Handshake Timing
An Extensible, ScalableMicroprocessorArchitecture 60
The output side works in a similar manner, but is simpler because the processor
internals only need to pass the data out; there is no need to wait for a response
from the processor side of the interface as there is when reading data. When the
processor executes a WRIT instruction, the CU generates the Outdata signal to
latch the data, which is on the Y bus, into the output latch. This also sets the
output handshake on the output port (OHo). When the external device receives
the data, it signals with the input handshake (OHi), causing the IOU to drop the
output handshake. The output handshake is also passed back to the CU to indicate
the state of the port; if it is asserted, then the port is still busy and the processor
mustwait to send further output. Diagram 3.5 shows the output process.
I ... I
OutData
OHo
OHi
i i
i
Diagram 3.5 - Output Handshake Timing
3.2.6 Data Stack (DS)
The DS provides storage for operands and results. This implementation has a
four-element stack, meaning that four, 8-bit registers are available for data. The
stack is addressed by the stack pointer (SP) which is stored in the CRB. Access to
the stack is provided by an input bus which feeds the four registers, and a
two-level multiplexer array which selects the output.
An Extensible, ScalableMicroprocessorArchitecture 61
Normally, the current top-of-stack (TOS) register is selected by the SPO and SP1
bits and passed to the output. Since it is common to use the second item on the
stack for two-operand operations, it can be quickly selected using the SP+1 signal
(since the stack grows downward, the item at SP+1 is the second item on the
stack), which adds one to the value of the stack pointer inside the DS (without
modifying the SP register). This selectionmechanismworks at both the input and
output sides of the DS. On the input side, the DLatch signal is gated to the
selected TOS register to latch the data coming into the DS.
In the final design, the processor reset signal was not connected to the registers
so that their contents would remain past a reset for examination (in case of an
unexpected failure).
3.2.7 Control Register Block (CRB)
The CRB contains three registers which store the processor's state information:
the stack pointer (SP), the input/output control register (IOCR), and the status
register (SR). All of these provide state information to other parts of the processor,
and are modified by other parts of the processor. Additionally, they can be read
or written under programmed control. The processor reset signal clears all of
these registers.
An Extensible, ScalableMicroprocessorArchitecture 62
The SR contains the four ALU status flags (N,C,V,Z), as well as a processor status
bit. Since Level 0 does not support an instruction stack, the only valid status
settings are 00 (Normal) or 11 (Error), which can be represented with a single bit.
Also, since there is no IS, there is no need to support interrupts in the processor
(this would be done in the program controller), so the interruptmask bits are not
present. For compatibility, all bits appear in there respective positions when the
status word is pushed onto the DS. Inputs to the SR come from either the bus or
directly from the ALU. The Error flag is currently not set by the hardware (it
would only indicate an illegal instruction), but it can be set in software.
The IOCR contains two bits since there is only one port. Bit 0 is the Instruction Bit
for port 0; if it is set, then the ninth bit of port zero is set at the output. This could
be used to pass instructions to other processors, or as a separate signal line. Bit 1
is the Lockout Bit for the port; if it is set, the port is locked-out, meaning than no
incoming data or instructions will be latched. Although the bit only affects the
input side of the port, the fact that there is only one port makes it impossible to
perform any output once the bit has been set. Input to the IOCR is only through
the bus.
The SP contains the current stack pointer. This 2-bit register has two sets of
inputs. The first comes from the bus and is used to load a new stack pointer. The
second comes from the CU and is used as an offset from the current stack pointer
An Extensible, ScalableMicroprocessorArchitecture 63
value. A dedicated adder adds the current value to the incoming value and
passes it to the DS. This allows operations like GET to access any part of the
stack. This offset value can also be independently stored in the register; this is
used to perform the ADJ instruction.
All of the registers' outputs are connected to the bus. Enable lines coming into
the CRB select the register to pass to the bus, as well ass the register to be
affected by the LATCH signal, which stores the data coming into the CRB in the
appropriate register.
3.2.8 Control Unit (CU)
The CU consists of an Instruction Register (IR), a clock phase generator, and
decoding and control signal generation logic.
When the processor is idle, that is, it is not executing an instruction or loading
data, it waits for input at the port, which is signaled by the Dav signal from the
IOU. Upon receiving this signal, the execution cycle is initiated by starting the
clock phase generator on the next external clock cycle. By not keeping the clock
phase generator running (and thereby executing no-operation cycles when there
is not data available), the processor is better able to respond to asynchronous
input (it only needs towait until the next clock cycle rather than the next processor
An Extensible, ScalableMicroprocessorArchitecture 64
cycle). A complete processor cycle is four clocks long. The phase generator provides
eight overlapped phases. Even-numbered phases (0,2,4,6) are setup and hold
phases which last for one cycle. During this time, the next event is setup internally
(i.e. data is routed and allowed to become stable). The odd phases occur at the
midpoint of each even phase and are the active phases. For these, the rising edge
of the phase is used to clock data into the next stage of the operation. When the
cycle completes, a test is made to determinewhether more data is already available.
If it is, the next cycle is immediately begun. Otherwise, the processor becomes
idle. Diagram 3.6 shows the timing of the clock phases.
EXTCLK
PHIO
PHI1
PHI2
PHI3
PHI4
PHI5
PHI6
PHI7
Diagram 3.6 - Clock Phase Timing
If an instruction is to be executed (this is indicated by the Inst signal from the
IOU), the instruction is latched into the IR phase 1. The control signal generation
logic then creates the necessary control signals for the operation through an AND
- OR type array. Signals are gated against the appropriate clock phase before
distribution to the other components. A complete table of the signals generated
and the phases inwhich they are generated is given in Table 3.2.
An Extensible, ScalableMicroprocessor Architecture 65
oO ~ 6; o o ac p 6;c O W
. .1 . . j . J. . .1 . .1 .
a -. - - -.7- a -- _. a >^ * a
;.:;. :: !V. .v.
<
a
LO
676 6 6 6 6 6 6 66 6 6c .6 6 ir. .6 .T: ir. 6 6 TT. 6 .6 vS 6. v. 6
V. .'.'. ^V '.'.*.
a
LO
T>
ra
o
_i
: 7 .
.
1 1
7
-
:-- 7 '-:.-. >
+
CL
C/l
CM fM CM "0 CM CM r\j cm (M CM ro cm CM CM CM ;
.
:*:-: :
n1
'
:;::::v G:: cm :G G:
_
u
_
c/)
Q
Is. f^ r*. s. r^ Is. rs. is. ts. 1^ N n. r- Is- fv. ^ 5SS r- N f^ : :'"-G^AI,-
ra -
4-i -
_:
_;
O :
61 II :
->:-: :-:-:: :
G
: : :
s n. n.
o
ra
a
M rvj <M M rvj CM M CM M C\J CM M CM CM CM CM CM CM CM r^j :.:": "- <\J OJ (M fNJ (NJ
UJ
en
ro
_l
i
- r^
n LO
s. |s- s. f- 1*- 1s. N.
rs.
o . io in
LO lo :7;.
LD Ln ss; uo sjj -O (s_
U
CJ
ra,
LU
to _ co co to <D CO CO CO CO cO CO to tpij
: : 111
CL C
to :-
ra -:-
c -:
lu ::
5 * t : f :i :
;v
^ fi *t" "t St" Tj" -. ^- *t :.;: ^- :''::; tt :-.
an ;:-
co ::
ra ->
_ ::
::: ill 111 :-: ::-::': " G
':*" : cj cd ;"'::
: -
yy-.r. ''.
G|ll
t_ V
_ 5
O :>
ra
61-.G
il f 1 ill 11
HI|
f66:i|t
:; Sv: :-:7 cm _ 77 11lllil
lu >: :
ovi
0)
q:
d j:
LO
G :vS 7 1111 illIB o.J : . CM CM:-~:v 6G G1 |i; 1 1
7j
00 :G> 5|| 16
v vvv G :G: :S
1111 CD 7 ;
_ :::::
"v. ::
< ::
a3 -
00 ;
?s:7G
11 :
G
G 111 : _ -7: LD tt
: : to
t/j '':
w :::
q :-:-:
Q.
1 II
:S
;;ll II 1
IX CD LD CD CD CD CD CX
Q
ra
_J
ro ro c ro ro er ro
a"
ro ro
r<-
ro ro ro ro ro ro ro ro ro ro tr m ro ro m ro
O
Q
jC
ro
_J
O
2
i
<
1% CJ_
O
3- U
_i _
_i c_
CO CO
5
CO
< -
_ _i
J) CO
r_
or
CO 3 Q 00< < _
00 LO
00 _
CL
^ o
00 -r
3 h-
< s
u a.
r; uj > O lo
| o5 < oo
g
'M
TO
i_
<_
C
(1)
CD
"ci
c
D)
o
o
(NJ
h-
An Extensible, ScalableMicroprocessorArchitecture 66
The standard processor cycle is as follows:
Phase 0 (1) : Latch TOS to DO Register
Phase 2 (3) : Acknowledge data (Dack), latch second operand to Dl
Phase 4 (5) : Adjust stack pointer as necessary to store result
Phase 6 (7) : Store result
All ALU instructions follow this pattern. Because the ALU is a combinational
unit, as soon as the second operand is clocked in on phase 3, the computation can
begin. The result is routed back to the DS and stored on phase 7, providing two
cycles for the calculation.
Control instructions function similarly, except that the second operand is either
read from the CRB (any of the push operations), or the first operand is written to
the CRB (any of the set operations).
The SWAP instruction uses the SP+1 signal to both obtain its second operand
and to store the first. The first operand is stored back to SP+1 on phase 5, while
the second is stored at SP on phase 7. This is the only operation in which two
results are written in one cycle.
An Extensible, ScalableMicroprocessorArchitecture 67
There are several special cases. When there is no instruction, but rather data
arriving at the port, a READ cycle is simulated. Unlike a normal READ cycle,
phases 2 and 3 are skipped by sending the SKIP2 signal to the phase generator.
This has the effect of keeping the Dack signal from becoming asserted and clearing
the input register of the IOU. Instead, the processor moves on and latches the
data on phase 7, and then asserts Dack. This also allows data loading cycles to be
executedmore quickly and efficiently.
The READ and WRIT cycles are normally initiated by those instructions, and the
Dack signal is sent on phase 2, clearing the input register. In the case of the READ
instruction, data needs to be present by phase 7 so that it can be stored in the
stack. If data is not available, the processor cycle is frozen in phase 6 by asserting
the Hold6 signal to the phase generator. This signal is cleared when Dav is
asserted by the IOU. Similarly,when thewrit instruction is executed, the processor
expects the output port to be free on phase 7. If it is not, the Hold6 mechanism is
used to wait until the port becomes clear. Note that port will only be busy if data
placed there by a previous WRIT instruction was not handshaked out by an
external device.
An Extensible, ScalableMicroprocessorArchitecture 68
3.2.9 Additional Design Notes
All of the additional top-level logic is used for routing data. Several main
multiplexers are used in the data path. Going into the DS is the inputmultiplexer
which selects between the Y bus and the IOU input bus (when Selln is asserted).
The operand multiplexer selects the source of the operands going to the DO and
Dl registers from either the DS or the CRB (when SelReg is asserted). The Y bus
multiplexer selects between results coming from the ALU or data coming directly
from DO or Dl (when Pass is asserted). The source of the passed data is normally
Dl, unless SelAB is asserted, inwhich case the source is the DO register.
3.2.10 Design Testing
The design was initially entered in LogicWorks, a Macintosh-based schematic
capture/logic simulator. Generic parts were used to verify the logic of the design.
This version, IXAipl08a, was tested at themodule level.
This design was then transferred to the Mentor Graphics version 7 tools and
modified to take advantage of the Actel libraries. This process resulted in Revision
B of the processor design.
Prior to programming the FPGA, extensive testing of the circuit model was
performed using the design tools. Initially, each module was tested by hand in
An Extensible, ScalableMicroprocessorArchitecture 69
QuickSim using the default delays to verify the logic design and schematic entry.
A few bugs were caught at this point and corrected. The most critical test (and
the most complex) was the test for the CU; every instruction was loaded into the
instruction register and a complete cycle executed to ensure that the proper
signals were being generated at the proper times.
Once the top-level design was completed, each instruction was again tested, this
time against data loaded into the stack. No formal test program was run yet,
because there was some concern as to whether or not the design was too large to
place and route on the chip. A place-and-route was run at this stage,with positive
results (approximately 74% utilization).
After routing, it was possible to back-annotate the design file with delays more
accurate to the actual layout. A test simulation of the back-annotated file was not
particularly encouraging, as the processor locked-up after a few instructions. The
problem was traced to the point where the external, asynchronous inputs are
synchronizedwith the external clock used to generate the processor's clock phases.
Occasionally, if the incoming data were too close to one edge of the external
clock, a setup problem occurred. This was corrected by adding a buffer stage to
the cycle timing, the result of which was to make the processor cycle one clock
An Extensible, ScalableMicroprocessorArchitecture 70
longer. In a VLSI implementation, this problem could be eliminated by making
the system truly asynchronous using an on-chip oscillator triggered by the incoming
data.
With the cycle timing reworked, a second place-and-route was performed (leading
to Revision C), this timewith successful back-annotated simulations. The standard
Level 0 testwas run,withmostly successful results. Onemajor problem uncovered
at this time affected several instructions and was timing-related. In order to
reduce the size of the design, transparent latches were used in several places.
Certain timing situations caused data sent to these latches to be improperly stored
if the data changed prior to the end of the latch signal (note that the latch signals
were originally intended to be edge-triggering, not level-sensitive). This problem
was solved by replacing those latches with true, edge-triggered registers. Again,
a place-and-route was performed and, although the FPGA resources utilization
was 10% higher (due to the use of edge-triggering devices), the design was still
routable. Further simulations met expectations; results for the Level 0 test program
are provided in Appendix G. The final version, IXAipl08d was then prepared for
programming into the FPGA chip. The schematics used to program the chip are
shown inAppendix F.
An Extensible, ScalableMicroprocessorArchitecture 71
3.2.11 FPGA Test Bench
To test the FPGA implementation, a simple board with connections to the proper
I/O's was built. Since there is no need to add additional memory or support
chips, very little wiring and time was required to get the processor working. The
pin placement information generated by the development system (see Appendix
H) was used to wire the processor socket to the I/O sockets. Diagram 3.7 shows
the pin placement in the 68-pin PLCC chip.
sws
o
o
17
II
10
GND
GND
IS
RESET
13
OHo
OHI
vcc
CLK
Vpp
10
11
12
13
14
15-1
16
17
IB
19 cr
20
21
22
23 t_
24
25
26
IHi 07IHOI2 I5> 14 16 |
~
06050008 02
987654321 68 6766 6564 6362 61
nnnnnnnnnnnnnnnnn
/
(TOP VIEW)
uuuu IJ U IJ LI U U LI U U
60
59
58
57
56
55
54
53
52
51
50
49
48
47
46
ZD 45
44
04
PRBOfl/Q
PRA or I/O
DCLK OR I/O
SDI or I/O
Vcc
MODE
01
CLKofl/O 03
swz
swv
GND
swc
SWN
2728 293031 323334 35 36 3738 394041 42 43
Q
z
o
Diagram 3.7 - Pin Placement
An Extensible, ScalableMicroprocessorArchitecture 72
To provide the necessary signals and output indicators, two standard switch/lamp
boards were attached to the processor board through ribbon cables. A basic
interconnection diagram is provided below (Diagram 3.8).
IXAipl 08d
Processor Board
_* Status Word
IPReset
OHo
OHi
Switch/Lamp
Board 2_^
_- IHo
IHi
Port 0 Out
Port 0 In
Switch/Lamp
Board 1
Diagram 3.8 - Processor/Switch Board Test Bench
A second test bench was also build to demonstrate the ease with which the
processor can be interfaced with other devices. An MC68008 board was connected
as shown in Diagram 3.9, and a simple software program (listed in Appendix I)
was written to feed instructions to the processor and store results. Little time was
spend on the system, although it could be easily expanded to provide a basis for
amore powerful program controller and test environment.
An Extensible, Scalable MicroprocessorArchitecture 73
Port A
Port B(0)
PortC
Port B(1)
MC68008
Board _
Port B(3:7)
H2, H4
H1.H3
Port B (2)
Port 0 in (0:7)
Port 0 in (8)
Port 0 out (0:7)
Port 0 out (8)
IXAip108
Status Word
IHi, OHi
IHo, OHo
IPReset
_
-#
_
-^
Diagram 3.9 - Processor/MC68008 Test Bench
The time spent debugging the design with the design tools proved worthwhile
when the processor was finally programmed into the FPGA chip; the processor
worked 100% without any further modification. The system was tested up to 4
MHz (the limit of the available clock generator) at the high-end, and as slow as
hand-clocking would allow at the low end, demonstrating the asynchronous
capabilities of the architecture.
3.3.0 General Implementation Notes
The FPGA implementation performed here was simple but provided many insights
into designing for the architecture. This section discusses a few of these ideas
which could be applied to future designs.
An Extensible, ScalableMicroprocessorArchitecture 74
The FPGA's requirement that multiplexers be used to implement internal buses
necessarily limits the size of the memory which can be built into the processor.
Additionally, it limits the rate at which the memory can be accessed. It would be
muchmore efficient to acquire both operands from the stack in one cycle instead
of two. Also, to support the ability to load multiple data items (and execute an
instruction against them) in one processor cycle requires a more efficient internal
bus.
Along these same lines, the ALU should be implemented with the faster logic
such as a carry-look ahead adder. Since the processor's other circuitry requirements
are minimal (in terms of complexity), a fastmultiplier for Level 2 implementations
could be used instead of one which performs the operation in less hardware, but
more time.
Another problem facing larger implementations is the number of pins necessary
to support up to four ports with largeword-sizes. This is evenmore of a problem
if the ports are physically separated to improve performance. The requirements
for different scales of the architecture are listed in Table 3.3. Note that this table
does not optimize for unnecessary status word pins (as was done with the FPGA
design), and does not include power and ground pins (which will vary according
to the requirements of the design). With larger implementations, trade-offs will
probably bemade necessary by pin limitations.
An Extensible, ScalableMicroprocessorArchitecture 75
Word Size Loqical Ports Phvsical Ports Interrupts # of Pins
8 1 2 0 33
8 2 2 0 33
8 2 4 0 55
8 4 4 2 59
16 2 7 2' 2 53
-7JM6 2 4 2 91 -
16 4 U-4 4 95
16 4 8 4 171
32 2 2 4 89
32 2 4 4 159
32 4 4 4 159
32 4 8 4 299
Table 3.3 - Pin Requirements for Various Processor Scales
As mentioned above, the timing cycle may be shortened by combining IXAipl08's
two operand fetch cycles into one clock cycle. However, the minimum number of
unpipelined cycles is probably three: operand fetch/instruction decode, execute,
result store. On-chip clockmultiplying technology found in recent microprocessors
could be used to generate high internal performance. The completely asynchronous
interface demonstrated so clearly with this implementation allows the processor
internals to be truly independent from the external systems. It may even be the
case that the internal system runs fast enough that it appears to support multiple
data items per cycle handling, while it really does not, simplifying the design.
Pipelines and superscalar designs are a common RISC (and CISC) approach to
improving performance. As discussed above, both of these are difficult to
implement in a stack machine because of the inherent data dependencies. Some
pipelining could be accomplished by folding the result storage cycle with the
An Extensible, Scalable MicroprocessorArchitecture 76
operand fetch cycle, reducing the required number of cycles per instruction
effectively to two (the theoretical minimum for a stack machine [5, 6.2.3.1]). This
approach would also not suffer the problems associated with branches, because
the instructions themselves would not be pipelined. If the processor
implementation supports a floating-point extended instruction set, integer and
floating-point instructions could be handled simultaneously, as in superscalar
designs.
Another design optimizationwhich should be investigated is a common technique
used in procedural-language compilers called combining and deferring stack
adjusts. This technique reduces pushing and popping of data from the stack
when it is known in advance that the data will be overwritten or used immediately
by the next operation (as discussed with pipelining above). At the end of a
period of predictable transactions against the stack, the correct results are placed
on the stack where they would have normally ended-up, and the stack pointer is
properly adjusted. This is already done to some extent by IXAipl08 in that the
operands to an operation are not really popped off the stack and the result
pushed. Instead, the stack pointer is simply adjusted and the data written back to
the stack. This only occurs within a single instruction; the suggestion here is that
the technique could be applied across several operations.
A final consideration which impacts possible uses for the architecture is power
An Extensible, ScalableMicroprocessorArchitecture 77
consumption. Since the processor is completely idle when there is no activity at
the ports, it uses almost no power, automatically. No additional hardware is
required to monitor power usage as is commonly used in notebook computers to
extend battery life. Calculated power consumption for IXAipl08 is plotted in
Diagram 3.10.
800
700
5 600
Isoo
| 400
in
_:
cS 300
_.
_
o 200
Q.
100
_
:
:
:
:
\
'-
'-
25 0 5 1 > i\ 8
Frequency (MHz)
Diagram 3.10 - Dynamic Power Consumption
This result is based on the formula [12, p. 2-9]:
Power (mW) = (0.20N x fl) + (0.80P x f3)
Where N is the number of logic modules used, f1 is the average module switching
An Extensible, ScalableMicroprocessorArchitecture 78
rate (in MHz), P is the number of I/O's with a 50pF load, and f3 is the I/O
average I/O switching rate. Taking N = 460, P = 17 (the outputs), f3 = 1/5 fl
(I/O's switch once per cycle), the power consumption at the nominal 4MHz
speed is estimated at 400mW. This is, of course, only if the processor is kept
active. If it is not, then these results can be scaled by the percentage of active
cycles.
An Extensible, ScalableMicroprocessorArchitecture 79
4 Discussion
4.0.0 Overview
Part II provided some discussion of IXA relative to other computer architectures
as they related to the design process. This part builds on that discussion by
comparing many of the major features of IXA with other modern architectures.
Possible applications are also discussed. Possible directions for further research
and development of the architecture are also given.
4.1.0 IXA & RISC
The RISC philosophy reduces the complexity of a processor (and improves its
performance) by applying several design tenets [11, 8.1.2]:
Use a load/store approach to limit memory access
Require that all instructions execute in one cycle (optimally). Instructions
which exceed this should only be included if they are useful enough to
offset the performance loss and increased complexity they require.
Encode instructions horizontally to reduce decoding.
Use caches, pipelining and super-scalar designs to improve performance.
Use large register files for local variable storage and parameter passing.
An Extensible, ScalableMicroprocessorArchitecture 80
Memory access is left entirely to the implementation. Instead, a high-speed, basic
external interface is used resulting in very high I/O performance. It is not possible
to pipeline the instruction execution mechanism except in rare cases when there
is no contention for the data at the TOS. By introducing some of the performance
optimizations discussed in section 3.3.0, the cycle time can be reduced to two
clocks per cycle. Since the processor can function at the limit of the technology
internally, this is not much of a limitation.
There is verly little horizontal encoding, mainly since there is no register-based
addressing scheme. The width of an instruction is one byte, one-quarter the
standard width of a RISC instruction. This leads to far more efficient use of
memory and simpler interconnection schemes.
This is not to say that IXA is superior to RISC. On the contrary, IXA is not well
suited to operate in the RISC stronghold area of high-performance workstations.
This is because RISC is optimized for an operating system environment and the
types of applications and hardware found there.
An Extensible, ScalableMicroprocessorArchitecture 81
4.2.0 IXA & StackMachines
Many other stack machine architectures have been done in the past, so IXA is not
revolutionary in this respect. However, several elements of the architecture are
unique to stackmachine design and bear some discussion.
IXA supports true zero-operand addressing. The stack is the implicit destination
of data items. Some other stack-based systems allow for more than one stack or
several user-registers usually to improve performance. Doing this requires some
form of addressing to direct the data to the appropriate location, a departure
from one of the stack's strongest features.
The use of a stack for storing and executing instructions is not found in any other
design. In IXA, this is a result of the 0-operand load mechanism and a need to
boost performance over that which can be obtained by relying solely upon an
external program controller to feed instructions and data, and process program
branches. A similar idea regarding the use of a stack to hold code (but for safe
self-modifying code) is discussed inKoopman [5, 9.5.2].
Conditional subroutine entrance and exit is another feature not often found in
other processors. This, combinedwith the use of an instruction stack, is of particular
interest on a stack machine because it allows for zero-cost conditional clauses
(such as IF and CASE statements) found in high-level languages. This is also
An Extensible, Scalable Microprocessor Architecture 82
based on an idea suggested in Koopman [5, 9.5.1] where it is noted that such a
structure can be efficiently executed through the use of conditional subroutine
returns. In IXA, the body of the IF clause can be stored on the IS and conditionally
entered (the initial IF), or exitted.
4.2.1 IXA and the Transputer
Of all other architectures, the Inmos Transputer is most related to IXA and most
heavily influenced the formation of the architecture^]. The Transputer family
was designed as a building-block component for parallel processing systems,
although the processors are more than capable of performing in uniprocessor
systems.
Much of the power of the Transputer is found in its four links which are serial
data ports in and out of the processor, allowing interconnection to other processors
or subsystems. Although the links run at a very high speed (up to 20MHz), their
serial nature limits their performance. To some extent this situation is a result of
pin limitations (the processor is a 32-bit system). IXA overcomes this by eliminating
the pins required for the memory/data interface and reducing the I/O port
handshaking pins to a minimum. Unlike IXA, the Transputer also has a standard
memory system with address and data buses, and executes a standard fetch cycle
(although it is possible to pass instructions over the links).
An Extensible, Scalable MicroprocessorArchitecture 83
The Transputer is also a stack-based machine, however, its evaluation stack is
much smaller; it is fixed at three elements. It is used primarily as registers for the
evaluation of operations and not as a storage space for data as in IXA. To provide
high-speed data and program storage, an on-chip memory is used. This is accessed
through a workspace pointer which allows it to act as a stack.
Instructions for the Transputer are not of a fixed length. Instead, encodings are
provided so that the most commonly used instructions can be stored in an 8-bit
field and executed immediately. The processor contains a shift register which
allows larger instructions and data to be constructed frommultiple smaller words
in a sequential manner. This may seem to cause a performance problem, but
most instructions executed canbe encoded in a single byte, providing fast execution
and requiring little memory for program storage.
4.3.0 Applications
No architecture can be created in a vacuum. If there is no need for it, it will not
survive beyond being a research endeavor. The development of IXA was driven
by a set of design parameters which can be seen emerging in several areas of the
computer industry. This section discusses some of these areas and how IXA
might be applied to them.
An Extensible, ScalableMicroprocessor Architecture 84
4.3.1 UniprocessorApplications
IXA's simplicity and ease of integrationmake it ideal for applications requiring a
single microprocessor to carry out standard computing tasks without being bound
to the standard system model.
One such application area is in embedded control. This area has long been a
strong market for stack-based designs because of their simplicity and small size,
traits which IXA exhibits. The architecture's asynchronous and interrupt handling
capabilities also make it well-suited for systems which must deal with irregular
programmed operations.
IXA will probably never fare well in the desktop workstation market since it is
not ideal for runningmultitasking,multiuser operating systems. It could, however,
find a niche as a form of coprocessor. Many recent machines use smaller, simpler
processors to handle I/O tasks (which IXA does very well) so that the main
processor's resources can be expended on running the operating system.
Similarly, the architecture would probably not fit well in the notebook market.
However, it does fit the needs of smaller, portable computing devices like the
recently introduced Personal Digital Assistants (PDA's). These small devices
perform tasks such as handwriting recognition and data communications, but do
not need to support a full operating system. Currently, RISC processors are used
An Extensible, ScalableMicroprocessorArchitecture 85
in these designs, although much of the work is really done by specialized
Application-Specific Integrated Circuits (ASIC's). An excellent example is the
Apple Newton, which uses an Advanced RISC Machines (ARM) 610 RISC
processor. Most of its control functions, however, are provided by an ASIC which
is a more complex and larger than the processor [2, p. 105]. One note of particular
interest is that the ASIC handles compression and decompression of data going
between the processor and memory, a functionwhich could be built into amemory
interface in an IXA system. Another processor used in such machines is the
AT&T Hobbit, which, although it is a RISC design, contains an on-chip stack for
executing C-language code efficiently [9]. The direction of technology in the field
is toward using simple processor cores which then have a variety of additional
functions built into the chip. This is exactlywhat IXA accomplishes.
4.3.2 Multiprocessor Applications
Another area of intense research is in multiprocessor systems. The Inmos
Transputer has become one of the premier multiprocessing microprocessors, and
IXA's close relationship to that architecture should make it an excellent candidate
for similar applications.
IXA is best suited for use in asynchronous, self-timed array applications such as
wave front processors [3]. In such an application, an array of IXA processors
An Extensible, ScalableMicroprocessorArchitecture 86
could be interconnected and each programmed independently with a particular
function to carry out against data passing through the array. No program controller
is necessary. Instead, simple data passing units are required to feed data to the
arraywith no programmed control.
Alternately, the architecture could be put to use inmachines executing a common
instruction stream against multiple data sets, commonly referred to a Single-
Instruction, Multiple-Data (SIMD) machines. In this arrangement, only a single
program controller is required to synchronize the entire array.
4.4.0 Issues for Further Research
Most of the effortmade in this workwas toward the development of the architecture.
When the amount of time required to create the two implementation models is
considered, very little time was left to do any but the most rudimentary testing.
The testing which was done was aimed primarily at validating the designs and
some of the key components of the architecture. However, little was done to see
how well the architecture performs in real-world situations. The discussion above
would tend to indicate that it should perform at least comparably to current
designs, and, in some cases, out-perform those designs. The main goal of any
future work done with this architecture should be to determine how well it
would perform, and for which problems it is best suited.
An Extensible, ScalableMicroprocessor Architecture 87
There are several possible branches such research could take. First, the VHDL
model developed here could be used as the basis for a more powerful test bench
capable of showing how the processor could be used alone orwith other processors.
Additional program controller models could be developed to solve various
problems.
Since the program controller is the center of an IXA system, its design and efficiency
is critical to overall system performance. Various designs could be evaluated and
a designmethodology developed to help in the development of complete systems.
This could also be tested using VHDL models.
The extensibility of the architecture is one of its key features. Whether or not this
is a useful feature, if it is too much or too little, and how it can be used effectively
should be researched.
Another direction future research could take would be to investigate what
technology may be best used to implement IXA processors. Issues such as
fabrication technology, logic designmethodology, and scale require furtherwork.
Along the same lines is the question of developing a VLSI cell which could be
used as the core to larger systems. The FPGA approach should not be neglected;
An Extensible, ScalableMicroprocessorArchitecture 88
experimentation with larger FPGA's, or FPGA's with different attributes could
provide more information on the possibilities of low-end production of IXA
processors.
Finally, some time needs to be spent considering the programmability of the
processor. How well can current high-level languages be compiled to run on the
architecture? Of particular interestmay be the comparison of C, a language which
makes heavy use of stacks, Forth, a stack-based language, and occam, a parallel
processing language, as they apply to IXA.
An Extensible, ScalableMicroprocessorArchitecture 89
5 Conclusions
The architecture presented here is designed to provide basic computing services
to a larger, more complex, and often application-specific system. It accomplishes
this by taking the approach started with the RISC movement of reducing the
complexity of the instruction set (and thereby placing the burden ofmore complex
software development on the compiler) one step further to reducing the complexity
of the hardware supporting the core computing functions. Doing so provides the
system implementer with a basic interface which can be developed as necessary
into a complete system.
The architecture is also extensible and scalable, allowing the system implementer
to easily define new features for a specific application while maintaining a level
of software compatibility with other designs using the architecture. The ability to
implement the architecture at various levels of definition and scale allows for
fabrication in a wide variety of technologies, an important factor in cost-sensitive
applications.
This work has defined this architecture as an experiment. The implementations
performed and discussion provided were demonstrative of the architecture's
potential. Further research fabrication, programming and applications for the
architecture would help to develop this potential.
An Extensible, ScalableMicroprocessor Architecture 90
References
[1] Bhasker, Jayaram. A VHDL Primer. New Jersey: Prentice-Hall, Inc., 1992.
[2] Bortman, Henry. "The Newton Generation,"MacUser, October 1993, 102 -
108.
[3] DeCegama, Angel L. The Technology of Parallel Processing. New Jersey:
Prentice-Hall, Inc., 1989.
[4] Graham, Ian and King, Tim. The TransputerHandbook. Cambridge: Prentice-
Hall International (UK) Ltd., 1990.
[5] Koopman, Philip J. Jr. Stack Computers : The New Wave. Chichester: Ellis
Horwood Limited, 1989.
[6] Motorola, Inc. MC68000 8-116-132-BitMicroprocessors Programmer's Reference
Manual. New Jersey: Prentice-Hall, Inc., 1989.
[7] Motorola, Inc. Technical Summary: PowerPC 601 RISC Microprocessor.
Phoenix: Motorola Literature Distribution, 1993.
An Extensible, ScalableMicroprocessor Architecture gj
[8] Myers,Genford J. and Budde, David L. The 80960MicroprocessorArchitecture.
New York: JohnWiley & Sons, Inc., 1988.
[9] Pountain, Dick. "PDA CPUs: New Form Demands New Functions," Byte,
October 1993, 80-81.
[10] Preparata, Franco P. Introduction to Computer Engineering. New York: Harper
& Row, Publishers, Inc., 1985.
[11] Tanenbaum, Andrew S. Structured Computer Organization, Third Edition.
New Jersey: Prentice-Hall, Inc., 1990.
[12] Texas Instruments. Field Programmable GateArray DataManual. Dallas: Texas
Instruments Incorporated, 1993.
An Extensible, ScalableMicroprocessor Architecture 92
Appendix A - Architectural Definition
This appendix contains a stand-alone definition for the architecture.
Definition for the
Implementation Extensible
Architecture
A.1.0 Introduction
The Implementation Extensible Architecture (IXA) is a specification for a
computer system inwhich the basic design philosophy is not only to reduce
the instruction set (leaving much of the programming complexity to the
compiler), but also to minimize the hardware (leaving the much of the
design complexity to the systems implementer). The architecture defines
the programming model, instruction set and I/O protocols for the system;
all other aspects of the machine are implementation dependent.
A.1.1 IXA Overview
The architecture is designed around an extremely reduced instruction set.
This reduction is achieved through the use of a stack machine as the
processor. Two hardware stacks are supported: a Data Stack (DS) and an
Instruction Stack (IS); only the DS is required. The size of the stacks is not
defined and not necessarily the same.
There is no defined memory interface. Instead, the processor has up to
four I/O ports which can be externally interfaced to any type of I/O system.
IXA is most different from other architectures in the way it receives
instructions for execution. Instead of keeping a program counter and
executing a fetch cycle, the processor handles instructions as they arrive at
the I/O ports. The task of feeding instructions to the processor and
interpreting the results is left to an implementation-defined external
controller. A group of instructions can be loaded into the IS for execution,
as well. The processor can be set to execute instructions in either mode.
A large number of the available opcodes have been reserved for
implementation-defined purposes. These instructions may be used to add
functionality to a complete system.
A.2.0 Architecture
IXA takes a multi-layered approach to the architecture. There are three
defined layers:
Implementation ExtensibleArchitecture Definition
Level 0 defines the absolute minimum requirements of the architecture
to provide a useful computing device. In this level of implementation, the
IS is not implemented, a minimal DS (at least two elements required) is
used, only one port is required, and a subset of the instruction set required
to support these functions is implemented. This implementation would be
targetted at at systems implemented in low-speed technology where the
value of an internal IS is negated by the additional hardware required to
support it.
Level 1 defines a system that implements all Level 0 components and
adds support for the IS. One or more ports may be implemented. Some
instructions which require extensive hardware support (or which would
not be of value to the processor due to its limited size) are omitted. This
level would be optimized for medium-speed, stand-alone systems.
Level 2 covers the full IXA instruction set and hardware features. A
Level 2 implementation should contain at least two ports, and the
implementationmethod and technology should provide high-performance.
At each level, there are thre categories of features. Mandated features are
the instructions and hardware necessary for an implementation to meet
the requirements of a level. For levels 0 and 1, Defined features are those
which are defined for higher levels and which can be implemented, but
are not required. Finally, Extensible features are those which are added at
any level to meet implementation-specific needs. These elements are not
defined except in terms of how they relate to the rest of the architecture.
An implementer may choose to partition the extensible layer into proprietary
layers for system design and integration purposes.
This document defines the standards for all three base levels as well as the
Extensible Architecture Interface.
A.2.1 Data Types
Internally, the processor provides support only for a word-sized operand.
The size of a word is processor implementation dependent; the minimum
is eight bits. Other data types may be externally defined and handled or
passed to the processor for processing.
IXA-defined instructions are always eight bits. Data and instructions are
differentiated by the state of an additional bit (the Instruction Bit) which
is appended in the word_size-plus-one bit position. A set Instruction Bit
Implementation Extensible Architecture Definition
indicates an instruction. This bit is not used internally andmaybe discarded.
The I/O ports have the capability of turning this bit on to allow the processor
to output instructions.
A.2.2 Operation of the Data Stack
The Data Stack is a circular buffer which as addressed in a LIFO manner
by the Data Stack Pointer (DSP). Data may be pushed onto the stack from
the I/O ports implicitly or under the control of a program. Data can also
be popped from the Instruction Stack on to the DS.
The minimum size of the DS is two elements. The DS can be no larger than
the number of elements which can be addressed by a word-sized value in
a particular implementation. In general, the DS will either be relatively
small (2 32 elements) supporting only one stack frame, or very large
(128+ elements) supporting multiple, concurrent stack frames. Other than
the ability to directly or relatively set the stack pointer, there is no defined
support for multiple stack frames.
In general, operations take one or two items from the DS and may return a
result to it, all of which is handled implicitly. The DSP can also be moved
relatively or absolutely allowing great flexibility in the use of the stack
space.
The stack pointer is initialized to zero. It points to the itemwhich is currently
at the TOS. When an item is pushed, the pointer is pre-decremented, and
the new item inserted at the new location. For a pop, the pointer is
incremented. The items available to immediate operations are those at the
current location, and the current location plus one.
A.2.3 Operation of the Instruction Stack
The Instruction Stack functions in a manner similar to the DS, except that
it is the implicit destination for instructions arriving at any of the ports
during a LOAD operation. ALU operations cannot act upon its contents,
nor can some stack manipulation operations.
The main purpose of the IS is to store and execute one or more code
segments. Code is loaded into the stack in HFO order (i.e. in the reverse
of the execution order) beginning at the location of the current stack pointer.
The load is terminated with the RESUME instruction. The code can be
executed at any timewith the EXEC instruction.When code is being executed
Implementation ExtensibleArchitecture Definition
from the stack, the processor is in stack-based execution mode. Stack-based
execution ends with the HALT instruction. With the ADJI and SSPI
instructions, jumps, subroutine calls, branches, and returns can all be
simulated.
The instruction stack pointer is initially zero. Operation is as above such
that (a) when code is pushed on to the stack, the pointer pre-decrements
and the code is inserted at the new location, and (b) when the code executed,
the pointer is incremented through the program. When executing an
instruction, the pointer is incremented either one or two positions
(depending on the instruction) immediately after the instruction is read
for processing, but before the instruction is executed. This means that any
changes the instruction makes to the pointer will occur after it has been
incremented.
The IS is not implemented in the Level 0 architecture. This means that all
instructions must come through the I/O port(s), and that an external
controller must handle any conditional changes in execution by observing
the status register.
A.2.4 I/O Ports Operation
IEA allows up to four parallel I/O ports to be incorporated into the
processor; only one is required. The I/O ports are controlled by the
processor's router which is responsible for differentiating incoming data
from instructions and prioritizing the resulting groups for the processor's
internal control systems.
Words can arrive at the ports asynchronously. Each port has word-size
plus one bits and may be implemented with
uni- or bidirectional I/O. If
the implementation is uni-directional, the two physical ports (one for input,
one for output) are mapped to the same logical port. Ports must be numbered
sequentially beginning at zero. Each physical I/O port also has input and
output handshaking signals.
To use an I/O bus, the processor or external system asserts its output
handshake and places its data on the bus. It must then hold the data and
the handshake until receiving an acknowledgment on its input handshake
line, at which time it should isolate itself from the bus and drop its
handshake. Both handshake lines must become unasserted for a period of
time before the bus can be used again. A receiving processor should only
use the initial handshake as a data latch signal with the understanding
that the data may not be stable at the point
it is asserted. Note that the
Implementation ExtensibleArchitecture Definition
protocol specifies no handling of collisions on shared busses in keeping
with the implementation-oriented nature of the architecture. Instead, the
expectationis that if collisions are a possibility, theywill be avoided through
software control or handled through hardware interfacing.
The I/O Control Register (IOCR) affects how the processor handles incoming
instructions and data, and the state of the instruction bits for each port
during output. If the Port Lockout Bit (bits 1, 3, 5, 7 of the IOCR) is set for
a particular port, then instructions and data arriving at thatport are ignored.
During normal mode, this simply disables a port. During stack-based
execution, if the bit is not set and an instruction arrives, an implicit HALT
is executed, followed immediately by the pending instruction. Data arriving
under these conditions is available to the next instruction to execute as if
it were on the top of the DS. EXEC can be used to restart stack-based
execution. This mechanism can be used to perform fast interrupts, although
care should be taken not to modify the DS or IS if it is desirable to resume
stack-based execution.
The Instruction Bit (bits 0, 2, 4, 6 of the IOCR) determines whether the
upper-most bit in the specified I/O port is set during output. This bit can
be set to send instructions to other processors or used with other systems
as an additional signal line.
Data can be read and written under programmed control with the READ
and WRIT operations. The result of a WRIT to a port which has incoming
data pending is undefined. Small implementations may choose to treat it
as an error condition, while larger implementations may use buffering or
queuing of data to deal with the event. If a READ is executed on a port,
and no data is available, the processor stalls until the data becomes available.
This implements a handshaking or rendezvous protocol for parallel
interprocessor communications.
A.2.5 Interrupts
In addition to the ability to interrupt with an instruction as discussed
above, standard interrupt operations are supported. There are four interrupt
levels which may be signalled; the highest, interrupt level 0, is non
maskable. The other levels may be masked by appropriately setting the
interrupt mask bits in the Processor Status Register (PSR, bits 4 and 5). A
given interrupt is not masked if it is greater than or equal to the mask. A
mask of 00 disables all but interrupt 0, while 11 allows all interrupts. Only
the non-maskable, level 0 interrupt is mandated.
Implementation Extensible Architecture Definition
When an interrupt occurs, the processor stops executing a program from
the IS or accepting any pending inputs. The interrupt is acknowledged by
asserting the appropriate LACK signal for the level of the interrupt accepted.
Upon IACK being signalled, all devices should withdraw all pending I/O
requests (including the requesting device, if appropriate). Additionally,
the requesting device should drop its request signal when IACK is asserted.
When all I/O is cleared and the IRQ to be serviced is dropped, the processor
will push the current status word onto the DS, go to Normal mode, and
begin accepting input as normal; IACK will remain asserted. When the
requesting device has completed the interrupt function, it can clear the
interrupt mode with the CLRINT instruction. This simply causes the IACK
signal to be dropped, so that if it is necessary for the pre-interrupt status
to be restored, the requesting device must perform a SSW instruction.
Higher-level interrupts are allowed while the processor is already
interrupted. Each new interrupt performs the same procedure as above,
pushing a new copy of the Status Word on the DS. To disable further
interrupts, the first interrupting processor should set the interrupt level to
00 to lockout all but the NMI. Note that interrupts are non-nestable and
non-reentrant.
A.2.6 Conditional Execution
Several instructions allow for conditional execution. The given condition
(a three-bit code) is matched against the current ALU state flags in the
Status Register. If the condition is true, the instruction is executed.
Otherwise, the equivalent of a no-op is performed.
The condition codes are:
Binary Condition(mnemonic) Boolean
000 On Any (ANY) any
001 On Zero (EQ) Z
010 On Not Zero (NE) Z
011 On Negative (NEG) N
100 On Carry (CY) C
101 On Overflow (OV) V
110 On Greater Than or Equal (GE) N-V + N-V
110 On Less Than or Equal (LE) Z + N-V + N"-V
Implementation Extensible Architecture Definition
A.2.7 Execution Cycle
The system is initially in the reset state in which the stacks are empty, the
stack pointers are set to their reset state, the I/O ports are cleared, the
IOCR is zeroed, and the status register is zeroed. From this point, the
system begins accepting input on its ports.
Words arriving at the ports are prioritized for processing as follows:
1. Instructions arriving at lower-numbered ports have higher priority
over those arriving at higher-numbered ports, as well as over all data.
2. Data arriving at lower-numbered ports have priority over data
arriving at higher-numbered ports.
One instruction (if available) and any number of data words (if available)
are routed to the processor each processor cycle. Since both are
simultaneously available, it is possible to load instructions in parallel with
loading data, or execute instructions on immediately arriving data. It is
the implementer's responsibility to handle concurrency issues.
If the system is in the Normal state, instructions are processed as they
become available to the processor from the router. If no instruction is
available, any incoming data is pushed onto the DS. If an instruction is
executing and data is available to the processor from the router, it appears
to the current instruction as if it were pushed onto the stack already (with
proper precedence being observed). The number of data items which can
be concurrently pushed is defined by the implementation, and may be
critical where concurrency is an issue. When an instruction executes in
normal mode, the system state temporarily moves to the Executing state;
this can be used as an indication of processor activity. Again, an
implementation of the processor may allow superscalar execution of
instructions which do not have stack dependencies which would prevent
proper sequential execution.
When the LOAD instruction is executed, the system moves to the Loading
state. In this mode, all incoming instructions are placed on the IS. This
continues until the RESUME instruction is executed, which returns the
processor to the Normal mode.
If the EXEC instruction is executed, the processor moves to the Executing
mode. In this mode, instructions are
'popped'
off the IS and executed as if
they were arriving from the ports. Execution continues until the HALT
instruction is executed, when the system returns to Normal mode.
Implementation Extensible Architecture Definition
If the system is in Normal mode and there are no pending instructions or
data, it simplywaits until there are. This is different from other architectures
which require the processor to always be doing something, even if it is a
no-op.
The only other state that the system can enter is an error state. If this
condition occurs, the processor completely stops and indicates the error in
the Status Register as 11; external lines may be used to provide error
specification. The only error condition mandated by the architecture is the
illegal instruction error. In general, errors found in other processors do
not occur in this architecture (i.e. memory-related errors).
The number of cycles required by each operation is not specified by the
architecture. The architecture has been designed to optimize certain
operations, such as the concurrent loading of data and instructions.
Processor implementations should strive tominimize time for all operations.
A.3.0 Programmer's Model (Level 2)
Data Stack DO, DTOS
D1
DS Pointer DSP
Port 1/0 IO PO
Regs.
11 P1
12 P2
13 P3
IOCR L3 13 L2 12 L1 11 LO IO
Status Reg. S1 SO M1 MO N c V z
Instruction
Stack
IS Pointer
IO, ITOS
11
ISP
Register Descriptions:
Data Stack & Instruction Stack: The two hardware stacks. The stacks
are circular queues. Overflow is not monitored since, using the Adjust
instructions, it is possible to keep several areas of the stack active at once.
Implementation ExtensibleArchitecture Definition
Stack Pointers: point to TOS. These can be read to the stack with the
PSP and PSPI instructions, and modified relatively with ADJ or absolutely
with SSP. The stack is implemented as a circular memory so that the pointers
roll over and under as necessary. The pointers may be physically only as
large as necessary, but are always viewed by the programmer as word-sized
registers.
Port I/O Registers: Word-plus-one bit registers which hold data as it
is moved in and out of the system. The router handles these directly,
although the programmer can specifically read from and write to any one.
The Instruction Bits are stored in the IOCR (for output). The ports may or
may not be physically present in the form of data latches.
I/O Control Register (IOCR): Stores I/O mode information. The I
bits represent the instruction bits for each of the output ports. The L bits
are the instruction lock out control bits. The IOCR may be read with the
PIO instruction and set with SIO.
Status Register: Lower 4-bits contain the standard ALU status, bits
4-5 hold the current interrupt mask, and bits 6-7 contain the system status.
The status codes are:
00 Normal
01 Executing
10 Loading
11 Error
The interrupt state is indicated by a separate interrupt acknowlegement
signal, as is the level of an accepted interrupt. If a particular error indication
is required, it is also implemented as separate signals.
A.4.0 Instruction Set
The instructions have been broken into five groups; the first two or three
bits of the instruction indicate the group to which it belongs. The groups
are:
Extensible Architecture Group (00)
Arithmetic Group (010)
Control Group (011)
Stack & I/O Group (10)
Implementation Extensible Architecture Definition
Stack Adjust Group (11)
Many instructions have several modes of operation. To differentiate these
modes, one or more letters is affixed to the basic mnemonic. These affixes
are:
-I Apply to the instruction stack
L- Long or large; operand comes from the stack.
-C Constant; maintain the second operand to use as a
constant
The I postfix indicates that the instruction is to act on the I Stack. If there
is no I postfix, and the instruction does not implicitly operate on the I
Stack (such as EXEC), then the instruction operates on the D Stack.
Using the L prefix indicates that the operand for the instruction is to come
from the stack. If this operand is to come from the DS, then it is popped
off the top of stack. If it comes from the IS, then it is interpreted to be the
next word following the instruction. Note that this prefix is not used with
operations which always take an argument from the stack, but rather with
those which can either take an argument from the stack or use information
encoded in the instruction word.
The C postfix is used to indicate the constant mode. In this mode (used
with ALU operations), the second argument to the operation is not popped
from the stack. This allows it to be used repeatedly as a constant to an
operation.
In general, arguments come from the stack(s) or from within the instruction
byte. Whenever possible, data has been encoded in the instruction to reduce
stack access and usage.
Bits in the instruction are numbered from zero starting at the right (the
LSB).
The instruction set presented here contains all of the instructions defined
for the architecture. The minimum architecture level associated with each
instruction is noted in parentheses after the instruction's name. Additional
instructions may be added either within the processor or in an external
processor by using the Extensible Group. Note: the few unused bit patterns
remaining are reserved and may not be used.
Implementation Extensible Architecture Definition 10
Appendix A contains the generic instruction formats. Appendix B contains
several assembler pseudo-instructions which perform standard stack
operations and can be implemented using single IXA instructions.
A.4.1 Extensible Architecture Group (00)
All 64 opcodes prefixed by 00 are reserved for use by external controllers.
The only instruction specified by the architecture for this group is EXTOP:
Name Mnemonic Bit Pattern Comments
Extended EXTOP 00000000 w ;w is word
representing op
EXTOP causes the next word to be interpreted as the instruction. This
allows for 2word-size additional instructions.
A processor which does not use any extended codes should treat all 00
group instructions as NOP instructions.
An implementation which does not support any extended instructions can
either treat 00 group instructions as NOPs or as illegal instructions.
A.4.2 Arithmetic Group (010)
The arithmetic group implements the standard arithmetic and logical
functions. These operations can only be performed on the DS. In many of
these instructions, bit 0 represents constant mode; instructions postfixed
with 'C have this bit set and only drop the TOS (the second element is
unmodified to be used again).
Name Mnemonic Bit Pattern Comments
Not (0) NOT 01000001
Bit-invert the TOS.
And (0) AND 01000010
ANDC 01000011 ;Save DS2
Logical AND of DS1 and DS2.
Implementation Extensible Architecture Definition 1 1
Or (0) OR
ORC
Logical OR of DS1 and DS2.
Xor (0) XOR
XORC
Logical XOR of DS1 and DS2.
01000100
01000101 ;Save DS2
01000110
01000111 ;SaveDS2
SLL 01001000
SRL 01001001
SLA 01001010
SRA 01001011
SLR 01001100
SRR 01001101
Shifts (0) ;Shift-Left-Logical
;Shift-Right-Logical
;Shift-Left-Arith.
;Shift-Right-Arith.
;Shift-Left-Rotate
;Shift-Right-Rotate
Shifts DS1 as indicated. Logical shifts cause zeros to be placed in the
emptied-bits, and one's shifted out to set the C flag. Arithmetic shifting
causes the sign bit (7) to be preserved. Rotational shifting causes the bit
shifted out to fill the emptied bit position. Bit 0 is used as the direction
indicator, bits 1 and 2 indicate that the fill-bit source is zeros (00), the sign
bit (01), or the carry-out (10).
Add (0) ADD
ADDC
01010000
01010001 ;Save DS2
Adds DS1 to DS2.
Subtract (1) SUB
SUBC
01010010
01010011 ;Save DS2
Subtracts DS1 from DS2.
Implementation Extensible Architecture Definition 12
Multiply (2) MUL 01010100
MULC 01010101 ;Save DS2 (to DS3)
Multiplies DS1 by DS2. Only the LSW is returned. The multiplication is a
signed operation.
Divide (2) DIV 01010110
DIVC 01010111 ;SaveDS2
Divides DS2 by DS1, returning the quotient. Overflow occurs if the resulting
quotient would exceed the representable range. An error occurs if the
dividend is zero. The division is a signed, integer operation.
Compare (2) CMP 01011000 ;Fully destructive
CMPI 01011001 ;Constant mode
CMPN 01011010 ;Non-destructive
Compare subtracts DS1 from DS2 and sets the condition flags. CMP pops
both operands, CMPI pops only the TOS, and CMPN leaves the operands
untouched. No result is pushed. In Level 0 and 1 implementations, this
function can be performed using combinations of SUB (or ADD and NOT),
ADJ and GET.
A.4.3 Control Group (011)
The control group contains miscellaneous instructions used to test and
modify various aspects of processor operation.
Name Mnemonic Bit Pattern Comments
Push Status Word (0) PSW 01100000
Pushes a copy of the current status word onto the DS.
Set Status Word (0) SSW 01100001
Sets the status word from the DS. Use to modify ALU settings, set interrupt
mask, or change processor status.
Implementation ExtensibleArchitecture Definition 13
Halt (!) HALTcond OlllOccc ;ccc is the condition
Conditionally stop IS based execution.
Push Stack Pointer (O)PSP 01100010 ;DS pointer
(1) PSPI 01100011 ;IS pointer
Pushes value of selected stack pointer onto DS. Value of DS for PSP is
prior to pushing pointer; value of IS for PSPI is after popping current
instruction. PSPI is not used for a Level 0 implementation
Push IO Mode (0) PIO 01100100
Pushes current IO Mode byte onto DS.
Set IO Mode (0) SIO 01100101
Sets the IO mode from the DS.
Load Instructions (1) LOAD 01100110
Loads instructions from all enabled ports into the IS. An implied PUSH is
performed for each incoming instruction. Load is terminated with the
RESUME instruction.
Resume Normal (1) RESUME 01100111
End a load and resume immediate execution of instructions as they arrive.
Execute from IS (1) EXEC Ollllccc ;ccc is condition
Conditionally begin executing instructions from IS.
Implementation ExtensibleArchitecture Definition 14
No Operation (0) NOP 01101000
Perform no operation this cycle. Processor state is unchanged.
Toggle Trace (1) TTRA 01101001
Toggles the current trace mode state. In stack-based execution, setting
trace mode causes the processor to stop after each instruction. An external
controller/ debugger must then issue an EXEC instruction to perform the
next instruction.
Clear Interrupt (1) CLRINT 01101010
Clears all interrupt acknowledgement lines (IACK), and returns the
processor to Normal mode. The pre-interrupt status word is not
automatically reset, but must be reloaded by the interrupting process.
A.4.4 Stack Manipulation & I/O Group (10)
The StackManipulation group contains instructions to read and write from
the four ports under the control of an instruction (normally port input is
automatic), as well as move data on the stacks and modify the stack pointers.
Name Mnemonic Bit Pattern Comments
Read from Port READ p lOOOOOpp ;pp is the port
Reads a word from the given port to the DS. An implied PUSH is performed.
The processor will wait indefinitely (or until RESET) for the word.
Write to Port (0) WRIT p lOOOOlpp ;pp is the port
(0) WRITC p 10001Opp
(1) WRITI p,w 10001 lpp
Writes a word from the DS (WRIT and WRITC) or IS (WRITI) to the given
port. An implied POP is performed. WRITI is not implemented in Level 0.
The processor will wait indefinitely (or until RESET) for the port's output
queue to accept the word.
Implementation ExtensibleArchitecture Definition 15
PushWord (1)
(1)
PUSHw
PUSHI w
10010000 w
10010001 w
Pushes the next word from the IS onto the DS or from the DS on to the IS.
Retrieve Word (0)
(0)*
GETn
LGET n, src
lOlOnnnn
10110000
;nnnn is offset
;n is offset
Copies the word at the given offset to the TOS of the DS. For LGET, the
offset comes from the DS and is taken to be the offset from the TOS after
the word representing the offset is popped. The assembler must either
assemble a PUSH prior to LGET, or provide another means of getting the
offset on to the DS.
*LGET is not required in any implementation if the depth of the DS is less
than 16 elements.
Swap Words SWAP 10010010
Swaps the top two elements of the DS.
A.4.5 Stack Pointer Adjust Group (11)
There are two instructions (and their variations) in this group. These
instructions directly modify the stack pointers, either relatively (ADJ) or
absolutely (SSP).
Name Mnemonic Bit Pattern Comments
Adjust Stack (0) ADJ cond, off HOOnccc ;ccc is condition,
Pointer ;n+l is offset
(0)* LADJ cond, off HlOOccc n
(1) ADJI cond, off HOlnccc
(1)* LADJI cond, off HllOccc n
Conditionally adjust the stack pointer by the given offset for the indicated
stack. For the long-mode instructions, the offset comes from the DS, and
the adjustment is relative to the TOS after the offset is popped (or, in the
case of ADJI/LADJI, after the instruction is popped). The assembler must
either assemble a PUSH prior to LADJ, or provide another means of getting
the offset on to the DS.
Implementation Extensible Architecture Definition 16
*LADJ and LADJI are only required if the IS is present (LADJI) or it is
necessary to modify the stack pointer by more than two elements and it is
more efficient to do so with a long instruction as opposed to multiple
short instructions.
Set Stack Pointer (0)
(1)
SSP cond, val
SSPI cond, val
lllOlccc
lllllccc
;ccc is condition
Conditionally sets selected stack pointer from the DS. The assembler must
either assemble a PUSH prior to SSP, or provide another means of providing
the offset.
Implementation ExtensibleArchitecture Definition 17
Appendix B - Condition Code Results
This appendix contains a complete listing of the frequencies of various 68000
condition codes used in section 2.5.7. Thesewere determined by lexically scanning
single code resources in ten different Macintosh applications. The applications
scannedwere:
Application Purpose Resource Number
ADExpand DecompressionUtility 6
TrueType Converter Font Translation Utility 2
Spectre Game 7
Sound Tracker Sound GenerationUtility 3
Shufflepuck Cafe Game 5
Expert Color Paint Graphics Application 7
SoftPC DOS Emulation 11
StyleWriter Printer Driver -8192
Think C C Compiler 7
ZTerm Communications 8
A simple text scan was made of each selected resource. Selection of resources
was based primarily on size; extremely large
resources were unscannable and
small ones were of lesser value. No attemptwas made to decode the resources.
en
CO
+j
O
r-
LO
CJ)
CM
CM
C\J
Lf)
v o
o
or 01
CD
ro
en O
cn
rt-
c
0C
o
o
LU
_1
m
TT ( Tt t? -C <M W s> rr
e' LO
*
LO
_
co
O ;7; a XT .V-. a in O CO a er
CM
o
CO
CM
K
_l
CD
? rr t>. 5? .<? rv t-r 00
CM 5
ro
LD
LU
tn
o o *" CM en o a m
ro LO
t
co
rv O w TV .Q .07 VT- .. O CM
CM
O
-j
CO
o a ,* O CM a. ^. "* LP LO
LD
00
2
CO
Q a w .Q -Q O D O. ,o o LO
CD
d
ro
>
co
6 o o d oO o o o o O O
O
d
LO
LO
o
CO
CJ ,Q Q O D. .Q o .*-. a o CM
IN
en
o
o
CQ
CSJ
.<?.
ro TT <?. .Q <? P. .?. CD ro
d
-
LO
-J
CO
*^.' o O. .rr-. Q- OLo. .Q v? o ro
ro
d
*
I
CO
T. <?.>. .Q > <9. -O. *> LO
CXI
d
CM
cfLU
CD
TO.
jOI
CM'
CM ro.
ffi LO
O
CM
o
o
LO
CM
CM
LU
z
CO
o, *?:' w
ro
C*>
CM-
O
CM co
<t. C
1"^
CM
ro
tis
CM
cft
rn
t_-'
rV. in
CM
ro
ro
"
2
CQ
tV
r
ro.
_
_
<
_
_
>
c
0
o
cu
L.
*-
o
_
L.
cu
c
_
o
CO
c_>
o
a
it
3
_C
CO
c
CO
a.
_
o
o
o
t
a
X
UJ oo
53
_
o
c
X
h-
-
Nl
"co
o
UJ
a>
ra
+^
c
cu
o
aj
CL
j^:
c
CO
a:
Appendix C - VHDL Source Code
This appendix contains the source code to the three VHDL programs described
in section 3.1. The first program represents a two-port, Level 2 implementation of
the architecture. The second is a simple program controller for testing the model.
The last program is a test bench connecting the first two programs into a single
unit.
ft
0)
<D JJ
i-H JJ CD CD
-Q cd r-l X
H X! cd
CO 0 H g
C c CO
<D 0) 0
JJ * 0 jj
X .-i ft
w CD
Ti >1
>i
I 1
c 0 a a
0 g cd 0
H
JJ rH M-1 TS
cd cd 0 CD
JJ i-i Ti
a 0 c -r-l
CD -H 0 >
e > -H 0
CD cd JJ u
r-i X CJ ft
ft CD g
g Xi 3 <D
H
cd
M-1 S-I
<d
JJ rH
M CO cd CO
0 <C c fi
ft S-l
CD
0
-H CD
0 u JJ JJ rH
3 0 c cd XI
JJ CO
CO
H JJ
fi
H
CO
* CD CD Q) I-I
CM U
0 JJ
CO
CD
>
rH rH S-i S-l >1
a> 0) ft JJ ft JJ
T5 > C CD H
0 Q) c (D u >
2 .-1 0 ra H
H CD Dl -U
. i cd JJ U c u
d 0 ft H <d
i-i CO 3 CD g
0 , i u S-I H c
r-l 0) JJ Eh H
> 13 ra 0
nf CD 0 c JJ W
j3 U g H C >1
Q) 0 CD 0 cd
m 6 ro g CD Ti H ^H
c cn cd S-I id JJ CD
j H ai M 3 g td TS
Q a rH Dl JJ jj
ffi 0 U fi c rH
> 5 * U (D CD CD cd
Q) 4J ft JJ CD g 0
ft ,C W H X! CD -rl
H 4J 3 CQ .fi rH ra
< JJ Dl H u W ft >i
X cd 3 .fi S-I cd g ,fi
M
1
1
2
i
i
<
I
1
Eh
1
1
c<
1
1
i
i
H
1
1
ft
i
i
JJ
3
ft
C
H
JJ
3
ft
JJ
3
o
JJ
3 o
JJ
3
ft
G
ft
g jj 3 jj
rl o u
o o
ft o a o p. <-h
3
ft
JJ
3
0
JJ
3 rH
ft
fi JJ
rH M
0
ft
JJ JJ
JJ 3 -U 3
3 ft 3 ft
ft -U ft JJ
fi 3 fi 3
H 0 -H 0
JJ -
S-i C
0 -H
ft
CD
- a;
jj cd
3 J3
O en
Ti
JJ -
^J fi
O -r-l
ft
CD
- X
jj cd
JJ
u
o
ft ft ft ft
.fi
CJ CO
CD fi
a; cd
cd ffi
CO I
-
I
G
cd
JJ -
S-l fi
O -H
ft
CD
jj cd
,fi
en o
TJ
C cu
cd X
x rd
I co
I T*
c
cd
O *-H
JJ JJ
en en
CD CD
3 3
D1 D1
CD CU
Sj Sh
JJ JJ
ft ft
3 3
S-i S-i
S-i S-l
CD cd
JJ JJ
C C
H
CD CD
Dl Dl
CD CD JJ
3
ft
JJ
3
O
JJ JJ
a ft
3 3
Sj Sj
S-i S-l
(D CD
JJ JJ
fi fi
TS C
S-l -H
O .-I
o
S-l
jj
c
0
0C oz
h h co u
I I I JJ
I I I CD
en
CD
<_
Pi
W
CJ
w
Eh
2
Eh t^
m m h
pel w W
w co w CO
CO w ro w
UJ H w H
H 2 H 2
X H 2 H
Eh H Eh H Eh M
Eh
O H O H
- Eh
Eh
HPQHPjHpqHpqHH
PQ
Eh
2 D
M O
CQ
Eh
D
o
PQ
Eh
D
o
PJ
Eh
D
o
M Eh Eh
PQ PQ
2 2
o o
rH -rH 0 0 -H -H
-rH O-H 0 O O O O rH rH
O O rH rH -rH O-H 0 -rH 0
ftftftftffiamwmffi
o o
h o
O rH
O rH j*J ^
CX O U CJ
Pi Pi <C C<
H M H H
tH
M
PQ
2
M
Eh
W
CO
H
Pi
ft
ft
H
<
>H
Eh
H
Eh
2
W
a: X
u CJ
cd cd
jj jj
CO CO
M Q
en
4-1 4-1 C
0 O 0
H
CD 0) JJ
N N -rH
H -H fi
CO CO H
H-l
g g CD
3 3 TS
g g
H -H CD
X X t;
cd <d 0
2 2 2
31 -v o
_ CO
II
n II
Pi
pel c_ H
H W O
O O W
W w Eh
Eh Eh 2
2 2 M
H M
rH
a; a: cd
u u g
cd cd Sh
jj jj 0
CO CO 2
M Q CD
X X Xi
cd >d 0
2
Eh Eh Eh
^ < ^
^ Eh Eh
CO CQ CO
2 2 2
O O o
CJ CJ CJ
Pi
w II
CO Pi
pa W
&H o Pi
2 H K
h-t Eh O
2 W
H Eh
2
Dl M
C
H Dl
JJ C
3 H rl
U TS 0
CU rd Sh
X 0 Sh
w J H
CD CD CD
T3 Ti Ti
0 0 0
Eh Eh Eh
Eh Eh Eh
CO CO CO
2
'
o
2
O
ft
cj cj o pj
Q
2
H
ft
x:
ft
o
o
H
>
rd
CD
m
ft
ft
Pi
D
cj
H
Eh
H
K
U
Pi
<
Sh CO
0 H
JJ
U Pi
O
Eh
I O
JJ w
-rl
1
JJ
rl
Xi
I
JJ
J3
>.
PQ
2
Pi
Dl H
H pq
CD Pi
G
rd Pi
W
O CO
JJ w
Eh
rl 2
as h
Dl
<D
JJ
fi -U
H 3
O
Eh
Pi
o
CJ -
PQ Pi
> Pa
l o
Eh pa
H Eh
PQ 2
JJ fi
3 -H
ft
fi
-H JJ
Cd H
> ft
JJ g
CD CU
fi m ta pa
rd cm J iJ
CO
JJ JJ H
H H
FQ CU 2
CM > O
JJ fi H
C 0 tH
H O CJ
2
i i D
I I PL,
PQ PQ
< <
H H
Pi Pi
<c <
> >
2
pa
Eh
D
ft o
o
o
- J
JJ
3 C--
ft
C O
-H Eh
II o
2
JJ H
fi
H -H
ft
g Pi
CD O
JJ ft
jj cd
fi >
H JJ
ft <D
g Sh
CU
JJ
Ph
O
w
PQ
CD
3
rH
rd
>
JJ
(U
Sh
Pa
CO
j
pa
jj
c
H
ft
g
CD
JJ
JJ
C
D
2
pa jj
CU ft
a>
3
rH
td
>
JJ
0)
Sh
2 -
Pi JJ
Q
2
pa oi
D
Eh PQ
pa CM
Q
2
pa
Sh
CU
Dl
CU
JJ
G
H
G
rd
0
JJ
Sh
0
JJ
U
CD
>
2
Pi
Eh
pa
Pi
IIPi
o
Eh
CJ Pi
w pa
I >
JJ
H
-Q
I
CO
JJ
3
ft
C
CO
ta
Eh Eh
H 2
PQ M
CO
G h
H CU
CM >
JJ fi
H 0
PQ O
I I
JJ
C
H
CM
JJ
-H
PQ
2
o
H
Eh
CJ
2
ft
ft
CD
3
rH
id
>
JJ
<D
Sh
pq
ft
PQ
c<
M
Pi
2
pa
ft &H
o
o
J rH
CD
Dl II
G
cd ~
M -H
- J JJ
o 3 3
ft ft
II fi C
-H -rl
2 ftQ)
3
rH
Cd -H
>
JJ Pri
CD O
M ft
O
pa
PQ
CO
CM
CD
3
rH
rd
>
jj
CD
U
CD
3
rH
rd
>
JJ
CU
u
ft
H
Q
2
ft
ft
O
o
ft
Q
2 .
ft Pi
CD
3
^H
id
>
jj
CD
SH
2
Pi
ft
Eh
ft CM
JJ
H
PQ
Q
2
ft
C
o
H
JJ
o
3
Sh
JJ
en
C
-H
fi
rd
pa
ft
o
o
m
2
ft
ft
Eh
pa
ft
g
0 ra ft
Sh -u ft
mh en O
h pq
fi X Eh
0 <D 2
jj fi
-rl 0
Ti -H
fi JJ
0 -H
O Ti
fi
rd
Ti
C
id
en
3
-P
rd
JJ
ra
jj
G
CD
U
U MH
3 -n
0
Ti
CD
JJ
en
CD
3
[jH _-
CD
U C
0
CU -H
ft JJ
JJ -H
JJ Pi
3 ft
ft O
w
a>
c
H
g
Sh
CD
JJ H
CU Eh
CJ Ti CJ
2
I I ft
I I ft
Ti CD
fi -U
0
cj ta
JJ ft
ra pq
<D <
B H
ft
O
2
en
3
JJ
rd
jj
m
co
ft
ft
Pi
2
Pi
ft
Eh
ft
Pi
ft ft
2
H
O
ft
ft
ft
2 ft
ft Pi
ft e^
Eh
2
rH Pi
ft
Eh
h
ft Pi
g
ai
JJ
2
pj
ft w
fi 5
-H
II
ft
2
ft
ft
3
ft
co
ft
<C
ft
2
ft
ft
Eh
ft
ft
w
CO
ft
ft
ft
2
pq
2
ft
ft
Eh
rH 2
Pi
M ft
\ Eh
ft
ft ft
g
<D
JJ
ft
2
ft
ft
IS
ft
CO
J
<
Ph
2
Pi
ft
Eh
w
ft
ft
CO
J
ft
ft
ft
2
ft
h
2 ft
w ft
ft Eh
Eh
2
co ft
ft
II Eh
w
ft Pi
g
cu
jj
ft
2
ft
ft
w
CO
ft
<c
ft
2
ft
ft
Eh
ft
Pi
ft
CO
ft
ft
ft
ft
2
ft
2
ft
ft
ft
o
pa
2 ft
pa ft
ft Eh
Eh
2
* ft
ft
II Eh
ft
ft ft
cu
jj
w
CO
ft
<
ft
2
ft
ft
Eh
pa
ft
ft
H
w
co
ft
w
ft
ft
2
ft
w
2 ft
pa ft
ft Eh
Eh
2
CM Pi
ft
II Eh
ft
ft ft
g
CD
ft
CO
ft
<
ft
2
ft
ft
Eh
w
ft
ft
ft
CO
J
ft
2
ft
ft
3
ft
ft
2
ft
ft
CD
JJ
. o
rH rH
II II
ft ft
g g
cu cu
JJ JJ
Pi Pi
o o
w
ft
Pi
2
ft
ft
ft ft ft
g g ft
CU <D
JJ JJ
o m
il
ft
CO
ft
<
ft
2
ft
ft
Eh
ft
Pi
A
II ft
ft
CO
J
ft
2
ft
ft
3
Pj
ft
2
ft
ft ft
o o
2
ft
ft
Eh
ft ft
g g
cu
JJ
<D
JJ
II
V
CU
JJ
ft
ft Q
rtj
-. ;_
-. CM ft
H CO H Et
ft ft ft
g g
CD CD
JJ JJ
il 2
A ft
D
w
CD Pi
ft
CO
ft
ft
2
ft
ft
Eh
ft
ft
ft
2
pa
ft
3
ft
pa
CO
j
<
Ph
h
co
ft
w
ft
Q ft
2
co ft
2
ft
Pj
ft ft
Eh
O
2
ft
ft
3
ft
c
o
~ -H
ft JJ
CO -H
< Ti
CJ C
o
ft u
2 JJ
ft en
cu
ft
2
ft
o
o
o O
Eh Eh
o o
ft ft
O O
t^ Eh
CJ CJ
ft ft
> >
Eh Eh
H H
ft ft
ft
CJ
o ft
H CO
ft J
< <
2 2
CO O
co co
cd
g
Sh
0
2
CD
Ti
O
o ft .~ ._ - - - - ...
- ft - - o o o o ^ .^
o ~ * o o - - - - ^ -
II ft - - - II - o
Eh O o II II II II ... o -
2 - - II II - -
Eh H Pi o II
M II II En Eh Eh t^ ft - II
PQ Eh t^ H H H H CO
M H pq ft ft pq PQ II EH
CU t^ Eh PQ ft Eh Eh H
Ti H H 2 SH ft
JJ 0 PQ ft H ^ pq
-rl 2 o r-l o rH H
ft jj o rH rd rd >i >C ft
CU fi rH rH JJ JJ en en 0
TS CD o rH H H rd rd 3 3 rH jj CD
0 Sh rd rd rd td ft ft pq PQ <D CO X
2 Sh jj JJ > > JJ JJ JJ JJ > D1 C ft
cu 3 rd rd < r< ft ft 3 3 CD CD l-H ft
CJ CJ ft ft rd rd CD CD ft ft J ft CJ 0
td JJ JJ JJ JJ 0 0 JJ JJ JJ JJ CU rd
Sh ft 3 3 rd rd U u 3 3 C C X JJ
t^ <
2
O
O O ft ft < <c O O H H ft CO
ft ft J ft ft J J ft ft ft ft ft J
< H < <c <C < <C < < < <C < < <
2 CO 2 2 2 2 2 2 2 2 2 2 2 2
CO- O CJ O CO CO O CO CO CO O 0 CJ
in 1 H H H H H H H H M H H H
CO 1 CO CO CO CO CO CO CO CO CO CO CO CO 2
H
CO
ft
m
Eh
ft
CO _
pa o
ft
a,
M il
..
O O rH
rd 2
jj jj ft ft
M cd ft CJ
0 ft Eh o
ft JJ H
ft .
C CD -
0 CJ r-l ft
u -
JJ < ^
3 II
ft - ^_,
JJ o Eh _
3 cd pq rH
0 JJ CO ~ ~ -
cd pa CO CO
Ti ft ft c c rd II
C JJ ft JJ 2
cd 3 M v-l rH ~ td H W
O - - - Ti o ffi .^
JJ ft Pi - o H Eh
3 - Q pa ft o - Dl ft r-l
ft 0 2 Eh Eh - C
C o <, ft ft II H _
H -H < < II V g ft o II
ft Eh - . V 0 V
en pa e^ - - o u ^
3 - CO 2 o o o >1 c II o
0 -H ft H - - rH CO H rH
C o ft > H 3 Eh o H
0 -H PJ II II id ft 0 2 rH rd
Sh ft ft - V V > jj JJ ft -h >
ft H i^ < 3 > rd <
0 w rl 0 td ft Ti ft > cd
C CO CD CO o o JJ JJ c - < jj
>i CO rH ft 0 0 id 3 0 H cd rd
en ft Ti Pi ft ft ft O * ft O JJ ft
rd U G ft ft en ri cd Pn
O rd H H CD ft Q H
en ft ft ft
CD ft ft Q
rH 1 ft 2 I ft 2
Ti
c
rd o 2
1 H ft I H ft
ft -P H
Sh O
i 0 ft
ft PQ
C
ft
0
CD
X
ft
>i
ft
JJ rH
cu u rl
X 0 rd ^^
td ft > Eh
ft <C ft
en G rd 2 CO
Ti 0 JJ pq ft
fi rd ft ft
rd Ti p Eh ft
ft CU
CJ ft
H
JJ rd 2 0 - *
3 r-l ft Sh r-l r-l r-l
ft en ft ft Ti - rd 2
fi ft Eh JJ JJ ft
-H 0
id jj f rd
II Sh
0
rd
ft
ft
CO cd - jj O ft JJ
ft h Ti rH rd rd ft .~-.
0 2 CU 2 - P JJ G 0) -
H ft > ft ~ rd 0 0 rH
Ti ft H ft cd II rn P u -
Eh CU ^ jj jj JJ JJ <
Sh CJ rd O ft ft 3 II
CU - 0) . Q rd cu 01 ft ~
Ti - Sh - JJ JJ CJ CJ JJ rH Eh
fi o rH 3 rd 0 0 3 rd ft
CU - G - O ft < < ~ 0 JJ CO ~ ~
en 0) JJ *' CO rd pa CO CO
ll ft II G 3 jj G Ti P ft fi G
fi 3 0 O rl P C jj ft
CU -rl 0 ~ - ... C S rH rd 3 H r-l rH ^
ft o 0) o - cu ft i<C ^ O - - v
3 -H ft H o ft ft rH 0 ft - JJ ft ft - o
ft td ft - rd s cu ^v ft o 3 ~ p ft ft o -
0) ft ^^ ft ^H X Eh Eh - ft 0 ^ Eh Eh -
X en II ra II ft 2 Ph fi r-l si ft ft II
cd ft T5 ft V Ti .- . v V ft <q II H H < < II V
ft 2 v C [2 ^ C Eh c > V ft Eh , , V
en esq - rd r<!
- o rd 2 o CD pq CO ft Eh - - r-l
Ti o ft o >i ft w rH >1 ft - rH o 3 .. CO 2 CD O r-\ >l
fi - , - en > - CO 3 o - r-l 0 -rl ft ft - - rH CQ
rd l^ jj Eh 3 jj ft 3 rd H G r-l ft > H 3
ft 2 II 3 2 II ft 3 - II CQ Sh JJ II rd 0 rl ft II II rd ft
ft V ft pa V jj ft o V JJ CU rd V > - Sh ft ft - V V > JJ
ft > JJ > 3 JJ rd 3 Ti P < o ft ' H c\-> <: 3
o pa H 3 PJ 0 ft 3 JJ 0 ft C JJ H rd jj 0 ft H 0 rd ft
< - O O - o -U 0 rd o JJ CU ft O JJ Sh c CO 0) CO r-l r-l JJ -U
H 0 0 0 3 ft 0 3 CO 01 0 rd 0 >1 CO rH ft 0 0 rd 3
ft o ft .~ ft o ft O - JJ jj ft O * CJ ft P * ft en ft TS ft ft ft P O
0 -H ft 0 -H ft rl 3 ft ft CJ ft rd CJ C ft
h ft M U ft H G O H CJ <c H CO o rd H
ft
ft
ft * '
Q
H
ft
<
P
CO
ft
ra
0)
ft
ft
ft ^^
i ft 2 1 Ph 2 1 Ph 2 1 Pm 2 CJ r-l 1 ft
1 H ft 1 H ft 1 H ft 1 H ft o
ft
ft
p
2
ft
Ti
c
rd
ft
I
I
rH
JJ
Sh
0
ft
2
H
CO
ft
PQ
1 H
JJ
rl
G
ft
0
0)
X
ft
>1
ft
jj
P
CD
JJ
Sh
rH
rl
Sh
0
< ft
rd
0
ft
td
>
ft
^^ ft r< Ti
- CO G rd 2 Sh
o Ti 0 JJ ft 0
- C
rd Ti
rd
ft
ft
Eh
3
II ft CU
0 ft . ,
en
3
, . JJ td 2 0 jj
ro 3 rH ft Sh rH rd
ft en ft ft Ti - JJ
ft G ft Eh CO
CJ H 0 rd * II
O rd JJ - - rd r-l
H en cd jj rH td
ft
0 2
Sh
CD 2
Ti r-l rd
P
rd
JJ
G
P Sh
Ti
ft
ft
>
H
ft
ft td II co
rd
ft
01
JJ
<
U
Eh 0)
CJ
Eh jj
rd rH
jj
ft
jj
ft
X
0)
. . CD . CD . P rd 0) 0)
_ Ti - M JJ JJ CJ CJ 0
rH C o r-l 3 rd 0 CJ jj
0)
CO
- G
CU
~ O P
JJ
< <
en Sh
td II II ft II G 3 JJ G as
jj 2 C 3 0 O rl a JJ
rd rl pq CD H 0 ~
- * G 2 rH en
Ti r-l ft ... ft rH 01 rH - 0) ft esq * H
-rl Eh 3 H ft H o ft P r-l 0 ft - Di
Dl ft rH ft rd ft - rd ft - CD . ft o 0)
C ^^ - CD ft ' " ft esq X Eh Eh - rl
H _ ft CO II CO II ft 2 ft
g P o II cd P T3 P V Ti . . V ft C II ra
0
CJ
- V ft
en
- G
td <i
-
rH
C
rd
Eh
2
"
rH
G
CU
>
ft
V 3
JJ ft
G II r-l Ti O ft o >1 ft ft rH >l ft - rH r-l rd Ul
rH ^_. r-l fi ^-^ - . - en > - CO 3 r-l - rH JJ
Eh c-l -rl rd tr> JJ Eh 3 JJ ft 3 rd H ra
0 2 rH rd ft 2 II 3 2 II pq 3 - II ft Sh JJ II td W
JJ ft -rl > ft V ft ft V JJ ft r-l V jj 01 rd V > ^ r-{ Ul
> td < ft > JJ > 3 JJ rd 3 T3 P esq rH id ft
Ti H > rd 0 ft rl 3 ft 0 ft 3 JJ 0 ft G jj H rd JJ G CJ
G <: JJ esq - rH O - rH JJ 0 rd rH JJ 0) ft rH JJ Sh Sh O
0 rH rd rd rl 0 0 0 3 P 0 3 co 0) 0 rd 0 CU ft
.^ ft r-l JJ P ... ft r-l ft ~ ft rH ft O ... JJ JJ ft O v CJ ft P X ft JJ ft
Ph ra H td ft 0 H ft 0 rl Ph H 3 ft ft CJ ft fi
H 0)
ft
ft P H Sh
ft
ft H Sh
P
ft H G
H
O H U
<
< H CO
CO
H
P P P P P P pq JJ JJ
2 i ft 2 1 ft 2 I ft 2 1 ft 2 1 ft 2 CJ rd 3
ft I M ft 1 H H I H ft 1 H ft 1 H ft o
ft
ft
p
2
ft
CU O
ft ra
cu 3
ft -P
rd
I JJ
I CO
Pi
o
CD
>
CU
ft
JJ
fi
2
ft
ft
Eh
o>
ft
p
ft .>
CO JJ
' - 3
JJ O
G en
M 3
CM jj
JJ id
-H jj
CQ oo
II CO
V CO
ft
3 CJ
CO o
ft
2 ft
l-H
O p
ft 2
ft ft
^
- - 2
LD ft
>
o ft
Eh
rH
M< o>
ft
Pi H
CO
- 2 -
W
P ft ft
2 Eh o
rH r-i O o
a <y o< a
ft Pi Pi ft
H H H M
O P P .^ P . ^
a
ft ^ ^ rH o
H - _ ,^
^^
. . *~~. . u
fc II Eh II CDen co 2 2 V 2 V rH
jj co ft ft ft Ti
ft ft > > W > D1 C
3 CJ w pq 0) ft cu rd
Sh O - ft ft ft
Sh ft rH O JJ o JJ C
cu ft a o> G a C Pi
jj ft ft M * ft M .^ M
G H H ft M ft
H - - H H CO
M 1 CO
CU CD P P W
rH rH ft 2 ft 2 O
Ti Ti M ft H ft o
C fi ft
cd cd 2 ft
ft ft H
Oi CD p
1 ft ft 2
1 H ft ft
w
o
w
Eh
2
H - ...
Pi =
ra ft Pa o
jj O CO o
ft w o
3 ~ Eh o
Sh ft 2 o
Sh U M o .^
CU rd o . i
JJ JJ ft o .^ rdG CO o = r-l g
S-lH M 1
X II oCJH td ft II 2
o>
Ti
0 2 o2 rd
Dl JJ r- ft 0C o w ft 2
rl H P - o CJ
ra X X tn ft
CO - * o cd 0 i-l n01 o O -2 it) o 2l) ft JJ ... o H
0 II II >h CO o Pi
ft
CJ
ft
Sh < O G Pi II
ft ft Eh 0 - O II
ft Pi ft -h a; Eh fi - , ^Ti ft ft < O JJ CJ CJ Pi 0 o o E-hC o O CJ rd ft ft ft H 2rd pq H CO 3 JJ > ft CJ JJ II II MEh Eh h>i h ffl 1 O Pa CJ0) 2 2 < jj cd in ft ^ 3TS H H ft ft en jj H Eh 2 ^4 ft Pi0 0 ft C id PQ 2 M jj w pq 0)U " id <; h q H en cj CJ Ti
HH
0
jj
CO CO
fi w
H Eh
ft
Eh
0
fi H ft ft JJ 2 2 jj
G
0 XX g JJ g fi H l-H a
rl x U CJ CD r-l CD 0) 010 jj cj cd cd ^ 3 Eh u .. <-i
H ft ft u cd jj jj jj en X S-i Sh
3
CJ
JJ CO CO CO 3 jj co ra H CD r-l 3 o r-l3 CO
0 w
H p U Ul -rl t!
jj rd
ft ft CJ U ft a
CU CJ
x o
ft ft ra jj w fd ft pq ft w w ft ftP p c n j a ft ft J ft ft J jCD pi ft cq h P pq pq ft CQ ft pq pq W CQft
en
<
M
<
M
< <
H W H H
< <
H H
< < esq <
M
<
Mcu ft Qi ft ft ft Pi ft ft ft ft ft ft ft
<
>
rH JJ
TJ -H
c c
g i^ >< >< a; <:Eh Eh > > > >
cd D
ft CJ 2
0) l-H
i X CJ
1 ft ft
ft
Eh
2
ft
>
ft
ft
CO
ft
Pi
ft
H
ft
o
rd 2
fi ft
Dl ft
H Eh
CQ
. .
JJ
CU r-l
en -
CD
ft ll
r-l
Sh Eh id
0 ft g
en co Sh
en ft 0
0) ft 2
CJ ft ~ cu
0 H ~ - Ti '. ~
r(
-- = o 0 - -
ft o - ~ 2 o o
P o = 2 - -
fi 2 o II o
0 < o V o II II II ~
rl o o V V o ^ *
JJ o JJ o - -
U Eh o rl o 0) o rH II O o
3 2 o PQ o Ti rd td V - -
Sh ft ~ ~ = CU o 0 JJ JJ
JJ > O o Ti o 2 rd id r-l II 11
CO ft II 0 = jj P P CU V V
fi - II II V 2 c JJ jj >
H tn cu II 0) ft ft 0) o rH
ft ft CJ V Sh 0) 0) ft ft ft
0) CO ft ft CJ rd Sh CJ CJ JJ U CJ
rH ft CO CO O Sh Pi 3 CJ CJ fi < <
TS ft p H H Eh CO CJ <q esq H r-l H
fi ft
rd H
ft
1 ft
1 H
ft
2
pq
2
pq
ft
Eh
ra
jj
ft
3
Sh
Sh
0)
JJ
C
4H
0
Di
fi
H
en
co
cu
ft
o
rd
jj
CO -
p
X ft
rd CO
CQ
rd
g
Sh
0
2
0)
- TJ
= 0
2
o X
II
II 2
Eh ft
ft rl ft
CO r-l in
pq 2 rl
ft pq ft . .
ft ft =
M Eh o
P o
ft
- ^ =
o o II
u H
0
o
i> 0> H
ft ft
- l-H
[jH _
0)
ft ft
ft --
CO ft
P CO
p
II X
CJ
rd
ft JJ
CO CQ
P Ti
CU
TJ
0
2
jj
fi
CD o
Sh ft
il
o
2 O
ft ft
ft H
Eh
ft
- H
O ^
- 2
ft
V O
ft
Sh
ft 3
CO CJ
Ph
Ti JJ
C C
Cd H
ft
I ft
I H
rl II
rH
-H -rl
ft o
-
-rl
ft
Pi "
o
ft
- H
O Eh
- 2
ft
ft
p
2
ft
ft
O
tn
ft
co
P
ft
CJ
cd
jj
co -
P ~
X ft
rd CO
X jj
G
P H
O <M
2 -u
- II
ft
H rH
a
p
2
w
<D
>
0)
ft
ft JJ
G
-H O
pq o
I II
V
ft -
CO ft -
P CO [-
p
o
X EH
CJ
Id U3
JJ
ra Cri
M P Ti W
CO
ft
ft
Eh
2
ft
>
ft
Eh
ft
CO
ft
Pi
ft
H
ft
o
-~- " co
G
rH -
" O CO
II
II
X
u
ft
ft
Eh rd in
ft H JJ -. - ft
CO r-l V CO en CO r=q
W 2 H rH H C v G
ft ft ft 2 rd X ^ vo -
ft ft - pq 2 g id <J3 rH en r-l o
M Eh
p
ft
Eh
ft
ft
Eh
0
2
Ln
CM ft
ft
CM
i
ce
pq
CO
C
ft - tsq . 0) P 1 Eh Eh en ~
o o
r-l D>
2
ft
Ti
0
'" o
2 H
ft
<
H
o
ft
<
C X
CJ
r-l
. _
- c ft S o _ ft en rd ft
- II o rH Eh .y o . . ft - - JJ ft
^ o \ - n Ti = rH O II o ft CO Eh
rn - rd ro II II - - ft ft ft
cd rl II o 0 o 11 1 ~ .. Eh X <
g II r-l r-l ft rH V C ft td
Sh rl H rl 0) 0) ft . rH 0 rH esq S -
0 r-l ft _ rd Ti II TS . CO ft - -rl - X o
2 2 a H > 0 0 r^ H CO JJ -
CD ft ft ft <q S .--. 2 *-- H II CJ II r-l ft
TS ft H ft td ft _ JJ O V 3 V - o '- ^
0 Eh - o ^^ JJ
rd II CM
C
0)
Eh 11 ft
0 o
Sh
JJ o II
2 H
O r-l
2 - ft
H
P
H
P
0) 1
!h
Sh
_
ft
id
jj
rd
JJ
ra
C
td
JJ
V
rH
ft ~
n o Eh o Eh Ti 3 ft CO ra rd M cd JJ II II
- - 2
ft
- 2
ft
P 2
ft
0
2
H
o
CJ CO H H P
JJ
JJ
G
P
-U
rn
fi
1 V
CD rH II II S3 ft jj ft H ft 0) ft H ft - . o
TS \ Eh E-< ^ G ^^ ft CD U 0) CJ CO ft td
0 H H ra s~^ 0) CO P 0 u u CU ft CO jj
2 II r-l <: H i< Sh Eh . U ft J 2 CJ 3 CJ X
- p rd
jj V cu 3 ... O 3 .~ CD 2 Ln u H ft ft < CJ < ft '-
- P
c ft Ph -H Ph rH ft en 3 ft II ft JJ
0 rH H M ft H Ti > CM CJ H 0 ft
Sh ft *^ G ft ^^ ft rd CU
Sh CJ P P id - A CO P ft JJ CJ
3 < ft 2 ft 2 ft o ft p 2 CO en 0
CJ H M H H ft
ft
H
P
2
ft
ft
H
P
2
ft
Ti
rd
0
rH
td
JJ
cd
P
i
i
rH
H
rd
>
<
id
JJ
rd
P
ft
H
H
O
ft
Ph
H
H pa ft
ft
CO
J
ft
ft Ti <
H
p
2
ft
Ph
l-H
ft
2
ft
2
ft
ft
Eh
0
CD
X
H
X
CJ 2
id ft
jj ft
CO in
2
ft
ft
Eh
td
>
esq
rd
JJ
rd
P
P
2
ft
ft
in
2
Dl ft
C ft
H Eh
Ti
rd ro
0 o
ft rH
CU
TS II
o
X co
Ln
II CM
2
ft
ft
Eh
(?
2 Ln
ft Ln
> CM
ft
rd
g
Sh
0
2
cu
Ti
0
V
CD
Ti
0 r-
2
jj O
fi
"
cu
Sh
Sh
3 ft
CJ Ul
ft
ft
rd ft
~
rd ft
JJ H
rd
P
ft
H
CD
ft
CJ
td
jj
co
H
X -
rd vo
2 l"
ft CM
p I
O
2 -h
rH
ft
ft -.
CO ft
H OO
ft
0
rd
ft JJ
en
h
co
ft
co
P
ft
CD
C
CD
Pi
ft
Eh
- ft
ra esq
co
2 LD
ft CM
ft
Eh I
I ft
fi
0
H
JJ
CJ
3
Sh
JJ
JJ
CJ II
3 V
Sh
ft
rd fi
JJ H
td JJ
P fi -u
JJ 0)
CD Sh
CJ 3
CJ CJ
esq
ft
H
CO
J
ft
ld
o ft
- ft
- Eh
ft
rH esq
en rd v
C jj
-H rd JJ
P
jj
H a Sh CU ft H
0) CJ
o cu
U X
esq pq
ft
p
2
ft
ft
O
cd
jj
co
P
X
id
P
O
2
ft
ft
ft
esq
II II
.. v
ft -.
CO ft
P co
p
id
jj
rd
P
JJ
ft
0)
CJ
CJ
P TS < -
ft
ft
CO
p
ft
p
2
ft
ft
P
2
Pa
Eh fi
2 O
ft -H
> -u
ft u
- 3
cj u
CU JJ
X en
ft C
.* h
0 JJ
rd G
jj 01
CO Sh
Sh
~ 3
CJ -
Pi
O ft
P co
ra
jj
G
cu
>
0)
G
O
H
JJ
3
CJ
01
X
0)
G
O
ft
- 0
Dl rd
G -U
H CQ
JJ -H
3
CJ II
0)
X
ft c
0) 0
T3 -H
O JJ
2 cj2 3
Sh
II JJ
en
fi
Eh
JJ 2
CJ ft
CU
TJ H
Sh CJ
3
CJ
ft
ft
ft
2
ft
X
u
rd
jj
co
P
X
rd
P
O
2
- +
ft
ft co
co p
P
X X
CJ CJ
id rd
JJ JJ
en m
TS Ti
II II
O r-l
p p
Eh
W O
H 2
fi
O
H
JJ
CJ
3
Sh
jj
en
C
M
JJ
c
CD
Sh
Sh
3
CJ
ft
CO
<
CJ
CD
2
ft
ft
i ft
P r-l P
' C
jj - jj
H JJ H
CQ H PQ
CM PQ (M
JJ (M JJ
G JJ c
- H C H
- - M
' P 2 2 ft 2
o 2 ft Pi ft o PQ
p esq ft O ft X ft
^^ Eh Eh Eh
JJ . . - . ,
-H o . . o . , o , .
ft P CD p CD P CO -^
CM ^ CD CD CD CD
JJ JJ JJ JJ in
fi H II H II H II CM
H
.^
pq
CM C .^
PQ
CM G , ^
CQ
CM C _ P .,
Eh JJ JJ 0 ~ jj JJ 0 ~ jj JJ 0 ^ jj p O JJ P JJ
O rH CJ G H rH rn C H rH r-l U C H r-l r-l ft 2 rH ft rn
2 3 * ft H JJ 3 ^ H JJ 3 ... Pi H JJ 3 ... CO 3 ... . CO .^ 3
- ra = 2 - CJ + en = CJ CJ + ra = O - (J + CQ z ^-^ CQ z 2 . , ra =
jj cu o esq JJ 3 cu o ft JJ 3 0 o X JJ 3 0 o 1 CM 0 O ft rH 1 CM 0 O
C ft o C Sh ft Pi o o G Sh ft ft o c U ft ft o 1 ft O ft - 1 ft O-
M = P M JJ CO z M JJ CO = ft H JJ CO z -X z Eh \ =
CM n 2 CM en P n ft CM ra P n O CM CQ P II A II II A n
JJ II esq JJ C II o JJ G II X JJ c II II o II ^^ V II O II
rl V H H II V H H II V -H M II V p V c- P V
CQ
ft s
1
1
ft JJ
C ft , K
i
i
CQ JJ
G ft r ^
I
i
CQ JJ
c ft ft
CM
rH CM ft
II CO
p
CM
A
II 0
!h
ft
CO
CO
P
CM
A
II 0
Sh
ft
CO
CO
ft
CM
A
n 0
Sh
ft
CO
CO
p
CM II CO
p
CM
A ft
II CO
ft
CM
^ ' o II Sh p . - o II Sh p -. - o II Sh p - - o - O CO .* O
JJ ft ^ JJ 3 ft ft in JJ 3 ft ft Eh jj 3 ft X in JJ ft in o ft JJ X Eh
rH CJ r-l CJ H CJ r-l CJ H 0 rH CJ H u rn CJ p M ^1 u
3 id rH o 3 rd r-l en 3 td r-l r-l 3 * rd rH 3 id rH -^ 3 rd rH
CO jj -* CD en p JJ - CD ra p jj [-- CO P JJ CO jj - p W JJ - -
CD en ft CD ft 2 en Pi 0 ft 2 CO ft 0 ft 2 CQ ft 0 en Pi ft 2 0 CQ Pi
ft Ti CO CD
CO
2
pq
ft
3
ft H ft Ti CO CO
CD
2
ft
ft
3
ft H ft Ti Ul o
c^
2
ft
ft
3
Pi H ft Ti CO CM
t-
2
ft
ft
3
Oi Ti CO H ft ro
r-
2
H
ft
3
Pi TS CO
2
ft
ft
Eh
ft ^^
o .
[--
- . CM
. ^ rH
CO
rM A
CD
Ln
CM
p
o
2
CO
CM
CD
Ln
eg
p
o
2
CD jj en
i_n rH 0 *
2 CM 3 ft
ft en '*-' r-l
ft ft ~ 0 -
Eh <
J
o
2
jj
r-l
ft P
II
^ ^ CO 3 ^ ^ 5: V
r-l . , en z 2 P
r-l 1 CM 0 O ft r-l S ^~- ~-^
II - 1
*
ft O ft
Eh
- 3 oo
CM
rH
^^ II A ll II ^ rH Pi
<M V II o
p
II
V r-
V r-
CM V
CO
P . . ' ^ CM ^-~ rH
O CM ft .- , rH CM o
2
Pi
II CO
p
CM
A ft
A p
o CO - - - o CO ~ o '
P ft JJ ft i-l o ft p
H rH
3
en
CJ
rd
JJ
r-l
p H
P
--
ft 2 0 ra ft ft 2 ft
H ft M<
r-
2
ft
ft
3
ft Ti CO H ft H
CO CD
+
2
u-i
CM
+ m
rM
JJ ft JJ
rH ^ ft ft rH * P
e=C 3 jj Eh ft O 3 jj Pi O
ft CQ r-l J 2 CO r-l ft 2
CO ^ 0 3 ~ ^-. -. CO - 0 ~ 3 CO ~
--^ 2 Pi CQ = r-l , . z 2 ft CQ ^ =
1
1
CXI ft
ft
0
ft
O
o II
rH 1
1
CM O
O
ft
ft
rH 0
ft
1
I
CM o
o
\ Eh II = * z Eh II \ z
A II *~. II A II II A
II o . II CV V II O II ^~- V II o II
Q C JJ V P V c- JJ p V
- CM rH . a . CM r-l - . ^
rH 3 ft . . o CM . r-l 3 CM ft , .
n
A
CO
0
CO
p
CM 2
Pi
II CM
A
CO
0 ft
CO
p
II CM
^ Pi ~ - o o CO ^ o ft CO ... - o
ft jj O ft ft Eh P ft JJ Eh o ft X JJ Eh
H r-l P H 0 - H r-l p H CJ r-l
3 * rd r-l 3 r-l - rd 3 rH
P en P JJ P CQ P JJ CO ~--
2 0 ft 2 CO ft ft 2 0 ft ft 2 CQ 0 ft
pa in
r~
2
ft
ft
3
Pi H ft TS CO H ft CO
r-
2
ft
ft
3
ft CO H ft Ti
r--
2
ft
ft
3
ft CO
CO
Ln
CM
p
O
2
CO
CM
2
ft
ft
Eh
P
o
2
o
p
3 cm
CQ ~
0 ft
ft CO
ft
ft
CJ
p
p
<
p
p
<
ft
CO
P
X
CJ
rd
JJ
en
ft Ti
2
W
ft
Eh
i_n
Ln
CM
P
cm +
ft
CO
CD
in
CM
o
P
CM
P
o
CO
2
ft
ft
3
ft ft
CO H
ft
H
P
2
ft
o
p
CO
m
CM
P
CM
ft
ft
h a
a
2 ft
ft H
ft
2
ft
ft
in
co
CM
3
CO
0
ft
ft
O
CM
O
P
ft JJ
P
2
ft Pi
3 ft
CO CO
0
ft
. 2
- pa
Ln ft
CM Eh
p
o
2
ft jj
3
co
0 ft
P
2
w ft
CD
m
CM
X
CJ
rd
JJ
co
P
X
rd
fi
o
-H
JJ
u
3
Sh
JJ
co
fi
JJ
C
0 ft
3
co
0 ft
ft
P
2
2
ft
2
cj
a
cu
2
a
ft
2
a
CJ
CQ
ft
CO
CO
ft'
01
A
II
o
CT.
ft en -.
CO co CM
P
ft
CJ
cd ro
jj co
ra
co O
co Eh
ft
ft TJ cm co
co
2
ft
ft
3
2
ft
ft
Eh
m
Ln
CM
CQ rH
P
ft
CO
CD
in
CM
P
CM
ft o
II HP
P
oft 2ft
p h pa h
p
2
ft
ft
Eh
r-
CM
ft rH
H P
P
2 ft
ft h
2
ft
ft
Eh
CO
CO
m
CM
P
il
rH
P
2
ft
ft
Eh
co
CM
rH
I
V
JJ
rH
3
en
0
ft
ft
O
o
P
ft JJ
A
JJ
r-l
3
CQ
0
ft
JJ
CJ
3
rl
JJ
CO
fi
H
JJ
c
0
Sh
Sh
3
CJ
CD
m ft
CM O
p
O CM
2 co
CO
LD fi
CM 0
ft JJ
3
co
0 ft
ft ft H
P
2
ft ft
ft
u 2
rd ft
jj ft
CO Eh
P
X --
rd co
2 co
3
CD
0 ft
ft
O
rd
JJ
co
P
X
rd
II
P
c o
O 2
H
JJ -
CJ CM
3
rl +
JJ
CQ ft
fi Ol
H P
JJ
fi
0
Sh
Sh
ft 3 ft
CO CJ CO
P P
2
pa
ft
Eh
CO
CO
ft
3
m
0
ftC
o
-H II
JJ
0
3 --
^j ft
JJ CO
CQ P
fi
H ft
JJ CJ
C rd
0 jj
S4 ra
Sh TS
3
CJft
H
CO P
J 2ft
ft ft H
o
ft
ft =
CD
in
CM
V r-
CM
o
p
A
- II
ft
H
in
p co
2
ft <=*
co
2
ft
ft
3
o
P
m
CM
P
r-
CM
ft ft
CO H
ft r-l
H P
P
2 ft
pq h
P
- 2
- pq
in ft
CM in
P
O =#
2 co
-. Il
P
P
ft JJ JJ
ft
CJ
td
jj
co
P
X
rd
fi
o
H
JJ
CJ
3
Sh
JJ
CQ
C
H
JJ
c
0
Sh
Sh
3
CJ
ft
ft Pi ft H
rH CJ
3 > -
en h z
0 p o
ft o
>
H
P
CD
in
cm
ft
CO
P
ft X
H cj
id
P
2
ft Ti cd
CO
o
p
2
ft
ft
Eh
CM
Eh o
P
f- rH
p
jj co
ra ft ft
co H
ft rH
M P
P
2 ft
ft h
2
ft
ft
3
2
W
ft
in
pq
ft
ft
Eh
Pi
co
jj
C
Dl
C *
rl
JJ
Dl
C ,
3 H u
CJ Ti 0
0 rd Sh
X 0 Sh
CM
JJ
CQ
2 0 P
pq 2 ft ft ft o
ft 0 0 0 0 2
in
ft
TJ
0
Ti
0
TJ
0
Ti
0 c
CO
0
cd
0
H
CM jj JJ
rH
1 CO
2
H
ft
CO
P
X X X
II II II II CJ
3 rH
td X X
V CM Eh cd u
td
CJ
rd
0 0
Ti
0
Ti
0
Ti
JJ
en
g
S^
0
<d
0
td
JJ P . 2 jj JJ 0 0 0 0 C 0 jj jj
rH O CO CO ~ 0} 2 2 2 2 H 2 CO CO
3 2 co P P ^~~ P JJ jj JJ jj JJ 0 P p
ra o X Pi X G c c G C T3 ^ X X
0 . II 2 rd CO rd 0 0 0 0 0 G z rd rd
ft CD V ~^ 2 Sh Sh Sh Sh Sh 2 O v
* m c , . ~ 2 JJ 2 Sh Sh Sh Sh Sh X o 2 .~ H 2
~ CM 0 H jj 3 G 3 3 3 3 3 3 z ft JJ ft
CD Pi rl rH CO p H CO P CJ CJ CJ CJ Eh CJ II CO p rH CO p
m O ... + JJ + 3 ft o (M CO o J - II ft o 3 ft o
CM ~ CJ en 2 JJ 2 V CO A A A A < - V 2 rn 2
o ^-~ rH JJ 3 ft 0 1 H 1 . H II II II II ft G 0 i 0 1
1 p IT-
CM
- rH
3
Sh
JJ
CO
P
ft 1
r-l
CQ 1
r-i
o
p , - - i
0
H
TJ
0 r-
i
r-i
Pi 1
r-i
H \ rH II CO en n A II A r- o o r-i r-i i JJ 2 A ~ ll A ~
p
r-l A
V 0
ft
C
H n
II 1 II + JJ
H o
o r-i O r-i
A
-H
Ti
jj
c
o
in
II ft
CO
1 II ft
CO
1
II P . . JJ , ft - . ft pq Eh II G 0 P ft . H ft
JJ r-l G ft CO ft CO CM 2 2 2 2 0 Sh CD CO ft CO
II rH II 0 ft CO p CO P JJ CD pq ft pq ft ^ cn CJ Sh ' n p CO II p
r-l 3 ft Sh CO p p - C ft ft ft ft ftl r-i JJ 3 Pi - P -
p .V en CO .^ Sh p .* - H Pi 3 3 3 3 CO rH en CJ CO ^
ft JJ 0 ft JJ 3 ft ft II X II CO < 0 ft jj II ft JJ II
H r-l
3
Pi H rH
3
CJ H 0
rd
0
rd
II
V pq
CJ O
Eh
H H r-i
3
CJ
id
rn
3
p ra P CQ p JJ ft jj ft CO p P CO ft jj CQ ft
2 0 ft 2 0 ft 2 CO CO en CO Pi e< 2 CM ft 2 0 CO ra 0 CO
pq ft H ft ft H ft TJ CD
en
2
ft
ft
3
p Ti
2
ft
ft
3
p CO U ft rH
H
2
ft
ft
3
H ft CO
cn
2
ft
ft
3
Pi p T cn
CT\
2
ft
ft
3
CC p
2
ft
ft
Eh
W
ft
ft
ft
CO
JJ
c
ft
Eh
2
ft
>
ft
Eh
ft
co
pq
ft
ft
ft
co o X
u
P . rd
O JJ
2
2
rH CO
p
C ft X
0 - ft II rd
H Dl Eh 2
JJ C O 2
CJ H v O 2 rH
'- - 3 JJ jj W H P
ft ft Sh 3 H II ft rd o .^
CJ CJ jj 0 CQ e^ > 2 rl
rd rd ra 0 0 . . < 2 o
JJ jj ~ C X Ti CM . rd ft . . ft
CO co Dl ~ H ft 0 jj ft H
P P C rH JJ 0 2 P rH rd Eh II
X X H cd G Ti ~ 0 O - P 1
^ rd rd Ti g 0 0 z u 2 - .
- * 2 V rd Sh Sh 2 O rd II - ft .
~ ft 2 "~ 2 0 0 in 2 r-i Sh fi \ P o CO ft
JJ CJ JJ P 2 3 = >, ^ 0 H - p CO
r-i o P r-l ^ p 0 0 CJ CJ n rH P rl o Eh p
3 H o 3 ^~~. o T ^ TS ^ pq - II r-l in e< JJ r-i 2 II
CO - 2 CQ o 2 0 z pq 0 z X V id O b^ ft CJ H ft II X
0 JJ 0 Q 2 rH 2 v O ft c 0 Sh 2 2 ft 3 td Eh CJ
ft c . ft , . p 2 O 2 2 o 0 T . 3 < H Sh > Eh ft td
o r-i rH o jj r-l esq z CO = I H 0 r- ft JJ ft II ft i jj <q H CO ft jj
II H CM II H H o ii H n I JJ 2 O rd Eh V P ~ i en td esq pq CO en
ft JJ
rl
1 CO ft
CM
+ p II
V
ft II
V A
H
Ti
jj
G
o
Eh
2 c Eh
JJ
CJ ^f
_
*~
A
C
H
jj
td
3 ft
ft
p TJ
, 1 ft ft . i JJ ft 1 0 i 0 II C 0 .. 1 H n o O II JJ ft H H
ft 1 CO ft i G CO 1 Ti ^-^ i Ti .. 0 Sh CO i Dl 1 PQ 1 V - - G -
CO II p CO H p 0 [-- 0 [-- r- CJ Sh - C 0 H 0 P
ft A .- p A A 2 A 2 <M JJ 3 Pi A H A Ti A r-l II II ro Sh ft 2 ft
II II II II jj o II jj O H en CJ CO ~ II ft II 0 II 0 V V H Sh H W H
ft JJ II ft V II G Eh G Eh 0 ft JJ 2 > 3
0 r-i CJ 0 0 O Eh H 0 0 0 o H o CJ
id 3 rd Pi Sh CO Sh CD in - 2 CJ P ft ft H
jj W ft JJ CJ ft Sh ^ Sh - P rd JJ CJ CJ
en o 0 CO ra r-i o CO CM 3 ft CM 3 ft o ft 2 M< I in Sh CD c <
esq"
CO ft
TS o
r-l
2
ft
ft
3
ft p T O
r-l
2
ft
ft
3
H p O
r-l
2
W
ft
3
CJ CO O
r-l
2
ft
ft
3
CJ CO CM
H
2
ft
ft
3
H ft o
r-i
2
ft
ft
3
i o
H
2
pq
ft
3
in O
rH
2
pq
ft
3
H H H CM
rH
2
ft
ft
3
H
ra
G
ft
ft
Eh
ft
<
II
V
o
rd
JJ
rd
ft
JJ
a
0
CJ
CJ
esq
ft
H
P
2
ft
Eh
2
H
>
ft
Eh
ft
CO
pq
ft
ft
ft
O
2 rH
ft -h
ft cd
Eh >
<
. rd
JJ
rH rd
- p
Eh
2
ft
ft
co
ft
ft
ft
u
rd
JJ
CO
p
X
rd
Pi
ft
ft
esq
2
ft
ft
Eh
P
o
2
ft --
OO ft
P CO
p
p
ft 2
h pa
ft
ft
CJ
td
jj
ft co en
ft P Ti
ft
ll
EH
ft
CO ft
rd
jj
rd
P
JJ
ft
0
u
CJ
ft
p
2
ft
CJ
in
ft
P
2
ft
in
2
ft
>
w
in
ft
co
ft
ft
ft
ft
o
2
ft
ft
o
2 >,
ft co
ft
Eh
ft
3
pq
jj
3
ft
JJ
3
O
H 2 ii
ft
3
"
O H
>1 Eh
2
ft
ra
3
ft
JJ
3 M
ft <
jj 3
3
2
ft
ft
Eh
2 -
pq o -
ft - o
Eh P
II
-. II
- V
0
ft o
cj ft
O
II
ft
Eh
ft
Ul
ft ft
ft H
ft
CO
in
CM
o
P
ll
V
0
o
ft
ft
CJ
rd
2 jj
ft co
ft
ft
Eh
ft
P
X
rd
P
O
2
o
rd
ft JJ
ft
CO
p
w
JJ
G
0
Sh
Sh
3
rd CJ
P
2
ft
ft
ft
ft
H
P
2
ft
P
2
H
Eh
2
ft
>
ft
Eh
ft
CO
pq
ft
ft
ft
O
2 >
ft ra
ft
in
3
ra
jj
3
ft
JJ
3
O
P
r-i H
>, f
en
3
CQ
jj
3
ft eC
-U 3
3
O
2
ft
Eh
H
2
pq
ft
in
2
ft
ft
Eh
ll -
o
P
ll
V
ft
ft
p
2
ft
ft
ft
cj
o
ft
pq
co
P
pq
2
ft
ft
3
Eh Eh
2 2
ft H
> >
ft pq
Eh Eh
ft ft
CO CO
ft ft
*~ Pi Pi
ft ft ft
CJ H H
rd
2 JJ
ft CO ft ft
* ft p o ... .^ o ... .^
en Eh X ra ft CQ X
C rd - G 0 ^-^ G CJ
r-l CD
ro
^ o H rdJJ
Ul
o rn
rd
JJ
CO
CC r-t P 2 Pi r-i CC H
ft o ft II ft X 1 ft XEh V 2 ft in rd Eh rd
.>
ft
< G ^^
in
2
o
ft
ft
esq 2
r-l
>,
ft
e<
CO 0 rH o ft en ft CQ
in - -H ft 3 - P ft 3 - P .^ .^
CM o JJ
0
+ II Eh ft
jj ^^
o O
2
Eh pq
jj
- o O
2
ft
CJ
ft
CJ
+
^
3
Sh
ft
CO <M
3
ft
2
ft
ft
CO K
~ 3
ft
2
ft
ft
01
rd
JJ
rd
jj
o JJ p o jj ft H r-l o JJ ft H r-i OO CO
P rH ra
G
P
O
- 3
O
in
ft
rH
+
- 3
O
Eh
ft
rH
+
H
X
P
X
il H II 2 II _ ^-. u II * ^ . CJ rd cd
V II
V
JJ
fi C
^
ft _
td
jj
II
V
ft
CO
\
P o
rd
JJ
II
V
ft
CO
0 0 ft H 0 o H - en H H H - CQ H . . JJ
r-l rH Sh CO Eh H >i E-1 -H O >1 Eh H rH ^ ft P P rn
ft ~ td Sh p " r-i JJ rn 2 n td CQ 2 II rd CO O o 3
ft JJ 3 ft (C 0 3 ft II jj II 3 D II jj II H 2 2 CO
H rd CJ H 3 3 ft Eh V td P Eh V rd 0 HI
pq P Sh JJ Eh ft P -U Eh ft P ft ft ^^ ^-^ ft ft
CO P jj P i JJ 3 H CO 0 jj ft 3 H CO 0 jj ft CO u rH H CO
ft 2 3 ft 2 i en ft < ft o 3 CO ft e< W rH 3 CO D rd II D
ft ft O H ft
H
P
2
ft
H
P
2
ft
A
II
CO
=*
H
O
Eh
O
H
2
ft
ft
3
fi
H
JJ
fi
0
Sh
Sh
3
U
ft
H
jj
3
O
ft
H
3
H
P
2
ft
ft
ft
H
ft
H
ft O H
ft
H
P
2
ft
ft
CO
p
W
JJ
3
O
ft
H
3
H
P
2
ft
ft
ft
m
ft
H
ft O H
PH
H
P
2
ft
H
P
2
ft
ft
i
i
A
II
M<
<sf
r-t
2
ft
ft
3
JJ
en
H
II
JJ
r-l
3
CQ
0
ft
+
ft
CO
H
II
ft
CO
H
1
ft
CO
p
II
ft
CO
p
ft
CO
p
ft
CJ
rd
jj
ra
Ti
ft
i
i
A
II
in
r-l
2
ft
ft
3
X
CJ
rd
JJ
CO
p
X
rd
2
W
ft
Eh
ft
ft
Pi
in
2 2
ft ft
ft ft
Eh Eh
_.
ft ft
ft ft
ft ft
Eh ii
a
o
2
Pi
co
jj
fi
ft ft
CO CO
JJ JJ
c c
H H
CM CM
P . H
4->
-H
j-*
H
o
2
ft
CJ
rd
pq
-
ft ft
-
c jj co c X ft co -~ CO c X X
0 CO 0 u CJ X 0 CJ u
H P P H td rd ft CJ ft rl rd rd
JJ X O JJ jj jj o td O JJ JJ jj
o rd .. 2 CJ CO CO 2 jj 2 CJ CO CO3 2 o 3 P p CO 3 HI HI
Sh X P G Sh X X c ft G Sh X X
JJ 0 JJ rd rd 0 X 0 JJ td rd
ra
fi
H
a
o
2
II H
JJ
0
m
C
H
^ ^ HJJ
u
cd rl
JJ
0
en
fi
HI
- '* JJ ". . 3 JJ 2 P P 3 3 jj 2 P PX X G ft ' - ft Sh G ft O O Sh P Sh C ft o oCJ u 0 CJ r-i 0 JJ 0 ft 2 2 JJ o JJ 0 ft 2 2
td rd Sh rd rd en Sh ^ CQ 2 en Sh Eh
jj JJ Sh JJ + JJ G Sh ^-. . . C G Sh , .
CO CO 3 CO CO H 3 . . r-i <M H ^^ H 3 ^^ rH (M
H p CJ D o P JJ O - JJ <M jj CJ _
X X X p X C - o + + fi C o + +
td rd rd rd 0 JJ - 0 + 0 jj _
2 2 + 2 + 2 M H ft ft Sh Sh H ft ft
* ft ft '- X " ^ 2 u CQ ll CO CO Sh O Sh CQ ll CO CO
JJ ft JJ ft JJ . 3 CM p p 3 P 3 CM HI HI
ft P P r-i CO a rH CO rH ft P U JJ . ~--. - - H, CJ H CJ JJ ^^ - -
CO O o 3 Eh p o 3 p 3 CO o ft --- G ro P + ft C ro
p 2 2 CQ ft 2 en ra p * 2 P - H ^ II II e< ^ P ^ M II II
--^ 0 O 0 - 0 - r-l < G ft p c ft < fi ft
ft - . - Pi ft . ft Eh X ft ft ft p ^ 0 II g 0 CO 0 II
CJ rH rH 1 CJ r-l ft 0 < 0 r-l i H 0 ft ft 1 H P 1 -H 0 ft ft
rd II 1 td n CD rd ll 3 td II i JJ Eh CO CO JJ 1 JJ H CO CO
JJ 1 + jj 1 ft JJ CO jj + H ft JJ p p ... H H ft JJ H HI
ra A ra CO ra A TJ g H ft A TJ II A TS g H
Ti ft
CO
ft
CO ft
II Ti ft
CO ft
i
I
Ti
ft
1
1
TS
ft
ft
CO
II G
0
0 ft
H
HI II C
0
II fi
0
0
Eh
ft
ft
ll H P CO in n p CO II CO II CO P [-- CJ JJ CO P r-i CJ ft ro u JJ CO
- ' HI c^ - P A p A P " * o JJ H ft P 2 CM JJ CO CM JJ -H ft p
~
rH
- II II ' " - CM CO ft HI ft ft ... <M ra p ... CM ra ft HI pq
JJ II II X jj II X JJ ft JJ ft ft 0 ft 0 ft 0
rH CJ o rH 0 rH 0 r-l CJ CJ o Eh H O eh HI O Eh
3 rd Eh 3 rd 3 rd 3 rd id Eh ~* in Eh
in ft ft JJ CQ ft JJ en JJ en JJ jj P P
0 CO CO en o 0 01 ra CD 0 en CO 0 en en r\i ft 2 HI ft 2 oo ft
ft H p -H CD
rH
2
H
ft
3
ft p Ti
rH
2
H
ft
3
ft TJ
rH
2
ft
ft
3
ft Ti Ti en
r-l
2
pq
ft
3
H ft (M
CM
2
ft
ft
3
H pq o
CM
2
ft
ft
3
HI
2
ft
ft
Eh
ft
ft
Pi
2 2
ft ft
ft ft
Eh Eh
ft ft
ft ft
ft ft
Eh ^
ft ft ft
CO CO w
-
2
ftjj JJ jj
fi G fi ft
HI HI H Eh
<M CM CM
JJ JJ JJ ^~^ P
-rl H H 00
ft CQ ft CO g ft
- - pi O
II o
2
0
JJ
0
CO
p
ft
U
CO
p
CO
P
V
G
O
CMO
2
rd
JJ
O
2
O
2
-' 0
H
r-l
c
CO
HI c C G
JJ
0
Dl V
0 X 0 0 0 3 v G
H rd H H rl Sh G oJJ
CJ
JJ
u
JJ
CJ
JJ
CJ
JJ
ra
0
H
H
4J
3 3 3 3 C 4_) rjSh P Sh . U - U H o 3jj o JJ ^ JJ ft JJ JJ 3CQ 2 CO u CQ CJ CQ G S-l 4_)
c C td C rd C 0 jj CQ
HI -~> HI jj H JJ H Sh CQ G
JJ CM JJ CO JJ CO Sh c M 2C G p c HI rH 3 rl JJ ft0 + 0 X 0 X rd CJ G ftSh Sh rd ^1 rd D) - - o 0 Eh
HI
Sh
3
O
P
U
3 J> in3
0
rH P
H
X
Sh
S-i
ft
P
CJ
+ ft
CJ
P
H
ft
CJ
P
rH
HI <!
ft 3
CJ o
rH
td< * ' CO - ' o CO * O c CM g
ShP fi ft CO C 2 CO C 2 1 ^ rd _. r-l
0 CO 0 0 1 M< 2 0
1 rl Hi i H o 1 H o CO ft JJ p A 21 JJ - i JJ P 1 JJ P A 2 ft -. 0 0
-- H H H II II pq * -. Eh - G est! c TJft A Ti II A T5 II A Ti ll A ft - r-l o o 0
r-i II G
0
II fi
0
II C
0 C
Eh r-l o
[--
- - Ti
G
H
JJ
a C^ CJ ft en CJ ft in CJ ft 0 .^ CM II II rd r-i CJ
2 *Hf JJ CO ro JJ CO in JJ CO H O II II r-l V V 3 II
w CM CQ
0
r-i
PH
CM CO
0
p CM en
0
H JJ
CJ II
V V
A
0
TJ II
Sh
jj
H O Eh HI O Eh HI O Eh H CO 3 ^^ , . CO ro 0 ra 0Eh * in " Eh - ft Sh JJ o o JJ - 5 JJ c Ti
P P P P ft JJ rn - 1 - r-i H HI o
2 CD ft 2 CM fc 2 CO fe 2 ft en 3 ft ft 3 ft Pi 0 CQ jj 2ft s"
CM
2
ft
HI ft CO
CM
2
ft
h ft
r\]
2
ft
M H Eh
O
2
pq
G
H
JJ
G
0
en
0
ft
CO
pq
CO
CO
H
p
m
0
Pi
Ul
W
CO
CO
H
P
CJ
rd
Sh
JJ
0
TS
0
2
0
G
0
Sh
Sh
3
jj
c
0
Sh
S-i
ft ft ft ft ft Sh ft J 2 ft P 2 G CJ CJ 3
3 3 3 3 CO
esq
CJ
p
2
H
Sh
3
CJ
ft
H
H ft ft HI ft ft
HI
P
2
ft
rl
HA
HI
1
1
td
Sh
ft
H
CJ
CQ
fi
r-l .^
r-l u
0
CC X
ft H
Eh ft
ft CJ
0 < rd
Ti JJ
0 CO
g o
Di JJ
C * ra
ri CQ fi
JJ c HI
3 0
CJ m 0
0 X
X ft W
ft ft
Eh
G ft tr
-H < 0
ft
MH jj
-H
2
r-l c
H
0 ft
rH ft * ^
Sh 0 Eh en Eh
0 >1 C H
JJ CJ Dl CO
en c rH ft
H c H ft
Di 0 JJ ft ft
0 H 3 ft HI
Sh JJ u Eh
... ... 3 0 ft ^
= G r-l U X esq rH
o 0 1 0 ft r-l
o H X 0 - H
= JJ
CJ
II 0 Ti
0
O id
>
II 3 Sh 2 e<
V Sh
jj
C
0
0
ft
2 II
V
td
JJ
. ra H JJ II rd
r- G
H
JJ
CJ
0
G 0
CJ
0
P
O 3 rd Ti X ~
Eh 0 Sh 0 pq o
ft JJ 0 2 X rH
CO JJ CQ
C
JJ
rd
JJ
c
CJ
rd
H
rd -
ft Sh HI H 0 JJ > JJ
CO ... rd JJ JJ Sh CO - <q -rl
ft 0 G H H ft id c
HI rH
CJ
0
Sh
G
HI
3
CJ
HI -u ft
td cj
P Sh p P 0
2 1 3 1 ft 2 X
pq 1 CJ 1 HI ft
H
2 h
o
CO
Eh CO Sh
0
rH
P hi pq
2 esq CJ
ft s 2ft >rd
ftft
p
2
ft
0
pq
ft
H
p
2
ft
0
Ti
0
2
rl
0
r-l
0
Sh
JJ -
G 0 ro rn
0 U ej\ r-l
CJ 0 en rd
g rH CO
g C O H
rd -H * HI
rl P Sh >~ Eh CJ
Dl 0 P X ft
0 3 ft Eh ft e<
Sh 0 g CO ^ Xi
ft ft 0 H
JJ JJ >h P
< JJ ft Pi Eh >H
X id 0 < CO Eh
HI 2 CO ft H
CQ pq Eh
i i 1 HI CO 2
i i 1 ft ft ft
JJ JJ
JJ JJ 3 JJ JJ 3
JJ 3 3 ft JJ 3 3 ft
3 ft ft jj 3 ft ft JJ
ft C JJ 3 ft C JJ 3
fi H 3 0 G H 3 0
H
O
0
o
H
rH
0
rH
O
JJ
o
jj
rH
JJ
rH
JJ H
JJ Sh JJ Sh JJ Sh JJ Sh rd JJ
Sh 0 Sh 0 Sh 0 Sh 0 c 0
0 ft 0 ft 0 ft 0 ft Di CO
ft ft ft
.
ft
..
H
CO 0
0
ft
~ JJ v JJ - JJ * JJ c
fi 3 C 3 G 3 G 3 T H Sh
H 0 H 0 H 0 -H 0 jj
3
rd
0
p 0
rH
0 0 0 0 0 0 0 0 ft P JJ r-l
JJ ft ft X ft JJ X ft ft X G 0 0
3 rd rd rd rd JJ 3 rd cd td td H g CO U
ft ft ft ft ft 3 ft ft ft ft ft cd 0 JJ
JJ en ra en CQ ft JJ CQ ra in en TJ Sh ft c
3 Ti Ti Ti T5 G 3 TO TJ TJ Ti Sh Dl 0
0 C
rd
G
rd
C
rd
G
rd
rl 0 G
rd
c
id
G
rd
fi
rd
0
3
0
Sh
Sh
0
CJ
jj ~ ft ft ft ft ~ ~ ft ft ft ft ft w g
3 o rH r-l en CQ rd
ft 1 i i 1 1 i 1 i 3 I 0 Sh
C JJ 1 i i 1 JJ JJ I i I i JJ I 0 Di
H Sh
0
Sh
0
U
0
rd
JJ
0
Sh
0
Sh
.. ft ft ft CO ft ft
O '-
JJ I 1 1 I I I o
Sh ~ -
0 -
ft
1
1
ft
CD
W
ft
CD
pq
CD
ft
W
CD
H
PQ
Eh
H
ft
o
II
o
II
o
II
Eh
H
PQ
II
in
HI
CQ
^i .^ v ft Eh ... ^ i^ ft ~ in CO
1 j
^ ft o r-l
2 in H Eh HI in 2 Eh H e^ m Eh H ft 2 H ft - Sh
.* HI H PQ H PQ 2 H H CQ H ft 2 H O H CQ CD r-i CO
ft PQ ft HI pq ft HI CQ 0
Bf
esq
X
| j
pq r-i II 3
ft Eh Eh Eh Eh Eh b^ ^ H ft
CD ft 2 ft 2 D 2 ft 2 ft 2 ft 2 2 2 td jj
ft O HI O H o HI O H O H O H H Eh ^ rH H > in 3
in ft ft rd <c HI ~ ft
2 CO CO JJ rd PQ - JJ
r-i H -H 0 0 rl H 0 0 P pq ft ft
O
rd JJ o 3
0 O o O o H 0 r-l rH rH r-l f< Pi ft Ti fi rd - O
2 o H 0 H 0 rH r-l H 0 H 0 3 o ft CJ JJ H P
H ft ft ft ft ft ft ft ft ft ft ft CO p H ft Sh
0
H
3 rH rH II -
O Dl - X o
0 o CJ >i
>
td
ft
0
ft
CJ
ft
~ ft rn td Eh en
H o -H P H 3
O td * rd CQ ft
ft jj c > ~ jj
td H < o 3
TJ o rd ft ft
jj Dl jj 0 ft JJ
3 0 rd cd ft 3
-
ft O ft P P CJ O
ft
ft
Eh
CJ
H
Eh
H
P P P ft ft ft
CJ
ft
esq
X
H
< < esq < < <q
Eh 2 2 2 2 2 2
ft CD O CD CD CD CD
o H H M HI H HI
ft CO CO CO CO CO CO
ft
P CJ
2 ft
ft <
CD
ft
CQ
0
ft
id
ft
en
TJ
G
- - td
o ft
X
CJ JJ
o rd 3
P 2 ft en
jj ft G ft
Sh ft H CJ
0 in in id
ft ft CQ
CQ - ft Sh
fi ft - 2 0 2 0 2
0 ft rH ft ^H ft > ft
U - ft Ti ft H ft
JJ ft Eh Eh 0 e^
3 II Sh CJ
ft - . 0 . 0 _ .
JJ o Eh Ti - iH _
3 id ft rH C o rn
0 JJ CO -- - - - 0 - G
rd ft en CQ CQ CQ 0
TJ P ft G fi rd II C II ft II
fi JJ CJ jj fi 3
rd 3 ft in m ^ rd -H in 0 -H 0 .^
O - - Ti O * ft o 0 o _
JJ ft ft o H ft 3 -h ft H o
3 - Q ft W - Dl ft ft rH ft rd ft _
ft 0 S Eh Eh C Eh - 0 ft
C o 5* ft ft II H ~ ft ft en ll
rl -rl esq esq V g c H e< II id P TJ ft V
ft - . ^ 0 jz O V <3 ~ G .^
en Eh Eh - - o o 0 5] ft en esq - rd <q o
3 - ft 2 o o > G rH o TS o ft O >c
0 -H CO ft - - II co H - ^ II - rH G - - . - - en
C o ft > V 3 Eh V H td Eh jj Eh 3
0 -H ft ft II II ft 0 2 II td ft 2 II 3 2 II ft
h ft CJ - V V fi JJ JJ W c V > ft V ft ft V JJ
ft ft Eh H 3 > H < ft > JJ > 3
CJ ft H 0 O ft Ti pq O H id 0 PQ H 3 ft 0 ft
C CO 0 CO o- o Dl jj G - Dl O jj < - O O - o jj
>i CO rH ft 0 0 0 3 0 H 0 0 rd H 0 0 0 3
co pq Ti ft ft ft ft O ~ ft O ft ft P - ft o ft ~ ft o ft O .*
cd cj fi O ft m H ft 0 -H ft 0 H ft
O rd ft H 0 ft H M ft HI Sh ft HI
ra ft ft - Pi ^^ P P
0 ft P P P P
rH i ft 2 i ft 2 1 ft 2 1 ft 2
Ti I HI ft I H pq 1 H ft 1 HI ft
G
rd o 2
ft JJ HI
Sh CO
1 0 ft
CJ
ft
>1
ft
JJ
3
0
o
Dl
0
ft
G
-H
Ti
0
CJ
rd 2
rH PQ
ft ft
Eh
td
JJ -
rd
P rH
n
jj
cd o
P rd
jj jj
3 rd
O TJ -
jj TO
G 3 G
0 O
* en ^
0
ft P ft r-l
rd 2 w -
ft <! Eh
CQ ft II
Ti e=C V
G in
rd 2 o
ft w r-i >1
> - m
jj w 3
3 - II ft
ft o V jj
JJ td 3
3 JJ 0 ft
0 rd o JJ
Ti 0 3
JJ JJ ft O .^
-H 3 ft
G O H
HI -
c
1 ft 2
1 H ft
I ft ft
0
ft
rd
ft
en
Ti
C
. td
rH ft
ft
CJ jj
r-i id
P 2
3
ft en
JJ ft G X
H *. ft -H CJ
0 Eh Eh rd
2 ft ft W
ft CO . . ft Sh
ft G H 2 0 2 0 2
^ 0 ft
CJ
r-l ft
ft
rl
TS
ft
ft
>
H
ft
ft
. . JJ ft H in 0 Eh
- 3 II U CJ
r-l ft ^ . 0 . 0 .
~ JJ
3
r-i
rd ft r-l
Ti
G o
Sh
rH
II 0 JJ
rd
CO
ft en CO
~
en
0
ra
- G
0
~
O Ti P Pi G G rd II G II ft II
ft C jj CJ jj C 3
0 id 3 ft m in -. rd H m 0 -H 0 ~
rd ... O - - Ti rH * ft r-l 0 rH -
ft - JJ ft ft o H ft 3 rl ft H CD
* ' CD 3
ft
p ft ft
Eh
- Di
C
ft ft
EH
r-l
0
ft rd
ft
ft ~
P G rH <q ft ft II H ^ ft X en II
II H H esq esq V g P H esq II id P TS P V
< V
CQ
ft
Eh EH CD rn
0
CJ
O
ft
V ft
en ^ '* Ccd ^ _ r-l
. , O 3 - ft 2 o O >1 G r-l rH Ti O ft O >.
Eh rH 0 H CO ft - - II CQ H ^-. II rH C -~ - - . - en
2 rl G rH ft > V 3 ^ V -H rd Eh jj Eh 3
ft rd 0 H ft H II II ft 0 2 II id ft 2 II 3 2 II PQ
> > ^ Sh ft CJ V V G JJ JJ ft c V > ft V ft ft V jj
h < o ft ft EH H 3 > H esq X > JJ > 3
rd jj 0 ft -H 0 r-i ft Ti ft rn rl cd CJ H H 3 ft 0 ft
o JJ u G CO 0 CO rH r-l Di jj G - Di r-l JJ < - rH O - r-l jj
ft rd 0 > CO r-i ft 0 0 0 3 0 -H 0 0 rd -H 0 0 0 3
0 P .~ ft ra ft TS ft ft ft ft O V ft rH ft ft P - ft rH ft ~ ft r-l ft O -.
rd ft rd CJ G CJ ft CQ H ft 0 H ft 0 H ft
P H
ft
CO
CO
ft
ra
0
o
ft
ft
rd
ft
ft H
P
0
ft
ft H
P
Sh
P
ft H
P
in
ft
ft HI
ft
ft 2 CJ r-l 1 ft 2 1 ft 2 1 ft 2 I ft 2
HI ft o
ft
a,
ft
2
ft
Ti
fi
td
ft
i
i
^1
JJ
Sh
0
ft
2
H
CO
W
PQ
1 H W 1 H ft 1 H ft 1 H H
2
HI
U)
Dl ft
C
H
Eh
Ti 0
CJ rd rH
ft 0
P
-H
JJ
>1 0
ft Ti
0
JJ
3
JJ 2 ft
3 c
0 ^ H
r-l Ti
Dl 0 0
0 Ti g
ft C
0
rd
C
C JJ
-H JJ
TJ Pi
rd
G -
1
0 ft ft TJ ,
CJ CD 0 0
cd 2 ft TS TS C -
rH PQ Eh 0 G 0 c
ft ft 2 2 0 ... H 0Eh H JJ o ... JJ -H
rd - JJ , . CJ JJ
JJ - ft TJ id II 0 3 CJ
rd 2 o 0 C ft c Sh 3Q rH ft TJ ft ~ O H JJ Sh
- ft - . G 0 Pi z 2 o P en jj
^ Eh M< 0 Ti pq 2 pq .^ ft JJ C en
id 11 <M JJ 0 CD HI ft TJ 3 HI fi
JJ . o ^ S ft in 0 . ft JJ HI
Cd r-l - rH <: Eh - in TJ 0 C C JJ
Q rd rH 0 II 2 o Ul . G r-l HI 0 G
JJ JJ o Ti * HI ft 0 H ^ Sh 0
3 id in 0 ". II Eh rH JJ .- ft 0 Sh Sh
O Ti ~ II 2 0 o >1 - - jj o JJ rH 3 Sh
JJ en o Ti - rd rd 3 -H CJ 3
G 3 G r-l - 0 Sh ^ G Pi 2 II C ll ft ft - CJ
0 O X Ti 2 II Sh o 0 ft H ^ ft C JJ 0
m ^ 0 >H 0 CJ < H CD ft ft 0 HI 3 C II
0 id - e=q JJ ft >i II JJ ft 01 2 esq TJ C 0 . ft r|
x a ft rH P - ft rn Eh Sh 0 tH HI H O 0 0 rH ft G P
rd 2 W - O ft cd H 0 3 2 ft P 2 H -H P H JJ -
ft < EH - CO esq ft CQ g ft Sh H Eh JJ MH HI - - 3 ft
Ul ft II P CO 0 0 0 W JJ X O II u ft ft a e<
TS est! V jz; II ft CO Ti Ti 2 CD en ft P 3 JJ P 2 c ~-
G Eh 5s V CJ H 0 0 ft C ^ 0 S 0 Sh 3 2 HI H >
rd 2 r-l o 2 2 D> Eh H JJ c S] JJ 0 jj ft ft P Sh
ft ft rH >1 .- . rH Pi >c jj id 2 JJ Sh H Ti TO G P P 0
> - in in rH ft rd G r-l >i H G 0 J . Di 0 C -rl in esq < g
jj ft 3 2 H Sh OO 0 ft Sh 0 ft 0 JJ Eh < - 2 H O ft ft 0
3 - II ft ft td U hi Sh TS 0 Sh 0 rH 3 2 O JJ JJ G 2 Pi ft 2
ft rH V JJ > > ~ esq Sh rd g Sh en -H ft ft JJ G c 0
JJ rd 3 ft <q r-l u >i 0 3 0 0 ft 3 td ft C > 0 II 0 0 ft ft
3 -U 0 ft - rd JJ 0 Sh Ti CJ ft 2 <C CJ CQ JJ H pq TO Sh Sh 0 P
0 rd rH JJ r-l JJ Sh r-i 0 0 3 - Sh in H
Ti 0 3 X rd 0 r-i g 2 ft ft ft ft H ft ft ft P 1 ft 3 3 1 ft
JJ JJ ft O .- CJ P ~ ft 0 0 CJ p P ft ft ft J C P esq 1 esq CJ CJ I 3
H 3 ft td ft u 2 ft ft ft PQ PQ ft ft H CQ o
fi O
H
HI
P
P H
P
CO
CO
PJ
JJ
G
0
ft
ft
<
H HI
ft ft
<
H
ft
<
m
cc
esq
H
Pi
<
H
Pi
e<
H
Pi
ft
P
<
r-i
CC
p
1 ft 2 ft 2 CJ CJ >h >H < est! < esq esS esq H esq ft
1 HI ft H ft o
ft
ft
p
2
ft
g
id
rl
Dl
0
Sh
ft
Eh Eh > > > > > > ft >
2
H
CD
ft
CQ
H
ft
o
ft
o
ra
C
Pi
ft
Eh
ft
<
+
ft
ft ft
esq O
ft
ft
Eh
ft
en
C
II LD
V
p
2
ft
EH O
ft ft
CO
ft Eh
Pi m
ft ft <
II
ft e< HI 3
ft
p
2
pq
2
ft
ft
EH
TJ
0
Ti
C
0
JJ
JJ
td
G
ft
0
Ti
0
2
0
Ti
0
2
jj
G
0
U
U
3
CJ
P
P
ft
<
>i
Sh
0
g
0
2
2
ft
ft
Eh
ft
P
CJ
c
0
H
JJ
CJ
3
Sh
JJ
CO
C
>, H
CQ
3
CQ
JJ
3
ft
jjEh
2
ft
>
ft
- ft
ft HI
P
CJ
ft
2
ft
ft
Eh
CO
m
C
O
jj esq
G
0 n
Sh
U
? %CJ e<
2
ft
ft
EH
en
in
ro
jj
0
n r-t zl o
jj - Sh
jj
II ra
CJ
3
Sh
JJ H
en Di JJ Dl
G td G
0
ll
rd
JJ ft Sh ft
G TJ Sh TS
0 rd
Sh
Sh
3
CJ
0 CJ
P
rd
0
P
ft
ft
OO P
ft P 2
H pq pq
in
in
CM
C
0
H
JJ
CJ
3
Sh
JJ
co
G
H
JJ
G
0
Sh
Sh
3
CJ
P
o
<M 2
ro ft
ft
V Eh
CO
G
O
H
JJ
CJ
3
Sh
JJ
co
G
G
O
H
JJ
CJ
3
Sh
JJ
CQ
G
H
JJ
fi
0
Sh
Sh
3
CJ
ft
Pi
C e<
0 ft
rd ft
0
p I
JJ I
CJ I
3
Sh A
JJ II
CQ
C CM
H [--
JJ CM
G
0 2
Sh ft
Sh ft
3 3
CJ
pq
co
<
CJ
Ti
0
TJ
C
0
JJ
JJ
e=C
0
Ti
0
< II
-~ Eh
Sh esq 0
O 3 Ti
0
I 2
JJ
c
II A 0
II Sh
Sh
ft r- 3
<q in CJ
CM
-H
o
P
2 est!
ft
ft
Eh Eh
2
CD PJ
r- >
CM PJ
CD ft
r- h
CM
2 2
ft PJ
ft ft
3 3
H
ft
P
2
ft
>
PJ
Eh
2
ft
>
ft
Eh
ft
CO
PJ
Pi
CJ
ft
ft
p
HI
Eh
2
ft
3
Eh
2
PJ
Eh
PJ
CO
ft
ft
CJ
ft
W
co
ft
W
e<
ft
p
2 oo
pq in
2
ft
ft
3
Pi
<C
>i
Sh
0
g
0 ...
2
EH
ll 2
ft
c >
H ftl
r-l -
Dl Eh
0 ft
ft Ul .^ ,fc
' ' PJ
ft
ra
G
CQ
G
ft CJ ... .^
O ft CQ
G
en
G
in m
^-~ 2 2 Pi ft 2
- . ft ft LD m PJ PJ PJ .~ ft
ft o ft ft in EH . en ft
< EH ft Pi EH ft ft Ti C Eh
*
- - ft ft < esq 0
>i - CD * EH ~ Eh ^f T in CO
Sh ft CO G ft G ft CO - - G CD
0 < CM -H esq H < CM o o 0 Pi CM
g - O r-i ~ - -^ - JJ ft
0 >1 II Di - Dl - II _. ^^ JJ Eh II
2 Sh
0 o G
0
ft
o 0
ft
o
H C
Pi
<
- Pi
<
rd
C
ft
< Pi C
n g ft 0 Pi 0 r-i r-t ft p 0
*- 0 pj H II .. II ~ * PJ H > - ~ >c - ... 0 - p -rl
G - ^ 2 ft JJ r-i r-t ft JJ Sh rH Sh r-l Ti Eh o esq JJ
H Eh X CJ r-i r-l X CJ 0 II 0 II 0 ft - ... X CJ
O 2 n 3 ^^ + - ^ + - 3 g V + g V + 2 Ul ft 3
Dl ft 1 Sh ft ft 1 Sh 0 0 ft ^ ft < i Sh
0 > CO 3 1 jj esq CC II < Pi II 1 JJ 2 o ft 2 rH CC n ft P i JJ
ft ft ~ Eh CO - in - esq V ' < V en rd esq td e< O CJ rH P n .^ CO
- r-l HI ^^ rH A G >1 >C A G n JJ n JJ Eh o - esC rH A G
^ esq II H Sh II o Sh II rH II H V rd II V rd II ft 0 Pi in II HI
ft ft + 3 ft + JJ 0 ft 0 ft JJ TJ Ti esq TS ft II Ul ^^ + JJ
H CO HI rH G g 0 g 0 m G 0 JJ 0 JJ 0 V ft en c
Eh ft cc 1 Eh ft CO 0 0 Pi rd 0 Pi rd co 0 o 3 ft r-i 3 ft 1 2 1 1 esq ft CD 0
2 ft < 1 2 < CM rl 2 P 2 e< P ~ CM Sh ft O <q ft O <q .* 1 JJ 1 Eh 1 fiC CM Sh
ft u ft Sh ft Sh ft G pq >1 in
ft ii A II O 3 H O 3 H A 0 A CO A Sh II O 3
Eh ' .. II Eh EH CJ ft in CJ ft II Sh II ft II 0 Eh CJ
H H CO P CO p Sh ft g
e=C ft ft <J\ -< ft o ft P 2 rrf ft ft 2 31 3 in ft CO 0 ft co ft
3 o esq in
CM
2
ft
ft
3
3 < CO
CM
2
W
ft
3
H ft ft CO
CM
2
PJ
ft
3
H ft ft CD
rM
2
pq
ft
3
CJ CD
CM
2
ft
ft
3
H CO
CM
2
ft
ft
3
2 esC CD
<M
2
ft
ft
3
HI
2
ft
ft
Eh
CO CQ
fi C
m m
ft ft
ft ft
in ^
ft ft
< <<
CC
e<
II
V
o
o
ft
<q
ft O
cd
n jj
v cd
TJ
0 JJ
rH 3
ft o
W
oo
J
ft
0
rl
JJ
CJ
3
Sh
jj
ra
C
HI
2
A co
ft
2
ft
CO rd
ft ft
P ft
ft i
Eh I
O
2
ft
ft
3
2
ft
ft
in
ft
co
esC
CJ
P
2
ft
TS
0
JJ
rH
rd
ft
0
Ti
0
2
0
TJ
0
2
jj
G
0
Sh
Sh
3
CJ
JJ
H
O
ft
o
JJ
CQ
en
rd
ft
G
0
H
JJ
0
3
Sh
JJ
ra
G
Sh
O
td
jj
td
Ti
td
g
Sh
O
2
ft
HI
CO
p
PJ
PJ
CO
ft
PJ
Pi
PJ
Eh
ft
<
U V
3
CJ CD
rd
II JJ
v id
T5
0 JJ
o 3
ft O
ft
HI
P
2
ft
2
PJ
ft
Eh
Ti
0
JJ
rH
rd
ft
0
Ti
0
2
ft
ft
PJ
ft
ra o
C -
0
Ti ft
0 O
2 ft
jj
P
2 ft
PJ H
Eh
H
ft
P
2
ft
ft
P
2
pq
2
ft
ft
Eh
Ti
0
Ti
c
0
JJ
JJ
<
0
TJ
0
2
P
2
ft
ft
cc
o
ii
ft rH
P "
U II
o
rH
P -H
2 J
est!
rd
Eh JJ
2 rd
ft p
>
H
- ft
ft H
P
CJ
Di
0
ft
II
2
pq
ft C
Eh 0
H
JJ
CJ
rH 3
- Sh
jj
rn
C
O HI
r-i JJ
H fi
Cd 0
> Sh
ft
Dl
0
ft
CJ
3
Sh
JJ
CQ
G
G
0
Sh
Sh
3
CJ
ft
CO
ft
ft
ft
H
P
2
ft
in
m
<M
C
0
H
JJ
U
3
Sh
jj
ra
G
H
JJ
G
0
U
U
3
CJ
ft
ra
C
0
rl
JJ
CJ
3
Sh
JJ
co
G
2
ui
u
o
CC
PJ
in
ft
esq
id
0 >
> <
u cd
0 jj
ra rd
0 P
ft
ll
V
o
ft
CJ
td
P
ft
ft
ft
o
ft
o
ft
o
ft
<
>1
Sh
0
g
0
2
- - Eh
r-l rH n 2
- - ft
II II
G
H
rH
PJ
H H Di Eh
o r-l 0 PJ
H H ft CO
ft ft PJ
" ' " '
Pi
Pi
CJ ... ...
Q - Q '- o ft en
fi
en
G
2 <l e6 <q - . 2 2
ft 2 2 - . Pi ft in in ft
ft - . ft - - pq Pi o ft ft
Eh Eh > Eh > f=C Eh ft ft EH
- 2 W 2 H ' -. . ft ft
Ti CD ft - PJ - >i s , o ... ^ ^ Eh M<
0 C-- > ^ > Eh u in Pi co c ft c ft CO
Ti CM ft PJ ft PJ 0 2 esq CM H < H < CM
C - CO - CO g ft O rH
0 n H ft H PJ 0 > >c II Di - Di - II
ra JJ O Pi rH Pi 2 PJ Sh 0 o 0 o
fi JJ
est:
ft
Eh
C
0
H
ft
CJ
ft
H
ft
CJ
ft ii Eh
0
g
o
ft
C
0
Pi - ft - HI
ft
fi
0
in 0
Ti
H
esq
H
JJ _.
" ' '
c
PJ
CO
0
2
ft
ft
H
JJ
II
r-l
- II
r-l
* ft
ft
rl
JJ
ft .. 0 3 CJ H PJ X CJ rH rH X CJ
ft s~~. 2 3 P J o Pi n 3 . + - ^^ + - 3
EH CC i Sh HI H Dl CJ 1 rl ft Pi 1 Sh
ft CO < n i jj Eh Eh T> 0 ft CO 3 1 JJ esq" CC II esq CC II 1 JJ
< HI Eh CQ 2 2 E-c ft - <en CO v CO * ' < V - e=C V ra
Pi >c H A C ft ft HI *- r-l HI - rH A c >1 >, A C
C esq Sh e< 0 II r-i < esq II HI Sh ll o u II rn II HI
o 0 ft 0 3 Ti JJ Eh Eh 3 P + 3 P + JJ 0 ^ 0 X JJ
- H g 0 r- fi HI H H H rH G g CJ g CJ in c
JJ 1 0 i 2 r- 0 <q esC 1 Eh CC 1 Eh ft CO 0 0 ft id 0 ft rd CO 0
- 0
3
1 2 i JJ
c
CM in
Sh
3 3 1 2
ft
e=C 1 2
ft
esC CM Sh
Sh
2 esC P 2 esq P CM Sh
Sh
rH Sh A n A 0 O 3 HI A II A II o 3 HI O 3
- jj
en
II II Sh
Sh
Eh CJ ft
CO P
II Eh
H
II Eh
H
in CJ ft
CO P
EH O
II C CM ft r- 3 CO ft p 2 00 e< Pi en esC ft o ft P 2 <SP ft
V HI
JJ
r-
CM
< m
CM
CJ f-
CM
H PJ PJ in
CM
3 < in
CM
3 eC co
CM
H ft ft CO
CM
HI
rH c
X 0 2 2 2 2 2 2 2
u u pq ft ft ft ft ft
rd u ft ft ft ft ft ft ft
P
HI
3
CJ
3 3 3 3 3 3 3
PJ ft
CO ft oo
ft 2 esc
H pq CJ
en
G
ft
PJ
Eh
ft
<
CC -
r-t
>l -
Sh
O II
V
0
2 o
cd
jj
td
Ti
JJ
o 3
ft O
0
ft
esq
ft
H
Eh
ft
est!
ft
>c
Sh
0
g
0
2
ft
CO
ft
ft
rd
II JJ
V id
Ti
0 JJ
rH 3
ft O
Pi
e<
ft
TJ
0
TO
G
0
JJ
JJ
td
C
ft
0
TO
0
2
O
Eh
ft 0
esq TO
0
i 2
i jj
G
A 0
II Sh
Sh
=# 3
CD CJ
ft
ft
Eh
ft
<
in o
ft
CO
ft
ft
CJ
<M
2
ft
ft
3
2
ft
ft
3
2
ft
ft
EH
co
CD
CM
Pi
P
P
O - esq
ft EH
ft II CO
v
i i
I Eh I
ft
A CO A
II ft II
ft
in ft co
CO HI CO
CM CM
ft
esq
ft
Pi
P
P
<
X
< CC CD
esq CM
>1
Sh
0
2
ft
ft
3
en
C
Pi
PJ
Eh
ft
esq
G
0
H
JJ
0
3
Sh
JJ
ra
G
HI
JJ
C
0
Sh
Sh
3
CJ
0 ft co ft
2 esq CO HI
CM
2
ft
ft
3
ft
ft
Eh
ft
e=C
ft
esq
cd
jj
cd
Ti
jj
3
O
ft
ft
CO
p
ft
G
0
H
JJ
CJ
3
Sh
JJ
CQ
G
2
A CO
II
TO
rdco
ft ft
P ft
2 ft i
ft EH I
O
2
PJ
ft
3
2
ft
ft
EH
ft
CO
e<
CJ
P
2
PJ
c
o
rl
JJ
CJ
3
Sh
jj
W
G
HI
JJ
c
0
Sh
Sh
3
CJ
TJ
0
JJ
r-l
rd
ft
0
Ti
0
2
ft
H
CO
J
ft
G
0
-H
JJ
0
3
U
JJ
CQ
fi
-H
JJ
o
c
0
Ti
O
g
Ti
0
Ti
C
0
JJ
JJ
rd
Dl
C
0
C
O
P
ft
ft
CO
P
ft
P
2
ft
2
ft
ft
Eh
TJ
0
JJ
r-i
rd
ft
0
Ti
O
2
n
ft
ft
Eh
ft
esq
en o
fi -
m
0 r-l
TS CC -
0 O
2 ft il
JJ V
fi Eh
0) H y
Sh esq J
Sh 3 CJ
ft 3
H CJ
P
2 ft
PJ h
2
ft
ft
Eh
Eh
ft ft
OO o
ft o ^
ft p o
CJ
ft ro II
CM
CD
P r-l , ,
3 o
EH
ft
5
- ^ >1
Eh o Sh
2 0
ft 2 g *
> HI 0 ft ~
... ft 2 O o
ft - ft O
HI Eh
ft
esq ft ll
P CO ft P
2 ft o 2 ft
ft
HI
P
2
ft
ft
CJ
ft
ft
H
ft ft esq
HI
P
2
ft
ft
p
u
Eh rH
ftl rH
co o
W Sh
ft JJ
cj c
ft 0
u
ft
esq
o
J
2
o
EH
H
rd
Sh
Dl
0
Sh
ft
CO
CO
pq
< cj
o
ft
ft
p
2
PJ
Sh
0
H
>
rd
ft
0
pq
U
ft
P
2
PJ
in
CJ
ft CQ
esq
X 2H
H
TO
C
rd
u
ft
ft
-H
<
X
Eh
ft
OO
ft
ftHI rH rH
r-i r-t OO
Sh
0
MH
rd
ft
rd
CJ
H
JJ ft
e<
h
...
5 hj
H ft ra
ft < < 0
0 X X jj
JJ c H HI < en
to 0 X
ft HI
0 ft ft ft H
JJ JJ Pi ft
< en O o Hh
X 0 3 3 ^
H eh r-t
PJ ft ^ P
1 i oo Ul 2 2
] ft ft ft ft
tH Eh
H HI
CQ CQ
ft ft
0 CJ
rd rd
o r-l
v CJ CJ
ft ft ft
PJ CM CM
O ft ft
ft HI H
Eh
2 - -.
H
ft
ft
CD
JJ
H
C
H
JJ
-H
G
H
CQ PJ O rH *- -
3 Eh u CJ ft * Cm
ft 2 ft ft W ft H
3 H CM CM CD ft CO ~ ~ ~
CO ft ft .~ ^ ft CD H ~ Eh ~ ^ v EhCO HI H O o in ft Eh Eh HI Eh H Eh HI
1 1
. 2 Eh 2 H PQ r-i ft HI CQ
CJ CJ ^ - II II ~ - - * HI 2 H PQ PQ PQ
4-J
ft ft X ft - o o o o ft HI Eh Eh EhCQ
CM CM 0 CJ o - - - - H Eh Eh 2 ft 2 ft 2 ft(IJ
ft ft rd td Pi Pi CD ft 2 ft H O H O H o4-J
<q
X
H H o r-l ft H II II II II ft O HI O
O rH ft ft CD CD II Eh
JJ JJ H HI ft ft 21 1
rt Sh CM CM Eh ^ in Eh Eh Eh HI H -H 0 0 rt H
ft
O
0 0 ~ CJ CJ 2 2 Eh H r-i HI H 0 H 0 O CD o o rH r-l
ft ft Eh ft ft H H H PQ pq CQ CQ 2 o rH rH H 0 H 0 H 0
H PQ HI ft ft ft ft ft ft ft ft ft
. .. PQ .. V0
Sh
3
ft ft JJ JJ
-H H H -H O r-l CD rH CM ro
CM CM C G JJ JJ JJ JJ JJ JJ JJ ft H
JJ
U 0 ft H H C C H H H H H H OIS
3
Sh
ft ft -H CD rH H HI CQ PQ PQ CQ PQ < ft
o r-l Eh ft ft >l ft- >i >i >i >i >, X -
JJ JJ ft HI H E E R E g R R HI
JJ
Sh U CO CM CM g g Eh
CO 0 0 PJ CJ CJ 3 3 3 3 3 3 3 Eh Pi
ft ft ft ft ft ft P P P P P P 2 Oft
ft
ft ft
P P P ft ft ft P P P P P P 2ft
EH esq < e< esq esq < <C esq r< < e=C esq o
2 2 2 2 2 2 2 2 2 2 2 2 ftCJ
ft CD CD CD CD
o CD O O CD CD CD CD 2
H HI H H H HI HI H HI HI HI H OEh
H CO CO
CO CO CO CO CO CO CO CO CO CQ CJ
ft
CJ
Pi
<=q
CJ H
V ft o
Eh esq ft
2 X
ft HI
2 Eh
O Eh ft
ft 2 O
2 ft ft
O 2
CJ O
ft
p 2
2 O
ft u
i^
-. ft
Eh O
2 ft
ft
2 0
O ft
ft e<
2 X
o HI
CJ
p
2 CJ
2 ft
H
CD
ft
ft
a CI
H ft
CM CM
(J ft
ft H
O r-i
JJ JJ
Sh Sh
0 0
.- .v CC ^
^ Eh ^ W H
v ^ ~ ^ r-i m CD CQ
in HI Eh Eh PQ PQ W
H CQ H H Eh 2
CQ CQ CQ Eh Eh 2 H
Eh ft ft H
2 ft 2 2 O o
r-t o H H
o rH
Eh
ft
O
Eh
ft
CQ
0 0 O rH ft ft ft
r-l r-i CJ C CJ CJ Pi
H 0 ft ft esq < 3 ft
ft ft H H HI r-t CO H
ft .- Pi Eh
ft ft ft .-. H Eh
CD pq CD ^ ^ * ^ CC ft HI
ft CD ft ~ Eh * Eh v Eh * Eh ft * ft
Eh ft Eh in H in HI Eh H ^ H CD Eh Eh
2 En 2 H CQ H pq HI ft HI CQ pq H ft 2
~ HI 2 HI CQ CQ CQ PQ Eh ft O H
ft H Eh Eh Eh b^ 2
ft Eh Eh 2 ft 2 ft 2 ft 2 ft HI 2
CD ft 2 ft H O H O H O H O HI
ft O HI O 2 ^ Eh
EH H ft W
2 CO CO
H H H 0 0 H H 0 0 P ft pq
0 H 0 CD CD o o rH rH r-l r-l < ft Di
2 o rH r-l H 0 H 0 H 0 H 0 3 O ft CJ
ftftftftftffiftftftftftOOftHlft
U
a
CM
ft
rl
O
JJ
Sh
0
ft
ft
a JJ .. ^ JJ JJ ^ ^ JJ
rl H X X H H X X H
CM c 0 u G G CJ CJ fi ^
0 rl rd rd H H id td H ft U
ft O CD o CD rH rH rH rH ~ .. H ft
r-l CJ CJ ft ft CJ CJ ft ft TO EH Eh Eh
JJ ft ft HI HI ft ft H H 3 Pi H PJ
Sh CM CM CM CM CM (M CM CM ft esq CQ CQ
0 ft ft CJ CJ ft ft CJ CJ 3 Eh ft PJ
ft H HI ft ft HI HI ft ft CO OO Pi ft
u a 0 JJ . ^ JJ JJ ^ ^ JJ . ^
ft H ft rl X ft H H ft X H * CM * ro
CM CM CM C U 0 c G CJ CJ C JJ JJ JJ JJ
a U ft rl cd rd H rt rd rd H H H H H a
rt ft H o o o o r-t rH rH r-i PQ PQ cq ra .. -rl
o r-l rH ft ft CJ CJ ft ft CJ CJ >i >, >! >, w Eh
JJ JJ JJ H HI ft ft HI H ft ft 3 pq
Sh >h Sh CM CM CM CM C\l CM CM CS) g g g ft CO
0 0 0 CJ CJ ft ft CJ CJ ft ft 3 3 3 3 3 PJ
ft ft ft ft ft H HI ft ft H H ft P P P CO ft
a
H
CM
CJ
ft
O
JJ
Sh
0
ft
ft
i^
cc
o
ft
a
H
esC
X
ft
0
Sh
3
JJ
CJ
3
Sh
JJ
OO
C
2
ft
Appendix D - Level 0 Test Program
This appendix contains the source code and assembled listings of the IXA Level 0
test program which tests all Level 0 instructions and several variations. This was
used with both the VHDL and FPGA systems for verification.
; IXA Level 0 Test Program
;A11 Level 0 instructions are tested.
PROCRESET
; PROCESSOR I/O TEST SET
DATA 01
WRITC 0
DATA 02
WRITC 0
READ 0
DATA 03
WRITC 0
READ 0
DATA 04
WRIT 0
WRIT 0
WRIT 0
WRIT 0
WRIT 0
AUTOMATICALLY PUSH 1
SHOULD WRITE 1
AUTOMATICALLY PUSH 2
SHOULD WRITE 2
READ PORT 0
DATA TO BE FED TO PORT 0
SHOULD WRITE 3
READ PORT 0
DATA TO BE FED TO PORT 0
SHOULD WRITE 4
SHOULD WRITE 3
SHOULD WRITE 2
SHOULD WRITE 1
SHOULD WRITE 4 - TEST WRAP-AROUND
; PROCESSOR ALU TEST SET
DATA 01
DATA 01
NOT
WRITC 0
ADD
WRITC 0
DATA 0
ANDC
WRIT 0
DATA &HFF
AND
WRITC 0
DATA 0
DATA 0
OR
WRITC 0
ORC
WRITC 0
DATA &HFF
XORC
WRITC 0
XOR
WRITC 0
DATA &HAA
SLL
WRITC 0
SRL
WRITC 0
DATA &HAA
SLA
WRITC
SRA
WRITC
; SHOULD WRITE FE
; SHOULD WRITE FF
; SHOULD WRITE 0
; SHOULD WRITE FF
; SHOULD WRITE 0
; SHOULD WRITE FF
; SHOULD WRITE 0
; SHOULD WRITE FF
; SHOULD WRITE 54
; SHOULD WRITE 2A
; SHOULD WRITE 54
; SHOULD WRITE 2A
DATA &HAA
SLR
WRITC 0
SLR
WRITC 0
SRR
WRITC 0
SRR
WRITC 0
; PROCESSOR
PROCRESET
PSW
WRITC 0
DATA &HFF
DATA &HFF
ADD
PSW
WRIT 0
DATA 0
SSW
PSW
WRIT 0
PIO
WRIT 0
DATA 1
SIO
PIO
WRIT 0
; PROCESSOR
PSP
WRITC 0
PSP
WRIT 0
DATA 01
DATA 02
DATA 03
WRITC 0
GET 0
WRIT 0
GET 1
WRIT 0
PSP
SSP ANY
WRITC 0
SWAP
WRIT 0
WRIT 0
WRIT 0
SSP ANY
WRIT 0
ADJ ANY,0
; SHOULD WRITE 55
; SHOULD WRITE AA
; SHOULD WRITE 55
; SHOULD WRITE AA
CONTROL TEST SET
; RESET PROCESSOR
; SHOULD WRITE 0
; SHOULD WRITE 0C (NEGATIVE, CARRY)
; SHOULD WRITE 0
; SHOULD WRITE 0
INSTRUCTION BIT OF PORT 0 SHOULD BECOME SET
; SHOULD WRITE 1
STACK MANIPULATION TEST SET
;WRITES CURRENT STACK POINTER FOR BASELINE TEST
WRITES NEW STACK POINTER -
SHOULD BE ONE LESS THAN ABOVE
FILL STACK WITH DATA
; STACK POINTER LEFT POINTING AT 3
; SHOULD WRITE 3
; SHOULD WRITE 3
; SHOULD WRITE 2
; SHOULD WRITE 3
SHOULD WRITE 2
SHOULD WRITE 3
SHOULD WRITE 1
WAS POINTING BACK AT STACK POINTER
SAVED EARLIER, NOW AT 2
SHOULD WRITE 2
WRITC 0
DATA &HFF
DATA &HFF
ADDC
ADJ EQ , 0
WRITC 0
ADJ NE , 0
WRIT 0
WRITC 0
ADJ NEG, 0
WRIT 0
WRITC 0
ADJ CY , 0
WRITC 0
ADJ OV, 0
WRITC 0
ADJ GE, 0
WRITC 0
ADJ LE , 0
WRITC 0
; SHOULD WRITE 1
ADJUST SHOULD FAIL
SHOULD WRITE FE
ADJUST SHOULD SUCCEED
SHOULD WRITE FF
SHOULD WRITE 1
ADJUST SHOULD SUCCEED
SHOULD WRITE 2
SHOULD WRITE FE
ADJUST SHOULD SUCCEED
SHOULD WRITE FF,
ADJ SHOULD FAIL
SHOULD WRITE FF
ADJ SHOULD FAIL
SHOULD WRITE FF
ADJUST SHOULD SUCCEED
WHOULD WRITE 1
Appendix E - VHDL Model Test Results
This appendix lists the results of running the Level 0 test program discussed in
Appendix D on the VHDL model. The columns in the report represent:
1. Time (ns)
2. IP2PCINTT (handshake out from the processor)
3. PC2IPINlT (handshake out from the program controller)
4. SWBUS (the status word)
5. PORT0IP2PC (processor output port 0)
6. PORT0PC2IP (processor input port 0)
Note that the results are slightly different than those run on the FPGA model
because the VHDL model has a larger DS so that wrap-around does not occur at
the same point.
0..0 0 0
25..0 0 0
30. 0 0 1
40..0 0 0
45..0 1 1
50..0 0 1
55..0 0 0
60..0 0 1
70..0 0 0
75 .0 1 1
80 .0 0 1
85..0 0 0
90 .0 0 1
100 ,0 0 0
105 .0 0 1
115 .0 0 0
120 .0 1 1
125 .0 0 1
130 .0 0 0
135 .0 0 1
145 .0 0 0
150 .0 0 1
160 .0 0 0
165 .0 1 1
170..0 0 1
175..0 0 0
180..0 1 1
185..0 0 1
190..0 0 0
195..0 1 1
200..0 0 1
205..0 0 0
210.,0 1 1
215..0 0 1
220..0 0 0
225. 0 1 1
230. 0 0 1
235. 0 0 0
240. 0 0 1
0 80000000 80000000
0 80000000 1
0 80000000 1
0 80000000 188
0 1 188
0 1 188
0 1 2
0 1 2
0 1 188
0 2 188
0 2 188
0 2 180
0 2 180
0 2 3
0 2 3
0 2 188
0 3 188
0 3 188
0 3 180
0 3 180
0 3 4
0 3 4
0 3 184
0 4 184
0 4 184
0 4 184
0 180 184
0 180 184
0 180 184
0 3 184
0 3 184
0 3 184
0 180 184
0 180 184
0 180 184
0 2 184
0 2 184
0 2 1
0 2 1
250.0 0 0
255.0 0 1
265.0 0 0
270.0 0 1
280.0 0 0
285.0 1 1
290.0 0 1
295.0 0 0
300.0 0 1
310.0 0 0
315.0 1 1
320.0 0 1
325.0 0 0
330.0 0 1
340.0 0 0
345.0 0 1
355.0 0 0
360.0 1 1
365.0 0 1
370.0 0 0
375.0 0 1
385.0 0 0
390.0 0 1
400.0 0 0
405.0 1 1
410.0 0 1
415.0 0 0
420.0 0 1
430.0 0 0
435.0 0 1
445.0 0 0
450.0 0 1
460.0 0 0
465.0 1 1
470.0 0 1
475.0 0 0
480.0 0 1
490.0 0 0
495.0 1 1
0 2 1
0 2 1
0 2 141
1 2 141
1 2 188
1 1 188
1 1 188
1 1 150
0 1 150
0 1 188
0 2 188
0 2 188
0 2 0
0 2 0
0 2 143
1 2 143
1 2 184
1 0 184
1 0 184
1 0 FF
1 0 FF
1 0 142
0 0 142
0 0 188
0 2 188
0 2 188
0 2 0
0 2 0
0 2 0
0 2 0
0 2 144
1 2 144
1 2 188
1 0 188
1 0 188
1 0 145
1 0 145
1 0 188
1 0 188
500.0 0 1
505.0 0 0
510.0 0 1
520.0 0 0
525.0 0 1
535.0 0 0
540.0 1 1
545.0 0 1
550.0 0 0
555.0 0 1
565.0 0 0
570.0 1 1
575.0 0 1
580.0 0 0
585.0 0 1
595.0 0 0
600.0 0 1
610.0 0 0
615.0 1 1
620.0 0 1
625.0 0 0
630.0 0 1
640.0 0 0
645.0 1 1
650.0 0 1
655.0 0 0
660.0 0 1
670.0 0 0
675.0 0 1
685.0 0 0
690.0 1 1
695.0 0 1
700.0 0 0
705.0 0 1
715.0 0 0
720.0 1 1
725.0 0 1
730.0 0 0
735.0 0 1
1 0 188
1 0 FF
1 0 FF
1 0 147
8 0 147
8 0 188
8 FF 188
8 FF 188
8 FF 146
8 FF 146
8 FF 188
8 FF 188
8 FF 188
8 FF AA
3 FF AA
8 FF 148
4 FF 148
4 FF 188
4 54 188
4 54 188
4 54 149
0 54 149
0 54 188
0 2A 188
0 2A 188
0 2A AA
0 2A AA
0 2A 14A
6 2A 14A
6 2A 188
6 54 188
6 54 188
6 54 14B
0 54 14B
0 54 188
0 2A 188
0 2A 188
0 2A AA
0 2A AA
745.0 0 0
750.0 0 1
760.0 0 0
765.0 1 1
770.0 0 1
775.0 0 0
780.0 0 1
790.0 0 0
795.0 1 1
800.0 0 1
805.0 0 0
810.0 0 1
820.0 0 0
825.0 1 1
830.0 0 1
835.0 0 0
840.0 0 1
850.0 0 0
855.0 1 1
860.0 0 1
865.0 0 0
870.0 0 1
880.0 0 0
885.0 1 1
890.0 0 1
895.0 0 0
900.0 0 1
910.0 0 0
915.0 0 1
925.0 0 0
930.0 0 1
940.0 0 0
945.0 0 1
955.0 0 0
960.0 1 1
965.0 0 1
970.0 0 0
975.0 0 1
985.0 0 0
0 2A 14C
4 2A 14C
4 2A 188
4 55 188
4 55 188
4 55 14C
8 55 14C
8 55 188
8 AA 188
8 AA 188
8 AA 14D
0 AA 14D
0 AA 188
0 55 188
0 55 188
0 55 14D
C 55 14D
C 55 188
c AA 188
c AA 188
c AA 160
c AA 160
c AA 188
c c 188
c C 188
c C FF
c C FF
c C FF
c C FF
c c 150
c c 150
c c 160
c c 160
c c 184
c c 184
c c 184
c c 0
c c 0
c c 161
990. 0 0 1
1000. 0 0 0
1005. 0 0 1
1015. 0 0 0
1020. 0 1 1
1025. 0 0 1
1030. 0 0 0
1035..0 0 1
1045..0 0 0
1050.,0 1 1
1055..0 0 1
1060..0 0 0
1065..0 0 1
1075..0 0 0
1080..0 0 1
1090 .0 0 0
1095 .0 0 1
1105 .0 0 0
1110 .0 1 1
1115 .0 0 1
1120 .0 0 0
1125 .0 0 1
1135 .0 0 0
1140 .0 1 1
1145 .0 0 1
1150 .0 0 0
1155 .0 0 1
1165 .0 0 0
1170 .0 1 1
1175 .0 0 1
1180 .0 0 0
1185 .0 0 1
1195 .0 0 0
1200..0 0 1
1210..0 0 0
1215..0 0 1
1225..0 0 0
1230,,0 1 1
1235,,0 0 1
0 c 161
0 c 160
0 c 160
0 c 184
0 0 184
0 0 184
0 0 164
0 0 164
0 0 184
0 0 184
0 0 184
0 0 1
0 0 1
0 0 165
0 0 165
0 0 164
0 0 164
0 0 184
0 101 184
0 101 184
0 101 162
0 101 162
0 101 188
0 106 188
0 106 188
0 106 162
0 106 162
0 106 184
0 105 184
0 105 184
0 105 1
0 105 1
0 105 2
0 105 2
0 105 3
0 105 3
0 105 188
0 103 188
0 103 188
1240. 0 0 0
1245. 0 0 1
1255. 0 0 0
1260. 0 1 1
1265. 0 0 1
1270. 0 0 0
1275. 0 0 1
1285. 0 0 0
1290. 0 1 1
1295. 0 0 1
1300..0 0 0
1305..0 0 1
1315..0 0 0
1320..0 0 1
1330..0 0 0
1335 .0 1 1
1340 .0 0 1
1345 .0 0 0
1350 .0 0 1
1360 .0 0 0
1365 .0 1 1
1370 .0 0 1
1375 .0 0 0
1380 .0 1 1
1385 .0 0 1
1390 .0 0 0
1395 .0 1 1
1400 .0 0 1
1405 .0 0 0
1410 .0 0 1
1420 .0 0 0
1425 .0 1 1
1430 .0 0 1
1435 .0 0 0
1440 .0 0 1
1450 .0 0 0
1455 .0 1 1
1460 .0 0 1
1465 .0 0 0
0 103 1AO
0 103 1A0
0 103 184
0 103 184
0 103 184
0 103 1A1
0 103 1A1
0 103 184
0 102 184
0 102 184
0 102 162
0 102 162
0 102 ICO
0 102 ICO
0 102 188
0 103 188
0 103 188
0 103 192
0 103 192
0 103 184
0 102 184
0 102 184
0 102 184
0 103 184
0 103 184
0 103 184
0 101 184
0 101 184
0 101 ICO
0 101 ICO
0 101 184
0 1FE 184
0 1FE 184
0 1FE ICO
0 1FE ICO
0 1FE 188
0 1AA 188
0 1AA 188
0 1AA FF
1470. 0 0 1
1480. 0 0 0
1485. 0 0 1
1495. 0 0 0
1500. 0 0 1
1510. 0 0 0
1515. 0 0 1
1525..0 0 0
1530..0 1 1
1535.,0 0 1
1540..0 0 0
1545.,0 0 1
1555..0 0 0
1560..0 1 1
1565..0 0 1
1570..0 0 0
1575..0 1 1
1580 .0 0 1
1585 .0 0 0
1590 .0 0 1
1600 .0 0 0
1605 .0 1 1
1610 .0 0 1
1615 .0 0 0
1620 .0 1 1
1625 .0 0 1
1630 .0 0 0
1635 .0 0 1
1645 .0 0 0
1650 .0 1 1
1655 .0 0 1
1660 .0 0 0
1665 .0 0 1
1675 .0 0 0
1680 .0 1 1
1685 .0 0 1
1690 .0 0 0
1695 .0 0 1
1705..0 0 0
0 1AA FF
0 1AA FF
0 1AA FF
0 1AA 151
C 1AA 151
C 1AA 1C1
C 1AA 1C1
C 1AA 188
c 1FE 188
c 1FE 188
c 1FE 1C2
c 1FE 1C2
c 1FE 184
c IFF 184
c IFF 184
c IFF 188
c 1AA 188
c 1AA 188
c 1AA 1C3
c 1AA 1C3
c 1AA 184
c 1AA 184
c 1AA 184
c 1AA 188
c 102 188
c 102 188
c 102 1C4
c 102 1C4
c 102 188
c 102 188
c 102 188
c 102 1C5
c 102 1C5
c 102 188
c 102 188
c 102 188
c 102 1C6
c 102 1C6
c 102 188
1710.0 1 1 C 102 188
1715.0 0 1 C 102 188
1720.0 0 0 C 102 1C7
1725.0 0 1 C 102 1C7
1735.0 0 0 C 102 188
1740.0 1 1 C 102 188
1745.0 0 1 C 102 188
1750.0 0 0 C 102 188
Time (ns) "/ ip2pc0init 'Vport0ip2pc
~/pc2 ipOinit /\ /port0pc2ip
~ / swbus
The second test run on the VHDL model was to verify that instructions could be
loaded executed from the stack. The following short program loads a subprogram
which, when executed, increments and writes the number on the top of the DS.
Note that the subprogrammust load in the reverse of execution order. The results
of executing this program are shown in the timing diagram below.
LOAD 166
HALT 170
WRITC 188
ADD 150
INST 1 101
PUSH 190
RESUME 167
DATA 0 0
EXEC ANY 178
END FFFF
BEGIN LOADING PROGRAM
END OF SUBPROGRAM
WRITE TOS BUT PRESERVE IT
ADD THE TWO NUMBERS
CONSTANT '1' ENCODED AS AN
INSTRUCTION TO GET IT ON TO
THE IS
PUSH THE NEXT IS NUMBER ON TO
THE TOP OF THE DS .
RESUME NORMAL MODE
PUSH A ' 0 ' ON TO THE DS
EXECUTE THE SUBPROGRAM
DONE
/ 1 papcLimit
/pc2ip0init
/fesetip
/swbus X0
JLJULJL
A<80 J0 _VG
/port0ip2pc yaoonoooo
/PoL-topc2ip yB0000000 )(T7GXnG)(i8GXi5o )(itjT~Xi9o XGTXo * XTtT
/start
/lesetpc
0.0 100.0
Time (ns)
Jx
_<_
Appendix F - FPGA Logic Diagrams
This appendix contains the logic diagrams used in the generation of the final
FPGA-based processor. These were created inMentor Graphics NETED, v7.
There are eight diagrams:
1. Top Level Schematic
2. ALU Bit
3. Arithmetic/LogicUnit
4. Input/OutputUnit
5. Data Stack
6. Control Register Block
7. Clock Phase Generator
8. Control Unit
*M&MmMMM&>
_$MS
?**** HHUH,. i
3
o
>.
rA CO
2 05
S C5
OO
- c5u r , bd h <-
tonGgtc
d&A

Schematic F-3
Arithmetic/Logic Unit
IXAipl08
Matthew Dinmore
September, 1993
LOO
IHIO
DockO
RasatO
Schematic F-4
Input/Output Unit
IXAipl08
Matthew Dinmore
September, 1993
ODow
OIHo
tOotoO-
0H1O-
C^-
DFCl
tCLK
CLE-
-OOHo
180
HO
ISO
130
mo
ISO
160
170
&-
OlnQ
Olnl
O-ln-
01n3
OlnU
OlnS
Oin6
01n7
outBO
outlO
out20
OoB
Ool
Oo2
o * oj en =* in to r-
oooooooo
o__oc_oooo
I 4000000
WT\W
CO
n.
'V K
\K
I
Xg!X\fe!X\f^
-h cm en =* in en r- od
aaooaooa
-*CMcnalincDi^oo
-<CM(-a,l/)(Dr~0D
CMcozi<int_i^e_
99T9T999
r-
Ey _ \ ,iy
r^
(V
u co
2 01
uo O a ai
1
XO BgCO
cmn ; in co r- oo
looooaao
cm m =* mm r-oo
gap
. . r iy (ij ^j- u.
r-
9,i
\
-< CM II) a1 in CO 1^ (D
cm en _-in_>i^od
goaacpep no
SPHIO-
SPHBO-
SPlinO-
SPBlnO-
LoodSPO-
EnoSPO-
LOinO
_qE^
r unoj}
-a
_u^y
I
; DFM3
^__
J DFH3
_Jk_
-OSPfloutQ
-OSPfloutl
jO*)1-
B-i Vt
_ flNDS}-'
-OBusl
OBusB
RESET_>
Schematic F-6
Control Register Block
IXAipl08
Matthew Dinmore
September, 1993
Hold6C^
Sklp20-
RESETO-
DowO-
EXTCLKO-
E>
noiR.
-D Q
ofcir
oCLK
-D Q
DFC1R
oCLK
-D Q
DFC1R
-c>CLK
n.R
-D Q
DFClfl
cCLK
n.R
-U^y
-OPHI6
-OPHI7
-OPHI4
^rndz)^ OPHI5
-OPHI2
-OPHI3
-OPHIQ
3_"rnd2^ OPHi:
Schematic F-7
Clock Phase Generator
IXAipl08
Matthew Dinmore
September, 1993
mA
a A
I I
Si
JQ1
s s
*1
ooooo
cjcjocjoctoo
(71Tlf7"?'7'7''7"7
[iJlJJLiJ_Jl_J_ULlJll
a a
M6MM_
_=
tH CO
2 os
Q *
i-tsslf
0 r "i. >< *=_ ,9
iicSiSe!
G^>J
Hi3
-M
Wf
6.
Appendix G - Test Results for the FPGA System
This appendix contains the simulation results for the Level 0 test program run on
the FPGA model. It was run against the back-annotated model using maximum
delays.
The simulation results have been annotated along the right-hand side to make
them easier to follow.
TIME ^inbus ASWs ASWc "SWz ^IHo '"OHo
"^outbus ASWn "SWv ~IHi AOHi
0.0 OOOz 000 X X X X X lz 0 Oz 0 ; processor
55.2 OOOz 000 X X 0 X X lz 0 Oz 0
55.8 OOOz 000 0 X 0 X X lz 0 Oz 0
57.2 OOOz 000 0 x 0 X 0 lz 0 Oz 0
58.0 OOOz 000 0 X 0 0 0 lz 0 Oz 0
68.9 OOOz 000 0 0 0 0 0 lz 0 Oz 0
5000.0 OOOz 000 0 0 0 0 0 Oz 0 Oz 0
6000.0 OOOz 000 0 0 0 0 0 lz 0 Oz 0
10064.8 OOOz 000 0 0 0 0 0 lz 1 Oz 0
11000.0 OOOz 000 0 0 0 0 0 Oz 1 Oz 0
11047.6 OOOz 000 0 0 0 0 0 Oz 0 Oz 0
12000.0 OOlz 000 0 0 0 0 0 lz 0 Oz 0 ; load a ' 1 '
16064.8 OOlz 000 0 0 0 0 0 lz 1 Oz 0
17000.0 OOlz 000 0 0 0 0 0 Oz 1 Oz 0
17047.6 OOlz 000 0 0 0 0 0 Oz 0 Oz 0
18000.0 188z 000 0 0 0 0 0 lz 0 Oz 0 ;wr i t e a ' 1
20603 .4 188z 000 0 0 0 0 0 lz 1 Oz 0
23000.0 188z 000 0 0 0 0 0 Oz 1 Oz 0
23047.6 188z 000 0 0 0 0 0 Oz 0 Oz 0
23070.3 188z 001 0 0 0 0 0 Oz 0 Oz 0
23078.0 188z 001 0 0 0 0 0 Oz 0 Oz 1
25000.0 188z 001 0 0 0 0 0 Oz 0 lz 1
25046.0 188z 001 0 0 0 0 0 Oz 0 lz 0
26000.0 188z 001 0 0 0 0 0 Oz 0 Oz 0
27000.0 002z 001 0 0 0 0 0 lz 0 Oz 0 ; load a ' 2 '
31064.8 002z 001 0 0 0 0 0 lz 1 Oz 0
32000.0 002z 001 0 0 0 0 0 Oz 1 Oz 0
32047.6 002z 001 0 0 0 0 0 Oz 0 Oz 0
33000.0 188z 001 0 0 0 0 0 lz 0 Oz 0 ;write a '2
35603.4 188z 001 0 0 0 0 0 lz 1 Oz 0
38000.0 188z 001 0 0 0 0 0 Oz 1 Oz 0
38047.6 188z 001 0 0 0 0 0 Oz 0 Oz 0
38070.8 188z 003 0 0 0 0 0 Oz 0 Oz 0
38071.4 188z 002 0 0 0 0 0 Oz 0 Oz 0
38078.0 188z 002 0 0 0 0 0 Oz 0 Oz 1
40000.0 188z 002 0 0 0 0 0 Oz 0 lz 1
40046.0 188z 002 0 0 0 0 0 Oz 0 lz 0
41000.0 188z 002 0 0 0 0 0 Oz 0 Oz 0
42000.0 180z 002 0 0 0 0 0 lz 0 Oz 0 ; read a . . .
44603 .4 180z 002 0 0 0 0 0 lz 1 Oz 0
47000.0 180z 002 0 0 0 0 0 Oz 1 Oz 0
47047.6 180z 002 0 0 0 0 0 Oz 0 Oz 0
48000 .0 003z 002 0 0 0 0 0 lz 0 Oz 0 ;
'3'
48113.9 003z 002 0 0 0 0 0 lz 1 Oz 0
53000 .0 003z 002 0 0 0 0 0 Oz 1 Oz 0
53047.6 003z 002 0 0 0 0 0 Oz 0 Oz 0
54000.0 188z 002 0 0 0 0 0 lz 0 Oz 0 ;wr i t e a '3
56603 .4 188z 002 0 0 0 0 0 lz 1 Oz 0
59000.0 188z 002 0 0 0 0 0 Oz 1 Oz 0
59047.6 188z 002 0 0 0 0 0 Oz 0 Oz 0
59070.3 188z 003 0 0 0 0 0 Oz 0 Oz 0
59078.0 188z 003 0 0 0 0 0 Oz 0 Oz 1
61000 .0 188z 003 0 0 0 0 0 Oz 0 lz 1
reset
TIME "inbus ~SWs ASWc ASWz ~IHo AOHo
Aoutbus '-SWn ASWv AIHi AOHi
61046. 0 188z 003 0 0 0 0 0 Oz 0 lz 0
62000. 0 188z 003 0 0 0 0 0 Oz 0 Oz 0
63000. 0 180z 003 0 0 0 0 0 lz 0 Oz 0
65603. 4 180z 003 0 0 0 0 0 lz 1 Oz 0
68000. 0 180z 003 0 0 0 0 0 Oz 1 Oz 0
68047. 6 180z 003 0 0 0 0 0 Oz 0 Oz 0
69000. 0 004z 003 0 0 0 0 0 lz 0 Oz 0
69113. 9 004z 003 0 0 0 0 0 lz 1 Oz 0
74000. 0 004z 003 0 0 0 0 0 Oz 1 Oz 0
74047. 6 004z 003 0 0 0 0 0 Oz 0 Oz 0
75000. 0 184z 003 0 0 0 0 0 lz 0 Oz 0
77603. 4 184z 003 0 0 0 0 0 lz 1 Oz 0
80000. 0 184z 003 0 0 0 0 0 Oz 1 Oz 0
80047..6 184z 003 0 0 0 0 0 Oz 0 Oz 0
80071..4 184z 002 0 0 0 0 0 Oz 0 Oz 0
80071..5 184z 006 0 0 0 0 0 Oz 0 Oz 0
80071..9 184z 004 0 0 0 0 0 Oz 0 Oz 0
80078, 0 184z 004 0 0 0 0 0 Oz 0 Oz 1
82000,.0 184z 004 0 0 0 0 0 Oz 0 lz 1
82046..0 184z 004 0 0 0 0 0 Oz 0 lz 0
83000..0 184z 004 0 0 0 0 0 Oz 0 Oz 0
84000..0 184z 004 0 0 0 0 0 lz 0 Oz 0
86603 . 4 184z 004 0 0 0 0 0 lz 1 Oz 0
89000..0 184z 004 0 0 0 0 0 Oz 1 Oz 0
89047 .6 184z 004 0 0 0 0 0 Oz 0 Oz 0
89070 .3 184z 005 0 0 0 0 0 Oz 0 Oz 0
89070 .8 184z 007 0 0 0 0 0 Oz 0 Oz 0
89073 .2 184z 003 0 0 0 0 0 Oz 0 Oz 0
89078 .0 184z 003 0 0 0 0 0 Oz 0 Oz 1
91000 .0 184z 003 0 0 0 0 0 Oz 0 lz 1
91046 .0 184z 003 0 0 0 0 0 Oz 0 lz 0
92000 .0 184z 003 0 0 0 0 0 Oz 0 Oz 0
93000 .0 184z 003 0 0 0 0 0 lz 0 Oz 0
95603 .4 184z 003 0 0 0 0 0 lz 1 Oz 0
98000 .0 184z 003 0 0 0 0 0 Oz 1 Oz 0
98047 .6 184z 003 0 0 0 0 0 Oz 0 Oz 0
98071 .4 184z 002 0 0 0 0 0 Oz 0 Oz 0
98078 .0 184z 002 0 0 0 0 0 Oz 0 Oz 1
100000 .0 184z 002 0 0 0 0 0 Oz 0 lz 1
100046 .0 184z 002 0 0 0 0 0 Oz 0 lz 0
101000 .0 184z 002 0 0 0 0 0 Oz 0 Oz 0
102000 .0 184z 002 0 0 0 0 0 lz 0 Oz 0
104603 .4 184z 002 0 0 0 0 0 lz 1 Oz 0
107000 .0 184z 002 0 0 0 0 0 Oz 1 Oz 0
107047 .6 184z 002 0 0 0 0 0 Oz 0 Oz 0
107070 .3 184z 003 0 0 0 0 0 Oz 0 Oz 0
107071 .9 184z 001 0 0 0 0 0 Oz 0 Oz 0
107078 .0 184z 001 0 0 0 0 0 Oz 0 Oz 1
109000 .0 184z 001 0 0 0 0 0 Oz 0 lz 1
109046 .0 184z 001 0 0 0 0 0 Oz 0 lz 0
110000 .0 184z 001 0 0 0 0 0 Oz 0 Oz 0
111000 .0 184z 001 0 0 0 0 0 lz 0 Oz 0
113603 .4 184z 001 0 0 0 0 0 lz 1 Oz 0
read a .
write a
;wr i te a
;wr i te a ' 2 '
: wr i te a ' 1 '
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
Aoutbus ASWn ASWv "IHi ~OHi
116000..0 184z 001 0 0 0 0 0 Oz 1 Oz 0
116047..6 184z 001 0 0 0 0 0 Oz 0 Oz 0
116071.,4 184z 000 0 0 0 0 0 Oz 0 Oz 0
116071.,5 184z 004 0 0 0 0 0 Oz 0 Oz 0
116078.,0 184z 004 0 0 0 0 0 Oz 0 Oz 1
118000,,0 184z 004 0 0 0 0 0 Oz 0 lz 1
118046,.0 184z 004 0 0 0 0 0 Oz 0 lz 0
119000,.0 184z 004 0 0 0 0 0 Oz 0 Oz 0
120000,.0 OOlz 004 0 0 0 0 0 lz 0 Oz 0
124064..8 OOlz 004 0 0 0 0 0 lz 1 Oz 0
125000..0 OOlz 004 0 0 0 0 0 Oz 1 Oz 0
125047..6 OOlz 004 0 0 0 0 0 Oz 0 Oz 0
126000..0 OOlz 004 0 0 0 0 0 lz 0 Oz 0
130064..8 OOlz 004 0 0 0 0 0 lz 1 Oz 0
131000,.0 OOlz 004 0 0 0 0 0 Oz 1 Oz 0
131047 .6 OOlz 004 0 0 0 0 0 Oz 0 Oz 0
132000 .0 141z 004 0 0 0 0 0 lz 0 Oz 0
134603 .4 141z 004 0 0 0 0 0 lz 1 Oz 0
137000 .0 141z 004 0 0 0 0 0 Oz 1 Oz 0
137047 .6 141z 004 0 0 0 0 0 Oz 0 Oz 0
137088 .4 141z 004 0 1 0 0 0 Oz 0 Oz 0
138000 .0 188z 004 0 1 0 0 0 lz 0 Oz 0
140603 .4 188z 004 0 1 0 0 0 lz 1 Oz 0
143000 .0 188z 004 0 1 0 0 0 Oz 1 Oz 0
143047 .6 188z 004 0 1 0 0 0 Oz 0 Oz 0
143069 .8 188z OOC 0 1 0 0 0 Oz 0 Oz 0
143070 .4 188z 04C 0 1 0 0 0 Oz 0 Oz 0
143070 .8 188z 04E 0 1 0 0 0 Oz 0 Oz 0
143071 .1 188z 05E 0 1 0 0 0 Oz 0 Oz 0
143071 .5 188z OFE 0 1 0 0 0 Oz 0 Oz 0
143078 .0 188z OFE 0 1 0 0 0 Oz 0 Oz 1
145000 .0 188z OFE 0 1 0 0 0 Oz 0 lz 1
145046 .0 188z OFE 0 1 0 0 0 Oz 0 lz 0
146000 .0 188z OFE 0 1 0 0 0 Oz 0 Oz 0
147000 .0 150z OFE 0 1 0 0 0 lz 0 Oz 0
149603 .4 150z OFE 0 1 0 0 0 lz 1 Oz 0
152000 .0 150z OFE 0 1 0 0 0 Oz 1 Oz 0
152047 .6 150z OFE 0 1 0 0 0 Oz 0 Oz 0
153000 .0 188z OFE 0 1 0 0 0 lz 0 Oz 0
155603 .4 188z OFE 0 1 0 0 0 lz 1 Oz 0
158000 .0 188z OFE 0 1 0 0 0 Oz 1 Oz 0
158047 .6 188z OFE 0 1 0 0 0 Oz 0 Oz 0
158070 .3 188z OFF 0 1 0 0 0 Oz 0 Oz 0
158078 .0 188z OFF 0 1 0 0 0 Oz 0 Oz 1
160000 .0 188z OFF 0 1 0 0 0 Oz 0 lz 1
160046 .0 188z OFF 0 1 0 0 0 Oz 0 lz 0
161000 .0 188z OFF 0 1 0 0 0 Oz 0 Oz 0
162000 .0 OOOz OFF 0 1 0 0 0 lz 0 Oz 0
166064 .8 OOOz OFF 0 1 0 0 0 lz 1 Oz 0
167000 .0 OOOz OFF 0 1 0 0 0 Oz 1 Oz 0
167047 .6 OOOz OFF 0 1 0 0 0 Oz 0 Oz 0
168000 .0 143z OFF 0 1 0 0 0 lz 0 Oz 0
170603 .4 143z OFF 0 1 0 0 0 lz 1 Oz 0
;wr i t e a
load a ' 1 '
load a
; invert it
; write
' FE '
: add ' 1 ' + ' FE '
:write
'FF'
load
;ANDC it
TIME Ainbus ASWs ASWc ASWz -IHo AOHo
"outbus ASWn ASWv AIHi AOHi
173000. 0 143z OFF 0 1 0 0 0 Oz 1 Oz 0
173047 . 6 143z OFF 0 1 0 0 0 Oz 0 Oz 0
173077. 5 143z OFF 0 1 0 0 1 Oz 0 Oz 0
173092. 7 143z OFF 0 0 0 0 1 Oz 0 Oz 0
174000. 0 184z OFF 0 0 0 0 1 lz 0 Oz 0
176603 . 4 184z OFF 0 0 0 0 1 lz 1 Oz 0
179000. 0 184z OFF 0 0 0 0 1 Oz 1 Oz 0
179047. 6 184z OFF 0 0 0 0 1 Oz 0 Oz 0
179071..3 184z 0B7 0 0 0 0 1 Oz 0 Oz 0
179071..4 184z 0B6 0 0 0 0 1 Oz 0 Oz 0
179071.,9 184z 0A4 0 0 0 0 1 Oz 0 Oz 0
179072..5 184z 024 0 0 0 0 1 Oz 0 Oz 0
179073 .,2 184z 000 0 0 0 0 1 Oz 0 Oz 0
179078.,0 184z 000 0 0 0 0 1 Oz 0 Oz 1
181000.,0 184z 000 0 0 0 0 1 Oz 0 lz 1
181046.,0 184z 000 0 0 0 0 1 Oz 0 lz 0
182000..0 184z 000 0 0 0 0 1 Oz 0 Oz 0
183000..0 OFFz 000 0 0 0 0 1 lz 0 Oz 0
187064..8 OFFz 000 0 0 0 0 1 lz 1 Oz 0
188000,.0 OFFz 000 0 0 0 0 1 Oz 1 Oz 0
188047,,6 OFFz 000 0 0 0 0 1 Oz 0 Oz 0
189000 .0 142z 000 0 0 0 0 1 lz 0 Oz 0
191603 .4 142z 000 0 0 0 0 1 lz 1 Oz 0
194000 .0 142z 000 0 0 0 0 1 Oz 1 Oz 0
194047 .6 142z 000 0 0 0 0 1 Oz 0 Oz 0
194079 .5 142z 000 0 0 0 0 0 Oz 0 Oz 0
194088 .4 142z 000 0 1 0 0 0 Oz 0 Oz 0
195000 .0 188z 000 0 1 0 0 0 lz 0 Oz 0
197603 .4 188z 000 0 1 0 0 0 lz 1 Oz 0
200000 .0 188z 000 0 1 0 0 0 Oz 1 Oz 0
200047 .6 188z 000 0 1 0 0 0 Oz 0 Oz 0
200069 .8 188z 008 0 1 0 0 0 Oz 0 Oz 0
200070 .3 188z 009 0 1 0 0 0 Oz 0 Oz 0
200070 .4 188z 049 0 1 0 0 0 Oz 0 Oz 0
200070 .8 188z 04B 0 1 0 0 0 Oz 0 Oz 0
200071 .1 188z 05B 0 1 0 0 0 Oz 0 Oz 0
200071 .5 188z OFF 0 1 0 0 0 Oz 0 Oz 0
200078 .0 188z OFF 0 1 0 0 0 Oz 0 Oz 1
202000 .0 188z OFF 0 1 0 0 0 Oz 0 lz 1
202046 .0 188z OFF 0 1 0 0 0 Oz 0 lz 0
203000 .0 188z OFF 0 1 0 0 0 Oz 0 Oz 0
204000 .0 OOOz OFF 0 1 0 0 0 lz 0 Oz 0
208064 .8 OOOz OFF 0 1 0 0 0 lz 1 Oz 0
209000 .0 OOOz OFF 0 1 0 0 0 Oz 1 Oz 0
209047 .6 OOOz OFF 0 1 0 0 0 Oz 0 Oz 0
210000 .0 OOOz OFF 0 1 0 0 0 lz 0 Oz 0
214064 .8 OOOz OFF 0 1 0 0 0 lz 1 Oz 0
215000 .0 OOOz OFF 0 1 0 0 0 Oz 1 Oz 0
215047 .6 OOOz OFF 0 1 0 0 0 Oz 0 Oz 0
216000 .0 144z OFF 0 1 0 0 0 lz 0 Oz 0
218603 .4 144z OFF 0 1 0 0 0 lz 1 Oz 0
221000 .0 144z OFF 0 1 0 0 0 Oz 1 Oz 0
221047 .6 144z OFF 0 1 0 0 0 Oz 0 Oz 0
wr i te a ' 0
load an ' FF '
;AND it
;write an 'FF
load a ' 0
load a ' 0
:0R them
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
Aoutbus ASWn ASWv AIHi AOHi
221077.5 144z OFF 01001 OzOOzO
221092.7 144z OFF 00001 OzOOzO
222000.0 188z OFF 00001 lzOOzO ;write a '0'
224603.4 188z OFF 00001 lzlOzO
227000.0 188z OFF 00001 OzlOzO
227047.6 188z OFF 00001 OzOOzO
227071.3 188z 0B7 0 0 0 0 1 Oz 0 Oz 0
227071.4 188z 0B6 00001 OzOOzO
227071.9 188z 0A4 00001 OzOOzO
227072.5 188z 024 00001 OzOOzO
227073.2 188z 000 00001 OzOOzO
227078.0 188z 000 OOOOlOzOOzl
229000.0 188z 000 00001 OzOlzl
229046.0 188z 000 00001 OzOlzO
230000.0 188z 000 00001 OzOOzO
231000.0 145z 000 00001 lzOOzO ; ORC them
233603.4 145z 000 00001 lzlOzO
236000.0 145z 000 0 0 0 0 1 Oz 1 Oz 0
236047.6 145z 000 0 0 0 0 1 Oz 0 Oz 0
236079.5 145z 000 00000 OzOOzO
236088.4 145z 000 OlOOOOzOOzO
237000.0 188z 000 01000 lzOOzO ;write an ' FF '
239603.4 188z 000 01000 lzlOzO
242000.0 188z 000 01000 OzlOzO
242047.6 188z 000 01000 OzOOzO
242069.8 188z 008 01000 OzOOzO
242070.3 188z 009 01000 OzOOzO
242070.4 188z 049 01000 OzOOzO
242070.8 188z 04B 01000 OzOOzO
242071.1 188z 05B 01 0 0 0 Oz 0 Oz 0
242071.5 188z OFF 01000 OzOOzO
242078.0 188z OFF 01000 OzOOzl
244000.0 188z OFF 01000 OzOlzl
244046.0 188z OFF 01000 OzOlzO
245000.0 188z OFF 01000 OzOOzO
246000.0 OFFz OFF 01000 lzOOzO ; load an
'FF'
250064.8 OFFz OFF 01000 lzlOzO
251000.0 OFFz OFF 01000 OzlOzO
251047.6 OFFz OFF OlOOOOzOOzO
252000.0 147z OFF 01000 lzOOzO ;XORC it
254603.4 147z OFF 01000 lzlOzO
257000.0 147z OFF OlOOOOzlOzO
257047.6 147z OFF 01000 OzOOzO
257077.5 147z OFF 01001 OzOOzO
257092.7 147z OFF 00001 OzOOzO
258000.0 188z OFF 00001 lzOOzO ;write a
'0'
260603.4 188z OFF 00001 lzlOzO
263000.0 188z OFF 00001 OzlOzO
263047.6 188z OFF 00001 OzOOzO
263071.3 188z 0B7 0 0 0 0 1 Oz 0 Oz 0
263071.4 188z 0B6 0 0 0 0 1 Oz 0 Oz 0
263071.9 188z 0A4 0 0 0 0 1 Oz 0 Oz 0
263072.5 188z 024 0 0 0 0 1 Oz 0 Oz 0
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
Aoutbus ASWn ASWv AIHi AOHi
263073 ,.2 188z 000 0 0 0 0 1 Oz 0 Oz 0
263078..0 188z 000 0 0 0 0 1 Oz 0 Oz 1
265000,.0 188z 000 0 0 0 0 1 Oz 0 lz 1
265046,.0 188z 000 0 0 0 0 1 Oz 0 lz 0
266000,.0 188z 000 0 0 0 0 1 Oz 0 Oz 0
267000,.0 146z 000 0 0 0 0 1 lz 0 Oz 0
269603 . 4 146z 000 0 0 0 0 1 lz 1 Oz 0
272000..0 146z 000 0 0 0 0 1 Oz 1 Oz 0
272047 . 6 146z 000 0 0 0 0 1 Oz 0 Oz 0
272079..5 146z 000 0 0 0 0 0 Oz 0 Oz 0
272088..4 146z 000 0 1 0 0 0 Oz 0 Oz 0
273000..0 188z 000 0 1 0 0 0 lz 0 Oz 0
275603 . 4 188z 000 0 1 0 0 0 lz 1 Oz 0
278000..0 188z 000 0 1 0 0 0 Oz 1 Oz 0
278047..6 188z 000 0 1 0 0 0 Oz 0 Oz 0
278069..8 188z 008 0 1 0 0 0 Oz 0 Oz 0
278070..3 188z 009 0 1 0 0 0 Oz 0 Oz 0
278070 .4 188z 049 0 1 0 0 0 Oz 0 Oz 0
278070 .3 188z 04B 0 1 0 0 0 Oz 0 Oz 0
278071 .1 188z 05B 0 1 0 0 0 Oz 0 Oz 0
278071 .5 188z OFF 0 1 0 0 0 Oz 0 Oz 0
278078..0 188z OFF 0 1 0 0 0 Oz 0 Oz 1
280000 .0 188z OFF 0 1 0 0 0 Oz 0 lz 1
280046..0 188z OFF 0 1 0 0 0 Oz 0 lz 0
281000 .0 188z OFF 0 1 0 0 0 Oz 0 Oz 0
282000 .0 OAAz OFF 0 1 0 0 0 lz 0 Oz 0
286064 .8 OAAz OFF 0 1 0 0 0 lz 1 Oz 0
287000..0 OAAz OFF 0 1 0 0 0 Oz 1 Oz 0
287047 .6 OAAz OFF 0 1 0 0 0 Oz 0 Oz 0
288000 .0 148z OFF 0 1 0 0 0 lz 0 Oz 0
290603,.4 148z OFF 0 1 0 0 0 lz 1 Oz 0
293000 .0 148z OFF 0 1 0 0 0 Oz 1 Oz 0
293047 .6 148z OFF 0 1 0 0 0 Oz 0 Oz 0
293075,.9 148z OFF 0 1 1 0 0 Oz 0 Oz 0
293092,.7 148z OFF 0 0 1 0 0 Oz 0 Oz 0
294000..0 188z OFF 0 0 1 0 0 lz 0 Oz 0
296603 . 4 188z OFF 0 0 1 0 0 lz 1 Oz 0
299000..0 188z OFF 0 0 1 0 0 Oz 1 Oz 0
299047..6 188z OFF 0 0 1 0 0 Oz 0 Oz 0
299071..3 188z 0F7 0 0 1 0 0 Oz 0 Oz 0
299071..4 188z 0F6 0 0 1 0 0 Oz 0 Oz 0
299071..9 188z 0F4 0 0 1 0 0 Oz 0 Oz 0
299072,.5 188z 074 0 0 1 0 0 Oz 0 Oz 0
299073 , 2 188z 054 0 0 1 0 0 Oz 0 Oz 0
299078..0 188z 054 0 0 1 0 0 Oz 0 Oz 1
301000 . 0 188z 054 0 0 1 0 0 Oz 0 lz 1
301046.,0 188z 054 0 0 1 0 0 Oz 0 lz 0
302000 0 188z 054 0 0 1 0 0 Oz 0 Oz 0
303000 .,0 149z 054 0 0 1 0 0 lz 0 Oz 0
305603 . .4 149z 054 0 0 1 0 0 lz 1 Oz 0
308000.,0 149z 054 0 0 1 0 0 Oz 1 Oz 0
308047.,6 149z 054 0 0 1 0 0 Oz 0 Oz 0
308077 . 5 149z 054 0 0 0 0 0 Oz 0 Oz 0
:XOR it
;write an
'FF'
load an 'AA'
.-SLL it
; wr i t e a '54'
;SRL it
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
'2A'
Aoutbus ASWn ASWv AIHi AOHi
309000. 0 188z 054 0 0 0 0 0 lz 0 Oz 0 ;write a
311603 . 4 188z 054 0 0 0 0 0 lz 1 Oz 0
314000. 0 188z 054 0 0 0 0 0 Oz 1 Oz 0
314047. 6 188z 054 0 0 0 0 0 Oz 0 Oz 0
314069. 8 188z 05C 0 0 0 0 0 Oz 0 Oz 0
314070..8 188z 05E 0 0 0 0 0 Oz 0 Oz 0
314071.,3 188z 01E 0 0 0 0 0 Oz 0 Oz 0
314071.,5 188z 03E 0 0 0 0 0 Oz 0 Oz 0
314071.,9 188z 02E 0 0 0 0 0 Oz 0 Oz 0
314073 .,2 188z 02A 0 0 0 0 0 Oz 0 Oz 0
314078,.0 188z 02A 0 0 0 0 0 Oz 0 Oz 1
316000,.0 188z 02A 0 0 0 0 0 Oz 0 lz 1
316046,.0 188z 02A 0 0 0 0 0 Oz 0 lz 0
317000,.0 188z 02A 0 0 0 0 0 Oz 0 Oz 0
318000..0 OAAz 02A 0 0 0 0 0 lz 0 Oz 0 ; load an
322064..8 OAAz 02A 0 0 0 0 0 lz 1 Oz 0
323000,.0 OAAz 02A 0 0 0 0 0 Oz 1 Oz 0
323047,.6 OAAz 02A 0 0 0 0 0 Oz 0 Oz 0
324000 .0 14Az 02A 0 0 0 0 0 lz 0 Oz 0 ;SLA it
326603 .4 14Az 02A 0 0 0 0 0 lz 1 Oz 0
329000 .0 14Az 02A 0 0 0 0 0 Oz 1 Oz 0
329047 .6 14Az 02A 0 0 0 0 0 Oz 0 Oz 0
329075 .9 14Az 02A 0 0 1 0 0 Oz 0 Oz 0
329078 .1 14Az 02A 0 0 1 1 0 Oz 0 Oz 0
330000 .0 188z 02A 0 0 1 1 0 lz 0 Oz 0 ;write a
332603 .4 188z 02A 0 0 1 1 0 lz 1 Oz 0
335000 .0 188z 02A 0 0 1 1 0 Oz 1 Oz 0
335047 .6 188z 02A 0 0 1 1 0 Oz 0 Oz 0
335070 .4 188z 0 6A 0 0 1 1 0 Oz 0 Oz 0
335071 .1 188z 07A 0 0 1 1 0 Oz 0 Oz 0
335071 .3 188z 072 0 0 1 1 0 Oz 0 Oz 0
335071 .5 188z 076 0 0 1 1 0 Oz 0 Oz 0
335071 .9 188z 074 0 0 1 1 0 Oz 0 Oz 0
335073 .2 188z 054 0 0 1 1 0 Oz 0 Oz 0
335078 .0 188z 054 0 0 1 1 0 Oz 0 Oz 1
337000 .0 188z 054 0 0 1 1 0 Oz 0 lz 1
337046 .0 188z 054 0 0 1 1 0 Oz 0 lz 0
338000 .0 188z 054 0 0 1 1 0 Oz 0 Oz 0
339000 .0 14Bz 054 0 0 1 1 0 lz 0 Oz 0 ;SRA it
341603 .4 14Bz 054 0 0 1 1 0 lz 1 Oz 0
344000 .0 14Bz 054 0 0 1 1 0 Oz 1 Oz 0
344047 .6 14Bz 054 0 0 1 1 0 Oz 0 Oz 0
344077 .5 14Bz 054 0 0 0 1 0 Oz 0 Oz 0
344080 .3 14Bz 054 0 0 0 0 0 Oz 0 Oz 0
345000 .0 188z 054 0 0 0 0 0 lz 0 Oz 0 ;write a
347603 .4 188z 054 0 0 0 0 0 lz 1 Oz 0
350000 .0 188z 054 0 0 0 0 0 Oz 1 Oz 0
350047 .6 188z 054 0 0 0 0 0 Oz 0 Oz 0
350069 .8 188z 05C 0 0 0 0 0 Oz 0 Oz 0
350070 .8 188z 05E 0 0 0 0 0 Oz 0 Oz 0
350071 .3 188z 01E 0 0 0 0 0 Oz 0 Oz 0
350071 .5 188z 03E 0 0 0 0 0 Oz 0 Oz 0
350071 .9 188z 02E 0 0 0 0 0 Oz 0 Oz 0
'AA'
'54'
2A'
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
Aoutbus ASWn ASWv AItti A0r-:[i
350073 . 2 188z 02A 0 0 0 0 0 Oz 0 Oz 0
350078. 0 188z 02A 0 0 0 0 0 Oz 0 Oz 1
352000. 0 188z 02A 0 0 0 0 0 Oz 0 lz 1
352046. 0 188z 02A 0 0 0 0 0 Oz 0 lz 0
353000. 0 188z 02A 0 0 0 0 0 Oz 0 Oz 0
354000. 0 OAAz 02A 0 0 0 0 0 lz 0 Oz 0
358064. 8 OAAz 02A 0 0 0 0 0 lz 1 Oz 0
359000. 0 OAAz 02A 0 0 0 0 0 Oz 1 Oz 0
359047. 6 OAAz 02A 0 0 0 0 0 Oz 0 Oz 0
360000. 0 14Cz 02A 0 0 0 0 0 lz 0 Oz 0
362603. 4 14Cz 02A 0 0 0 0 0 lz 1 Oz 0
365000. 0 14Cz 02A 0 0 0 0 0 Oz 1 Oz 0
365047. 6 14Cz 02A 0 0 0 0 0 Oz 0 Oz 0
365075. 9 14Cz 02A 0 0 1 0 0 Oz 0 Oz 0
366000. 0 188z 02A 0 0 1 0 0 lz 0 Oz 0
368603 . 4 188z 02A 0 0 1 0 0 lz 1 Oz 0
371000. 0 188z 02A 0 0 1 0 0 Oz 1 Oz 0
371047.,6 188z 02A 0 0 1 0 0 Oz 0 Oz 0
371070.,3 188z 02B 0 0 1 0 0 Oz 0 Oz 0
371070. 4 188z 06B 0 0 1 0 0 Oz 0 Oz 0
371071.,1 188z 07B 0 0 1 0 0 Oz 0 Oz 0
371071,.3 188z 073 0 0 1 0 0 Oz 0 Oz 0
371071,.5 188z 077 0 0 1 0 0 Oz 0 Oz 0
371071,.9 188z 075 0 0 1 0 0 Oz 0 Oz 0
371073,.2 188z 055 0 0 1 0 0 Oz 0 Oz 0
371078..0 188z 055 0 0 1 0 0 Oz 0 Oz 1
373000 .0 188z 055 0 0 1 0 0 Oz 0 lz 1
373046 .0 188z 055 0 0 1 0 0 Oz 0 lz 0
374000 .0 188z 055 0 0 1 0 0 Oz 0 Oz 0
375000 .0 14Dz 055 0 0 1 0 0 lz 0 Oz 0
377603 .4 14Dz 055 0 0 1 0 0 lz 1 Oz 0
380000 .0 14Dz 055 0 0 1 0 0 Oz 1 Oz 0
380047 .6 14Dz 055 0 0 1 0 0 Oz 0 Oz 0
380088 .4 14Dz 055 0 1 1 0 0 Oz 0 Oz 0
381000 .0 188z 055 0 1 1 0 0 lz 0 Oz 0
383603 .4 188z 055 0 1 1 0 0 lz 1 Oz 0
386000 .0 188z 055 0 1 1 0 0 Oz 1 Oz 0
386047 .6 188z 055 0 1 1 0 0 Oz 0 Oz 0
386069 .3 188z 05D 0 1 1 0 0 Oz 0 Oz 0
386070 .3 188z 05F 0 1 1 0 0 Oz 0 Oz 0
386071 .3 188z OIF 0 1 1 0 0 Oz 0 Oz 0
386071 .4 188z 01E 0 1 1 0 0 Oz 0 Oz 0
386071 .5 188z OBE 0 1 1 0 0 Oz 0 Oz 0
386071 .9 188z OAE 0 1 1 0 0 Oz 0 Oz 0
386073 .2 188z OAA 0 1 1 0 0 Oz 0 Oz 0
386078 .0 188z OAA 0 1 1 0 0 Oz 0 Oz 1
388000 .0 188z OAA 0 1 1 0 0 Oz 0 lz 1
388046 .0 188z OAA 0 1 1 0 0 Oz 0 lz 0
389000 .0 188z OAA 0 1 1 0 0 Oz 0 Oz 0
390000 .0 14Dz OAA 0 1 1 0 0 lz 0 Oz 0
392603 .4 14Dz OAA 0 1 1 0 0 lz 1 Oz 0
395000 .0 14Dz OAA 0 1 1 0 0 Oz 1 Oz 0
395047 .6 14Dz OAA 0 1 1 0 0 Oz
0 Oz 0
load an 'AA'
:SLR it
;write a
'55'
:SRR it
;write
'AA'
:SRR it
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
Aoutbus ASWn ASWv AIHi AOHi
395077 . 5 14Dz OAA 0 1 0 0 0 Oz 0 Oz 0
395092. 7 14Dz OAA 0 0 0 0 0 Oz 0 Oz 0
396000. 0 188z OAA 0 0 0 0 0 lz 0 Oz 0 ;wr i t e
398603 . 4 188z OAA 0 0 0 0 0 lz 1 Oz 0
401000..0 188z OAA 0 0 0 0 0 Oz 1 Oz 0
401047..6 188z OAA 0 0 0 0 0 Oz 0 Oz 0
401070..3 188z OAB 0 0 0 0 0 Oz 0 Oz 0
401070..4 188z OEB 0 0 0 0 0 Oz 0 Oz 0
401071.,1 188z OFB 0 0 0 0 0 Oz 0 Oz 0
401071.,3 188z 0F3 0 0 0 0 0 Oz 0 Oz 0
401071..5 188z 0F7 0 0 0 0 0 Oz 0 Oz 0
401071..9 188z 0F5 0 0 0 0 0 Oz 0 Oz 0
401072,.5 188z 075 0 0 0 0 0 Oz 0 Oz 0
401073 . 2 188z 055 0 0 0 0 0 Oz 0 Oz 0
401078,.0 188z 055 0 0 0 0 0 Oz 0 Oz 1
403000 ,.0 188z 055 0 0 0 0 0 Oz 0 lz 1
403046,.0 188z 055 0 0 0 0 0 Oz 0 lz 0
404000,.0 188z 055 0 0 0 0 0 Oz 0 Oz 0
405087,.1 188z 015 0 0 0 0 0 Oz 0 Oz 0
405087,.2 188z 014 0 0 0 0 0 Oz 0 Oz 0
405087..7 188z 004 0 0 0 0 0 Oz 0 Oz 0
405089..0 188z 000 0 0 0 0 0 Oz 0 Oz 0
407000..0 160z 000 0 0 0 0 0 lz 0 Oz 0 ;PSW
409603..4 160z 000 0 0 0 0 0 lz 1 Oz 0
412000 .0 160z 000 0 0 0 0 0 Oz 1 Oz 0
412047 .6 160z 000 0 0 0 0 0 Oz 0 Oz 0
413000 .0 188z 000 0 0 0 0 0 lz 0 Oz 0 ;write
415603 .4 188z 000 0 0 0 0 0 lz 1 Oz 0
418000 .0 188z 000 0 0 0 0 0 Oz 1 Oz 0
418047 .6 188z 000 0 0 0 0 0 Oz 0 Oz 0
418078 .0 188z 000 0 0 0 0 0 Oz 0 Oz 1
420000 .0 188z 000 0 0 0 0 0 Oz 0 lz 1
420046 .0 188z 000 0 0 0 0 0 Oz 0 lz 0
421000 .0 188z 000 0 0 0 0 0 Oz 0 Oz 0
422000 .0 OFFz 000 0 0 0 0 0 lz 0 Oz 0 ; load
426064 .8 OFFz 000 0 0 0 0 0 lz 1 Oz 0
427000 .0 OFFz 000 0 0 0 0 0 Oz 1 Oz 0
427047 .6 OFFz 000 0 0 0 0 0 Oz 0 Oz 0
428000 .0 OFFz 000 0 0 0 0 0 lz 0 Oz 0
432064 .8 OFFz 000 0 0 0 0 0 lz 1 Oz 0 ; load
433000 .0 OFFz 000 0 0 0 0 0 Oz 1 Oz 0
433047 .6 OFFz 000 0 0 0 0 0 Oz 0 Oz 0
434000 .0 150z 000 0 0 0 0 0 lz 0 Oz 0 ;ADD
436603 .4 150z 000 0 0 0 0 0 lz 1 Oz 0
439000 .0 150z 000 0 0 0 0 0 Oz 1 Oz 0
439047 .6 150z 000 0 0 0 0 0 Oz 0 Oz 0
439075 .9 150z 000 0 0 1 0 0 Oz 0 Oz 0
439088 .4 150z 000 0 1 1 0 0 Oz 0 Oz 0
440000 .0 160z 000 0 1 1 0 0 lz 0 Oz 0 ;PSW
442603 .4 160z 000 0 1 1 0 0 lz 1 Oz 0
445000 .0 160z 000 0 1 1 0 0 Oz 1 Oz 0
445047 .6 160z 000 0 1 1 0 0 Oz 0 Oz 0
446000 .0 184z 000 0 1 1 0 0 lz 0 Oz 0 ;write
55'
'FF'
FF'
OC
TIME Ainbt:is ASWs ASWc ASWz AIHo A0Ho
Aoutbus ASWn ASWv AIHi AOHi
448603 .4 184z 000 0 1 1 0 0 lz 1 Oz 0
451000.0 184z 000 0 1 1 0 0 Oz 1 Oz 0
451047.6 184z 000 0 1 1 0 0 Oz 0 Oz 0
451069.8 184z 008 0 1 1 0 0 Oz 0 Oz 0
451071.5 184z OOC 0 1 1 0 0 Oz 0 Oz 0
451078.0 184z ooc 0 1 1 0 0 Oz 0 Oz 1
453000.0 184z OOC 0 1 1 0 0 Oz 0 lz 1
453046.0 184z OOC 0 1 1 0 0 Oz 0 lz 0
454000.0 184z ooc 0 1 1 0 0 Oz 0 Oz 0
455000.0 OOOz OOC 0 1 1 0 0 lz 0 Oz 0 ; load
459064.8 OOOz OOC 0 1 1 0 0 lz 1 Oz 0
460000.0 OOOz OOC 0 1 1 0 0 Oz 1 Oz 0
460047.6 OOOz OOC 0 1 1 0 0 Oz 0 Oz 0
461000.0 161z OOC 0 1 1 0 0 lz 0 Oz 0 ;SSW
463603 .4 161z OOC 0 1 1 0 0 lz 1 Oz 0
466000.0 161z OOC 0 1 1 0 0 Oz 1 Oz 0
466047.6 161z OOC 0 1 1 0 0 Oz 0 Oz 0
466077.5 161z OOC 0 1 0 0 0 Oz 0 Oz 0
466092.7 161z OOC 0 0 0 0 0 Oz 0 Oz 0
467000.0 160z OOC 0 0 0 0 0 lz 0 Oz 0 ;PSW
469603 .4 160z OOC 0 0 0 0 0 lz 1 Oz 0
472000.0 160z OOC 0 0 0 0 0 Oz 1 Oz 0
472047.6 160z OOC 0 0 0 0 0 Oz 0 Oz 0
473000.0 184z OOC 0 0 0 0 0 lz 0 Oz 0 ;write
475603 .4 184z OOC 0 0 0 0 0 lz 1 Oz 0
478000.0 184z OOC 0 0 0 0 0 Oz 1 Oz 0
478047.6 184z OOC 0 0 0 0 0 Oz 0 Oz 0
478071.3 184z 004 0 0 0 0 0 Oz 0 Oz 0
478073 .2 184z 000 0 0 0 0 0 Oz 0 Oz 0
478078.0 184z 000 0 0 0 0 0 Oz 0 Oz 1
480000.0 184z 000 0 0 0 0 0 Oz 0 lz 1
480046.0 184z 000 0 0 0 0 0 Oz 0 lz 0
481000.0 184z 000 0 0 0 0 0 Oz 0 Oz 0
482000.0 164z 000 0 0 0 0 0 lz 0 Oz 0 ;PIO
484603 .4 164z 000 0 0 0 0 0 lz 1 Oz 0
487000.0 164z 000 0 0 0 0 0 Oz 1 Oz 0
487047.6 164z 000 0 0 0 0 0 Oz 0 Oz 0
488000.0 184z 000 0 0 0 0 0 lz 0 Oz 0 ;write
490603 .4 184z 000 0 0 0 0 0 lz 1 Oz 0
493000.0 184z 000 0 0 0 0 0 Oz 1 Oz 0
493047.6 184z 000 0 0 0 0 0 Oz 0 Oz 0
493078.0 184z 000 0 0 0 0 0 Oz 0 Oz 1
495000.0 184z 000 0 0 0 0 0 Oz 0 lz 1
495046.0 184z 000 0 0 0 0 0 Oz 0 lz 0
496000.0 184z 000 0 0 0 0 0 Oz 0 Oz 0
497000.0 OOlz 000 0 0 0 0 0 lz 0 Oz 0 ; load
501064.8 OOlz 000 0 0 0 0 0 lz 1 Oz 0
502000.0 OOlz 000 0 0 0 0 0 Oz 1 Oz 0
502047.6 OOlz 000 0 0 0 0 0 Oz 0 Oz 0
503000.0 165z 000 0 0 0 0 0 lz 0 Oz 0 ;SIO
505603 .4 165z 000 0 0 0 0 0 lz 1 Oz 0
508000.0 165z 000 0 0 0 0 0 Oz 1 Oz 0
508047.6 165z 000 0 0 0 0 0 Oz 0 Oz 0
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
Aoutbus ASWn ASWv AIHi AOHi
508073 ..7 165z 100 0 0 0 0 0 Oz 0 Oz 0
509000. 0 164z 100 0 0 0 0 0 lz 0 Oz 0
511603.,4 164z 100 0 0 0 0 0 lz 1 Oz 0
514000. 0 164z 100 0 0 0 0 0 Oz 1 Oz 0
514047.,6 164z 100 0 0 0 0 0 Oz 0 Oz 0
515000. 0 184z 100 0 0 0 0 0 lz 0 Oz 0
517603. 4 184z 100 0 0 0 0 0 lz 1 Oz 0
520000. 0 184z 100 0 0 0 0 0 Oz 1 Oz 0
520047. 6 184z 100 0 0 0 0 0 Oz 0 Oz 0
520070. 3 184z 101 0 0 0 0 0 Oz 0 Oz 0
520078. 0 184z 101 0 0 0 0 0 Oz 0 Oz 1
522000. 0 184z 101 0 0 0 0 0 Oz 0 lz 1
522046..0 184z 101 0 0 0 0 0 Oz 0 lz 0
523000..0 184z 101 0 0 0 0 0 Oz 0 Oz 0
524000.,0 162z 101 0 0 0 0 0 lz 0 Oz 0
526603 .,4 162z 101 0 0 0 0 0 lz 1 Oz 0
529000. 0 162z 101 0 0 0 0 0 Oz 1 Oz 0
529047,,6 162z 101 0 0 0 0 0 Oz 0 Oz 0
530000. 0 188z 101 0 0 0 0 0 lz 0 Oz 0
532603 , ,4 188z 101 0 0 0 0 0 lz 1 Oz 0
535000.,0 188z 101 0 0 0 0 0 Oz 1 Oz 0
535047.,6 188z 101 0 0 0 0 0 Oz 0 Oz 0
535070.,8 188z 103 0 0 0 0 0 Oz 0 Oz 0
535071..4 188z 102 0 0 0 0 0 Oz 0 Oz 0
535078.,0 188z 102 0 0 0 0 0 Oz 0 Oz 1
537000.,0 188z 102 0 0 0 0 0 Oz 0 lz 1
537046,.0 188z 102 0 0 0 0 0 Oz 0 lz 0
538000,.0 188z 102 0 0 0 0 0 Oz 0 Oz 0
539000 .0 162z 102 0 0 0 0 0 lz 0 Oz 0
541603 .4 162z 102 0 0 0 0 0 lz 1 Oz 0
544000 .0 162z 102 0 0 0 0 0 Oz 1 Oz 0
544047 .6 162z 102 0 0 0 0 0 Oz 0 Oz 0
545000 .0 184z 102 0 0 0 0 0 lz 0 Oz 0
547603 .4 184z 102 0 0 0 0 0 lz 1 Oz 0
550000 .0 184z 102 0 0 0 0 0 Oz 1 Oz 0
550047 .6 184z 102 0 0 0 0 0 Oz 0 Oz 0
550070 .3 184z 103 0 0 0 0 0 Oz 0 Oz 0
550071 .9 184z 101 0 0 0 0 0 Oz 0 Oz 0
550078 .0 184z 101 0 0 0 0 0 Oz 0 Oz 1
552000 .0 184z 101 0 0 0 0 0 Oz 0 lz 1
552046 .0 184z 101 0 0 0 0 0 Oz 0 lz 0
553000 .0 184z 101 0 0 0 0 0 Oz 0 Oz 0
554000 .0 OOlz 101 0 0 0 0 0 lz 0 Oz 0
558064 .8 OOlz 101 0 0 0 0 0 lz 1 Oz 0
559000 .0 OOlz 101 0 0 0 0 0 Oz 1 Oz 0
559047 .6 OOlz 101 0 0 0 0 0 Oz 0 Oz 0
560000 .0 002z 101 0 0 0 0 0 lz 0 Oz 0
564064 .8 002z 101 0 0 0 0 0 lz 1 Oz 0
565000 .0 002z 101 0 0 0 0 0 Oz 1 Oz 0
565047 .6 002z 101 0 0 0 0 0 Oz 0 Oz 0
566000 .0 003z 101 0 0 0 0 0 lz 0 Oz 0
570064 .8 003z 101 0 0 0 0 0 lz 1 Oz 0
571000 .0 003z 101 0 0 0 0 0 Oz 1 Oz 0
PIO
,-write
'101'
,-PSP
;write DSP (2)
:PSP
;write DSP (1)
load
load
load
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
"outbus ASWn ASWv AIHi AOHi
571047.6 003z 101 0 0 0 0 0 Oz 0 Oz 0
572000.0 188z 101 0 0 0 0 0 lz 0 Oz 0 ;write '
574603.4 188z 101 0 0 0 0 0 lz 1 Oz 0
577000.0 188z 101 0 0 0 0 0 Oz 1 Oz 0
577047.6 188z 101 0 0 0 0 0 Oz 0 Oz 0
577070.8 188z 103 0 0 0 0 0 Oz 0 Oz 0
577078.0 188z 103 0 0 0 0 0 Oz 0 Oz 1
579000.0 188z 103 0 0 0 0 0 Oz 0 lz 1
579046.0 188z 103 0 0 0 0 0 Oz 0 lz 0
580000.0 188z 103 0 0 0 0 0 Oz 0 Oz 0
581000.0 lAOz 103 0 0 0 0 0 lz 0 Oz 0 ;GET 0
583603.4 lAOz 103 0 0 0 0 0 lz 1 Oz 0
586000.0 lAOz 103 0 0 0 0 0 Oz 1 Oz 0
586047.6 lAOz 103 0 0 0 0 0 Oz 0 Oz 0
587000.0 184z 103 0 0 0 0 0 lz 0 Oz 0 ;wr i t e '
589603 .4 184z 103 0 0 0 0 0 lz 1 Oz 0
592000.0 184z 103 0 0 0 0 0 Oz 1 Oz 0
592047.6 184z 103 0 0 0 0 0 Oz 0 Oz 0
592078.0 184z 103 0 0 0 0 0 Oz 0 Oz 1
594000.0 184z 103 0 0 0 0 0 Oz 0 lz 1
594046.0 184z 103 0 0 0 0 0 Oz 0 lz 0
595000.0 184z 103 0 0 0 0 0 Oz 0 Oz 0
596000.0 lAlz 103 0 0 0 0 0 lz 0 Oz 0 ;GET 1
598603 .4 lAlz 103 0 0 0 0 0 lz 1 Oz 0
601000.0 lAlz 103 0 0 0 0 0 Oz 1 Oz 0
601047.6 lAlz 103 0 0 0 0 0 Oz 0 Oz 0
602000.0 184z 103 0 0 0 0 0 lz 0 Oz 0 ;write ':
604603 .4 184z 103 0 0 0 0 0 lz 1 Oz 0
607000.0 184z 103 0 0 0 0 0 Oz 1 Oz 0
607047.6 184z 103 0 0 0 0 0 Oz 0 Oz 0
607071.4 184z 102 0 0 0 0 0 Oz 0 Oz 0
607078.0 184z 102 0 0 0 0 0 Oz 0 Oz 1
609000.0 184z 102 0 0 0 0 0 Oz 0 lz 1
609046.0 184z 102 0 0 0 0 0 Oz 0 lz 0
610000.0 184z 102 0 0 0 0 0 Oz 0 Oz 0
611000.0 162z 102 0 0 0 0 0 lz 0 Oz 0 ;PSP
613603 .4 162z 102 0 0 0 0 0 lz 1 Oz 0
616000.0 162z 102 0 0 0 0 0 Oz 1 Oz 0
616047.6 162z 102 0 0 0 0 0 Oz 0 Oz 0
617000.0 ICOz 102 0 0 0 0 0 lz 0 Oz 0 ;SSP ANY
619603 .4 ICOz 102 0 0 0 0 0 lz 1 Oz 0
622000.0 ICOz 102 0 0 0 0 0 Oz 1 Oz 0
622047.6 ICOz 102 0 0 0 0 0 Oz 0 Oz 0
623000.0 188z 102 0 0 0 0 0 lz 0 Oz 0 ;wr i t e
'
625603 .4 188z 102 0 0 0 0 0 lz 1 Oz 0
628000.0 188z 102 0 0 0 0 0 Oz 1 Oz 0
628047.6 188z 102 0 0 0 0 0 Oz 0 Oz 0
628070.3 188z 103 0 0 0 0 0 Oz 0 Oz 0
628078.0 188z 103 0 0 0 0 0 Oz 0 Oz 1
630000.0 188z 103 0 0 0 0 0 Oz 0 lz 1
630046.0 188z 103 0 0 0 0 0 Oz 0 lz 0
631000.0 188z 103 0 0 0 0 0 Oz 0 Oz 0
632000.0 192z 103 0 0 0 0 0 lz 0 Oz 0 ; SWAP
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
Aoutbus ASWn ASWv AIHi AOHi
634603 .4 192z 103 0 0 0 0 0 lz 1 Oz 0
637000.0 192z 103 0 0 0 0 0 Oz 1 Oz 0
637047.6 192z 103 0 0 0 0 0 Oz 0 Oz 0
638000.0 184z 103 0 0 0 0 0 lz 0 Oz 0 ;wr ite ' 2 '
640603 .4 184z 103 0 0 0 0 0 lz 1 Oz 0
643000.0 184z 103 0 0 0 0 0 Oz 1 Oz 0
643047.6 184z 103 0 0 0 0 0 Oz 0 Oz 0
643071.4 184z 102 0 0 0 0 0 Oz 0 Oz 0
643078.0 184z 102 0 0 0 0 0 Oz 0 Oz 1
645000.0 184z 102 0 0 0 0 0 Oz 0 lz 1
645046.0 184z 102 0 0 0 0 0 Oz 0 lz 0
646000.0 184z 102 0 0 0 0 0 Oz 0 Oz 0
647000.0 184z 102 0 0 0 0 0 lz 0 Oz 0
649603 .4 184z 102 0 0 0 0 0 lz 1 Oz 0 ;write ' 3 '
652000.0 184z 102 0 0 0 0 0 Oz 1 Oz 0
652047.6 184z 102 0 0 0 0 0 Oz 0 Oz 0
652070.3 184z 103 0 0 0 0 0 Oz 0 Oz 0
652078.0 184z 103 0 0 0 0 0 Oz 0 Oz 1
654000.0 184z 103 0 0 0 0 0 Oz 0 lz 1
654046.0 184z 103 0 0 0 0 0 Oz 0 lz 0
655000.0 184z 103 0 0 0 0 0 Oz 0 Oz 0
656000.0 184z 103 0 0 0 0 0 lz 0 Oz 0
658603 .4 184z 103 0 0 0 0 0 lz 1 Oz 0 ;write '1'
661000.0 184z 103 0 0 0 0 0 Oz 1 Oz 0
661047.6 184z 103 0 0 0 0 0 Oz 0 Oz 0
661071.9 184z 101 0 0 0 0 0 Oz 0 Oz 0
661078.0 184z 101 0 0 0 0 0 Oz 0 Oz 1
663000.0 184z 101 0 0 0 0 0 Oz 0 lz 1
663046.0 184z 101 0 0 0 0 0 Oz 0 lz 0
664000.0 184z 101 0 0 0 0 0 Oz 0 Oz 0
665000.0 ICOz 101 0 0 0 0 0 lz 0 Oz 0 ;SSP ANY
667603 .4 ICOz 101 0 0 0 0 0 lz 1 Oz 0
670000.0 ICOz 101 0 0 0 0 0 Oz 1 Oz 0
670047.6 ICOz 101 0 0 0 0 0 Oz 0 Oz 0
671000.0 184z 101 0 0 0 0 0 lz 0 Oz 0 ;write ' 2 '
673603.4 184z 101 0 0 0 0 0 lz 1 Oz 0
676000.0 184z 101 0 0 0 0 0 Oz 1 Oz 0
676047.6 184z 101 0 0 0 0 0 Oz 0 Oz 0
676070.8 184z 103 0 0 0 0 0 Oz 0 Oz 0
676071.4 184z 102 0 0 0 0 0 Oz 0 Oz 0
676078.0 184z 102 0 0 0 0 0 Oz 0 Oz 1
678000.0 184z 102 0 0 0 0 0 Oz 0 lz 1
678046.0 184z 102 0 0 0 0 0 Oz 0 lz 0
679000.0 184z 102 0 0 0 0 0 Oz 0 Oz 0
680000.0 ICOz 102 0 0 0 0 0 lz 0 Oz 0 ; ADJ ANY , 0
682603 .4 ICOz 102 0 0 0 0 0 lz 1 Oz 0
685000.0 ICOz 102 0 0 0 0 0 Oz 1 Oz 0
685047.6 ICOz 102 0 0 0 0 0 Oz 0 Oz 0
686000.0 188z 102 0 0 0 0 0 lz 0 Oz 0 ;write
'1'
688603 .4 188z 102 0 0 0 0 0 lz 1 Oz 0
691000.0 188z 102 0 0 0 0 0 Oz 1 Oz 0
691047.6 188z 102 0 0 0 0 0 Oz 0 Oz 0
691070.3 188z 103 0 0 0 0 0 Oz 0 Oz 0
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
"outbus ASWn ASWv AIHi AOHi
691071.9 188z 101 00000 OzOOzO
691078.0 188z 101 00000 OzOOzl
693000.0 188z 101 00000 OzOlzl
693046.0 188z 101 0 0 0 0 0 Oz 0 lz 0
694000.0 188z 101 00000 OzOOzO
695000.0 OFFz 101 0 0 0 0 0 lzO OzO ; load ' FF '
699064.8 OFFz 101 00000 lzlOzO
700000.0 OFFz 101 OOOOOOzlOzO
700047.6 OFFz 101 00000 OzOOzO
701000.0 OFFz 101 00000 lzOOzO
705064.8 OFFz 101 00000 lzlOzO ; load 'FF'
706000.0 OFFz 101 00000 OzlOzO
706047.6 OFFz 101 00000 OzOOzO
707000.0 151z 101 0 0 0 0 0 lz 0 Oz 0 ;ADDC them
709603.4 151z 101 00000 lzlOzO
712000.0 151z 101 00000 OzlOzO
712047.6 151z 101 00000 OzOOzO
712075.9 151z 101 00100 OzOOzO
712088.4 151z 101 01100 OzOOzO
713000.0 lClz 101 01100 lzOOzO ;ADJ EQ (fail)
715603.4 lClz 101 01100 lzlOzO
718000.0 lClz 101 01100 OzlOzO
718047.6 lClz 101 01100 OzOOzO
719000.0 188z 101 01100 lzOOzO ;write ' FE '
721603.4 188z 101 01100 lzlOzO
724000.0 188z 101 01100 OzlOzO
724047.6 188z 101 01100 OzOOzO
724069.8 188z 109 01100 OzOOzO
724070.4 188z 149 01100 OzOOzO
724070.8 188z 14B 01100 OzOOzO
724071.1 188z 15B 01100 OzOOzO
724071.4 188z 15A 01100 OzOOzO
724071.5 188z 1FE 01100 OzOOzO
724078.0 188z 1FE 01100 OzOOzl
726000.0 188z 1FE 01100 OzOlzl
726046.0 188z 1FE 01100 OzOlzO
727000.0 188z 1FE 01100 OzOOzO
728000.0 lC2z 1FE 01100 lzOOzO ; ADJ NE (succeed;
730603.4 lC2z 1FE 01100 lzlOzO
733000.0 lC2z 1FE 01100 OzlOzO
733047.6 lC2z 1FE 01100 OzOOzO
734000.0 184z 1FE 01100 lzOOzO ;write
'FF'
736603.4 184z 1FE 01100 lzlOzO
739000.0 184z 1FE 01100 OzlOzO
739047.6 184z 1FE 01100 OzOOzO
739070.3 184z IFF 01100 OzOOzO
739078.0 184z IFF 01100 OzOOzl
741000.0 184z IFF 01100 OzOlzl
741046.0 184z IFF 01100 OzOlzO
742000.0 184z IFF 01100 OzOOzO
743000.0 188z IFF 01100 lzOOzO ;write
'1'
745603.4 188z IFF 01100 lzlOzO
748000.0 188z IFF 01100 OzlOzO
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
Aoutbus ASWn ASWv AIHi AOHi
748047.6 188z IFF 01100 OzOOzO
748071.3 188z 1B7 01100 OzOOzO
748071.9 188z 1A5 01100 OzOOzO
748072.5 188z 125 0 1 1 0 0 Oz 0 Oz 0
748073.2 188z 101 01100 OzOOzO
748078.0 188z 101 01100 OzOOzl
750000.0 188z 101 01100 OzOlzl
750046.0 188z 101 01100 OzOlzO
751000.0 188z 101 01100 OzOOzO
752000.0 lC3z 101 01100 lzOOzO ; ADJ NEG (succeed)
754603.4 lC3z 101 01100 lzlOzO
757000.0 lC3z 101 01100 OzlOzO
757047.6 lC3z 101 01100 OzOOzO
758000.0 184z 101 01100 lzOOzO ;write '2'
760603.4 184z 101 01100 lzlOzO
763000.0 184z 101 01100 OzlOzO
763047.6 184z 101 01100 OzOOzO
763070.8 184z 103 0 1 1 0 0 Oz 0 Oz 0
763071.4 184z 102 01100 OzOOzO
763078.0 184z 102 01100 OzOOzl
765000.0 184z 102 01100 OzOlzl
765046.0 184z 102 0 1 1 0 0 Oz 0 lz 0
766000.0 184z 102 0 1 1 0 0 Oz 0 Oz 0
767000.0 188z 102 01100 lzOOzO ;write ' FE '
769603.4 188z 102 0 1 1 0 0 lz 1 Oz 0
772000.0 188z 102 01100 OzlOzO
772047.6 188z 102 01100 OzOOzO
772069.8 188z 10A 01100 OzOOzO
772070.4 188z 14A 01100 OzOOzO
772071.1 188z 15A 01100 OzOOzO
772071.5 188z 1FE 01100 OzOOzO
772078.0 188z 1FE 01100 OzOOzl
774000.0 188z 1FE 01100 OzOlzl
774046.0 188z 1FE 01100 OzOlzO
775000.0 188z 1FE 01100 OzOOzO
776000.0 lC4z 1FE 01100 lzOOzO ;ADJ CY (succeed)
778603.4 lC4z 1FE 01100 lzlOzO
781000.0 lC4z 1FE 01100 OzlOzO
781047.6 lC4z 1FE 01100 OzOOzO
782000.0 188z 1FE 01100 lzOOzO ;write
' FF '
784603.4 188z 1FE 01100 lzlOzO
787000.0 188z 1FE 01100 OzlOzO
787047.6 188z 1FE 01100 OzOOzO
787070.3 188z IFF 01100 OzOOzO
787078.0 188z IFF 01100 OzOOzl
789000.0 188z IFF 01100 OzOlzl
789046.0 188z IFF 01100 OzOlzO
790000.0 188z IFF 01100 OzOOzO
791000.0 lC5z IFF 0 1 1 0 0 lz 0 Oz 0 ;ADJ OV (fail)
793603.4 lC5z IFF 0 1 1 0 0 lz 1 Oz 0
796000.0 lC5z IFF 0 1 1 0 0 Oz 1 Oz 0
796047.6 lC5z IFF 0 1 1 0 0 Oz 0 Oz 0
797000.0 188z IFF 01100 lzOOzO ;write
' FF '
TIME Ainbus ASWs ASWc ASWz AIHo A0Ho
"outbus ASWn ASWv AIHi AOHi
799603 . 4 188z IFF 0 1 1 0 0 lz 1 Oz 0
802000. 0 188z IFF 0 1 1 0 0 Oz 1 Oz 0
802047 . 6 188z IFF 0 1 1 0 0 Oz 0 Oz 0
802078. 0 188z IFF 0 1 1 0 0 Oz 0 Oz 1
804000. 0 188z IFF 0 1 1 0 0 Oz 0 lz 1
804046. 0 188z IFF 0 1 1 0 0 Oz 0 lz 0
805000. 0 188z IFF 0 1 1 0 0 Oz 0 Oz 0
806000.,0 lC6z IFF 0 1 1 0 0 lz 0 Oz 0
808603 .,4 lC6z IFF 0 1 1 0 0 lz 1 Oz 0
811000.,0 lC6z IFF 0 1 1 0 0 Oz 1 Oz 0
811047.,6 lC6z IFF 0 1 1 0 0 Oz 0 Oz 0
812000..0 188z IFF 0 1 1 0 0 lz 0 Oz 0
814603..4 188z IFF 0 1 1 0 0 lz 1 Oz 0
817000..0 188z IFF 0 1 1 0 0 Oz 1 Oz 0
817047..6 188z IFF 0 1 1 0 0 Oz 0 Oz 0
817078..0 188z IFF 0 1 1 0 0 Oz 0 Oz 1
819000 .0 188z IFF 0 1 1 0 0 Oz 0 lz 1
819046 .0 188z IFF 0 1 1 0 0 Oz 0 lz 0
820000 .0 188z IFF 0 1 1 0 0 Oz 0 Oz 0
821000 .0 lC7z IFF 0 1 1 0 0 lz 0 Oz 0
823603 .4 lC7z IFF 0 1 1 0 0 lz 1 Oz 0
826000 .0 lC7z IFF 0 1 1 0 0 Oz 1 Oz 0
826047 .6 lC7z IFF 0 1 1 0 0 Oz 0 Oz 0
827000 .0 188z IFF 0 1 1 0 0 lz 0 Oz 0
829603 .4 188z IFF 0 1 1 0 0 lz 1 Oz 0
832000 .0 188z IFF 0 1 1 0 0 Oz 1 Oz 0
832047 .6 188z IFF 0 1 1 0 0 Oz 0 Oz 0
832071 .3 188z 1B7 0 1 1 0 0 Oz 0 Oz 0
832071 .9 188z 1A5 0 1 1 0 0 Oz 0 Oz 0
832072 .5 188z 125 0 1 1 0 0 Oz 0 Oz 0
832073 .2 188z 101 0 1 1 0 0 Oz 0 Oz 0
832078 .0 188z 101 0 1 1 0 0 Oz 0 Oz 1
834000 .0 188z 101 0 1 1 0 0 Oz 0 lz 1
834046 .0 188z 101 0 1 1 0 0 Oz 0 lz 0
835000 .0 188z 101 0 1 1 0 0 Oz 0 Oz 0
;ADJ GE (fail)
;write
' FF '
,-ADJ LE (succeed)
,-write
Appendix H - FPGA Place & Route Results
The following pages contain the results of the FPGA place and route process as
reported by the Actel Action Logic System software. The list files provided are:
1. The results of automatic pin placement (ixaip.pin)
2. The results of placing and routing (ixaip.pli)
3. The design validation results (ixaip.vld)
In the validation results, there are 15 warnings reported related to fanouts over
10. These generally resulted from the use ofActel library macros which internally
generate large fanouts, and therefore could not be corrected. These did not seem
to cause any problems (except possibly to limit the maximum speed to 4MHz).
1. Automatic Pin Placement
HEADER
FILEID PLACEPIN . /ixaip/ixaip .pin 3 6d62c61
CHECKSUM 3 6d62c61
PROGRAM certify
VERSION 1.14
NODEID 0003ed5a
DEPEND DDFFAMILY /user/als/data/alOOO/family .ddf 6062d6e3
DEPEND DDFDIE /user/als/data/al000/al020a/diel020a . ddf 362672b9
DEPEND DDFPACKAGE /user/als/data/al000/al020a/lcc68 .ddf 61c2ce59
DEPEND PLACEAFL . /ixaip/ixaip . afl 778da8e2
DEPEND PLACEIPF . /ixaip/ixaip . ipf 95cc23f2
VAR DDFDIE /user/als/data/al000/al020a/diel020a . ddf
VAR DDFFAMILY /user/als/data/alOOO /family . ddf
VAR DDFPACKAGE /user/als/data/al000/al020a/lcc68 . ddf
VAR PLACEAFL . /ixaip/ixaip . afl
VAR DVDCRT . /ixaip/ixaip . crt
VAR ADLIB /user/als/data/al000/adl05.1ib
VAR PLACEIPF . /ixaip/ixaip . ipf
VAR RESTRICTPROBEPINS 1
VAR DEFSYS /user/als/data/system. def
VAR DEFUSR /user/mdd2257/mdd2257 . def
VAR DEFDES . /ixaip/ixaip .def
VAR QUIETDEFOPENFAIL 1
ENDHEADER
DEF ixaip.
NET 07 ; ;
PIN:8.
NET II;;
PIN: 12.
NET 18; ;
PIN:16.
NET 01 ; ;
PIN:53 .
NET OHO ; ;
PIN:19 .
NET EXTCLK ; ;
PIN:22.
NET 04 ; ;
PIN:60 .
NET 14; ;
PIN:3 .
NET SWV; ;
PIN:50.
NET 15;
PIN:5.
NET 12;
PIN: 6.
NET IHO;
PIN:7.
NET SWZ;
PIN:51.
NET SWC ; ;
PIN:48.
NET 03 ; ;
PIN: 52.
NET 02 ; ;
PIN: 61.
NET 10; ;
PIN: 13 .
NET 08 ; ;
PIN:62.
NET IHI ; ;
PIN:9.
NET 17 ; ;
PIN: 10.
NET OO ; ;
PIN: 63 .
NET 13 ; ;
PIN: 18.
NET 05 ; ;
PIN:64.
NET SWS ; ;
PIN: 67 .
NET OHI ; ;
PIN:20.
NET IPRESET; ;
PIN: 17-
NET 16;;
PIN: 68.
NET SWN; ;
PIN: 47 .
NET 06; ;
PIN:65.
END.
2. Placement Information
HEADER
FILEID PLACEINFO . /ixaip/ixaip .pli 8461c246
CHECKSUM 8461c246
PROGRAM certify
VERSION 1.14
NODEID 0003ed5a
DEPEND DDFFAMILY /user/als/data/alOOO/family . ddf 6062d6e3
DEPEND DDFDIE /user/als/data/al000/al020a/diel020a .ddf 362672b9
DEPEND DDFPACKAGE /user/als/data/al000/al020a/lcc68 . ddf 61c2ce59
DEPEND PLACEAFL . /ixaip/ixaip .afl 778da8e2
DEPEND PLACEPIN . /ixaip/ixaip .pin 3 6d62c61
VAR DDFDIE /user/als/data/al000/al020a/diel020a . ddf
VAR DDFFAMILY /user/als/data/alOOO/family . ddf
VAR DDFPACKAGE /user/als/data/al000/al020a/lcc68 .ddf
VAR PLACEAFL . /ixaip/ixaip . afl
VAR DVDCRT . /ixaip/ixaip . crt
VAR ADLIB /user/als/data/al000/adl05.1ib
VAR PLACEPIN . /ixaip/ixaip .pin
VAR PLACEIPF . /ixaip/ixaip . ipf
VAR PLACEABSOLUTECRITCOEFF <NOT-SET>
VAR PLACEABSOLUTEFASTCRITCOEFF <NOT-SET>
VAR PLACEVERTUNCRITCOEFF <NOT-SET>
VAR PLACEHORUNCRITCOEFF <NOT-SET>
VAR PLACEVERTCRITCOEFF <NOT-SET>
VAR PLACEVERTFASTCRITCOEFF <NOT-SET>
VAR PLACEHORCRITCOEFF <NOT-SET>
VAR PLACEHORFASTCRITCOEFF <NOT-SET>
VAR PLACECLOCKBALANCESTRENGTH 0
ENDHEADER
Average horizontal net length is 7.19751 columns.
A total of 39 nets need long horizontal tracks.
A total of 31 nets need long vertical tracks.
Automatic Placement completed successfully
The design has 481 routed (excluding GND, VCC, global CLKs ) nets.
450 nets need no long vertical tracks,
av. horiz. length for these nets is 6.0178, av. fanout 2.6067-
31 nets need to use long vertical routing tracks.
31 of such tracks are of the standard type (LVT),
av . horiz. length for these nets is 24.3226, av . fanout
7 .5161.
List of all nets using standard long vertical tracks (LVT) to route:
The net I$96/N$667 driven at location XY = ( 3 , 9) uses an LVT.
LVT data: column = 20, Y-span = ( 8, 0) .
Net data: fanout = 8, Y-spread of inputs = ( 9, 1) .
The net I$96/N$64 driven at location XY = (12,13) uses an LVT.
LVT data: column = 12, Y-span = (14, 0) .
Net data: fanout = 1, Y-spread of inputs = ( 4, 4) .
The net I$96/N$49 driven at location XY = (15,13) uses an LVT.
LVT data: column = 19, Y-span = (14, 0).
Net data: fanout = 1, Y-spread of inputs = ( 5, 5).
The net I$96/N$320 driven at location XY = (16, 2) uses an LVT.
LVT data: column = 7, Y-span = ( 7, 0) .
Net data: fanout = 3, Y-spread of inputs = ( 7, 3)
The net I$96/N$169 driven at location XY = (13, 2) uses an LVT.
LVT data: column = 13, Y-span = ( 8, 0).
Net data: fanout = 4, Y-spread of inputs = ( 7, 1).
The net I$95/N$362 driven at location XY = (12, 5) uses an LVT.
LVT data: column =31, Y-span = (14, 0).
Net data: fanout = 12, Y-spread of inputs = (13, 0)
The net I$95/N$361 driven at location XY = (18, 1) uses an LVT.
, LVT data: column = 24, Y-span = (14, 0) .
Net data: fanout = 12, Y-spread of inputs = (13, 1) .
The net I$95/N$34 driven at location XY = (33, 1) uses an LVT.
LVT data: column = 29, Y-span = (14, 0).
Net data: fanout = 16, Y-spread of inputs = (12, 0).
The net I$95/N$30 driven at location XY = (37, 1) uses an LVT.
LVT data: column =35, Y-span = (14, 0) .
Net data: fanout = 16, Y-spread of inputs = (12, 0).
The net I$95/N$26 driven at location XY = (38, 1) uses an LVT.
LVT data: column = 40, Y-span = (14, 0) .
Net data: fanout = 16, Y-spread of inputs = (13, 0).
The net I$95/N$22 driven at location XY = (31, 0) uses an LVT.
LVT data: column = 37, Y-span = (14, 0) .
Net data: fanout = 16, Y-spread of inputs = (13, 0).
The net N$99 driven at location XY = (11,11) uses an LVT.
LVT data: column = 11, Y-span = (14, 0) .
Net data: fanout = 3, Y-spread of inputs = (12, 1).
The net N$97 driven at location XY = (14,11) uses an LVT.
LVT data: column = 6, Y-span = (14, 0) .
Net data: fanout = 3, Y-spread of inputs = (12, 1).
The net N$9 6 driven at location XY = (17,11) uses an LVT.
LVT data: column = 25, Y-span = (14, 0) .
Net data: fanout = 3, Y-spread of inputs = (12, 1).
The net N$945 driven at location XY = (19, 3) uses an LVT.
LVT data: column = 33, Y-span = ( 8, 0).
Net data: fanout = 16, Y-spread of inputs = ( 8, 3).
The net N$944 driven at location XY = ( 4,10) uses an LVT.
LVT data: column = 14, Y-span = (14, 0) .
Net data: fanout = 10, Y-spread of inputs = (13, 2).
The net N$88 driven at location XY = (28, 7) uses an LVT.
LVT data: column = 32, Y-span = (14, 0) .
Net data: fanout = 2, Y-spread of inputs = (10, 1).
The net N$821 driven at location XY = (11,13) uses an LVT.
LVT data: column = 15, Y-span = (14, 0).
Net data: fanout = 11, Y-spread of inputs = (14, 2) .
The net N$578 driven at location XY = ( 0, 4) uses an LVT.
LVT data: column = 2, Y-span = (14, 0).
Net data: fanout = 13, Y-spread of inputs = (10, 6).
The net N$336 driven at location XY = (20, 2) uses an LVT.
LVT data: column = 16, Y-span = (14, 0) .
Net data: fanout = 1, Y-spread of inputs = ( 8, 9) .
The net N$288 driven at location XY = (23,12) uses an LVT.
LVT data: column = 18, Y-span = (14, 0).
Net data: fanout = 2, Y-spread of inputs = ( 5, 5) .
The net N$284 driven at location XY = (22, 9) uses an LVT.
LVT data: column = 22, Y-span = (14, 0) .
Net data: fanout = 2, Y-spread of inputs = ( 6, 5).
The net N$249 driven at location XY = (20, 0) uses an LVT.
LVT data: column = 27, Y-span = (14, 0).
Net data: fanout = 8, Y-spread of inputs = (12, 4).
The net N$248 driven at location XY = ( 5, 5) uses an LVT.
LVT data: column = 28, Y-span = (14, 0) .
Net data: fanout = 8, Y-spread of inputs = (10, 1) .
The net N$23 3 driven at location XY = ( 4, 4) uses an LVT.
LVT data: column = 10, Y-span = (14, 6) .
Net data: fanout = 3, Y-spread of inputs = (13, 5) .
The net N$230 driven at location XY = ( 6,13) uses an LVT.
LVT data: column = 5, Y-span = (14, 0) .
Net data: fanout = 8, Y-spread of inputs = (14, 2) .
The net N$180 driven at location XY = ( 8, 6) uses an LVT.
LVT data: column = 8, Y-span = (14, 0) .
Net data: fanout = 4, Y-spread of inputs = ( 9, 3) .
The net N$17 8 driven at location XY = (21, 9) uses an LVT.
LVT data: column = 34, Y-span = (14, 0) .
Net data: fanout = 6, Y-spread of inputs = (10, 4) .
The net N$1043 driven at location XY = (14,13) uses an LVT.
LVT data: column = 21, Y-span = (14, 0) .
Net data: fanout = 10, Y-spread of inputs = (14, 3)
The net N$102 driven at location XY = ( 0, 9) uses an LVT.
LVT data: column = 9, Y-span = (14, 0) .
Net data: fanout = 10, Y-spread of inputs = (13, 1) .
The net N$101 driven at location XY = ( 6,11) uses an LVT.
LVT data: column = 3, Y-span = (14, 0).
Net data: fanout = 5, Y-spread of inputs = (13, 5) .
3. Validation File (ixaip.vld)
HEADER
FILEID DVDCHK . /ixaip/ixaip .vld ac6f3b89
CHECKSUM ac6f3b89
PROGRAM certify
VERSION 1.14
NODEID 0003ed5a
DEPEND DVDCRT . /ixaip/ixaip . crt 9 5cc23f2
DEPEND DVDAFL . /ixaip/ixaip . afl 778da8e2
DEPEND DVDIPF . /ixaip/ixaip . ipf 9 5cc23f2
VAR DVDCRT . /ixaip/ixaip . crt
VAR DVDAFL . /ixaip/ixaip .afl
VAR DVDIPF ./ixaip/ixaip. ipf
ENDHEADER
Design variables:
DESIGN = ixaip
DIE = 1020a
PACKAGE = lcc 6 8
ADLIB = /user/als/data/al000/adl05.1ib
Loaded design netlist.
Loaded pin locations.
Loaded net criticalities .
Beginning Pass 1...
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
Checking definition
ADLIB :MX4. .
ADLIB :AND2.
ADLIB :OR2. .
ADLIB :AND3B.
ADLIB: XOR.
ADLIB:AND3A.
ADLIB: GND.
ADLIB:AND2A. . .
ADLIB :DFE1B_0.
ADLIB :DFE1B_1.
ADLIB :DFE1B. . .
ADLIB :TA377. . .
ADLIB :AND3 . . .
DS. . .
ADLIB :OUTBUF. .
ADLIB :INBUF. . .
ADLIB :MX2.
ADLIB :BUF.
ADLIB :A01.
ALUBIT. . .
ADLIB :0R3 .
ADLIB :XNOR.
ADLIB :OR4.
ADLIB :NOR2
ADLIB.-XA1.
ALU . . .
ADLIB :A01A. . .
ADLIB :AND4A_0.
ADLIB :AND4A 1.
Checking definition ADLIB :AND4A. .
Checking definition ADLIB:DLC_0 . .
Checking definition ADLIB:DLC...
Checking definition ADLIB :DLC8A. .
Checking definition ADLIB :DFM3_0 .
Checking definition ADLIB :DFM3_1 .
Checking definition ADLIB :DFM3 .. .
Checking definition ADLIB :DFC1A_0 ,
Checking definition ADLIB : DFC1A_1 ,
Checking definition ADLIB :DFC1A. .
Checking definition CLKPHI . . .
Checking definition ADLIB :0R2A.
Checking definition ADLIB :0A1..
Checking definition ADLIB :X01..
Checking definition ADLIB :AND4C,
Checking definition ADLIB :AND4B,
Checking definition ADLIB:INV..
Checking definition ADLIB:A02..
Checking definition ADLIB :AND4D_0 .. .
Checking definition ADLIB :AND4D_1 .. .
Checking definition ADLIB :AND4D .. .
Checking definition ADLIB :MX8...
Checking definition ADLIB:A03...
Checking definition CU. . .
Checking definition ADLIB :DFC1_0 .. .
Checking definition ADLIB :DFC1_1 .. .
Checking definition ADLIB:DFC1 . . .
Checking definition REGBLK. . .
Checking definition IOU. . .
Checking definition ixaip...
Checking global and external connections...
Checking physical consistency
Calling the Combiner. . .
Beginning Pass 2 . . .
Checking definition ADLIB:AND2, used 67 times...
Checking definition ADLIB :DFE1B_0 , used 48 times...
Checking definition ADLIB : DFE1B_1 , used 48 times...
Checking definition ADLIB:DFE1B, used 48 times
Checking definition ADLIB :A01, used 20 times.
Checking definition ADLIB :BUF, used 13 times.
Checking definition ADLIB :MX2, used 37 times.
Checking definition ADLIB :AND3A, used 17 times
Checking definition ADLIB :OR3, used 14 times.
Checking definition ADLIB :A01A, used 3 times.
Checking definition ADLIB :DLC_0, used 24 times
Checking definition ADLIB:DLC, used 24 times.
Checking definition ADLIB :XOR, used 37 times.
Checking definition ADLIB :INV, used 5 times..
Checking definition ADLIB :OUTBUF, used 16 times.
Checking definition ADLIB :OR2, used 19 times,
Checking definition ADLIB :INBUF, used 13 times.
Checking definition ADLIB :DFM3_0 , used 3 times.
Checking definition ADLIB :DFM3_1, used 3 times.
Checking definition ADLIB:DFM3, used 3 times..
Checking definition ADLIB:XNOR, used 2 times..
Checking definition ADLIB:MX4, used 18 times...
Checking definition ADLIB :AND2A, used 20 times.
Checking definition ADLIB :XA1...
Checking definition ADLIB :DFC1A_0, used 4 times
Checking definition ADLIB :DFC1A_1, used 4 times
Checking definition ADLIB:DFC1A, used 4 times..
Checking definition ADLIB:AND3, used 11 times..
Checking definition ADLIB:AND3B, used 6 times..
Checking definition ADLIB : 0R4 , used 9 times...
Checking definition ADLIB : DFC1_0 , used 10 times
Checking definition ADLIB :DFC1_1, used 10 times
Checking definition ADLIB:DFC1, used 10 times..
Checking definition ADLIB :AND4B, used 3 times..
Checking definition ADLIB :0R2A. . .
Checking definition ADLIB:X01...
Checking definition ADLIB :N0R2 .. .
Checking definition ADLIB :0A1...
Checking definition ADLIB :AND4A_0
Checking definition ADLIB :AND4A_1
Checking definition ADLIB :AND4A. .
Checking definition ADLIB :AND4D_0
Checking definition ADLIB: AND4D_1
Checking definition ADLIB :AND4D. .
Checking definition ADLIB:A03...
Checking definition ADLIB:AND4C, used 2 times...
Checking definition ADLIB:A02...
Checking definition ixaip...
Checking global and external connections...
VLD3202: WARNING : Fanout of 12 exceeds recommended
Net N$228
VLD3202: WARNING : Fanout of 16 exceeds recommended
Net N$239
VLD3202: WARNING : Fanout of 13 exceeds recommended
Net N$578
VLD3202: WARNING : Fanout of 12 exceeds recommended
Net N$804
VLD3202: WARNING : Fanout of 11 exceeds recommended
Net N$81
VLD3202: WARNING : Fanout of 11 exceeds recommended
Net N$821
VLD3202: WARNING : Fanout of 11 exceeds recommended
Net N$944
VLD3202: WARNING : Fanout of 16 exceeds recommended
Net N$945
VLD3202: WARNING : Fanout of 16 exceeds recommended
Net I$95/N$22
VLD3202: WARNING : Fanout of 16 exceeds recommended
Net I$95/N$26
VLD3202: WARNING : Fanout of 16 exceeds recommended
Net I$95/N$30
VLD3202: WARNING : Fanout of 16 exceeds recommended
Net I$95/N$34
VLD3202: WARNING : Fanout of 12 exceeds recommended
Net I$95/N$361
VLD3202: WARNING : Fanout of 12 exceeds recommended
limit
limit
limit
limit
limit
limit
limit
limit
limit
limit
limit
limit
limit
limit
of 10.
of 10.
of 10.
of 10.
of 10.
of 10.
of 10.
of 10.
of 10.
of 10.
of 10.
of 10,
of 10 ,
of 10.
Net I$95/N$362
VLD3202: WARNING : Fanout of 11 exceeds recommended limit of 10.
Net I$96/N$701
Checking physical consistency...
VLD5300: Design uses:
468 logic modules
29 io modules
1410 module inputs driven by 481 signal nets with 2.93 average fanout.
0 errors and 15 warnings .
VLD2600: This design contains 15 nets with fanouts greater than
the recommended limit of 10. You are strongly advised to keep
net fanouts below 10 .
VLD2601: The probability of successfully routing this design is 91%.
Appendix I - MC68008-based Program Controller
This appendix contains an assembler listing of the simple program controller
written for the MC68008 board which was used with the FPGA-based processor.
The program uses the parallel output chip on the board to implement the
handshaking and data transfer to the processor. It reads data back from the chip
after any WRIT instruction is sent. The program to be sent is stored as a memory
image in the 68000 code; this can be modified by overlaying other programs. The
number -1 (FFFF hex) is used to signal the end of the program.
Eh
CJ
o
3
c
ill
e
QJ
JJ
tri
CD
CJ
Ch
P
o
co
o
Sh
jj
C
o
u
Cj LTt
Di ej\
O rH
Sh
3
QJ CD
Eh ,C
(JJ
Sh
. cd CD
M g >
o
o
o
u
o
JJ
o
Sh
ft
Cn
c
Sh X
Di cd
O <p
U CO
ft TS
CJ
H
CJJ
t
73
Dl
CCO
JJ
d to
CD p
Qj TS
r-l S-l
ft rd
E 8
QJ
Jp
JJ
TS
c
rd
QJ
Tl
O
g
JJ JJ
cd Sh
CJ cd
Sh
CD
TS ft
C ft TS
H cd QJ
Sh
O
JJ
TS
C
rd
Xi cd
P
ft
jj
P
o
Cj
O
td
Q
cd
TS
JJ
P
ft
C
JJ JJ
Sh S-i
M J CC
O
CL
Cj
Dl
td
C
O
-H
4J
CJ
Ql
C
C
o
u
O CJ
o o
o o
I. fc,
Ci, tK
LO- -LO
CO
Eh Eh ^-H
S O-H O-H
o o ~ :n k :x in
CL; CL M H O O
TS
Sh
cd
O
CQ
A A
_, t_ n,
cm n ^
m m m
< PQ
LU
O Eh Eh
O CC CC
OD O O
vo CC CU
CO
H
i^
O
Cd
a cu
DC
CJ o
CN QJ
.^ TS
2 O
^ u
fc CO
H to
CL QJ
CO Sh
T3
r~- Ti
LO <
o
_
li
CD m tr
01 LO QJ
rd CO rH CO
CL en CC
w
t- CO
rH D W
THcNm^i-n^i>cocr\OiHcn m ^ Ln *-o o 'X
tH H rH rH <H ^H *
OrHCNrO-^LnvDr-CO
rNCNCNCNCNCNCNCNCS
r-t
I
PS
Eh
W^TCDOOOCMODrf
OOOOrHrHrHr-1
OOOOOOOO
ftftftftftftftft
ftftftftftftftft
LO-LOLO-LOLOLOLO-LO
DDDDDDDD
aaoaaaoo
CdKIKIKIKlKIKIKI
CN VO LO CN CD LO
O O O rH rH rH
CO CX) CO CO CO CO
ft ft ft ft ft ft
ft ft ft ft ft ft
LO- </> LO LO LO- LO
D D D P ft D
a a a a c a
W ft W Cd Cd KI
o
o
o
PS a a a ft cc PS
CJ
CQ
Q
co
a
o
a
CQ
a
CJ
os
CO
a, CL CC CL CL CL CL Ch
cc as
OS Eh
CQ CQ
CQ OS OS
OS CC
^
CO OS
cc
CO
os
Cd
in
CO
H
o
Cd
PS
Q rH CM ro
CI Q Q Q
O
PS
o
Cd ^r CO OD o CN CO
r6
CM LP CO CN LO LO
o o o o rH rH rH o o o rH rH rH
o o o o o o o o CO OD CO CO CO 00
ft ft K ft ft Ch K K On ft ft ft ft ft
CH ft K ft ft ft ft Ch ft K ft ft ft ft
o o o o O O o O o o o o o o
o o o o O o o O o o o o o o
o o o o O o o o o o o o o o
II II II II II II II II II II II II II
o
o
o
cnorHc^rn^i_'iu3r--cocri
r^cnrorncorncnrnrororn
rH^cn-^LnUDC^COCriOT-HCNrO^
^^^^^^'^-^^uni_nLn_nLn
m
en
o
o
3
ac
o
M
ft
Q
ft
Eh
PS
Cd
CO
CO
<
<
ft. Q Q
Eh
PS
w Cd
Eh
Cd
Eh
2
H
o
Ph
*^r
en
<
_
<
o CO _ CO g 2 OSft O
CN ft Cd ft 3 Eh w 6 Eh Eh
ft 2
CN B
Cd
B CJO t6CO QOS fto
H
Eh
CJ
a CQ
CO
CQ
W
03o ft CC CL O CL CrS Cd o ft D Eh 2
C-l ^ ^ B 2H CL OS 3 Eh ftEh COCd ft g EhPSQ
O
X X o B ft ft Ph Ch CO CO Eh > rrH rH DS o o G p^ Cd 2 P| Q CQ Cu CN
CO o O 5 s Eh Cd H ft 2 2 CO CC
~ ft Cd ft ft CO CO o o ^ 2 O 5 ~ 2 O
Q Q H l/l CO CO u u O S ft o Eh Eh
Q O Dh CQ CJ Cd Cd Q 5. u Eh OS2 2 CO ft ft Eh CL Q ft Cd Cd
ft ft Cd Q Q H H ft Eh Cd u H > CO
CC CO CO 3 CJ COD 9 2H ftCO ^r 9 KIO 2H ccCO g 9
CJ ** '* ^ " -- ft
o PS
CL
T_i
2
H
ft < Cd CL
rn PS PS PS o ft -
LO ft os Q Q Q < B
O o os
4C o CJ 9 ft ft o CJ o Q CJ< CQ 03 O 2 5 Q pj Q OS <
CQ CL ft Ph CL CL H Cd ~ G * CQ Q CL
Cd Q <3- + 3 s H- ro rr O CQ ~KI O O ft ro o ft o ft . Q Q
c6
ft CL 'X,
> < < ft o o o CJ o CL J O v <
O LO LO LO LO LO CJ # o < ^ 9 < o rH O CO O LO2 # *= * * # =#= * CJ Q * 2 * Q Jfc
JJ
CS
a
e
CD
J J
CQ CQ 03 03 CQ 3 3 3 3 03 03
_ a
rX
> $ a Cd> 66
3
ft
3
PS
Cd
>
Cd
>
jj o O o O O o o O O Cd O o CO O o
td
jj
CO
Qi
o
2 2 2 2 2 2 2 2 2 CQ 2 2 J 2 2
Eh B
Sh
3
0
Eh
l-H
2 1
o
9
CO HH CO CL
ft o o ft CO o rH rH r-l ft ft 00
CO
o
<
CJ
<
cd
ft
^r
o
VD
o
CO
O
o
O
O
O
o
o
o
CO
03
ft
o
ft
o
<
o o o o o o o o o o o o o o o o ^r o o o
iXl o o o o o o o o o o o o CD o o o O o o o
CN CD ft ft ft ft ft ft
T5 CJ ft CJ ft u ft u ft U ft u ft CJ CJ CJ CO CP. o CO o ^r o CO o CJ
2
<
O ft o ft o ft o ft o ft o ft o r- r- ro r-l r~ o rH o M* CJ ^ CJ ft
CJ ro o CO o en o ro o ro o no o o CN CO o CO t> O VO CN ro o ro ro
r-i o rH o ri o ri o r-t o r-i o CJ CN ro ro CQ LD ro en LCI rH Cd rH rH
ft
H
CL,
(JJ
CO
Qi CZ> CO o 00 o OD o LO CJ O CN CO CJ Cd O CN CO < o
CO Sh o o H rH CN CJ ro ro ro ^r ^r 31 ^r <* LO LD LO LO CO
TS o o o o o o O O O o o o o o O o o o o
[ ^c rH r-t H rH rH H rH rH rn rH rH rH r-l rH rH rH rH r-i
LO < o O o o O O o O o o o O o O o o O O CD
CN o o o o o o o O o o o o o O o o O o O
CN o o o o o o o o o o o o o o o o o o O
CJ
o
o
ft
ft
o
ooooooooo o o o o
Ql ro rr
01 LD 0)
cd 00 rH CO
CL ro CC
Cd
r- co
rH D
o o- r-- r-
ft
ft
ft
c_
O
cc
ft
CO
ft
CJ
<
rH CD*
CC CO
Cd
ft Cd
O
""
8
Eh Eh ft
Cd H O
2 < cc
H 3 Q
B B B
v
H
Eh
B
os
in
co
2
Cd
co ft
ft CL
2
"
8 Eh
O X
O W
2
Cd
PS Cd
O >J
o
Eh
PS
CO
CL
CQ
W Q O o
o ^ <c -lo
g =a= a, =tt
CQ
Eh
CO a
Eh Cd
03 03
Eh
ft
CO
Q
Cd Eh
> Cd
<
PS
o
2
gg
*4* ft CO Ph
Eh CO Eh
CO. rH Cd
ft
Eh
O Eh lo- Cd lo
2 Cd * Eh *
Eh
...
ft CQ CQ
ft
CQ
CL CX CL C<
Cd .
CQ ft
OS
CO
ft
ft
<
ft
Eh
CO
Cd
Eh
a
W a
o _
2 * Eh
03
ft
CJ
03
ft
Eh OS OD
Cd Q <
KI CJ LO
ft 41=
CQ CQ
Eh Cd Cd
Cd CU > >
Eh KI Q O
CQ CQ 2 2
OS
+ ft H
s;
rH en 3
< rH 2
ft Q H
CN O - <-.
Eh
CO Cd
b g
E-
PS
u
03
ft
o
<
LO
< <
o o
ft O ft
ft ^r < ft rr ^ CJ CO ^t1
o o U o O CO o CO O
o o O o o o rH o H o
o o o o
ft
o o O o o o
o-> rH 31 U ft cr\ rH ^r CO ro o ro o LO
ro o ft ft o ro O ft CQ ^P o ^ o <
CN CD r- ro o r] CO LO o CJ C- u r- o
rH o vo rH o rH O LO LD o co o LO LD
CO KI IN <3* CJ CN CO CO < ft] CN vo <
LD LO r- C-- r- CO CO CO co UJ CTl CTi o.
O O o O o o o o o o O O o
rH rH rH rH rH rH rH rH rH rH rH rH rH
O O O O O O o CD o O O O O
o O O O o o O O o O O o O
o o o o
o o o o
[-- r~ t> 0-
o O c
ft ft OD ft o
ft LD ft < ft LO <
o O o w o O ft
o O o o o o o O o
o O o o o
ft
o o O o
ft
CT\ rH ^ O", CJ ft CN CT, rH a1 CJ ft
m O [_-, ro Pl,
ooooooooo
ooooooooo
cho<HCNm^Lnu-i>co
i>-cooocococococococo
(J m o [_! Pl,
CNCOr^^mocNc^couDno
O <-D v-H rH O O U3 rH O
CO CO Cd LD as. Cd CJ r?
< < < CQ 03 CQ CJ o
o o o o o o o o
rH rH rH rH rH rH rH H
o O o O o O o O
O O o O o O o O
O o o O c o o O
o o o o o o o O
rH (N ro *3* LO LD r- 0D
<T\ 'DA en CTI CTi oi o\ CTl
ro
en
Eh
CJ
O
o
co
a
i
w
2
KI
CO
in ^-,
oo -LO
c
0)
e
QI
JJ r_
_
ft
rd CQ o
QJ
CJ
Sh
P
C
Cd
O
UO O
-oo-
rH o
-00-
o
H
*
S CCi co o OJ '-i o 3: ft
rH CO CN 00 1/1 UJ r-{ LD 866 o rH O r-i rH rH H rH H-00- -00- co </> 00- 00- -uo- -00- CJ
3 3 3 3 3 3 3
ft
Q
O
CJ
o
ft
o
B Cu2
o
Cd s
Q ft
O ft
u <
<3< o
l> o
ft CN
VO ft rH
CN CD o
^ TS o o
2 O o o
<
CJ o
LD
o
II
ft (JJ
H CO
ft Qi CJ
CO Sh CJ
1 1 TJ o
r- TS rH
LO < o
COrHODCNODOCOrH
OOODOCOLOCOrH
OeDrHCDrHrHrHrH
OOOOOOOrH
OCN^IOCO^UM
oooooooo
CNCNCNCNCNCNCNCN
rHrHrHrHrHrHrHrH
OOOOOOOO
OOOOOOOO
OOOOOOOO
OOOOOOOO
o <
o o
LO o
rH o
o
o o CN
o o r-
o o u
II o rr
o CN
o o
01 ro rr
Dl VO CD
rd CO rH CO
ft ro CC
ftl
r~ CO
rH D ftl
OrHCNm^Ln^r--.
oooooooo
OOCTiOrHCNm^Ln
O O rH rH
^-\ v-{ i~\ rH
9ro
CD
PS
A
ft
C
rd
rH
03
V
CD Sh
O 3
C
Ql II
Sh
CD LO
Ql ^
ft G
O
CO -H
CO JJ
o -H
Sh c
CJ -H
JH
+ CD
ft
QJ
CJ
C
CD
Cj
CD
JJ
QJ
ft LO LO- LO
rH CD OD rH O
CO LO LO o cn
O O O O O
0> m CN m CN (N CN CN CN
u
c
CD # Kfc # # # *
rH
>X> rH CN in cr. CO O cn in
0) CO CD 'XJ U*l r> CN cn m cr\
4-1 o O o O o O o o o
<1'
cr; CN CN CN
1
CN rH x-\ ^-\ CN
oo- -oo- -co- -oo- </>
r> c> m o cn un _n
_n l/i r~- cc cn ld r~-
o o o o o o o
'
CN CN CN CN CN CN CN
rHUOC^jH^CNLno-
\>~c-~c<ict-)cncnr~ics)r<-)
OOOOOOOO
Jfc * * 4fc
LD cn OJ ft.
ro ro ^ ro
O o O o
CN O O o CJ CJ ^J1 o OD CN OD Cd LO CN ft CO o < LD LD CN
o O O o r~ o o rH 03 LO VD o o rH o rH O' ft O rH o
LO CN LO o o o o, o o o o o o o o O O O OD CO CO
rH rJ rH rH rH ft ft ft rH rH rH ft ft ft ft ft ft ft ft ft ft
Ql o o O O o ft ft ft o o o ft ft ft ft ft ft ft ft ft ft
p o O o O o o o o o O o o o o o o O O O o o
rH O O o o o o o o o o o o o o o o c> o O o o
cd O O o o o o o o o o o o o o G' o O o O o o
> II II II II II II II II II II II II II
CD ro
Di VO
nS OD rH
ft ro cc
Cd
r- CO
rH D
Eh
CJ
o
%
Ql
>
o
o
o
CO
03 2
CO
& <
ft
TS H
QJ ft
O Cd
P
TS Eh
O CO
H ft
ft
Eh
CO
L?
P
CO
CJ
ft
CQ
KI
ft
ft
o
Cd
2
CO
<
CO
^ [^ H
CN CN ^
9
ft
CO
QJ ro
Di LD
cd OD rH
ft ro ft
KI
[> CO
H D
Q)
g O 01
-H H JJ
Eh QJ O rH
01 TS H p
TS rd QJ rd
CD (JJ Sh JJ ft
CO ft CD CJ
ft ft QJ QJ
rd ft MH Sh D
rH ft P -H rd
Cd U CQ Q CL
TJ
Qi
Sh
O
JJ
C
P
o
o
CO
Sh
O
Sh
Sh
Cd
O
2
