Feasibility of the PowerPc 603ETM for a LEO satellite on-board computer by Vos, Jacu
FEASIBILITY OF THE POWERPC 603E™
FOR A LEO, SA TELLITE ON-BoARD
COMPUTER
JACUVOS
1f'I:lESISPRESENTED IN PARTIAL FULFILMENT OF THE REQUIREMENTS
FOR THE DEGREE OFMASTER OF SCIENCE (ELECTRONIC ENGINEERING)
AT THE UNIVERSITY OF STELLENBOSCH
Supervisor: Prot P.J. Bakkes
December 2002
DECLARATION
I, the undersigned, hereby declare that the work presented in this thesis is my own original
work and that I have not previously in its entirety or in part submitted this work at any uni-
versity.
Signature Date
\
\
'.
Stellenbosch University http://scholar.sun.ac.za
ABSTRACT
For space designs, just as for terrestrial applications, the appetite for more computing
power is virtually insatiable. Further, like portable applications, space use implies severe
power constraints. Among currently available commercial processors, the PowerPC family
ranks high in Million Instructions Per Second (MIPS) per watt, but its suitability for space
applications outside low-earth orbits (LEOs) may be limited by the radiation environment,
particularly single ev nt effects (SEE).
This thesis covers the feasibility of using the PowerPC 603e™ processor for LEO satellite
applications. The PowerPC architecture is well established with an excellent roadmap,
which makes for a baseline microprocessor with long-term availability and excellent soft-
ware support. The evaluation board design leverages Commercial Off-The-Shelf (COTS)
technologies, allowing early integration and test. It provides a clear path to upgrades and
provides a high performance platform to suit multiple missions.
,
\
\
Stellenbosch University http://scholar.sun.ac.za
OPSOMMING
Die soeke na rekenaars met hoer werkverrigting sal nooit ophou rue. Dit geld vir beide
rekenaars op aarde as satelliet aanboord rekenaars. Rekenaars vir ruimte gebruik word ook
streng drywingsbeperkings opgele. Die PowerPC familie vergelyk baie goed met ander
verwerkers, maar hul bruikbaarheid vir ruimte toepassings kan dalk beperk word tot lae
wentelbane waar die ruimte radiasie omgewing meer toeganklik is.
Die skrywe behandel die bruikbaarheid van die PowerPC 603e verwerker vir lae wentel-
baan satelliet gebruik. Die welgestelde argitektuur, bekombaarheid en uitstekende sagte- _
ware ondersteuning verseker 'n standvastige fondasie. Kornmersiele komponente het
voorkeur geniet in die hardeware ontwerp wat spoedige ontwikkeling sowel as aanpas-
baarheid verseker. Die ontwerp bied 'n hoe werkverrigting en maklik opgradeerbare op-
lossing vir 'n groot verskeidenheid gebruike.
.
\
11
Stellenbosch University http://scholar.sun.ac.za
ACKNiOVVLEDGMENTS
Most importantly, I wish to thank the Lord God without whom nothing is possible. I
hereby also thank the following people for their invaluable help in the successful comple-
tion of this thesis: My family for their patience and their interest in my work; Gregor Drei-
jer for his assistance in bridging the many obstacles I encountered and also for his impera-
tive moral support; Francois Retief for compiling the PowerPC EABl toolchain; and my
supervisor, Prof. Bakkes, for his guidance and open-mindedness.
\
\
111
Stellenbosch University http://scholar.sun.ac.za
CONTENTS
DECLARATION
ABSTRACT I
OJ>SOMMING II
ACKNOWLEDGMENTS III
CONTENTS IV
LIST OF FIGURES VIII
LIST OF TABLES IX
LIST OF ACRONYMS XI
OVERVIEW 1
1. INTRODUCTION 2
2. THE POWERJ>C PROCESSOR 6
2.1. EXECUTION UNITS 6
2.2. Bus INTERFACE 8 .
2.3. MEMORY MANAGEMENT 8
\
\
\
2.4. POWER MANAGEMENT 9
2.4.1. Dynamic Power Management 10
2.4.2. Static Power Management JJ
IV
Stellenbosch University http://scholar.sun.ac.za
2.5. TIME BASEIDECREMENTER
2.6. TEST INTERFACE
2.7. CLOCK MULTIPLIER
2.8. PROGRAMMfNG MODEL
2.9. PACKAGE PARAMETERS
2.10. RADIATION FACETS
2.11. ROADMAP
2.12. CONCLUSION
12
13
13
14
15
18
19
20
3. HARDWARE DESIGN 23
3.1. DESIGN OVERVIEW
3.2. FUNCTIONAL DESIGN
3.2.1. CPU
3.2.1.1. System Interface.
3.2.1.2. Power Supply Filtering
3.2.1.3. Thermal Considerations
23
24
25
25
27
27
29
29
33
35
36
36 -
37
37
38
38
38
39
39
40
41
42
42
43
43
44
44
3.2.2. FPGA
3.2.2.1. Memory ontroller
3.2.2.2. EDAC
3.2.2.3. Interrupt Controller
3.2.2.4. UARTs
3.2.2.5. 12C Controller
3.2.2.6. Reset Controller
3.2.2.7. Debug & Expansion
3.2.3. FLASH ROM
3.2.4. SRAM
3.2.5. Clock Generator
3.2.6. Real-Time Clock
3.2.7. Reset Generator
3.2.8. SCC
3.2.9. LVDS
3.2.10. Temperature Sensor
3.2.11. Current Sensor
3.2.12.ADC
3.2.13. Power
3.3. PHYSICAL LA YOUT
3.4. CONCLUSION
v
Stellenbosch University http://scholar.sun.ac.za
4. SOFTWARE DEVELOPMENT 47
4.1. DEVELOPMENT ENVIRONMENT 47
4.2. THE POWERPC EABI 47
4.3. PROCESSOR lNITIALIZA TION 49
4.4. SOFTWARE INTERFACING 51
4.4.1. UARTs 51
4.4.2./C Controller 53
4.4.3. RTC 54
4.4.4. Temperature Sensor 54
4.4.5. Clock Generator 56
4.4.6. Interrupt Controller 56
4.4.7. LVDS 57
4.4.8. SCC 58
4.4.9. System Management 58
4.4.10. Debug & Expansion 58
4.5. CODE UPLOAD 59
4.6. DEMO PROGRAM 60
4.7. SRAM DUMP 61
4.8. CONCLUSION 62
5. TEST AND MEASUREMENT 63
5.1. PROCESSOR TEMPERA TURE 63
5.2. POWER CONSUMPTION 64
5.3. POWER-UP CURVES 64
5.4. SRAM TEST 66
5.5. CONCLUSION 66
6. CONCLUSIONS AND RECOMMENDATIONS 67
REFERENCES 69
I
\
AP]>ENDIX A: REGISTER BIT ASSIGNMENTS A-l
AI. UART REGISTERS A-I
A2. rc CONTROLLER REGISTERS A-3
A3. INTERRUPT CONTROLLER REGISTERS A-4
A4. LVDS REGISTERS A-7
VI
Stellenbosch University http://scholar.sun.ac.za
AS. SYSTEM MANAGEMENT REGISTER
A6. DEBUG/ExPANSION REGISTERS
APPENDIX B: SUPPLEMENTARY CD
A-7
A-8
B-1
Vll
Stellenbosch University http://scholar.sun.ac.za
LIST OF FIGURES
Figure 1-1. Simplified Block Diagram of SUNSAT
Figure 2-1. Block Diagram of the 603e™
Figure 2-2. Execution Unit Idle Time for SPEC92
Figure 2-3. 603e Register Set
Figure 2-4. CBGA Solder Fatigue Field Life Projections
Figure 2-5. CBGA and Compliant Lead System
Figure 2-6. E-tec BGA Adapter System
Figure 2-7. PowerPC™ Roadmap
Figure 3-1. Hardware Block Diagram
Figure 3-2. PLL Power Supply Filter Circuit
Figure 3-3. Simplified Thermal Network of a C4/CBGA Package mounted to a PCB
Figure 3-4. Memory Controller Architecture
Figure 3-5. Single-Beat Reads Showing Data-Delay Controls
Figure 3··6.EDAC Unit Simulation Results
Figure 3-7. Internal Structure ofI2C Controller
Figure 3-8: Integration of Reset Sources with Reset Controller
Figure 3-9. PowerPC 603e™ OBC Evaluation Board Layout
Figure 4-1. Flow Diagram ofRTC Read Procedure
Figure 4-2. Block Diagram ofS-Record Programmer
Figure 5-1. Temperature and Current Curve at 200MHz
Figure 5-2. Temperature and Current Curve at 150MHz
Figure 5-3. Temperature and Current Curve at 30MHz
3
7
10
14
16
17
17
20
24
27
-28
31
34
35
37
40
45
55
60
64
65
65
Vlll
Stellenbosch University http://scholar.sun.ac.za
LIS,T OF TABLES
Table 1-1, Processor Specification Summary 5
Table 2-1, Page Access Protection 9
Table 2-2, Dynamic Power Management Results 11
Table 2-3. Static Power Management Results 12
Table 3-1. Evaluation Board Memory Space 32
Table 4-1. PowerPC EABI Registers 49
Table 4-2. UART Registers 52
Table 4-3. 12C Controller Registers 54
Table 4-4. Interruot Controller Registers 57
Table 4-5. LVDS Registers 57
Table 4-6. System Management Registers 58
Tab Ie 4-7. Debug/Expansion Registers - 59
Table 5-1. Temperature Measurements 63
Table AI-I. UART Control Register A-I
Table AI-2. UART Status Register A-2
Table A2-1. rc Control Register A-3 \,
Table A2-2. t'c Command Register A-3
Table A2-3. rc Status Register A-4
Table A3-1. Interrupt Mask Register A-4
Table A3-2. Interrupt Pending Register A-5
Table A4-1. LVDS Control Register A-7
Table A4-2. LVDS Status Register A-7
IX
Stellenbosch University http://scholar.sun.ac.za
Table AS-I. System Management Register
Table A6-I. Port Register
Table A6-2. Direction Register
Table A6-3. LED Register
Table A6-4. Switch Status Register
A-7
A-8
A-9
A-9
A-9
x
Stellenbosch University http://scholar.sun.ac.za
LIST OF ACRONYMS
ACRONYM DESCRIPTION
ADC Analog-to-Digital Converter
BGA Ball-Grid Array
BLVDS Bus LVDS
C4 Controlled-Collapse-Chip-Connection
BGA eramic Ball-Grid Array
COP Common On-chip Processor
COTS Commercial Off The helf
CPU Central Processing Unit
DMJ\ Direct Memory Access
EAS Embedded Array Block
EOAC Error Detection And Correction
FIT Failures In Time
FPGA Field-Programmable Gate Array
FR4 Woven Glass, Flame Retardant Epoxy Resin
]2C Inter-Integrated Circuit
120 Intelligent Input/Output
JTAG Joint Test Action Group
LEO Low-Earth Orbit
Xl
Stellenbosch University http://scholar.sun.ac.za
ACRONYM DESCRIPTION
LET Linear Energy Transfer
LUT Look-Up Table
LVDS Low Voltage Differential Signalling
MIPS Million Instructions Per Second
MSR Machine State Register
OS Operating System
PBGA Plastic Ball-Grid Array
PCI Peripheral Component Interconnect
PGA Pin Grid Array
PLL Phase Locked Loop
RAM Random-Access Memory
ROM Read-Only Memory
RTC Real- Time Clock
SCC Serial Communications Controller
SEp Single Event Effects
SEL Single Event Latchup
SEU Single Event Upsets
SOl Silicon-on-Insulator
SRAM Static Random-Access Memory
TCE Thermal Coefficient of Expansion
TID Total Ionising Dose
Xll
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
OVERVIEVV
This thesis is divided into 6 chapters and gives detail descriptions on the design process,
test results and measurements. The first two chapters provides some background on OBCs
and the PowerPC 603e™ architecture. Estimated performance and power figures are also
presented here and will be compared to actual measured data in the final chapters.
The following chapters introduce the hardware and elucidate the design process in detail.
The hardware includes the modules pertained in the support FPGA in addition to the
physical devices.
Following the hardware design, the software driver routines and initialisation code is pre-
sented. The development environment and the PowerPC Embedded Applications Binary
Interface (EABI) are also explained together with some debugging routines.
The final chapters present measurements and simulation results and the thesis ends with
some conclusive remarks and recommendations.
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
1
INTRODUCTION
On-board computers, or OBCs, are an essential subsystem of any spacecraft. Other
subsystems may be intelligent and be able to make decisions, but the main course of action
taken by them is still calculated by the OBC. The OBC interfaces with most of the other
subsystems on a digital and analog level and its design is highly dependent on the mission
objective. The most important tasks of an OBC are:
• Regulation of attitude
• Communication with earth
• Meas rernent of analogue signals, e.g. temperature, battery voltage, etc.
• Payload specific tasks, e.g. camera control.
Figure 1-1 contains a simplified block diagram of the SUNSAT micro satellite showing -
how the OBC connects to the various other satellite subsystems. From the figure, it is clear
that the OBC directs the other subsystems. It is therefore necessary for the OBC to com-
municate via the various protocols of the other subsystems. SUNSATwas built using only
COTS components.
COTS electronics offer compelling value not just because they are commercial or off-the-
shelf. Their greatest value for use in high reliability applications lies in their high-volume
production and widespread use: both drive down cost and drive up yield, performance and
reliability. Higher speed and superior electrical performance his led to an increased inter-
est in the possible use of unhardened commercial microprocessors in space. The use of
2
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
COTS open standards drives down development and life-cycle support costs as well as re-
ducing time to market for new products.
TeleCommand Boom
Analog Audio
Redundant OBC
and DSP
1BUSx2-411....--t
L- ....
Sciencet---H,_SSBt-- .....+ParallelL- .....
Telemetry
SCC/MODEM
LBAND/SBAND
Figure 1-1. Simplified Block Diagram of SUNSAT
While a debate continues in the space community regarding the merits and even the defini-
tion of COTS, most everyone can agree that adopting some aspects of the COTS electron-
ics industry technology into the space electronics industry is a certainty+
Still, using COTS devices all over the design will not ensure that the high-reliability objec-
tive, present in all satellite OBC designs, be met; especially not in the acrimonious space
radiation environment. Unhardened devices are susceptible to upset and degradation from
radiation and information is needed to determine the resulting effects and how they can be
detected and overcome. I
\
COTS devices are used throughout the design and data integrity is ensured by an EDAC-
enabled memory controller implemented in a FPGA. This also makes the design extremely
flexible as all peripherals and 10 devices are controlled by this custom FPGA that acts as a
bridge between the processor and its memory space.
3
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
Devices were selected with the low-power and high performance objectives, inherent to
any satellite subsystem, in mind. Most of the peripherals used boast power-saving modes
with fast recover times, allowing maximum efficiency and performance. For example, the
FLASH ROM features an automatic power-down mode when it has been idle for a fixed
amount of time and wakes up instantaneously on bus activity, inflicting no performance
penalty. Lessons learned with the development of SUNSATwere also incorporated. The
use of the Serial Communications Controller (SCC), for example, was based solely on its
high reliability and successful use throughout the mission. In addition, the OBCs used on
SUNSATwere used as reference designs to ensure a realistic OBC test platform.
The first step in the selection of a processor for an OBC is the compilation of a trade's ta-
ble. Table 1-1 was used in this processor selection with each processor evaluated based on
their merit for the respective categories. The table is adopted from a similar study done by
the Southwest Research Institute. They successfully developed a VME space qualified ra-
diation hardened workstation class processor board around the Thompson 603e processor.
Advanced high performance microprocessors, especially reduced instruction set, or RISe, -
are highly desired in the design and implementation ofOBCs. PowerPCs are powerful
RISC processors 'Withsignificant inherent radiation tolerance.i As shown in section l.1 0,
the SEE (Single Event Effects) rates and TID (Total Ionising Dose) tolerance makes the
PowerPC 603e processor suitable for a wide range of commercial aerospace applications+
The table clearly shows the merit of the PowerPC processors. The radiation-hardened
parts are software and pin-to-pin compatible with the commercial parts offering fast and
inexpensive development. The ARM architecture uses significantly less power but with
less fixed point performance as the Powerl'C devices. The StrongARM devices are also
110tequipped with a floating-point unit. No information regarding the radiation tolerance
or event susceptibility of the StrongARM processor could be obtained.
4
Stellenbosch University http://scholar.sun.ac.za
POWERPC OBC
Table 1-1. Processor Specification Summary
SEUs/ SELs/
DAY DAY
PROCESSOR! DVELOPMENT CLOCK RADIATION
MANFACTVRER TOOLS RATE MIPS POWER TID
KRAD
603rIMotorola Extensive 300MHz 480 4W 26 3x10-1 N/A
603ev/Thompson Extensive 100MHz 1101 3W 60 lx10-1 >lxlO-IO
603ev/]-]oneywell Extensive 100MHz 110 N/A 100 N/A N/A
StrongARMI
Good 206MHz 235 0.35W N/A N/A N/AIntel
486/Intel Extensive 66MHz 54 4.8W 30 3x10-1 >4x10-s
Pentium/Intel Extensive 100MHz 108 6.45W 100 N/A N/A
RAD6000/Lock Minimal 33MHz 34.6 3.86W >100 1x10-1 >lxlO-IOheed Martin
Thor Minimal 50MHz 50 4.4W >100 >lx10-6 >lxlO-IO
AD20 1O/Ternic Minimal 20MHz 20 2.l5W >100 >lx10-7 > lx10-10
The MPC603RRX266LC part from Motorola was used mainly due to the excellent soft-
ware and hardware support Motorola offer and the ease with which the part was acquired.
It can operate at frequencies up to 266MHz with the bus clock frequency as high as
75MHz. Motorola provides a wide range of reference designs and application notes for the
entire PowerPC family.
The following chapter provides some background on the PowerPC 603e™ processor and
its architecture.
5
Stellenbosch University http://scholar.sun.ac.za
POWERPC OBC
THE POVVERPC PROCESSOR
The 603e is a low-power implementation of the PowerPC microprocessor family ofRISC
microprocessors. It implements the 32-bit portion of the PowerPC architecture, which
provides 32-bit effective addresses, integer data types of 8, 16 and 32 bits, and floating
point data types of 32 and 64 bits.
The 603e is manufactured in a 2.5/3.3V 0.29 urn CMOS fabrication process using five lay-
ers of metal in a fully static design. The die size is 44mm2 and the operating die-junction
temperature can range from ODC to 105 DC.
The architectural organisation of the 603e focuses on high performance, low cost and
power management. This chapter enumerates the main design features of the PowerPC _
603e™ microprocessor and its architecture.
2.1. EXECUTION UNITS
The G03e is a high-performance, superscalar microprocessor and capable of issuing/retiring
as many as three instructions per clock. It contains five independent executions units,
hence can have as many as five instructions in execution per clock since most instructions
are single-cycle executable.
These five units include the following:
• Branch Processing Unit featuring static branch prediction, zero cycle branch
capability (branch folding), and Conditon Register (CR) lookahead operations
6
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
• 32-bit Integer Unit
• Fully IEEE 754-complient pipelined FPU for both single- and double-precision
operations
• Load-Store Unit
• System Register Unit that executes CR and Special Purpose Register (SPR) in-
structions and dispatches/ executes multiple integer add/compare instructions
per cycle
Figure 2-1 provides a high-level block diagram of the 603e that shows how these execution
units operate independently and in parallel.
Pi:M'Wr llmglHlCM"
DkluVc:litAl 'C,).Jlh-.,'
CXIf'ltr11 t:krecWTlQft"'"
~,roo.'!I c.no:
!flQJUtQ J.\tUd,v
Figure 2-1. Block Diagram of the 603e™
7
Stellenbosch University http://scholar.sun.ac.za
POWERPCQBC
2.2. Bus INTERFACE
The 603e features a selectable 32- or 64-bit data bus and a 32-bit address bus. The bus
protocol allows split-transactions, burst transfers, and out-of-order transactions with one-
level address pipelining. The efficient processor bus interface facilitates access to main
memory and other bus subsystems. It also allows multiple masters to compete for system
resources through a central external arbiter. This arbitration is flexible, allowing the 603e
to be integrated into systems that implement various fairness and bus parking procedures to
avoid arbitration overhead.
Typically, memory accesses are weakly ordered, maximising the efficiency of the bus
without sacrificing coherency of the data. Overall performance is improved by dynami-
cally optimising run-time ordering of load/store traffic.
The 603e maintains full interface compatibility with TTL devices and all pins are 5V com-
patible. Parity is also optionally provided on the data and address buses and is software-
enabled.
2.3. MEMORY MANAGEMENT
The 603e provides independent 16-Kbyte on-chip data and instruction caches with separate
memory management units (MMUs). The MMUs support up to 4 Petabytes (252) of virtual
memory and 4 Gigabytes (232) of physical memory. Demand-paged virtual memory is
supported by the PowerPC 603e and permits execution of programs larger than the size of
physical memory. Demand-paged implies that individual pages are loaded into physical
memory from system memory only when they are first accessed by an executing program.
The caches are four-way set-associative, physically addressed and are enabled/disabled via
software. The MMUs contain 64-entry, two-way set-associative, data and instruction
translation look-aside buffers (TLBs). Both the caches and TLBs use a least recently used
(LRU) replacement algorithm. The 603e also supports block address translation using two
8
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
independent instruction and data block address translation (!BAT and DBAT) arrays of
four entries each.
The MMUs also directs the address translation and enforces the protection hierarchy pro-
grammed by the operating system in relation to the supervisor/user privilege level of the
access and in relation to whether the access is a load or store. Table 2-1 shows the eight
protection options supported by the MMUs.
Table 2-1. Page Access Protection
Supervisor-only -J -J -J
Supervisor-only-no-execute -J -J
Supervisor-write-only -J -J -J -J -J
Supervisor-write-only-no-execute -J -J -J
Both user/supervisor -J -J -J -J -J -J
Both user/supervisor-no-execute -J -J -J -J
Both read-only -J -J -J -J
Both read-only-no-execute -J -J
Note:
-J Access permitted
Protection violation
2.4. POWER MANAGEMENT
The 603e provides four software controllable power-saving modes. Three of the modes
(nap, doze, and sleep) are static in nature, and progressively reduce the amount of power
dissipated by the processor. The fourth is a dynamic power management mode that causes
the functional units in the 603e to automatically enter a low-power mode when the func-
tional units are idle without affecting operational performance, software execution, or any
external hardware.
9
t:NM:llS!TEIT m:_lE!,rOSCil
BI6~':'F<
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
2.4.1. Dynamic Power Management
Dynamic power management is a software-enabled mode that turns on power-saving logic
for the execution units, caches and memory management units during normal operation.
Once the mode is enabled, no other software intervention is necessary.
The dynamic power management logic automatically manipulates clock regenerators to
reduce average power consumption by eliminating clock switching and inhibiting change
of registered values. Because the 603e features a fully static design, if registered values do
not change, the logic those values feed does not switch and thus reduces power consump-
tion.
The effectiveness of using dynamic power management in the execution units varies with
the type of code run. For example, the floating-point unit clocks will be frozen continu-
ously if integer-only code is run. However, if code is scheduled such that all of the units
remain busy continuously, few clocks will be frozen.
Figure 2-2 illustrates that for some applications, each functional unit may be idle during a
large percentage of the run time.f Since dynamic power management freezes execution
unit clocks during this idle time, it can be effective in reducing the average power con-
sumption of the execution units. The statistics were collected while running SPEC92
benchmark traces.
Loadl
Store
I0 SPECint921I- • SPECfp1l2
I
Fixed·
Point
Floating-
Point
System
Register
Unit
40 60 80 100
%Timeldle
Figure 2-2. Execution Unit Idle Time for SPEC92
10
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
Since the 603e has blocking caches, all other accesses are held off until cache miss data is
returned from memory. During this time the caches and MMUs are idle and can have their
clocks disabled.
Table 2-2 shows the percentage decrease in internal (core) power dissipation for various
applications if dynamic power management is used.Q The table data was obtained using an
earlier 603e which was manufactured in a 0.5flm 3.3V CMOS process using 4 layers of
metal and a die size of 981mn2. Still, these figures provide a feel for power savings obtain-
able with the dynamic power management feature.
Table 2-2. Dynamic Power Management Results
8.5% 14.0%
HE:APSORT
14.2%
C UNPACK DHRYSTONE:
2.4.2. Static Power Management
As mentioned earlier, the 603e provides three static power management modes, Doze, Nap
and Sleep. They allow the operating system or power management software to reduce av-
erage power consumption when the 603e is idle for any extended period. Once in one of
these modes, an extemal event, such as the external interrupt pin, will bring the 603e out of
that mode and instruction execution will resume by jumping to the address of the appropri-
ate interrupt vector.
Doze mode retains cache coherency as well as uninterrupted timer functionality. The 603e
will exit Doze mode in ten system clocks (SYSCLKs) or less, depending on the processor
to bus clock ratio. In Nap mode, further power savings are achieved with the data cache
and snooping logic disabled. The wake-latency for Nap mode is also ten SYSCLKs or
less. Sleep mode allows for maximum power savings by disabling the clocks to all units,
including the PLL and/or SYSCLK if desired. This allows the system to dynamically
11
Stellenbosch University http://scholar.sun.ac.za
POWERPC OBC
manage system power by changing the SYSCLK frequency, or change the Phase Locked
Loop (PLL) configuration. The wake-up time for Sleep mode is ten SYSCLKs or less is
the PLL and SYSCLK remain active and unaltered. If they were disabled, a maximum of
l Ouusec is required for the PLL to lock.
Table 2-3 shows total power consumed by the 603e using the static power management
modes. Again, these results were obtained using the earlier 603e and serve only as a guide
to obtainable power savings.
Table 2-3. Static Power Management Results
POWER (MW)
SLEEPFREQ
PLLoFF(MHz) DOZE NAP PLLoN PLLoFF CLK
CLKoN CLKoN OFF
25 133.2 49.4 38.8 12.8 4.7
168.0 62.0 13.5 4.7
50 241.7 88.8 66.2 15.1 4.7
66 307.1 113.0 88.5 17.7 4.7
366.1 135.1 105.5 19.3 4.7
2.5. TIME BASE/DECREMENTER
The time base is a 64-bit register that is incremented once every four bus clock cycles
while the decrementer is a 32-bit register is decremented once every four bus clock cycles.
The decrementer generates an interrupt exception after a programmable delay and can be
used as a software watchdog.
If the operating system initialises the Time Base to some reasonable value and the update
frequency of the Time Base is constant, it can be used for time-stamps in trace entries
(scheduler algorithms) and for computing time of day.
12
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
2.6. TEST INTERFACE
Board testing and chip debugging is facilitated primarily by IEEE 1149.l (JTAG) and
Common On-chip Processor (COP) functions. The JTAG interface provides a means for
boundary-scan testing of the 603e and the board. The COP function provide a means for
executing test routines, and facilitates chip and software debugging using a PC with dedi-
cated hardware and software. The standard COP interface header was used for connection
to the target system.
2.7. CLOCK MUL TIPLIER
A voltage-controlled oscillator-based PLL generates and synchronises the internal clocking
from/to the external clock signal, SYSCLK. The PLL can be programmed via four exter-
nal signals to allow for different internal clock frequencies that are multiples of SYSCLK.
This configuration of the PLL can be read by software.
The PLL is designed to lock to a wide range ofSYSCLK frequencies from 16 MHz up to
75 MHz. If lower frequencies are desired, the PLL can be bypassed altogether, allowing
SYSCLK to drive the internal clocking circuitry directly. Care should however be taken
when using this mode, since the timing specifications of the 603e is not guaranteed in PLL-
bypass mode.
The PLL configuration cannot be changed while the processor is running. It can be
changed:
• While the processor is off
• While the processor is in reset
• While the processor is in Sleep mode with the PLL and SYSCLK disabled
The last two options allow the system to change the processor clocking speed dynamically
without affecting system memory. The operating system can simply put the 603e into
Sleep mode and alter the SYSCLK frequency and/or the PLL configuration.
13
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
2.8. PROGRAMMING MODEL
•
PowerPC processors have two levels of privilege:
Supervisor mode of operation is usually used by the operating system, and
User mode of operation is used by the application software .
Having access to privileged instructions, registers, and other resources allows the operating
•
system to control the application environment and protect critical resources.
Figure 2-3 shows all the 603e registers available at both the user and supervisor level.
USER MODEL
I'iID·'*'IJoPolnl
~I.l""
C<>n.dnloo Rogh.lor
~
FID<OoI]n".PoI",5olnru.
ond C<>I>Ir<IIIlO~Dr
I F".P!tOR I
)(~R
~~
Link R~h,l.or
~9j'Ra
Counl~l.tor
~S'Rg
'TI..... Su. Facility
.F'or IR•• dlng.
ITiiITDR2&11
~TER2W
SUPERVI:SOR MODEL
Conflgurallo,n Reglstet"s
IIIKhlm' S"'1a
Rogl.t ..
~
l,np~omarltJ:ltjcm
Roglsa .... '
~a'l;lIQre
~antlOlQ
Memory Management Regl!llt!f8
l)il18 RAT RogltJtflNJ.
Sffi ~
SPR!.'Jl
Sf'R 53S
S.PR 5&~
SPR l<O
Sffi ~1
SPA ~.ra
OoCrDmet1lH
~SPR:n
t::dc:rnnl Addron
Roglo,.,.. (Optlooall
~&.PR:ttl2
Elcx:ep1ion Handling Reoglstel"'!!
[)~hl Addf"DEU!I H.4;',tor
~6f'f111)
sPA.Ga
Miscellaneous Reglsle,rs
nm. a.. " F.dlitl'
(f.. Wrttln!ll
~fffi~
~~ws
ImAruction Mtfrnl.
BroOk,...l", R.giIo! .. t '.'
~6Pil.'OlG
• I nese "'91'1)("" Of'. Gll:l ... p.otlo (I",f)fi-C.ooo and PIU71A)(J301.1-00/=1' DOt be> .upP"'1od tJy ~h..-
~,~ prooOS!lor.s.
Figure 2-3. 603e Register Set
14
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
The user-level registers can be accessed by all software with either user or supervisor privi-
leges. The supervisor model register set can be accessed only by supervisor-level instruc-
tions. A supervisor-level exception will be taken when access is attempted with user-level
instructions.
2_9_ PACKAGE PARAMETERS
The PowerPC 603e™ part from Motorola comes in Ceramic Ball-Grid Array (CBGA) and
Plastic Ball-Grid Array (PBGA) packages. From the PCB assembler's point of view, there
are many advantages in using BGA packages as well as some disadvantages. A key advan-
tage is the significantly better assembly yields for BGA packages+ There are no bent leads
and no coplanarity problems. The most apparent disadvantage is that most of the solder
joints are hidden under the package and makes visual inspection of the joints virtually im-
possible. In addition, the PBGA packages are moisture sensitive at present. CBGA pack-
ages are high thermal mass packages, and as such, require careful reflow profile manage-
ment to insure sufficient and uniform heat.
Solder ball metallurgy also differs between the PBGA and CBGA packages. The PBGA
solder balls melt at ~ 179°C, thus reflow and collapse in standard surface mount reflow
processes to provide ~20 mils stand off from the board. The CBGA solder balls melt at
~301 °C and do not melt in standard surface mount processes. Eutectic solder paste printed
on the pads of the PC board melts at standard surface mount reflow temperatures and
wicks up to the high lead solder ball. Because the high temperature ball does not melt and
collapse, the package will be held about 35 mills above the board compared to l Smils for
PBGA packages.
Due to the excellent, self-centring nature of all BGAs, both ceramic and plastic, the place-
ment accuracy requirement is very loose. Placement can be offby 12 mils or more and the
package will perfectly self-centre.
In this design, the high-volume CBGA device was used as it comes off the production line.
The CBGA package has much lower thermal resistances with respect to the die than the
15
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
PBGA package and is thermally more reliable. The PBGA package only ships at 200MHz
while the CBGA parts come in 200MHz to 300MHz versions. Also, it was estimated that
the solder joint fatigue life for the 21mm x 21mm CBGA package at an average of on-off
L\T of 20°C to be over 25 years, where L\T is the temperature rise above ambient at the sol-
d .. IIer jomt+'
Figure 2-4 shows the solder joint fatigue life for the 21mm x21mm CBGA, the package for
the PowerPC 603 microprocessors, and the 21mm x 25mm CBGA, the package for the
MPC 106 bridge devices. In the figure, each cycle represents the full temperature excur-
sion. It can be seen that a "worst-case" desktop situation with two on-off cycles per day
would still yield over 10 years of life for both packages.
100000
en
2o>-
U
t::;
0
~
0
..... 10000(\.)
~
0c,
4-<
0
~
"E
;::l
Z
1000
2 I x 21 mrn, 16 x 16 array I-
21 x 25 nun, 16 x 19 array
~
"'II .._.._
~ liiio..
""'lliIIo..--......
~ ~
~ ~
End-or-Life defined as IOOpptn. Toff ~ 25°C. -...........; ::::::::~For IOOOppmmultiply by 1.3X.
15 20 25 30 35 40 45 50
L\T (0C) - Solder Joint Temperature Defined by Power On-Off
Figure 2-4. CBGA Solder Fatigue Field Life Projections
A compliant lead system can be added to the commercial packaging to increase the ther-
mal-cycling capability of the device. Figure 2-5 shows a compliant lead system that can be
16
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
added to the CBGA package to eliminate the TCE (Transfer Coeeficient of Expansion)
mismatch problem=
Figure 2-5. CBGA and Compliant Lead System
Figure 2-6 shows another solution for increasing the thermal capabilities of the device.
This adapter system is manufactured by E-tec and comprises two elements: a BGA solder
adapter and a PGA socket that is soldered to the PCB. The BGA chip is soldered to the
adapter, converting the BGA to a PGA, and can then be plugged into the socket. The
adapter system is made from glass epoxy and has an operating temperature range of -66°C
Soldor Adapter
.Iini Grid Soeket
Figure 2-6. E-tec BGA Adapter System
17
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
Care must be taken when using BGA socket adapters as they increase the power and
ground inductance. One might expect the power and ground inductance to increase by 3%
to 7% as a result of the short distance between the balls and PCB.
2.10. RADIATION FACETS
Compared to previous generations, many modem deep sub-micron CMOS microcircuits
are very tolerant to TID radiation, but they are still sensitive to SEUs.1 Due to its fabrica-
tion technology, the COTS PowerPC has excellent total dose performance and is immune
to latchup.f..J. The custom support FPGA solves its SEU problems and helps exploiting the
full performance of the processor while maintaining full software compatibility with COTS
technology.
The results of radiation tests performed on an older version of the PowerPC 603 family, the
PowerPC 603e™, were shldied.1 This processor was manufactured in a 0.5flm, 4 metal
layer process with approximately 2.6 million transistors on a 98mm2 die and operated at
100MHz and 3.3V. The on-chip data and instruction caches were enabled for all exposures
and the test module was intended to be cache and I/O intensive.
Their measurements indicated that the device has a total dose tolerance of approximately
26 krad (Si) before functional failure. SEE measurements on complex microcircuits, such
as a processor, are highly sensitive to the application software used to perform the tests.
Nonetheless, the tests showed an overall event threshold of 17.2 to 18.2 MeV and an as-
ymptotic cross section of5xlO-9 to lxl0-8 cm2/device for energetic protons. For its sensi-
tivity to heavy ions, an application of the Calvel PROFIT model was used to estimate the
event threshold to be between 2.2 and 2.5 Mev/mig/crrr') and an asymptotic cross section
0.021 to 0.042 crrivdevice. Using these results the projected event rate for a sample circu-
lar low-earth orbit of 1400km, 48-degree inclination angle, Solar Max, and 1OOmilAlu-
minium shielding to be between l.8 and 3.8 days per event. Other tests show that the in-
herent TID tolerance of the PowerPC 603™ processors are adequate for orbits below
1400km and above 8000km for 15 years.i
18
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
Radiation tests performed by the Jet Propulsion Laboratory measured SEU in commercial
and silicon-on-insulator (SOl) PowerPC microprocessors.l They used SOl PowerPC
750™(G3) and PowerPC 740™(G4) processors from both Motorola and IBM and com-
pared the results to that of the commercial processors with bulk substrates. They found
that the SEU sensitivity of SOl PowerPC devices were nearly the same as those of the
standard commercial processors from the same manufacturers. The cross sections of the
SOl processors are lower than their counterparts with bulk substrates, but the linear energy
transfer (LET) threshold is about the same, offering little advantage over the commercial
parts. The results also show that the upset rates are low enough to allow these devices to
be used in space applications where occasional register or functional operating errors can
be tolerated. The SEL rate was estimated to be one in 25 years resulting from galactic
cosmic rays in deep space.
STM manufactures a 60krad and Honeywell a 100krad version of the PowerPC 603 proc-
essor. These can be used for increased reliability and lifetime.
2. .,1. ROADMAP
The PowerPC 603e is software- and bus-compatible with the PowerPC 604, PowerPC 740
and PowerPC 750 microprocessor families, which allows for rapid upgrades. Figure 2-7
shows Motorola's PowerPC processor strategy. The G5 series are available in parts capa-
ble of operating at frequencies of 2GHz. The upward compatibility policy of the PowerPC
strategy lets new designs take advantage of the increased performance of the new devices
immediately.
19
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
G6
&01
96xx
Gl
• $tJl"J~e OiOOllett (01 ~I~ed·
tH-d MId Ilt:<l'lljl!irlif"tt! mar\ea
·O,.tI°IICtl,\tr.",,1orlf,1lJ1G-1
PIOlllltl
·33.11:nMHJ.
&21. t23. ese, t6!l162.
5."x
IllC100sod IntoopationlAdvonelld P'OC9l$ Tochnologv
1991 6)1,1(, 110, 1Ji.r.III t 1111,Q(,·lo(!1 l:t11~" 111<~op·t;(~'S~ 1,'fW:'IT,1 LUrJ: 1.1,(19 Ifltlh 11" -et It<!lbrn~(I.,.<l
liU, 8Jr.IOI ":";j"';r.~ i'lt' .•I"M.f)r ~,"qr.tl .L) ~h,.. CU~I'n'JI'll',1I11,)1'~ _"":1 Ce;I\t, Jft r.r ,. ,1""',),
SII., h;)I)I "\'.1,,·,11" f p.;.>L""l'r Li'lft{P'11 tb" !r.'I~":."f"l.1 ,'" "'Jr""l
:200x
Figure 2-7. Powerf'C'?' Roadmap
2.12. CONCLUSION
These design features optimise the 603e for both power and performance, creating an ideal
microprocessor solution for portable applications. Its inherent radiation tolerance makes it
equally ideal for OBCs. Its excellent roadmap and the extensive suite of software tools
available facilitates fast and easy development. The memory management unit makes
software development easier by disallowing processes to access the same resources.
Regarding its feasibility for aerospace applications, the commercial PowerPC 603e™ proc-
essor embraces the following:
1. Good immunity to SELl,
2. Built by two world-class suppliers (Motorola and IBM),
20
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
3. Excellent reliability (low FIT rate),
4. Good MIPS/Watt performance,
5. Roadmap for increased performance,
6. Extensive software support, and
7. Long-term availability.
CMOS technology and careful physical design can provide low semiconductor junction
and joint temperatures for longer component life and higher reliability.
The conditions affecting solder joint reliability are:
• Mechanical vibration or impact
• Bending of boards
• Thermal shock
• External temperature
• Power dissipation internally
• Thermal cycling
• Solder paste composition
A satellite is subjected to about all of these conditions during its lifetime. The temperature
conditions can be improved to some extent by using a different PCB fabrication material.
The CBGA package, as a high thermal mass package, has a low CTE. Thermount®, for
example, more closely match the CTE of the package. Thermount® has a CTE of9 to 11
ppm/oC while FR-4 typically has a CTE of 15-17/50ppm/oC (x-y/z). It is therefore rec-
ommended by PCB manufacturers for high-reliability CBGA applications.
The PowerPC family of microprocessors are inherently immune to SEL and their SEU sen-
sitivity is good enough for them to be used in orbits oflower than 1400km and higher than
800km.2,J,4 Upset rates under these conditions are projected to range from once every 25
years, resulting from galactic cosmic rays in deep space, to about one every 1,8 to 2,8 days,
when subjected to radiation in a 1400km circular orbit, with only modest improvements
when using SOl technology.
21
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
The TID tolerance of the processor allows a projected lifetime in a 1400km circular orbit
of about 15 years. The PowerPC processor is thus adequate for LEO orbits where occa-
sional register or functional operating errors are tolerable.
The focus of the next chapter, Chapter 2, is the hardware design of the evaluation board.
The devices used and their interfacing with the processor will be discussed.
22
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
3
HARDVVARE. DESIGN,
This chapter is devoted to the hardware design of the PowerPC™ OBC evaluation board.
Firstly, the functions and features of the devices used in the design will be discussed. The
integration of these devices will then be presented followed by some conclusive remarks.
COTS devices offer many advantages over their space-qualified counterparts and are there-
fore used extensively throughout the design. Flexibility is one of the main concems when
designing an OBC. Hardware flexibility enables the adding and removal of certain divides
(modules) with no adverse affect on the overall performance of the system. This allows for
adaptation when certain devices become defective. Flexible software allows the use of op-
erating systems and routines across platforms and specific peripherals. This expedites fur-
ther work on the same system, but also expedites the design and tum-around time of new
systems if advantage of such software is taken.
3. 1. DESIGN OVERVIEW
The requirements of an on-board computer is usually mission dependent, i.e. different sat-
ellites wi II require different approaches to the design thereof. In the development of the
OBC evaluation board, the design scope was organized to attempt to satisfy all mission
independent requirements.
The following figure shows the block diagram of the design. From the diagram, it is clear
that the processor and memory controller together form the core of the design.
23
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
Power Processor COP
PT6303 PowerPC 603e™ (JTAG)
MAX1797
+- 6 -+
+ • +FLASH ROM ilL ....... Memory Interface
~
SRAM
4MB !lrY 2MB
90ns '"' Custom ..... 15ns~ ...$; =-= FPGA (.;;JSCC 00, U Checkbits- <
~Z85C30
1If__'" ~ 512 kB... Peripheral Interface Q
~ II""
~ ~ 15ns~
~~
~ ~ ~ ,. ~, ~ ,. ~,
Clock Reset RTC Temp. LVDS ADC
DSI077 DS1831 DS1337 Sensor DS29LV ADS7823
MAX6654
+~, ~,
DARTS Debug & Current
MAX3222E Expansion Sensor
MAX471
Figure 3-1. Hardware Block Diagram
In the following sections, more detail is given on the individual components and their func-
tions.
3.2. FUNCTIONAL DESIGN
The selection of devices used to build an on-board computer has to go hand in hand with
the purpose, dependability and availability of each device and of the devices with which it
24
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
interfaces. The following section motivates why the devices were used and explains their
respective roles in the evaluation OBC.
3.2.1. CPU
Chapter 1 gave some background on the processor and its architecture. This chapter elabo-
rates on its implementation. The system interface is described in the next section.
The system interface is specific for each PowerPC microprocessor implementation. The
60x family provide a versatile system interface that allows for a wide range of implementa-
tions and include a 32-bit address bus, 32/64-bit data bus, and 56 control and information
signals.
3.2.1.1. System Interface
Split address/data tenuring, bus snooping, multiprocessing support, cache coherency sup-
port, and other advanced features can be used to obtain additional performance for high-
performance systems, but for the purpose of a small, high-speed embedded controller, such
as an OBC, many of these complications can be avoided, especially since there is only one
bus master. Nevertheless, in the design of the evaluation board provision was made to
make use of these features, including multiple masters, by connecting the respective sig-
nals to the support FPGA. Support for multiple bus masters permit, for example, the im-
plementation of a DMA (Direct Memory Access) controller. The support FPGA is dis-
cussed in section 2.2.
The address and transfer attribute signals are pulled up through weak 10kQ pull-up resis-
tors to minimise sleep-mode power consumption. Since the 603e continually monitors
these signals for snooping, a float condition may cause excessive power consumption by
the input receivers on the processor. These address and transfer signals include the address
bus, A[O-31], address parity, AP[O-3], transfer type, TT[O-4], transfer burst, TBSTn, and
the global signal, GBLn. Similarly, the cache inhibit output signal, CIn, is also pulled up
via a weak 10kQ pull-up resistor to minimize sleep-mode power consumption. The APE
25
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
and DPE (address and data parity error) signals are open drain and are left unconnected.
Their input receivers are turned off when no read operation is in progress.
The parity buses of the 603e are not used since EDAC is implemented and since the parity
bus does not continue inside the processor, as is the case with the PowerPC 604™ proces-
sor. Itwill therefore provide no better redundancy than an EDAC system.
The ci», GBLn, WTn, CSE[O-l], TC[O-l], DBWOn, RSRVn, TBEN and TLBISYNCn
signals are not needed for a minimal design such as the evaluation board and were not con-
nected to the memory controller or any other device. Some of these signals are pulled up
via weak lOkQ pull-up resistors to ensure initial start-up. The CSE and TC signal groups
provide debug status and are connected to solder pads to make them accessible with an os-
cilloscope or logic analyser.
The checkstop signals are provided as an aid in problem determination. When the proces-
sor is in the checks top state, all latches are frozen so that the state of the processor can be
analysed. The two checkstop signals, CKSTP _INn and CKSTP _OUTn, are both pulled up
through weak pull-up resistors. The processor will halt immediately if CKSTP _INn is not
pulled up whereas CKSTP _OUTn is an open drain output and needs to pulled up to moni-
tor its status. The three LSSD test signals are pulled up through strong lkQ pull-up resis-
tors to keep noise from coupling to them.
The CLK_ OUT signal is useful for debugging purposes only. It cannot be used as a clock
source and is connected to a solder pad for debugging purposes.
The PLL_CFG[O-3] signals set the internal CPU frequency of operation. They are con-
nected to the support FPGA to allow the system to dynamically alter the PLL configuration
while the CPU is in reset. For completion, they are also connected to a DIP-switch to al-
low static configuration of the PLL.
26
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
The VOLTDETGNDn pin is internally tied to GND and is used to indicate to the power
supply that a low-voltage processor is present. Since the processor is to be soldered di-
rectly on to the board with no socket mechanism, this pin was left unconnected.
3.2.1.2. Power Supply Filtering
One decoupling capacitor was placed at each Vdd and OVdd pin of the processor. This
ensures a clean power supply to the 603e and prevents switching noise from the processor
to reach other components on the board. lOnF capacitors are used for the decoupling of
the 2.5V Vdd power rail and lOOnF capacitors for the 3.3V OVdd rail. In addition, a cou-
ple of lO!J.FAVX TPS tantalum capacitors are used for bulk storage and quick recharging
of the smaller capacitors. Only surface mount (SMT) capacitors were used to minimise
lead inductance.
The PLL is powered from the Avdd power pin. The power supplied to this pin should be
filtered to ensure a stable internal clock. Figure 3-2 shows the circuit used to filter the PLL
power supply. The trace from the circuit to the Avdd pin was made as short as possible to
numrruse noise.
10 Q
Vdd o---JI/0f''----I...--I....------<O AVdd
10IJFY O.lIIJF
GND
Figure 3-2. PLL Power Supply Filter Circuit
3.2.1.3. Thermal Considerations
The C4/CBGA offers the same connections in a significantly smaller board area than a
comparable C4/CQFP package. The CQFP (Ceramic Quad Flat Pack) gull-wing leads re-
quire additional space for wiring fan-out for electrical routing. Thus, the CBGA package
requires less board routing space than its CQFP counterpart.
27
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
This reduction of board area results in an approximate four-fold increase in package-level
thermal flux density.l- The primary heat transfer path for CBGA packages is through an
attached heat sink. However, for low-power applications the use of a heat sink is not nec-
essary. Heat conducted through the silicon may be removed to the ambient air by means of
convection. In addition, a second parallel heat flow path exists by conduction. Heat flows
through the C4 bumps and the epoxy underfill to the ceramic substrate for further convec-
tion cooling off the edges. Heat is also conducted from the ceramic substrate via the
leads/balls to the board whereupon the primary mode of heat transfer is by convection
and/or radiation. These heat transfer paths are illustrated in Figure 3-3.
~~
T
~ Heat Sink
, Attach
Silicon ~ Ch i J t i~ ... Ip line 10 n
C4 ~y~Under/ill
Package
Package
--,r----------- ~ Leads/Ball
Prin t ed-cir cui t B(){jr~ . .
Radiation ~ ~ Convect io n
Externsl Reslstsnce ~ ~ Secondary Heat
Transier Path
Extemul Resistance
Convect ionRadiation
Heat
Sink
Resistsnce
Primary Heat
Transfer Path
Figure 3-3. Simplified Thermal Network of a C4/CBGA Package mounted to a PCB
Since the evaluation board is not densely populated in the area surrounding the CPU, no
heat sink was deemed necessary. Section 3.2.10. gives detail on the temperature sensor
used on the evaluation board to aid in thermal management.
28
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
3.2.2. FPGA
The ACEX™ EPIK50 FPGA from Altera was used as the support FPGA. The ACEX
family are SRAM based and combine lookup-table-logic with embedded array blocks. The
EPIK50 features 50,000 gates and 40,960 bits of RAM.
Since the 603e has a 64-bit data bus, VO pins on the FPGA was a major concern, espe-
cially because the address lines had to be connected to the FPGA as well for the EDAC
system to function. The 484-pin FineLine BGA package was used to alleviate the matter,
providing a maximum of 249 user-programmable 110 pins.
On a satellite OBC, radiation tolerant FPGAs will be used instead. These devices offer
more reliability in the space radiation environment than their SRAM-based counterparts
do. Manufacturers like ACTEL provide a vast selection of radiation tolerant ASICs and
their RT54SX-S series FPGAs are specifically designed for space applications. Internal
clocking speeds of up to 310MHz are achievable and they have an 8.9ns clock-to-out (pin-
to-pin) delay. They compare well with the device used on the evaluation board and Actel
offers equivalent devices for prototyping.
The support FPGA performs a number of functions; the primary being to control the mem-
ory space and provide an VO interface for the PowerPC 603e™ processor. Other functions
include an EDAC system for memory integrity, communications, and an interface to the
onboard telemetry, e.g. temperature. The sections that follow elucidate these subsystems
implemented in the FPGA.
3.2.2.1. Memory Controller
Motorola offer two PowerPCTM compliant PCI bridge/memory controller parts: the
MPCI06 and MPCI07. Both are compatible with the PowerPC 603e™, PowerPC 740™
and PowerPC 750™ microprocessors. Both integrate secondary cache control and a rnem-
ory controller that supports DRAM, SDRAM, EDO DRAM, ROM and FLASH ROM.
Dual processor support and power management is also included. DMA support, r'c, 120
and clock drivers are added features in the MPC] 07. These devices offer much more than
29
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
is needed by an embedded system. Complexity can sometimes reduce performance; espe-
cially since cache coherency instructions can use valuable clock cycles.
The memory controller implemented in the FPGA is based upon the one used in the Mo-
torola Eximer evaluation board. A block diagram of the original controller is shown in
Figure 3-4. It provides the necessary controls for a block of RAM, ROM and access to
I/O. It is not programmable by software and the memory access cycles are tuned to pro-
vide only the necessary signals.
The use of a FPGA for the memory controller also allows the designer to partition the
memory space and control signals as desired. It can even be done dynamically and/or al-
low memory segments to overlap. A DMA controller can also be added to expedite block
memory transfers and assist the CPU.
The following sections elaborate on the internal modules that form the memory controller.
30
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
RST
CLK
-......--chlpsel() ........ ...
I . :- .,..) ..... -... I CTIME{0-3}..
startO.,.. Cl.AIM~l... UUI:::Ht-I_L- ....
~ -
WE_L_...- ...... bytedec(} ~r -...- ~,.. ...-.... -... cycler() .....,_. -... --- -
SCS
SUE
FCS"
FOE
XCS(o::1)
XOE
A(G-l
TT(0-4
TS"
A(29-31
TSIZ(G-2)
TBST
ew£(o::7)
Figure 3-4. Memory Controller Architecture
3.2.2.1.1. Start Detection Module
The "startt)" module provides the global signals used exclusively by other modules to de-
tect whether a cycle is in progress or unclaimed and if its a write cycle or not. These sig-
nals remain valid until the memory cycle is completed by the memory controller by assert-
ing the AACKn signal.
3.2.2.1.2. Byte Lane Decoder
The byte-lane write-enables, BWEn(O-7), are generated by the "bytedecr)'' module. The
TSIZ(O-2) signals along with the lower address lines, A(29-31), are used to determine
which byte lanes should be active. All lanes are enabled for burst transfers, while all other
transfers enable only the necessary lanes based upon the start address and transfer size.
The write status signal, decoded by the "startt)" module, is examined to establish if the cy-
cle is a write cycle or not.
31
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
3.2.2.1.3. Chip Select Unit
The higher address lines, A(0-3), are used by the "chipselt)" module to enable the corre-
sponding memory space and to pass the proper time delay for the access to the cycler. The
time delay is used to delay the assertion of TAn and thus the end of the transfer.
The evaluation board's memory space is shown in Table 3-1. The Flash ROM space was
put at the top of the memory space because the PowerPC boots up by executing code lo-
cated at OxFFFO_0100, which is the exception vector address of the system reset interrupt.
The SRAM is located at address OxOOOO_0000 to enable the interrupt vector table to be
relocated to RAM. This is accomplished by copying the table to RAM and clearing the IP
bit in the MSR (Machine State Register) to change the exception prefix from OxFFFx_xxx
to OxOOOxxxx.
Table 3-1. Evaluation Board Memory Space
START
END ADDRESS RIW SIZE DEVICE
ADDRESS
,
OxOOOO0000 OxOFFF FFFF 1,2,4 bytes 2Mb SRAM
Ox1000 0000 Ox1FFF FFFF 1 byte DART 1
Ox2000 0000 Ox2FFF FFFF 1 byte DART 2
Ox3000 0000 Ox3FFF FFFF 1,2 bytes LVDS
Ox4000 0000 Ox4FFF FFFF 1 byte SCC Channel A
Ox5000 0000 Ox5FFF FFFF 1 byte SCC Channel B
Ox6000 0000 Ox6FFF FFFF 1 byte l2C Controller
Ox7000 0000 Ox7FFF FFFF 1,2 bytes System Management
Ox8000 0000 Ox8FFF FFFF 1,2 bytes Debug port & LEDs
OxCOOO0000 OxCFFF FFFF 2 bytes Interrupt Controller
OxFOOO0000 OxFFFF FFFF 1,2,4 bytes 4Mb Flash ROM
32
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
3.2.2.1.4. Cycler
The "cyclen)" state machine has four flows. The first two handle SRAM single-beat and
burst transfers that are typically the majority of code and data accesses. The third handles
I/O and FLASH ROM transfers while the fourth is concerned with error transactions.
3.2.2.2. EDAC
For every 64-bit word, 16 extra bits are provided for the storage ofEDAC checkbits. Since
Hamming code require only eight checkbits for every 64-bit word protected, the 16 bits
available allows for the evaluation of other EDAC schemes, e.g. Reed Solomon and BCH
codes.
Hamming code provides a system with single error correction and double error detection.
This might be sufficient for some aerospace applications, but when data integrity is vital
for system operation and reliability, the study of other EDAC schemes are crucial. The
BCH family are short block codes and have a greater distance than Hamming.
A quasi-cyclic (16,8) code capable of correcting 2 bit errors (T=2) was developed at the
University of Surrey for their SNAP nano-satellite on-board computer+ The allocated 16-
bits enables the development of similar codecs to improve on the single-error correction
capability of Hamming code.
The address and data retry functions built into the PowerPC 603e are used to manage
memory errors. When an error occurs while a read transaction is in progress, the memory
controller can signal the CPU to invalidate the data read. This can be done for both the ad-
dress and data buses independently and permits an effective way of interfacing with an
EDAC unit. It allows for fast bus transactions and only slows the bus down in the event of
an error. See Figure 3-5 for a timing diagram showing three different ways of delaying
single-beat reads:
• The TAn signal can remain negated to insert wait states in clock cycles 3 and 4.
• For the second access, DBGn could have been asserted in clock cycle 6.
33
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
• In the third access, DRTRYn is asserted in clock cycle 11 to flush the previous
data.
I , I 2 3 I " I 5 I 6 7 I 8 I 9 10 11 12 13 14 I
BR~ cO cO
BG~
I I I
I L ~ I L ~ I L 7
AElBI I
~ ~\ II
lSI I I I I
A[O:31jl ;CPUA ; ~ ;CPUA; ;CPUA;
I I
TTt0411 Read }------I---( Read Read
I I I I I I I
TBST
I
GEL
I
AACK I
ImTRY I I
DBG, ~ L 7 \ ¢ I I
DBSI \ I ~I
0[0(3) I
I
TA I 7 \ L ~ I l
I I
tmTR"'? I LU
I
TEA
Figure 3-5. Single-Beat Reads Showing Data-Delay Controls
VHDL code was written, compiled and tested that performs Hamming code operations on
a 64-bit bus using eight checkbits. The code was not implemented due to the complexity
of the memory controller and the modifications necessary. Figure 3-6 shows the simula-
tion results of the EDAC unit.
34
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
~ .
166.ons 332.ons 498.ons 664.ons 83o.ons 9~Name: valq
__ SingleErr 0 I I I II
__ MultipleErr 1 I ~ I II
Ii)if Dataln 0000008080808080 X 0000008080808081
Ii)if DataOut '0000000000000000 :
DiP Checkln HOD 00 X F7 F6 X F4 X F7
~ CheckOut H 3D .. 3D
~ DataCorr . 0000008080808080. ::Cia ._
U Uns
Figure 3-6. EDAC Unit Simulation Results
The maximum delay paths were obtained using the delay matrix feature of the MaxPlus II
software. This maximum delay for checkbit generation (i.e. a write operation) was 26.2ns.
Read operations were much slower with a maximum delay of 153.3ns.
3.2.2.3. Interrupt Controller
Implementing the interrupt controller inside the FPGA allows custom trigger settings to be
programmed and thus minimises external components (glue logic).
The PowerPC 603e™ has three interrupt inputs - the MCPn, SMIn, and !NTn signals. The
machine check interrupt input signal, MCPn, is negative edge sensitive and initiates a ma-
chine check exception. The system management exception is initiated by the SMIn signal
while the !NTn signal generates an external interrupt. Both the SMln and !NTn signals are
level-sensitive. The machine check exception has a higher priority than the soft reset ex-
ception as well as the other two interrupt signals and is generally used to handle bus errors,
e.g. parity and/or EDAC errors. The system management interrupt and the external inter-
rupt differ only in the signal asserted and the vector taken.
The machine check interrupt is initiated upon the detection of an EDAC error condition
since it has the highest priority of the three interrupt signals. This will prevent the error
from propagating to the system level. The system management interrupt is reserved for
future use. The system management interrupt is used to trigger on the interrupt signal from
the temperature sensor. This allows the system management software to control the tem-
35
Stellenbosch University http://scholar.sun.ac.za
POWERPCQBC
perature of the processor by, for example, changing the bus clock frequency and/or chang-
ing the PLL settings or for bringing the processor out of sleep-mode.
The interrupt controller contains two registers. The one register is used to mask the indi-
vidual interrupts while the other contains the current pending interrupts. The interrupt ser-
vice routing (ISR) must read the latter register to determine the source of the interrupt.
Both registers have one bit for each interrupt source and include bits for both UARTs, rc
controller, and the interrupt signals from the external devices like the sec, real-time clock,
temperature sensor and LVDS (Low-Voltage Differential Signalling) channel. The
switches are also routed to the interrupt controller to be used as interrupt sources.
3.2.2.4. UARTs
The two UARTs implemented in the FPGA are based on the Atmel AT90S8515 AVR
RISC microcontroller's internal UARTs. They are fully independent and software pro-
grammable using the relevant registers. They support eight and nine data bits and are ca-
pable of full-duplex operation. Noise filtering is implemented in hardware by sampling the
incoming channel three times and using a voting circuit to determine the valid state. They
also feature overrun and framing error detection. Interrupts are generated independently
on completion of a transmission, when the transmit register is empty, and upon receiving a
character.
3.2.2.5. 12C Controller
rc is a two-wire, bi-directional bus providing a simple and efficient method of communi-
cation over short distances between many devices. The controller core used was
downloaded from the OpenCores website and is compatible with their WISHBONE archi-
tecture. This architecture is analogous to a microcomputer bus and offers a flexible inte-
gration solution that is easily tailored to a specific application.
Although the r'c standard is a true multi-master bus, the peripherals connected on the bus
are all slave devices. Since there is no need for multi-master capability, a single master
controller, in which it is the master, was a good alternative. It saves space on the FPGA
36
Stellenbosch University http://scholar.sun.ac.za
POWERPCQBC
and reduces the complexity of the controller itself, which, in tum, reduces the complexity
of the software driver. Figure 3-7 shows the block diagram of the controller architecture.
Control of the bus is provided on both a byte and bit level using its registers. This allows
the use of a single controller to interface with devices that are rc, 5MBus, and 2-wire bus
compatible. The controller generates a maskable interrupt upon completion of a task.
Prescale
WISHBONE
Interface
f--------~clock
generator
Bit CL
Command
Controller SDA
Figure 3-7. Internal Structure of I2C Controller
3.2.2.6. Reset Controller
To ensure the correct reset of all internal circuitry, especially at power-on, a reset control-
ler was added. It provides a reset pulse for the internal circuitry once the FPGA is config-
ured. It also provides a reset pulse with a programmable width to the processor.
3.2.2.7. Debug & Expansion
To facilitate the addition of external devices and to aid in debugging a 20-pin connector
was added. It provides 16 user configurable FPGA VO pins, write enable line, system
clock output and a ground connection. Four status LEDs and three debounced pushbutton
switches are also provided.
37
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
3.2.3. FLASH ROM
FLASH ROM is used for the storage of program code, the operating system (OS) and boot-
loader. It was decided to use a 64-bit wide FLASH ROM-space to allow the 603e to fetch
two instructions at once and to simplify the memory controller design. The FLASH ROM
used is 3.3V programmable and features a hardware sector protection mechanism where
sectors can only be erased and programmed with a 12V supply.
Four Mbytes of FLASH ROM is provided by four 8-Mbit (5I2K x I6-bit) devices. The
devices use the same software commands as E2PROMs and have very low power require-
ments. They feature an automatic low power mode that is enabled when the address lines
remain stable for 150ns. This feature is especially useful when the 603e is in a low power
mode to ensure maximum power saving.
3.2.4. SRAM
With processor bus speeds of 66MHz the SRAM used had to be fast. Access times of 15ns
are achievable with the parts used. They also only consume a maximum of 4mA each
when in standby mode, i.e. when the device is disabled. Operating currents are dependant
on cycle times and range from 190mAmax at 15ns to 140mAmax at 25ns (Manufacturer's
maximum values). This is quite high compared to currently available 5V devices, but the
speed advantage makes it well worth the extra power consumed.
Five 4-Mbit (256K x 16-bit) devices were used giving two Mbytes of RAM for use of pro-
gram data storage and one 4-Mbit device for the storage of checkbits. As mentioned ear-
lier, the memory controller is capable of implementing various EDAC schemes to for the
detection and correction of errors caused by radiation.
3.2.5. Clock Generator
When the PLL is enabled, the PowerPC 603e™ can run with a bus clock frequency of be-
tween 25MHz and 75MHz. The PLL can be bypassed altogether enabling the 603e to be
38
Stellenbosch University http://scholar.sun.ac.za
POWERPC OBC
run at frequencies below one MHz. This could further power reduction if the doze or sleep
modes are not favourable.
To be able to dynamically change the bus clock frequency of the processor, a clock genera-
tor is used. To minimize pin usage on the FPGA, an 12C-interface was preferred. The rc
bus is shared with other peripherals on the evaluation board, further reducing the amount
of pins needed.
The MAXI 077L 60MHz clock generator is used and it conforms to the above. It fits the
clock jitter and duty cycle requirements of the 603e and features two independent synchro-
nous outputs and a power-down mode. The power-down mode will however rarely be
used since the clock generator also feeds the FPGA that controls it.
The change of the bus-clock frequency together with the ability to change the PLL con-
figuration of the CPU allows the operating system to dynamically manage performance
and power.
3.2.6. Real-Time Clock
Although the 603e's Time Base feature can be used to calculate time-of-day, a real-time
clock was added for more flexibility and for calibration of the Time Base.
The DS1337U is fC-compatible and measures seconds up to years with leap-year compen-
sation. It is fully register driven and features two time-of-day alarms. These can generate
interrupts and can be used for general timing and/or watchdog purposes. The device uses
very little power-150~lAmax active supply current and 2~Amaxwhilst in standby mode
(Manufacturer's maximum values). The only external components needed are a 32.768kHz
crystal and a pull-up resistor on the open-drain interrupt signal.
3.2.7. Reset Generator
To ensure the correct integration of reset sources and sound reset timing a reset generator
was used. The critical power requirements of the PowerPC 603e™ led to the use of the
39
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
DS 1831C Multi-Supply Monitor & Reset that monitors both the 3.3V and 2.5V power
rails.
Itmonitors the 3.3V and 2.5V supplies with selectable tolerance levels and a temperature
compensated voltage reference and sensor. Three external reset inputs are provided that
provide manual pushbutton functionality. Reset delays are also user programmable.
A reset condition can be caused by the FPGA itself, pushbutton switch, reset circuit or the
COP interface. The use of the DS 1831C with its open-drain inputs/outputs greatly simpli-
fied the integration of these sources to provide a glitch-free reset pulse with an acceptable
width. This is shown in Figure 3-8.
r
l'll.H'lto)
MUll(
, 'N,. 1 ,.
---2...c Rl!'Ill =! 15 •• fhr1'"
Reset Switch J m.>. ltl.J ) ,.
"i.l&vl ~ rT"'~ 'trill--- • p--!L-0-- I'I!I<d'In' Flm'II'!l'T
III'W-rtl A,..:AUXJ I: L • IilIrf " .ou..:.IJO•• b.'fl~..,
"'''' 0"~"" r ... r '0 """""" ...'C.
IZi'IlIlllT • f-'-':l~ 11"-
0
%
o
~'I;"n".1'~'l· wi1
Figure 3-8: Integration of Reset Sources with Reset Controller
3.2.8. see
The Z85C30 from Zilog was used for its multi-protocol data communications capabilities.
It handles asynchronous formats, synchronous byte-oriented protocols such as IBM Bi-
sync, and synchronous bit-oriented protocols such as HDLC and IBM SDLC.
40
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
Features of the Z85C30 include two lOx 19-bit status First InFirst Out (FIFO) buffers and
DMA transfer support. It also generates and checks cyclic redundancy check (CRC) codes
in any synchronous mode and can be programmed to check data integrity in various
modes. Modem control signals are also provided that doubles as general-purpose VO pins
when unused.
The Z85C30 was used with great success on SUNSAT and provide a means for the devel-
opment and test of communications software and modem drivers.
3.2.9. LVDS
LVDS is a low-power, low noise producing, noise tolerant technology providing a fast,
failsafe data link. Putting the radiation issues of commercial LVDS transceivers aside,
LVDS was found extremely suitable for aerospace applications. However, since the en-
dorsement of the IEEE 1355 standard by ESA and major companies involved in the space
industry, numerous space-qualifiable radiation-tolerant components have been manufac-
tured.1
Bus LVDS (BL VDS) uses a differential transmission scheme similar to LVDS, but it is
enhanced for multi-point applications. It eliminates the need for active termination devices
commonly required by open-drain/collector technologies; thus simplifies backplane design
and improves system reliability. Moreover, live-insertion of devices into an active bus is
supported - the resulting glitch is seen as common mode noise and rejected by the re-
ceiver.
The DS92L V -series from National Semiconductor was used to exploit the abilities of
BLVDS. The DS92LVI021 and DS92LV1212 are 16-40 MHz 10 bit Bus LVDS serialis-
ers and deserialisers, respectively. The DS92LV1 021 can drive a heavily loaded backplane
or a point-to-point connection while the DS92LV 1212 locks to the embedded clock to re-
cover the serialised data.
41
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
3.2.10. Temperature Sensor
The PowerPC 603e™ is a powerful processor and as such can generate a substantial
amount of heat when being used at its full potential. To monitor its temperature, and its
temperature above the ambient temperature, a temperature sensor with local and remote
sensing capability was needed.
The MAX6654 features an internal temperature sensor for the measurement of the local
board temperature. It also supports an external remote temperature sensor that was used to
measure the temperature of the CPU. Very little external components are needed and a
low cost, easily mounted 2N3906 PNP transistor is used as the remote temperature sensor.
The MAX6654 interfaces with the FPGA via the r'c bus and enables it to read temperature
data and set alarm thresholds. Alarm threshold data is stored in four registers containing
high and low temperature values for each channel. A diode fault alarnl is also provided
that detects open and short-circuit conditions on the remote sensor pins. All these alarms
cause the ALARMn interrupt signal to be asserted and an exception to be taken by the
CPU. The readout of temperature data can occur automatically or autonomously (one-
shot).
These, together with the PLL-configuration and clock generator features, can be used by
thermal management software to control the temperature of the CPU by either slowing it
down or by forcing it to enter a low-power mode.
3.2.11. Current Sensor
The current sensor was added primarily for the dynamic detection of latchup conditions in
the CPU, but also for measuring the CPU's power consumption.
The MAX471 uses an integral 35mQ current-sense resistor and is capable of accurately
measuring currents of up to ±3A. The measurement is output as a current and converted to
a voltage by an external 2.0kQ resistor giving a voltage-to-current ratio of 1:l. This volt-
age is then read by an analog-to-digital converter (ADC) (see section 2.2.12.) to acquire a
42
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
digital value pertaining the current drawn by the processor. The 1:1 ratio eliminates the
need for conversions when measuring power (P = V x J) with an oscilloscope.
Operating current is less than lOOI-lAover the entire temperature range and a shutdown
mode, where the device draws only 18l-lAmax,is also featured.
3.2.12. ADC
To convert the measurement voltage of the current sensor to a digital value usable by sys-
tem management software, an ADC was needed.
Featuring 12-bit resolution, 8-channel multiplexer and an r'c interface, the ADS7828 was
elected for the task. Using the r2c bus meant the device could be employed with no extra
pin usage on the FPGA. The remaining seven channels can be used for other purposes.
Power requirements at the standard 12C interface clocking speed of 100kHz are 290I-lWtyp
and 2nAtyp when in powerdown mode. To filter power-supply noise a 5Q resistor is put in
series with the 3.3V power rail and +VDD power pin. The filtered 3.3V supply is also fed
into the external voltage reference input giving a least significant bit size of about 8061lV.
This should be sufficient for the detection of latchup conditions as well as the interfacing
of various analog circuitry.
3.2.13. Power
The nominal power supply on a satellite is about 12-14V. This is the output voltage from
the solar panels and batteries. Switch-mode regulators was used to convert this relatively
high input voltage to the required low voltages because of their inherently low losses, es-
pecially when compared to that of linear regulators.
Two PT6303 switch-mode regulator modules were used for supplying the 3.3V and 2.SV
rails. These parts are about 85% efficient when converting 14V to 3.3V at lA, which was
projected to be the maximum current consumption of the processor at full speed. Worst-
43
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
case ripple on the output voltage is 4% which is below the threshold of 5% for the
PowerPC 603e™ processor. The 3.3V supply does not need a regulator able to supply 3A
of current. However, to meet the required relation between 3.3V and 2.5V supply voltages
at start-up, two similar regulators were used that feature similar start-up transient re-
sponses.
A step-up DC-DC converter was used to supply the 5V rail for the SCc. The MAX1797
part offers an excellent efficiency of95% when converting 3.3V to 5V while supplying
100mA. Although these devices are capable of supplying currents of up to lA, the SCC
will draw currents of no more than 25mA, to which the efficiency drops to about 93%.
The PowerPC 603e™ processors' 3.3V supply must not exceed its 2.5V supply by more
than 1.2V at any time, including power-on reset. Therefore, a pair ofMUR420 bootstrap
diodes was connected between the 3.3V supply and the 2.5V supply. These diodes have a
forward voltage ofO.6V at 500mA to provide a 1.2V drop across the pair. The processor
draws about 500mA when in reset.
3.3. PHYSICAL LAYOUT
The physical board layout is shown in Figure 3-9. The board was manufactured using
standard FR-4 laminate.
3.4. CONCLUSION
Much consideration was given to the design of a power conservative system while also as-
piring to inflict no performance penalties. The current sensor can be used by power man-
agement software to inflict a strong power/performance relationship. This can be done by
regulating the processor speed or by putting the processor into a static power-down mode
(doze, nap or sleep).
The peripherals were chosen for, amongst other reasons, their respective abilities to enter
low-power states. By completely disabling the devices not being used, the board-level
power consumption can be reduced even more. In addition, the peripherals implemented
44
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
inside the support FPGA can be disabled as well. This reduces clocking inside the FPGA
and reduces its power consumption.
SCC~ SCCA UART2 UARTl
•
Current
Sep~
I'" !::2•• i I il"
I:: ,,",IADC.. ::!
i'jl'",:': 603e™Tempt- !"~
Sensor PLL
~';~lr~:;""~Colifigthl.;~,~~~':::::
•• ·1
•
"
•• Iii'.
••• I
:: i':·::.,
="111:1 .7
=11111= Con fig,
; Device" ., ,,..
~ - ~~ _~ ~ .I.
Jrjj(l) eN
I
I•
Power
Con.
Figure 3-9. PowerPC 603e™ aBC Evaluation Board Layout
45
Stellenbosch University http://scholar.sun.ac.za
POWERPC OBC
Interfacing the PowerPC processor can be made easy in an embedded system where caches
are normally not used. This simplifies the memory controller since many of the control
signals can be ignored or hard-wired to a desired state. The use of a custom memory con-
troller facilitates the incorporation of mission dependant modules, like EDAC, without the
use of separate devices. In this design, the memory controller performs many tasks that are
all independent and easy to remove or replace. Because all the devices (peripherals) on-
board (internal and external to the support FPGA) are register driven, interfacing these de-
vices to the processor is relatively easy.
Some improvements need to be done to the memory controller module if performance is to
be an issue for further development. The controller is optimised for a bus clock frequency
of 66MHz and as a result, cause memory transfers to be slower than possible when used
with a 30MHz clock. Registers can be included in the memory controller to make it dy-
namic, which is especially useful when interfacing with devices connected to the expan-
sion port.
The next chapter contains specifics on the test software developed.
46
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
4
SO,FTVVARE DEVELOPMENT
Software was written to aid in the evaluation of the processor and its feasibility for use in
aerospace applications. This software was also written to ease further software develop-
ment on the evaluation board. The code was compiled in a Linux environment and con-
formed to the PowerPC EABI.
4.1. DEVELOPMENT ENVIRONMENT
Although an evaluation copy of Metrowerks' CodeWarrior Software was acquired, the
GCC development environment was used for code compilation and assembly. Evaluation
of the CodeWarrior software revealed that it requires an expensive debugger module to of-
fer an eventful advantage over the GCC toolchain. The cross-compiler was compiled on a
x86 platform using GCC version 2.95.3 and BINUTILS version 2.12.1. Source code for
the toolchain is available on the supplementary CD.
To aid in the upload of new code, debugging and general-purpose serial I/O, a terminal
was set up on a host Pc. The use of a proprietary terminal program expedites software de-
velopment and provides a secondary means of interaction with the evaluation board. The
first being the debug and expansion port, status LEDs and switches.
4.2. THE POWERPC EABI
Code compiled for the evaluation board conformed to the PowerPC EABI.U This section
briefly describes the EABI and its features.
47
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
The PowerPC Embedded Application Binary Interface (EABI) was created to meet the
unique needs for PowerPC embedded applications, specifically minimizing memory usage
while maintaining high performance. The EABI defines a set of conventions intended to
afford interoperability between conforming software components (e.g., compilers, debug-
gers, assembly language code). These conventions are optimised for embedded applica-
tions, which typically differ from desktop applications in at least one of the following
ways:
• ROM based,
• Real-time oriented,
• Memory constrained,
• Single purpose application.
The EABI is sufficiently close to the Unix System V Release 4 (SVR4) ABI for PowerPC
that a single set of tools can support both ABI's and make it possible to use SVR4 func-
tions in an EABI environment without recompilation.
Embedded programs that conform to the EABI gain efficiency in space and time by using
the following features:
• Minimized stack usage,
• Relaxed alignment restrictions, optimising memory usage,
• Small data areas for RAM data, read-only data, and data around address zero.
These reduce code size and improve data access time.
For running compiled programs, the EABI-specified register conventions must be fol-
lowed. The EABI defines how the processor's registers are to be used by a conforming ap-
plication. Table 4-1 lists the register conventions for the PowerPC EABI.
48
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
Table 4-1. PowerPC EABI Registers
REGISTER CONTENTS
GPRI Stack Frame Pointer
GPR2 SDA2 BASE_
GPR13 SDA BASE_
GPR31 Local variables or environment pointer
GPRO Volatile _ may be modified during linkage
GPR3, GPR4 Volatile _ used for parameter passing and return values
GPR5-GPRIO Used for parameter passing
GPRII-GPR12 Volatile _ may be modified during linkage
GPR14-GPR30 Used for local variables
FPRO Volatile register
FPRI Volatile _ used for parameter passing and return values
FPR2-FPR8 Volatile _ used for parameter passing
FPR9-FPR13 Volatile registers
FPR14-FPR31 Used for local variables
The symbols _SDA_BASE and _SDA2_BASE are defined during linking. They specify
the locations of the small data areas that contain part of the data of the executable. A pro-
gram must load these values into GPR13 and GPR2, respectively, before accessing pro-
gram data.
Before executing user code, the start-up code must also set up the stack pointer in GPRI.
This pointer must be 8-byte aligned for the EABI and should point to the lowest allocated
valid stack frame. The stack grows toward lower addresses, so its location should be se-
lected so that is does not grow into data or bss areas.
4.3. PROCESSOR INITIALISA TION
This section explains the boot code executed on the evaluation board. It descri.bes the nec-
essary code for setting up the processor to execute a user program.
49
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
At power-up, the PowerPC 603e™ processor is in a minimal state with most features and
interrupts disabled. It boots up in big-endian mode and executes code beginning at
OxFFFO_OOO.This code, located at the system reset vector, must handle system initialisa-
tion. A typical initialisation sequence performs the necessary setup or hardware-specific
initialisation, and then enables exceptions.
If memory management features, such as memory address translation, are required, the
boot program will need to set up the MMU. For a minimal system like the evaluation
board, it is sufficient to use block address translation (BAT) to perform a rudimentary
mapping. For more complex systems, the segment registers and page tables need also be
initialised. There are eight BAT array entries allowing the programmer to specify options
such as whether the specified address range is valid for supervisor or user mode, the mem-
ory/cache access mode, and the protection bits for the block. Four of these map data re-
gions (DBATs), while the remaining four entries specify instruction regions (!BATs).
Each entry consists of two registers called the upper and lower BAT entries. The proce-
dure for initialising a pair of BAT registers is as follows:
1. Disable the MMU.
2. If modifying a data BAT, execute an isyoc instruction.
3. Initialise the lower portion of the BAT array entry.
4. Initialise the upper portion of the BAT array entry.
5. Execute an isyoc instruction.
6. Re-enable the MMU when all setup is complete.
In a complete operating system, MMU setup continues with invalidating TLB entries, ini-
tialising the segment registers, and setting up the page table. Even if only BAT mappings
are used for translation, it is possible that a user progranl will generate accesses to ad-
dresses that are invalid or not mapped by the BAT registers. In this case, the processor
hardware attempts to look at the page table to resolve the reference. For this reason, the
page table need to be initialised to prevent them from containing random data and cause
unintended memory accesses.
50
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
When the MMU setup completes, the MMU may be enabled. At this point, address trans-
lation is active. The instruction and data caches can be enabled at this point, but since this
is the evaluation of an on-board computer where caches are normally disabled due to the
radiation environment, they will be kept disabled.
Section 3.1.1. briefly described the PowerPC EABI. Much of the required EABI register
setup is accomplished through a call to _eabiO. The user does not call this function di-
rectly; a call to _eabiO is inserted at the beginning of maint) in the user program by the
compiler. Programs that lack a maint) should call _eabiO before executing any user code.
Most compile environments provide an _eabiO function that is automatically linked with
user programs. The _eabiO startup code is responsible for setting up the registers speci-
fied by the EABI. A simple _eabiO is used that initialises registers GPR2 and GPR13.
GPRI is initialised prior to the call to maint) by the init sequence.
4.4. SOFTWARE INTERFACING
This section focuses on how software interfaces with the devices on the evaluation board.
This is necessary for future development on the board and to test the interfacing capabili-
ties of the processor as well as that of the support FPGA. See Appendix A for the bit-
assignments of the registers implemented in the FPGA.
4.4.1. UARTs
The two identical UARTs are implemented inside the support FPGA with only the
MAX3222E device located externally. They are register driven with interrupts generated
upon completion of the transmission and/or reception of a byte and when the transmit reg-
ister is empty. These registers are the following:
• The UART Data Register (UDR) is written with a new byte to be trans-
mitted and is read to read the current received byte.
• The UART Status Register (USR) contains status information bits for
the contro 1of transmission and reception. Completion of transmission
51
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
and reception and if the UDR register is empty (for transmission) are
used to control data flow and are the sources of the DART interrupts.
Error status bits, including framing and parity errors, are also included
in this register. This register is read-only.
• Enabling of the DARTs, interrupts and the selection of8-or 9-bit char-
acter mode are done via the DART Control Register (UCR). It also con-
tains the ninth bit to be transmitted and the ninth bit currently received.
Both read and write operations can be performed on this register.
• The baud rate divisor is located in the DART Baud Rate Register
(UBRR). This 8-bit value is computed using the following equation:
UBRR = ( !sYSCIOCk 1_1
16xBAUD)
The factor 16 is used since the core uses a clock equal to 16 times the
baud clock frequency.
The driver implemented did not make use of the interrupt capability of the DARTs. In-
stead, the status register, DSR, was polled to establish completion of transactions.
Table 4-2 lists the registers of DART 1. DARTl is located at base memory location
OxlOOO_OOOOand DART2 at Ox2000_0000. The register addresses for DART2 are the
same as that for DARTl with the base address location moved to Ox2000 0000.
Table 4-2. DART Registers
NAME ADDRESS ACCESS DESCRIPTION
DARTl UBRR Oxl000 0090 RfW Baud Rate Divisor Register
UARTI DCR OxlOOOOOAO RfW Control Register
DARTl USR OxlOOOOOBO R Status Register
UARTl UDR OxlOOOOOCO W Transmit Register
UARTl UDR OxlOOOOOCO R Receive Register
52
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
4.4.2. 12C Controller
As mentioned in section 3.2.2.4. the rc controller offers control on both a byte and bit
level. This was necessary since the devices on the r'c bus did not use the same protocol
and allowed the use ofSM-bus (System Management Bus) compatible devices. Since the
SM-bus protocol is inherently similar to rc, they may be used on the same bus. Because
of these differences between the devices on the r'c bus, separate drivers had to be written
for each device.
The rc controller is fully register driven and as such is easy to set up. The devices con-
nected on the rc bus can all operate at a frequency of 100kHz or less. This frequency is
set by writing a clock divider value into one of its registers. The other registers contain
command, status and control information.
The PRESCALE register is a 16-bit register and is accessed via two 8-bit registers:
PRERhi and PRERlo. The prescale value is used to set the SCL clock frequency. Inter-
nally, the core uses clock equal to five times the frequency of the SCL clock. Thus, the
prescale value is calculated as:
I (
fSYSc!OCk) 1presca e = -
5 x fSCL
The control register is used to enable the core and its interrupt signal, while commands are
issued via the control register. These commands include the output of start and stop condi-
tions and the acknowledge bit to be sent.
The status information contained within the status register consists of the currently re-
ceived acknowledge bit, whether the 12C bus is busy, and if there is currently a transfer op-
eration in progress. The interrupt flag is also available in the status register.
The memory locations of the 12C controller registers are listed in Table 4-2.
53
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
Table 4-3. 12C Controller Registers
-
NAME ADDRESS ACCESS DESCRIPTION
PRERlo Ox6000 0000 RlW Clock Prescale Register lo-byte
PRERhi Ox6000 0010 RlW Clock Prescale Register hi-byte
CTR Ox6000 0020 RlW Control Register
TXR Ox6000 0030 W Transmit Register
RXR Ox6000 0030 R Receive Register
CR Ox6000 0040 W Command Register-
SR Ox6000 0040 R Status Register
4_4_3. Real-Time Clock
To read data from the real-time clock (RTC), its register pointer has to be programmed
with the address of the register to be read. Data is then read from that register and subse-
quent registers on following read operations. Since the time data, seconds up to years, are
stored in subsequent registers, the register pointer was set up only once prior to reading.
Consecutive reads are then performed to obtain the complete time data from the device.
Because the RTC is located on the r'c bus, all read and write operations are made via the
r'c controller. The flow diagram of Figure 4-2 illustrates the procedure executed when
reading the time information from the RTC. The writing of time information is done in
similar fashion.
4.4.4. Temperature Sensor
Although the temperature sensor is also situated on the rc bus, the modus operandi is a bit
dissimilar. To read temperature data from it, a command byte has to be sent first. This
command byte can be the address of a register to read from or write to, or it can be a com-
mand to, for example, order a one-shot conversion. Thus, the register pointer of the tem-
perature sensor is not automatically incremented as is the case with the RTC and has to be
written to before any read or write operation can be performed.
54
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
High and low temperature alarm thresholds can be set for both temperature channels.
These are controlled by four registers and can trigger an interrupt when either threshold is
exceeded. The control register is written to enable the interrupt signal and initiate standby
mode. The parasitic resistance cancellation feature, used to minimise the effect of diode
resistance on temperature measurement accuracy, is also enabled via the control register.
The status register shows whether a conversion is in progress and if the various tempera-
ture thresholds have been exceeded or not. It also shows if there is an open circuit condi-
tion in the external sense diode.
Send RTC Address with
Write Bit
Write Register Pointer to
Address of first Register
Send RTC Address with
Read Bit
Figure 4-1. Flow Diagram ofRTC Read Procedure
55
Stellenbosch University http://scholar.sun.ac.za
POWERPC OBC
4.4.5. Clock Generator
The clock generator used allows the system to dynamically change the bus and/or LVDS
clock frequency without clock jitter or glitches while still maintaining the processor's in-
ternal state. The LVDS and bus clocks are connected to the two independent outputs of the
generator allowing fully independent operation. The LVDS clock can even by disabled
while the system clock keeps running.
Changing the system clock frequency implies many complications, the biggest being the
processor PLL. Since the PLL has to relock to the new system clock frequency, it is im-
possible to use the processor to alter its own system clock frequency. The processor has to
be put in sleep mode or held in hard reset while changing the frequency (and or PLL con-
figuration) and while the PLL locks to the new frequency. It is the responsibility of the
support FPGA to change the bus clock frequency when told to do so after the system has
entered a quiescent state.
The memory controller has to adjust its timing to the new frequency to optimise memory
transfers. In addition, if software uses the time-base facility of the processor it has to con-
sider the new clock frequency - especially if the Time Base is used to compute time-of-
day. Further, all clock divisors, e.g. those of the UARTs and r'c controller, have to be at-
tuned to the new frequency too.
No software was written to change the system clock frequency. However, alterations to
the PLL configuration were made dynamically while the processor was in sleep mode.
4.4.6. Interrupt Controller
The Interrupt controller's registers provide a means of masking and identifying interrupts.
These two registers are shown in Table 4-4. !NT_REG contains information on currently
pending interrupts and identifies the source of the external interrupt exception. The other
register, !NT_MSK, is used to mask off interrupt signals not being used. Both these regis-
ters are 32 bits wide.
56
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
Table 4-4. Interrupt Controller Registers
NAME ADDRESS ACCESS DESCRIPTION
INT REG OxCOOO0000 R Interrupts Pending Register
INT MSK OxCOOO0010 RlW Interrupt Mask Register
In INT_REG a logical "1" implies a pending interrupt whereas in INT_MSK it implies that
the corresponding interrupt is enabled. All interrupts are enabled through the INT_MSK
register, including the interrupt signals from the switches and external VO port.
4.4.7. LVDS
The LVDS channel (transmit and receive) is memory mapped to location Ox3000_0000.
This 16-bit memory space is connected to the 10-bit LVDS interface with the six most sig-
nificant bits masked off. Enabling the transceivers is done by setting corresponding bits in
the LVDS_CTRL register. This register is also used to activate synchronisation mode in
the serialiser. The LVDS_STATUS register can be read to obtain the current lock status.
The lock bit is set when the deserialiser has locked to the incoming data stream. This bit
must be used by the synchronisation software to maintain the lock. Table 4-5 lists the reg-
isters used for LVDS transactions.
Table 4-5. LVDS Registers
NAME ADDRESS ACCESS DESCRIPTION
TXR Ox3000 0000 W Transmit Register
RXR Ox3000 0000 R Receive Register
CTRL Ox3000 0010 W Control Register
STATUS Ox3000 0020 R Status Register
The LVDS clock is supplied directly from the clock generator's second output. Any
change in this frequency is done by changing the clock divider in the clock generator. This
frequency must be between 16MHz and 40MHz for the parts used.
57
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
4.4.8. Serial Communications Controller
The Zilog serial communications controller (SCC) used features two independent multi-
protocol communications channels. These channels are mapped to two separate memory
locations: channel "A" to Ox4000 0000 and channel "B" to Ox5000 0000. There are 16- -
registers programmed separately to configure the channels, and 10 registers providing
status information. These registers, also called control registers, are accessed indirectly by
first writing the address of the desired register into WRO (Write Register 0). The following
read or write operation is then performed on that register. The data registers (transmit and
receive registers) for both channels can be accessed in similar fashion, or directly by pull-
ing the D/C line high.
No software routines were written to interface with the SCC due to its complexity and its
limited use in the evaluation of the processor.
4.4.9. System Management
Most of the components used on the evaluation board have the capability to enter a low-
power state. The driver IC for the DARTs can, for example, have its transmitters and/or
receivers disabled. It also features a power-down mode to minimise power consumption.
These features together with the various power saving features of the other devices are ac-
tivated via the system management register.
Table 4-6. System Management Registers
4.4.10. Debug & Expansion
The 16-pin expansion connector was discussed in section 3.2.2.6. These pins are con-
nected to the FPGA and can be configured in a number of ways to suit almost any external
interfacing requirement. For general I/O support the WEn signal is hard-wired to the port.
58
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
The port is memory mapped to address Ox8000_0000 via a read-write register. The pins of
the port can also be used as interrupt sources by enabling the corresponding bits in the in-
terrupt mask register. The direction of each pin, input or output, is set via the direction
register. Also mapped to this address are a read-only register representing the status of the
switches and a write-only register for status LED output. These registers are listed in Ta-
ble 4-7.
Table 4-7. Debug/Expansion Registers
-
NAME ADDRESS ACCESS DESCRIPTION
PORTREG Ox8000 0000 RlW Port Register
DIRREG Ox8000 0010 RJW Direction Register
LEDREG Ox8000 0020 RlW Status LED Register
SWREG Ox8000 0030 R Switch Status Register-
4.5. CODE UPLOAD
This section will firstly explain the VHDL code written to upload code to the evaluation
board. The source code is available on the supplementary CD.
Since the FLASH ROM used contain a bottom boot block located exactly where the proc-
essor starts executing from a hard reset condition, no removable FLASH devices were
used. The bootloader can be loaded into the boot sector and transfer control to an uploaded
user program. This program can reside in the remaining sectors of the FLASH devices, or
in SRAM. By programming the interrupt vectors in the bottom area of the SRAM and
clearing the IP bit in the MSR, the interrupt vector table is transferred from the FLASH
ROM to SRAM, thus enabling the user code to execute custom interrupt handlers without
modifying that of the boot software.
Motorola developed the S-Record file format to provide a humanly readable text represen-
tation of the binary equivalent 'hex'-file. This f01111atproved to be lucrative in that it al-
59
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
lowed the use of proprietary software for the serial transmission of the file. It also made
the inspection of memory dumps much easier.
The block diagram of the programmer is shown in Figure 4-2. The S-record is sent serially
to the FPGA that sends the bytes to the S-record decoder to retrieve address and data val-
ues. The state machine resides in the top-level design file and orchestrates the program-
ming of the SRAM by toggling the chip-select and write enable lines and enabling the bus
drivers to output the address and data on the bus.
S-RECORD ...... I UART I .... .....
"'I I ..... DECODER .........
J~
FINITE STATE_.
MACHINE ........ C....
ADDRESS
DATA
WEn
Sn
Figure 4-2. Block Diagram of S-Record Programmer
4.6. DEMO PROGRAM
This section discusses the demo program executed on the evaluation board that initialises
the processor and some of the peripherals. Time, temperature and current consumption
data are output on one of the serial ports. The source code is available on the supplemen-
tary CD.
The first part of the code initialises the processor as described in section 3.3. To gain ac-
cess to the PC's serial port (and terminal program), DARTI is initialised. Then, the r'c
controller is set up for the retrieval of the temperature and time information. The interrupt
controller is also initialised to allow the switches to trigger all external interrupt exception.
Finally, the program enters an endless loop and continuously outputs the time and tempera-
ture data via the serial connection to the PC.
60
Stellenbosch University http://scholar.sun.ac.za
POWERPCQBC
To achieve the chosen baud rate of 38.4kbps with the system clock frequency of 30 MHz
the UBRR register ofUARTl was loaded with the value Ox30H. Then, the UCR register
was programmed to enable the transmitter and receiver of the UART. Itwas programmed
with the value OxCOH.
The r'c is also initialised to gain access to the RTC, temperature sensor and ADC. The
slowest device on the r'c bus is the temperature sensor capable of running at a maximum
SCL frequency of 100kHz. The rc bus frequency was programmed at 100kHz by pro-
gramming the prescale register with the value Ox3C. The rc core is then enabled via the
r2C_CTR register.
To enable the test of interrupts, the interrupt controller was initialised and programmed to
enable interrupts from the three pushbutton switches.
The program now enters an endless loop where data is gathered from the RTC, the tem-
perature sensor's two channels and the ADC to read the current sensor output. This data is
output on UARTI by means of polling.
When a pushbutton switch is pressed, the interrupt routine is executed that reads the
INTPEND register to get the source of the interrupt and outputs it on UARTl.
4.7. SRAM DUMP
To aid in hardware debugging of the evaluation board VHDL code was written to dump
the SRAM contents to UART1. It also allows the software designer to verify that a previ-
ous code upload procedure was executed successfully and to evaluate the data and stack
segments. It can also be used to validate memory coherency while performing radiation
tests or to validate the correct operation of the EDAC unit. The source code is available on
the supplementary CD.
61
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
4.8. CONCLUSION
Software drivers were written and successfully executed for the UARTs, RTC, and tem-
perature sensor. Software drivers still need to be written for the SCC and LVDS devices.
The LVDS driver will require some hardware assistance. A DMA controller will need to
be added to the support FPGA and memory controller module to facilitate the fast data
transfers. If a DMA controller is not favourable, some other means of interaction with the
memory controller is unavoidable.
62
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
5
TEST AND MEASUREMENT
Power consumption and temperature are the main criteria when evaluating an OBC proces-
sor. Temperature measurements were made by fixing the extemal temperature sense diode
on the processor die with heatsink paste. The temperature sensor has a tolerance of ±1"C.
The on-board current sensor together with the ADC was used for the current measure-
ments. All measurements were made with caches disabled, floating point unit enabled and
dynamic power management enabled.
5. 1. PROCESSOR TEMPERA TURE
The following table shows the maximum temperatures measured at an ambient temperature
of21±1°C. The processor bus clock frequency was set at 30MHz while the PLL setting
was changed for different processor clock frequencies. Measurements were made 30 min-
utes after power-up for satisfactory results, i.e. when the temperatures have stabilised.
Table 5-1. Temperature Measurements
SPEED MAX CPU MAX BOARD
TEMP.loCII TEMP.loCII
200MHz 49 29
150MHz 43 28
30MHz 25 23
I. Allow tolerance of±1 °C
63
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
5.2. POWER CONSUMPTION
Current drawn by the processor core on the 2.5V supply ranged from about 470mA at
200MHz to 400mA at 150MHz and dropped to about 90mA at 30MHz. The latter meas-
urement was made by bypassing the PLL and running the processor at the bus clock fre-
quency. When internal clocking of the processor was turned off (PLL disabled) the current
drawn was about 30mA (75mW). This is also the case when the processor is in sleep mode
and the PLL and internal clocking is turned off. The 3.3V I/O current was not measured,
as it is implementation dependant, i.e. different boards will have different characteristics.
5.3. POWER-UP CURVES
The following three figures show the processor and board temperatures and processor cur-
rent curves from power-up. Exponential approximations for the temperature curves and
linear averages for the current curves are also shown. Allow a tolerance of ± laC for all
graphs.
Temperature and Current @ 200MHz
[-CPUTemp-Board Temp-CPU currentJ
50 700
I II
~--..:;;; -_- _.~- _::- -_..;-
/
/ ..,...---_._'•
650
45
40
35
Time (seconds)
Figure 5-1. Temperature and Current Curve at 200MHz
64
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
Temperature and Current @ 150MHz
1--CPU Temp -- Board Temp -- CPU Current 1
50 ..,-----,----,---,---,.---,---,----,----r--r 600
45 r--r--+--+--+--+--~-~-,_~
40t---r-~--_T--~~±=~~~-
35+--+-~·~~~-~-~-~-~-~~
~ 30+--rL+--+--r--r--r--r-~--1~
~
E 25 t~-=!-----;:::t::::::;t=::::r-;;;;;;;:-I--i
~ 20
15
10
5 ~-r--+--+--+--+--+--+--~~
o 300
o 30 60 90 119 149 179 209 239
Time (seconds)
Figure 5-2. Temperature and Current Curve at 150MHz
Temperature and Current @ 30MHz
[-CPU Temp - Board Temp -- CPU Current l
30
28 r--~---r---~--r--~----r----H
26 j---~----r---~----r---~----r---H
24+----t----r---nln...-+------;-
o-; 22
....
.i3 20til....
Ql
a. 18E
Ql
I- 16
14
12
10
0
••--r---~----r--~---r---4---~H 200 ~
Ql
t:
150 (5
29 58 88 117 146 175 205
Time (seconds)
Figure 5-3. Temperature and Current Curve at 30MHz
550
500~
.s
450 t:
C1>......
::J
400u
350
400
350
300
100
50
o
65
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
From the figures, it is clear that the processor temperature is a function of its internal
clocking frequency. It is also clear that a substantial amount of heat is transferred to the
PCB which means that thermal layers will provide an effective means of heat transfer to
the outside of the satellite.
5.4. SRAM TEST
To aid in hardware debugging of the evaluation board VHDL code was written to perform
a series of write and read operations on the SRAM. A test pattern is written to an incre-
menting address and subsequently read back for verification. When the cycle is com-
pleted, the test pattern is inverted and the process is repeated. The system is capable of
testing (read and write) SRAM at speeds of up to 89Mb/s with a bus clock frequency of
66MHz. The source code is available on the supplementary CD.
5.5. CONCLUSION
At 40°C the processor's temperature stayed well within the specified maximum die-
junction of 105°C and did not require a heat sink. The caches of the PowerPC 603e™
takes up just over half of the total transistor count of the processor. If they are enabled,
current consumption will definitely increase and more heat will be generated. Heat sinks
or any other heat transfer path, e.g. heat pipes, other than that of the PCB and/or thermal
layers may then be needed. The temperature curves show that much of the heat is trans-
ferred to the PCB. This implies that thermal layers will be an effective means of heat dis-
sapation.
The processor consumes a fair amount of power that can be reduced by reducing the clock-
ing speed. The power consumption is further reduced dramatically by putting the proces-
sor in sleep mode and disabling the PLL.
66
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
6
CO,N,CLUSIONS AND
RECOMMENDATIONS
The COTS PowerPC device offers a clear path for performance upgrades because its
commercial vendors leverage their investment in improved designs by maintaining back-
ward compatibility for many generations+ For example, the PowerPC 750™ series is fully
bus compatible with the PowerPC 603™ series. This implies easy implementation and in-
tegration of new PowerPC processors into existing designs as they are introduced. It
greatly reduces development time and cuts down on development costs.
The PowerPC family of processors are inherently immune to SEL with estimated life spans
of 15 years in a low-earth orbit. With expected "hang" rates of once every 3 days (with
caches enabled) their SEU sensitivity may limit their use to commercial and/or LEO appli-
cations.
The mechanical reliability of the high density CBGA package can be improved by investi-
gating new PCB laminate materials that more closely match the TCE of these high thermal
mass devices. It is recommended that Thennount® be used for high-reliability CBGA ap-
plications. The use ofBGA-to-PGA adapters also increases the thermal cyclability of
these devices.
For future development it is recommended that the intemal modules of the support FPGA
be clocked by the LVDS clock. The LVDS devices are able to operate at 16MHz to
67
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
40MHz. Clocking the support FPGA at a fixed frequency of, for example, 33MHz allow
the timing of internal modules to be independent of the bus clock frequency. The proces-
sor bus clock frequency can then be changed without any adverse effect on the functioning
of, for example, the UART baud rates.
The EDAC system still needs to be implemented in hardware. To make memory transfers
as fast as possible the effect of the EDAC delay in read operations need to be reduced. The
PowerPC architecture provides the data retry feature and can be utilised as follows:
1. When the processor requires data from memory the uncorrected data is fed directly
from the memory to the processor while the EDAC unit is busy checking its integ-
rity.
2. In the following cycle, if a correctable error was detected, the DRTRYn signal is
asserted and the corrected data presented to both the processor and memory. If no
error was detected the processor uses the data previously acquired.
3. Upon the event of an uncorrectable error, the MCPn signal should be asserted to
trigger a machine check exception. The exception routine should determine the re-
coverability of the error and generate a system reset via the support FPGA if the er-
ror is fatal.
The data retry feature allows effective error correction without compromising perform-
ance.
Memory bandwith can be increased radically with the use of synchronous SRAM. The
processor and memory controller both support burst transfers, but only when caches are
enabled. Itmust therefore be decided on a system level whether burst transfers, and
caches, are required or not. Caches increase performance, but dramatically decrease the
SEE performance of the processor.
Among currently available commercial processors, the PowerPC family ranks high in
MIPS per watt, but its suitability for space applications outside low-earth orbits may be
limited by the radiation environment, particularly single event effects.
68
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
REFERENCES
1. Poivey, c., "Use of commercial Components in Space Systems - Radiation Aspects",
Technical Event, 4thEuropean Conference on Radiation and their Effects on Compo-
nents and Systems (RADECS 97), Cannes, France, September 15,1997.
2. Lathi, D., "ISC (Integrated Spacecraft Computer) Case Study of a Proven, Viable
Aproach to Using COTS in Spaceborne Computer Systems", 14thAnnuallUSU Confer-
ence on Small Satellites, 2000.
3. McDonald, P.T., "PC603E 32-bit RISC IlP Radiation Effects Study", Innovative Con-
cepts Inc., White Paper, 1999.
4. lrom, F., "Single Event Upset in Commercial Silicon-on-Insulator PowerPC Micro-
processors", Jet Propulsion Laboratory/California Institure of Technology, July 16,
2002.
5. Swift, G.M., "Backside Device Irradiation for Single Event Upset Tests of Advanced
Devices", Jet Propulsion Laboratory/California Institute of Technology, SEE Sympo-
sium, Session E: Testing and Facility, April 25, 2002.
6. Ledebuhr, A.G., "Autonomous, Agile, Micro_Satellites and Supporting Technolo-gies
for Use in Low-Earth Orbit Missions", iz" AIAA/USU Conference on Small Satellites,
1998.
7. Gary, S., "The PowerPC™ 603 Microprocessor: A Low-Power Design for Portable
Appl ications",
8. Dr. Parks, S.M., "High-Speed, Low-Power, Excellent EMC: LVDS for On-Board Data
Handling", Applied Computing, University of Dundee, Dundee, Scotland, UK.
69
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
9. Wicker, S. and Bhargava, Y., "Reed-Solomon codes and their applications", IEEE
Press, 1994.
10. Hodgart, M.S. and Tiggeler, H.A.B., "A (16,8) Error Correcting Code (T=2) For Criti-
cal Memory Applications", Surrey Space Centre, University of Surrey, UK.
11. Kromann, G.B., "Motorola's PowerPC 603™ and PowerPC 604™ RISC Microproces-
sor: the C4/Ceramic-ball-grid Array Interconnect Technology", Motorola Advanced
Packaging Technology, Semiconductor Products Sector, Austin, Texas.
12. Gerke, R.D., "The Effect of Solder-Joint Temperature Rise on Ceramic-BaIl-Grid Ar-
ray to Board Interconnection Reliability: The Motorola PowerPC 603™ and PowerPC
604™ Microprocessors and MPCI05 Bridge/Memory Controller", Motorola Advanced
Packaging Technology, Semiconductor Products Sector, Austin, Texas.
13. Kromann, G.B., "Thermal Management of a C4/Ceramic-Ball-Grid Array: The Mo-
torola PowerPC 603™ and PowerPC 604™ RISC Microprocessors", Motorola Ad-
vanced Packaging Technology, Semiconductor Products Sector, Austin, Texas.
14. Parry, J., "The Development of Component-Level Thermal Compact Models ofa
C4/CBGA Interconnect Technology: The Motorola PowerPC 603™ and PowerPC
604™ RISC Microprocessors", Flomerics Group pic, Hampton Court, England.
15. Sobek, S., "PowerPC Embedded Application Binary Interface (EABI): 32-Bit Imple-
mentation", Microcontroller Technologies Group, Motorola, Austin, Texas.
16. "MPC603e RISC Microprocessor User's Manual Rev. 2.0", Motorola Literature Distri-
bution, Denver, Colorado, August 2001.
17. "Errata to MPC603e RISC Microprocessor User's Manual Rev. 2.0", Motorola Litera-
ture Distribution, Denver, Colorado, January 2002.
18. "PowerPC™ Microprocessor Family: The Programming Envirorunents For 32-Bit Mi-
croprocessors Rev. 1.0", Motorola Inc., January 1997.
70
Stellenbosch University http://scholar.sun.ac.za
APPENDIX A: REGISTER BIT
ASSIGNMENTS
There are several registers implemented in the support FPGA that are used for control,
status and data transactions. Their bit-assignments follow.i
A 1. UART REGISTERS
Each UART contains four registers of which two are bit-assigned. They are the Control
and Status registers.
Table AI-I. UART Control Register
BIT ACESS DESCRIPTION
0 RJW RXCIE, RX Complete Interrupt Enable
Cause an interrupt when RXC is set also.
1 RJW TXCIE, TX Complete Interrupt Enable
Cause an interrupt when TXC is set also.
2 RJW UDRIE, UDR Empty Interrupt Enable
Cause an interrupt when UDRE is set
also.
3 RJW RXEN, Receiver Enable
'1' = Receiver Enabled
'0' = Receiver Disabled
4 RJW TXEN, Transmitter Enable
'1' = Transmitter Enabled
'0' = Transmitter Disabled
i. All registers are big-endian A-I
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
BIT ACESS DESCRIPTION
5 R/W CHR9, 9-bit Characters
When set transmitted characters are 9 bits
long plus start and stop bits. 9th bit is read
and written by using RXB8 and TXB8 in
UCR register, respectively.
6 R RXB8, Received Data Bit 8
Contains the 9th data bit of the received
character.
7 W TXB8, Transmit Data Bit 8
Contains the 9th bit in the character to be
transmitted.
Reset Value: Ox02
Table Al-2. UART Status Register
BIT ACESS DESCRIPTION
0 R RXC, Receive Complete Bit
Is set upon completion of reception of a
byte. Cause an interrupt ifRXCIE is set.
1 R TXC, Transmit Complete Bit
Is set upon completion of transmission of
a byte. Cause an interrupt if TXCIE is set.
2 R UDRE, Data Register Empty Bit
Is set when data is shifted from data regis-
ter to shift register for transmission. Cause
an interrupt ifUDRIE is set.
3 R FE, Frame Error
Is set when the stop bit is received as '0'.
4 R OR, Overrun Error
Is set when the byte in the data register is
not read before a new byte has been
shifted in.
5-7 R Reserved
Will read as 'O's
Reset Value: Ox20
A-2
Stellenbosch University http://scholar.sun.ac.za
POWERPC OBC
A2. /2C CONTROLLER REGISTERS
The 12C controller has three bit-assigned registers, the control, command and status regis-
ters.
Table A2-1. J2C Control Register
BIT ACESS DESCRIPTION
a R/W EN, Core Enable Bit
When set to '1', core is enabled
When set to 'a', core is disabled
1 R/W lEN, Interrupt Enable
When set to '1', interrupt is enabled
When set to 'a', interrupt is disabled
2-7 R Reserved
Will read as 'a's
Reset Value: OxOO
Table A2-2. J2C Command Register
BIT ACESS DESCRIPTION
a R/W STA, Generate (repeated) start condition
when set to '1'.
I RJW STO, Generate stop condition when set to
'1'.
2 R/W RD, Read from Slave Device
3 RJW WR, Write to Slave Device
4 RJW ACK, Acknowledge to be sent
ACK='I'
NACK='O'
5-6 R Reserved
Wi 11read as 'a's
7 R/W lACK, Interrupt Acknowledge
Clears pending interrupt when set
Reset Value: Oxoo
A-3
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
Table A2-3. I2C Status Register
BIT ACESS
a R
is set.
RxACK, Acknowledge received from
Slave Device
'1' = No Acknowledge Received
'0' = Received
1 R Busy Bit
'1' After Start Condition Detected
'0' After Condition Detected
2-5 R Reserved
Will read as 'a's
6 R TIP, Transfer-In-Progress
'1' when Transferring Data
'0' when Transfer lete
7 R IF, Interrupt Flag
This bit is set when an interrupt is pend-
ing, i.e. when a single byte transfer has
completed. Will cause an interrupt ifIEN
Reset Value: Oxoo
A3_ INTERRUPT CONTROLLER REGISTERS
Interrupts are enabled via the interrupt mask register while pending interrupts are shown in
the interrupt pending register.
Table A3-1. Interrupt Mask Register
BIT ACESS DESCRIPTION
a RlW GIE, Global Interrupt Enable Bit
Set to enable the interrupt signal to proc-
essor.
1 R Reserved
Will read as '0'
2-17 RlW D/EIE
Set to Enable interrupt sourcing from the
respective signals of the Debug/Expansion
port.
18 RlW TempIE
Enables the Temperature Sensor Interrupt
when set.
19 RlW LVDSIE
Enables the LVDS Interrupt when set.
A-4
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
BIT ACESS DESCRIPTION
20 R/W RTCIE
Enables the RTC Interrupt when set.
21 R/W SCCIE
Enables the SCC Interrupt when set.
22 R/W UART1TxIE
Enables UARTI Transmit Complete In-
terrupt when set.
23 R/W UART1RxIE
Enables UARTI Receive Complete Inter-
rupt when set.
24 R/W UART1 UDRIE
Enables UARTI UDRE Interrupt when
set.
25 R/W UART2TxIE
Enables UART2 Transmit Complete In-
terrupt when set.
26 R/W UART2RxIE
Enables UART2 Receive Complete Inter-
rupt when set.
27 R/W UART2UDRIE
Enables UART2 UDRE Interrupt when
set.
28 R/W f'CIE
Enables the I2C Controller Interrupt when
set.
29 R/W SwOIE
Switch 0 Interrupt enabled when set.
30 R/W SwlIE
Switch 1 Interrupt enabled when set.
31 R/W Sw2IE
Switch 2 Interrupt enabled when set.
Reset Value: OxOOOO_OOOO
Table A3-2. Interrupt Pending Register
BIT ACESS
0 R Unused
Will read as '0'
1 R Reserved
Will read as '0'
2-17 R D/EIE
A-5
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
BIT ACESS DESCRIPTION
18 R TempIE
Set if the Temperature Sensor Interrupt is
pending.
19 R LVDSIE
Set if the LVDS Interrupt is pending.
20 R RTCIE
Set if the RTC Interrupt is pending.
21 R SCCIE
Set if the SCC Interrupt is pending.
22 R UARTITxIE
Set if the UART1 Transmit Complete In-
terrupt is pending.
23 R UART1RxIE
Set if the UARTl Receive Complete In-
terrupt is pending.
24 R UART1UDRIE
Set if the UART1 UDRE Interrupt is
pending.
25 R UART2TxIE
Enables UART2 Transmit Complete In-
terrupt when set.
26 R UART2RxIE
Set if the UART2 Receive Complete In-
terrupt is pending.
27 R UART2UDRIE
Set if the UART2 UDRE Interrupt is
pending.
28 R l"CIE
Set if the I2C Controller Interrupt is pend-
mg.
29 R SwOIE
Switch 0 Interrupt pending when set.
30 R SwlIE
Switch 1 Interrupt pending when set.
31 R Sw2IE
Switch 2 Interrupt pending when set.
Reset Value: Oxoooo 0000
A-6
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
A4. LVDS REGISTERS
The two bit-assigned LVDS registers provide control functionality and status information.
Table A4-1. LVDS Control Register
BIT Acess DESCRIPTION
0 RlW Tx Enable Bit
When set to '1" transmission is enabled
When set to '0', transmission is disabled
1 RlW Rx Enable Bit
When set to '1" reception is enabled
When set to '0', reception is disabled
2-6 R Reserved
Will read as 'a's
7 W Synchronisation Bit
Activate synchronisation by setting to '1 '.
When set to '0', synchronisation disabled
Reset Value: Oxoo
Table A4-2. LVDS Status Register
BIT ACESS DESCRIPTION
0-6 R Reserved
Will read as 'a's
7 R Lock Bit
When set to '1" PLL is locked
When set to '0', Lock lostlnot obtained
Reset Value: Oxoo
AS. SYSTEM MANAGEMENT REGISTER
The system management register offers power-down functions to the various peripherals
that support it. Its bit-assignment is shown in Table AS-I. All peripherals are active at
power-up.
Table AS-I. System Management Register
A-7
Stellenbosch University http://scholar.sun.ac.za
POWERPC OBC
ACESS DESCRIPTION
9 R/W UARTEN, UART Enable
'1' = UART Receivers Enabled
'0' = UART Receivers Disabled
10 RJW UARTShdn, UART Shutdown
'1' = UARTs Shut Down
'0' = UARTs Active
11 R/W LVDSDEN, LVDS Drivers Enable
'1' = LVDS Bus Drivers Active
'0' = LVDS Bus Tri-Stated
12 RJW LVDSREN, LVDS Receiver Enable
'1' = LVDS Receiver Active
'0' = LVDS Receiver Disabled
l3 R/W LVDSPwrdn, LVDS Powerdown
'1' = LVDS Devices Powered Down
'0' = LVDS Devices Operational
14 R/W TempStby, Temperature Sensor Standby
'1' = Sensor in Standby Mode
'0' = Sensor Active
15 RJW CurShdn, Current Sensor Shutdown
'1' = Sensor Shut Down
'0' = Sensor Active
Resct Value: Ox0058
A6_ DEBUG/ExPANSION REGISTERS
The four debug/expansion registers provide access to the debug/expansion port. They are
the port, direction, led, and switch status registers and their bit-assignments are shown in
Table AS-I.
Table A6-1. Port Register
BIT ACESS DESCRIPTION
0-15 R/W The port pins reflect the value of these
bits when the directions of the corre-
sponding pins are set as outputs. When
set as inputs, these bits are ignored.
Reset Value: OxOOOO
A-8
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
Table A6-2. Direction Register
BIT ACESS DESCRIPTION
0-15 RJW The direction of the corresponding pins of
the port are set to inputs when '1' and to
outputs when '0'.
The pins are tri-stated when set as inputs
and driven with the values of the corre-
sponding bits in the Port Register when
set as outputs.
Reset Value: OxFFFF
Table A6-3. LED Register
-
BIT ACESS DESCRIPTION
0-11 R/W Unused
Will read as 'O's
12 R/W Status LED 1
'1' - LED 1 off
'0' - LED 1 on
13 R/W Status LED 2
,1' - LED 2 off
'0' - LED 2 on
14 RJW Status LED 3
'1' - LED 3 off
'O'-LED 3 on
15 RJW Status LED 3
'1' - LED 3 off
'O'-LED 3 on
Reset Value: OxOOOF
Table A6-4. Switch Status Register
BIT ACESS DESCRIPTION
0-12 R Unused
Will read as 'O's
13 R Switch 1 Status
'1' - Switch 1 open
'0' - Switch 1 pressed
14 R Switch 2 Status
'1' - Switch 2 open
'0' - Switch 2 pressed
A-9
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
BIT ACESS DESCRIPTION
15 R
Reset Value: Ox0007
Switch 3 Status
'I' - Switch 3 open
'0' - Switch 3 pressed
A-IO
Stellenbosch University http://scholar.sun.ac.za
POWERPC aBC
APPENDIX B :
SUPPLEM'ENiTARY CD
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
Stellenbosch University http://scholar.sun.ac.za
POWERPCOBC
Stellenbosch University http://scholar.sun.ac.za
Stellenbosch University http://scholar.sun.ac.za
Stellenbosch University http://scholar.sun.ac.za
