Development of a radiation resistant communication node for satellite sub-systems by Thesnaar, Emile Jacobus
Development of a Radiation Resistant Communication
Node for Satellite Sub-Systems
by
Emile Jacobus Thesnaar
Thesis presented in fulfilment of the requirements for the degree of
Master of Engineering (Research) in the Faculty of Engineering at
Stellenbosch University
Supervisor:
Mr Arno Barnard
Department Electrical and Electronic Engineering
April 2014
Declaration
By submitting this thesis electronically, I declare that the entirety of the work contained
therein is my own, original work, that I am the sole author thereof (save to the extent expli-
citly otherwise stated), that reproduction and publication thereof by Stellenbosch University
will not infringe any third party rights and that I have not previously in its entirety or in
part submitted it for obtaining any qualification.
20 February 2014
Copyright © 2014 Stellenbosch University
All rights reserved
Stellenbosch University  http://scholar.sun.ac.za
Abstract
Within a complex electronic system, sub-system communication forms the backbone of the
functionality of any satellite. It allows multiple processors to run simultaneously and data
to be shared amongst them. Without it, a single processor would have to control the entire
satellite. Not only would such a design then be overly complicated, but the processor would
also not have sufficient capacity to service all the components efficiently.
Furthermore the detrimental effects that radiation have on integrated circuits are well doc-
umented and can be anything from a single bit flip to a complete integrated circuit failure.
If not repaired, a failure on a sub-system communication bus could lead to the loss of the
entire satellite.
Die goal is to create more radiation resistant Controller-Area-Network (CAN) node. Since a
full triple modular redundant design will have a large footprint and high power consumption,
a combination of techniques will be applied and tested. The goal is to achieve improved
footprint utilisation over triple modular redundancy, while still maintaining good resistance
to Single Event Upsets (SEU).
By applying simulation, it was sufficiently proven that the implementation of the individual
techniques used functioned according to expectations. These techniques included error de-
tection and correction using Hamming Codes, single event transient filter and triple modular
redundancy. Having applied these mitigation techniques, the footprint of the CAN control-
ler increased by only 116%. Simulation showed that the Error Detection and Correction and
Triple Modular Redundancy worked effectively with the CAN controller, and that the CAN
controller could function as originally intended. Using radiation testing, the design proved
to be more resistant to SEUs than the unmitigated CAN controller.
It was thus shown that through using a combination of mitigation techniques, it is possible
to develop an optimal design with a high level of resistance against Single Event Upsets,
utilizing a smaller footprint than implementing Triple Modular Redundancy.
iii
Stellenbosch University  http://scholar.sun.ac.za
Opsomming
Sub-stelsel kommunikasie vorm die basis van die funksionaliteit in ’n komplekse elektroniese
stelsel soos ’n satelliet. Dit skep die vermoë om veelvoudige verwerkers gelyktydig te laat
funksioneer en inligting tussen hulle te deel. Sonder sub-stelsel kommunikasie, sal ’n enkele
verwerker die hele sateliet moet beheer. Dit sal nie net die hele ontwerp oorkompliseer nie,
maar die verwerker sal ook nie genoeg kapisteit hê om al die komponente effektief te diens
nie.
Die newe-effekte van bestraling op geïntegreerde stroombane is goed gedokumenteer en kan
wissel van ’n enkele omgekeerde bis, tot die vernietiging van die geïntegreerde stroombaan.
Indien die fout in die kommunikasiestelsel nie herstel word nie, kan dit lei tot die verlies van
die hele sateliet.
Die doel is om ’n meer bestraling bestande Controller-Area-Network (CAN) nodus te skep.
Aangesien ’n volle drie-dubbele-modulêre-oortollige ontwerp ’n baie groot area beslaan en
hoë krag verbruik het, gaan ’n kombinasie van versagting tegnieke toegepas en ge-evalueer
word. Die doel is om beter area benutting as die drie-dubble-modulêre-oortollige ontwerp
te kry, terwyl ’n goeie weerstand teen foute behoue bly.
Deur middel van simulasies is voldoende bewyse gelewer dat die implimentasie van die indi-
viduele versagting tegnieke soos verwag funktioneer. Hierdie tegnieke sluit in, fout opsporing
en regstelling deur middel van Hamming kodes, enkele geval oorgangs verskynsel filter asook
drie-dubbele-modulêre-oortollige ontwerp. Nadat versagting meganismes toegepas is, het die
area verbruik van die CAN beheerder toegeneem met slegs 116%. Simulasies het bewys dat
Fout Opsporing en Regstelling en Drie-Dubbele-Modulêre-Oortollige ontwerp tegnieke binne
die CAN beheerder korrek funktioneer, terwyl die CAN beheerder self funktioneer soos dit
oorspronklik gefunksioneer het. Deur middel van bestralingstoetse, is dit bewys dat die
ontwerp meer bestand is teen foute geïnduseer deur bestraling as die onbeskermde CAN
beheerder.
Dit is dus bewys dat deur gebruik te maak van verskeie versagting tegnieke dit moontlik is
om ’n optimale ontwerp te implimenteer, met ’n hoë weerstand teen foute, maar met ’n laer
area verbruik as die van ’n Drie-dubbele-Modulêre-Oortollige ontwerp.
iv
Stellenbosch University  http://scholar.sun.ac.za
Acknowledgements
It would have been impossible to start, let alone complete, a project such as this without
the support and assistance of a number of people who deserve my humblest thanks.
Niki Steenkamp for his insights during the design process.
Asic Design Services for the supply of the FPGA devices for the project, as well as their
continued support during the project.
National Research Foundation for their support by providing the staff time and test facilities
at iThemba LABS, Cape Town, to perform the radiation experiments.
Drs Rudolph Nchodu, Ricky Smit, Retief Neveling and Peane Maleka for their assistance at
iThemba LABS prior and during radiation testing.
Arno Barnard for his continued guidance and assistance throughout the project.
My family for all their moral support during the project.
Most of all, Marna Rörich, who was always there for me. For her patience, continued
support and loving care. Her moral and emotional support helped me immensely in making
this project a success.
v
Stellenbosch University  http://scholar.sun.ac.za
Contents
Abstract iii
Opsomming iv
Acknowledgements v
Contents vi
List of Figures x
List of Tables xiii
Nomenclature xiv
1 Introduction and Problem Description 1
2 Literature Study 3
2.1 Radiation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
2.1.1 Sources of Radiation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
2.1.2 The Effects of Radiation . . . . . . . . . . . . . . . . . . . . . . . . . . 5
2.1.3 Radiation Hardening . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
2.1.4 Different Units . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
2.2 Sub-System Communication . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
2.2.1 Commonly Used Communication Systems . . . . . . . . . . . . . . . . 13
2.2.2 CAN in Hardware . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
2.2.3 SJA1000 CAN Controller from OpenCores.org . . . . . . . . . . . . . 17
2.3 FPGAs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
2.3.1 Different Types of FPGA . . . . . . . . . . . . . . . . . . . . . . . . . 18
2.3.2 Actel FPGA Comparison . . . . . . . . . . . . . . . . . . . . . . . . . 18
2.4 SoC Intercommunication . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
2.4.1 Wishbone Interconnect . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
2.4.2 8051 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
2.4.3 AMBA . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
2.5 Simulation of SEEs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
2.6 SEU Testing Using a Particle Beam . . . . . . . . . . . . . . . . . . . . . . . 22
vi
Stellenbosch University  http://scholar.sun.ac.za
CONTENTS vii
3 Design 24
3.1 CAN controller Verilog to VHDL translation . . . . . . . . . . . . . . . . . . 24
3.1.1 Motivation for Translation . . . . . . . . . . . . . . . . . . . . . . . . . 24
3.1.2 Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
3.2 SJA1000 CAN controller Breakdown . . . . . . . . . . . . . . . . . . . . . . . 25
3.2.1 Visual Breakdown . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
3.2.2 Registers and Sequential Logic . . . . . . . . . . . . . . . . . . . . . . 28
3.3 Hardware Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
3.3.1 Hardware Requirements . . . . . . . . . . . . . . . . . . . . . . . . . . 30
3.3.2 Summary of Requirements . . . . . . . . . . . . . . . . . . . . . . . . . 36
3.3.3 Top Level design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
3.4 Modifications to Original CAN controller . . . . . . . . . . . . . . . . . . . . 37
3.4.1 Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
3.4.2 Flattening of the CAN controller Tree . . . . . . . . . . . . . . . . . . 38
3.5 Mitigation Schemes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
3.5.1 SET Filter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
3.5.2 TMR . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
3.5.3 EDAC using Hamming Code . . . . . . . . . . . . . . . . . . . . . . . 40
3.5.4 Mitigation Scheme Design . . . . . . . . . . . . . . . . . . . . . . . . . 41
3.6 Final Implementation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
3.6.1 Logic Cells Required . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
3.6.2 Possible FPGAs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
3.7 Testing the Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
3.7.1 Radiation Testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
3.7.2 Simulated Testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
4 Implementation 48
4.1 PCB design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
4.1.1 Device Under Test . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
4.1.2 Controller . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
4.1.3 Power Supply and Monitoring . . . . . . . . . . . . . . . . . . . . . . . 51
4.1.4 Populating and Testing the PCB . . . . . . . . . . . . . . . . . . . . . 51
4.2 Required Development Due to Changes in Design . . . . . . . . . . . . . . . . 56
4.2.1 Custom Memory Interface . . . . . . . . . . . . . . . . . . . . . . . . . 56
4.2.2 Programming Sprite . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
4.2.3 Attempts at Fixing the Ethernet . . . . . . . . . . . . . . . . . . . . . 58
4.3 Vacuum Connector . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
4.4 Firmware Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
4.4.1 Controller Libero Design . . . . . . . . . . . . . . . . . . . . . . . . . . 61
4.4.2 DUT Libero Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
4.4.3 Controller Firmware Design . . . . . . . . . . . . . . . . . . . . . . . . 62
4.5 Mitigation Scheme Implementation . . . . . . . . . . . . . . . . . . . . . . . . 63
Stellenbosch University  http://scholar.sun.ac.za
CONTENTS viii
4.5.1 Implementation of the TMR circuit . . . . . . . . . . . . . . . . . . . 63
4.5.2 Improvement on the Hamming code design . . . . . . . . . . . . . . . 63
4.5.3 SET Filter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
4.6 CAN Controller Implementation . . . . . . . . . . . . . . . . . . . . . . . . . 70
4.6.1 Removal of Non-Reset Registers . . . . . . . . . . . . . . . . . . . . . 70
4.6.2 Flattening of the CAN Controller . . . . . . . . . . . . . . . . . . . . . 71
4.6.3 Protecting the registers . . . . . . . . . . . . . . . . . . . . . . . . . . 71
4.6.4 Protecting the FIFO module . . . . . . . . . . . . . . . . . . . . . . . 72
4.6.5 Protecting the CRC module . . . . . . . . . . . . . . . . . . . . . . . . 73
4.6.6 Protecting the ACF module . . . . . . . . . . . . . . . . . . . . . . . . 74
4.6.7 Protecting the BTL and BSP modules . . . . . . . . . . . . . . . . . . 75
4.7 Hardware Test Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
4.7.1 Controlling Software . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
4.7.2 Implemented Tests . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
4.7.3 Operational Test . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
4.7.4 Configuration Hold Test . . . . . . . . . . . . . . . . . . . . . . . . . . 77
4.8 Simulated Test Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
4.8.1 Error Detection and Correction on FIFO block . . . . . . . . . . . . . 79
4.8.2 TMR and Recovery on Registers . . . . . . . . . . . . . . . . . . . . . 79
5 Results 80
5.1 Mitigation Results . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
5.2 Simulations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
5.2.1 Error Detection and Correction on FIFO . . . . . . . . . . . . . . . . 80
5.2.2 Triple Modular Redundancy on Registers . . . . . . . . . . . . . . . . 82
5.2.3 Mitigated CAN Controller . . . . . . . . . . . . . . . . . . . . . . . . . 83
5.3 Radiation Testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
5.3.1 Pre Radiation Tests . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
5.3.2 Actual Radiation Test . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
5.3.3 Post Radiation Tests . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
5.3.4 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
6 Conclusions 88
6.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
6.2 Further Work . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
6.2.1 Practical Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
6.2.2 Optimization of design . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
6.2.3 Alterations to FPGA Radiation Test Board . . . . . . . . . . . . . . . 90
6.2.4 Minor alterations to the board . . . . . . . . . . . . . . . . . . . . . . 91
6.2.5 JTAG Chain and Programming Safety . . . . . . . . . . . . . . . . . . 91
6.2.6 Alterations to mitigation scheme applied to the CAN controller . . . . 92
Bibliography 93
Stellenbosch University  http://scholar.sun.ac.za
CONTENTS ix
Appendices 99
A Work Distribution 100
B PCB Schematics 101
C Source of XML Sprite 115
D Libero Design 121
E Simulation Waveforms 123
F iThemba Test Log 127
Stellenbosch University  http://scholar.sun.ac.za
List of Figures
2.1 Diagram Illustrating the Spiral Shape of the Solar Wind Due to the Rotation of
the Sun. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
2.2 Illustration of Van Allen Belts Surrounding Earth. . . . . . . . . . . . . . . . . . 5
2.3 Radiation Dosages Due to Van Allen Belts. Adapted From [1]. . . . . . . . . . . 5
2.4 Schematic Representation of a Traditional DMR Circuit and a Modern Imple-
mentation of a Self-Voting DMR Circuit . . . . . . . . . . . . . . . . . . . . . . . 8
2.5 Schematic Representation of a Traditional TMR Circuit . . . . . . . . . . . . . . 9
2.6 Diagram of the SET Filter using GG as in [2] . . . . . . . . . . . . . . . . . . . . 9
2.7 Diagram of the SET filter as Proposed in [3] . . . . . . . . . . . . . . . . . . . . 10
2.8 Illustration of the SET filter Implementation’s AND-gate Logic . . . . . . . . . . 10
2.9 Illustration of the SET filter Implementation’s OR-gate Logic . . . . . . . . . . . 10
2.10 Floor plan of iThemba LABS’ Separated-Sector Cyclotron Facility [4] . . . . . . 23
2.11 Illustration of Beam Defocussing . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
3.1 Functional Breakdown of the SJA1000 CAN Controller [5] . . . . . . . . . . . . . 26
3.2 HDL Structural Design of the SJA1000 CAN Controller . . . . . . . . . . . . . . 26
3.3 Block Diagram Showing the IP Cores of Web-Server Implementation in the Fu-
sion Development Kit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
3.4 Image Showing Detail of a Vacuum Connector and the Inside of the Scattering
Chamber . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
3.5 Diagram of the Top Level Design of the Experimental PCB . . . . . . . . . . . . 37
3.6 Diagram of the Complete Test Environment . . . . . . . . . . . . . . . . . . . . . 37
3.7 Diagram of the Traditional TMR . . . . . . . . . . . . . . . . . . . . . . . . . . . 40
3.8 Diagram of the Single Bit TMR With Recovery . . . . . . . . . . . . . . . . . . . 40
3.9 Diagram of the Hamming Code Encoder’s Parity Calculator . . . . . . . . . . . . 41
3.10 Diagram of the Hamming Code Decoder’s Wrong Bit Identification . . . . . . . . 41
3.11 Diagram of the Hamming Code Decoder’s Bit Flip Mechanism . . . . . . . . . . 42
4.1 Diagram of the Experimental PCB Design . . . . . . . . . . . . . . . . . . . . . . 48
4.2 DUT With SPI Flash, SDRAM and GPIO Header . . . . . . . . . . . . . . . . . 49
4.3 DUT With CAN Transceivers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
4.4 Controller With 2x SRAM and 2x Flash . . . . . . . . . . . . . . . . . . . . . . . 50
4.5 Plot of Temperatures During Temperature Tests . . . . . . . . . . . . . . . . . . 55
x
Stellenbosch University  http://scholar.sun.ac.za
LIST OF FIGURES xi
4.6 Plot of Voltages and Currents During Temperature Tests . . . . . . . . . . . . . 55
4.7 Diagram of the Dummy Interface Between Core8051s and AHB Bus . . . . . . . 59
4.8 Diagram of the Dummy Memory for Core10100 . . . . . . . . . . . . . . . . . . . 59
4.9 Image of the Vacuum Connector Showing the Modifications . . . . . . . . . . . . 60
4.10 Diagram of the TMR with Recovery Using ZOR3I . . . . . . . . . . . . . . . . . 63
4.11 Diagram of the Hamming Code Encoder . . . . . . . . . . . . . . . . . . . . . . . 64
4.12 Diagram of the Hamming Code Decoder’s Wrong Bit Identification . . . . . . . . 64
4.13 Flow-diagram of the SET Filter Injector . . . . . . . . . . . . . . . . . . . . . . . 66
4.14 Screen-shot of the SET Filter Injector . . . . . . . . . . . . . . . . . . . . . . . . 67
4.15 Register Before SET Filter Injection . . . . . . . . . . . . . . . . . . . . . . . . . 67
4.16 Register after SET Filter Injection . . . . . . . . . . . . . . . . . . . . . . . . . . 67
4.17 Comparison Between Buffer and Inverter Based SET Filters of Different Lengths 68
4.18 Average Delays of SET Filters of Different Chain Lengths . . . . . . . . . . . . . 69
4.19 Register Prior to TMR and Recovery . . . . . . . . . . . . . . . . . . . . . . . . . 71
4.20 Register After TMR and Recovery . . . . . . . . . . . . . . . . . . . . . . . . . . 72
4.21 Screen-shot of the Monitor Interface . . . . . . . . . . . . . . . . . . . . . . . . . 76
4.22 Flow Diagram of the Operational Test . . . . . . . . . . . . . . . . . . . . . . . . 78
4.23 Screen-shot of the Operational Test’s Software Interface . . . . . . . . . . . . . . 78
5.1 Image of Defocussed Beam as seen in the Control Room . . . . . . . . . . . . . . 83
5.2 X-Ray Image of ProASIC3 A3PE1500 FPGA Showing the Die Size . . . . . . . . 84
B.1 Connection of Sub-Parts of the Schematics . . . . . . . . . . . . . . . . . . . . . 102
B.2 Schematic of the Device Under Test FPGA showing I/O Connections, Crystal,
Decoupling Capacitor and Headers . . . . . . . . . . . . . . . . . . . . . . . . . . 103
B.3 Schematic of the Controlling FPGA showing I/O Connections, Crystal, Decoup-
ling Capacitor and Headers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104
B.4 Schematic Showing the Connection of the Power Supplies . . . . . . . . . . . . . 105
B.5 Schematic Showing the Current, Voltage and Temperature Sensors . . . . . . . . 106
B.6 Schematic Showing the Connection of the CAN Transceivers . . . . . . . . . . . 107
B.7 Schematic Showing the Connection of the Ethernet PHY . . . . . . . . . . . . . 108
B.8 Schematic Showing the Connection of the LED Daughter Boards . . . . . . . . . 109
B.9 Schematic Showing the Connection of the Device Under Test FPGA’s Memory . 110
B.10 Schematic Showing the Connection of the Controlling FPGA’s Memory . . . . . 111
B.11 Top layer of the PCB, excluding ground plane . . . . . . . . . . . . . . . . . . . . 112
B.12 Bottom layer of the PCB, excluding ground plane . . . . . . . . . . . . . . . . . 113
B.13 Schematic Showing the Connection of the UART Daughter-Board . . . . . . . . 114
D.1 Final Libero Design for the Device Under Test . . . . . . . . . . . . . . . . . . . 121
D.2 Final Libero Design for the Controller . . . . . . . . . . . . . . . . . . . . . . . . 122
E.1 Timing Diagram of the Mitigated CAN Controller’s FIFO Module With Injected
Errors Showing Mitigation and Hamming Code Recovery . . . . . . . . . . . . . 124
Stellenbosch University  http://scholar.sun.ac.za
LIST OF FIGURES xii
E.2 Timing Diagram of the Mitigated CAN Controller’s Bus Timing 0 Register With
Injected Errors Showing Mitigation and TMR Recovery . . . . . . . . . . . . . . 125
E.3 Simulation showing message transmission and reception between the mitigated
and unmitigated CAN controller . . . . . . . . . . . . . . . . . . . . . . . . . . . 126
Stellenbosch University  http://scholar.sun.ac.za
List of Tables
2.1 Summary of different sub-system communication networks . . . . . . . . . . . . . 16
2.2 List of Signals Used in the Wishbone Interconnect [6] . . . . . . . . . . . . . . . 20
2.3 List of Signals Used in the 8051 Bus . . . . . . . . . . . . . . . . . . . . . . . . . 20
3.1 Breakdown of FPGA Usage of the Original CAN Controller Post-Synthesis . . . 29
3.2 List of Connections to the Hardware . . . . . . . . . . . . . . . . . . . . . . . . . 35
3.3 List of Hardware Requirements . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
3.4 List of Connections for AMBA Master to CAN controller . . . . . . . . . . . . . 38
4.1 List of Measurements at the End of Phase 1 . . . . . . . . . . . . . . . . . . . . . 51
4.2 Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
4.3 Commands for Writing a Byte to the Flash device . . . . . . . . . . . . . . . . . 57
4.4 Commands for Completely Erasing the Flash device . . . . . . . . . . . . . . . . 57
4.5 Altered List of Connections to the Hardware . . . . . . . . . . . . . . . . . . . . 60
4.6 Average Delay for Different SET Filter Lengths . . . . . . . . . . . . . . . . . . . 69
4.7 Maximum Frequency of CAN controller Due to Delays inside SET Filters . . . . 70
4.8 Command Structure of PC-to-PCB Communication . . . . . . . . . . . . . . . . 75
4.9 List of Commands of PC-to-PCB Communication . . . . . . . . . . . . . . . . . 75
5.1 Breakdown of FPGA Usage of the Mitigated CAN Controller Post-Synthesis . . 81
5.2 Contents of the CAN FIFO . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
5.3 Unmitigated CAN Controller Register Values . . . . . . . . . . . . . . . . . . . . 86
5.4 Mitigated CAN Controller Register Values . . . . . . . . . . . . . . . . . . . . . . 86
A.1 Distribution of tasks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100
F.1 iThemba Test Logs Part 1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127
F.2 iThemba Test Logs Part 2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 128
xiii
Stellenbosch University  http://scholar.sun.ac.za
Nomenclature
Abbreviations and Acronyms
ACF Acceptance Filter
ACS Attitude Control System
ADC Analogue to Digital Converter
AHB Advanced High-Performance Bus
APB Advanced Peripheral Bus
ASB Advanced System Bus
BGA Ball Grid Array
BRP Baud Rate Pre-scaler
BSP Bit Stream Processor
BTL Bit Timing Logic
CAN Controller Area Network
CCD Charge-coupled device
CMOS Complementary Metal Oxide Semiconductor
CRC Cyclic Redundancy Check
DUT Device Under Test
DFF D Flip Flop
DMA Direct Memory Access
DMR Dual Modular Redundancy
EDAC Error Detection and Correction
EPS Electronic Power System
ESA European Space Agency
eV Electron Volt
xiv
Stellenbosch University  http://scholar.sun.ac.za
NOMENCLATURE xv
FIFO First In First Out
FPGA Field Programmable Gate-Array
GG Guard Gate
GPIO General Purpose Input Output
GPS Global Positioning System
HDL Hardware Descriptive Language
IBO Bit Order Inverter
I2C Inter-Integrated Circuit
IC Integrated Circuit
ID Identification
IP Intellectual Property
ISIS Innovative Solutions In Space
JAXA Japan Aerospace Exploration Agency
JTAG Joint Test Action Group
LABS Laboratory for Accelerator Based Sciences
LEO Low Earth Orbiting
LVDS Low Voltage Differential Signal
MAC Media Access Control
MBU Multiple Bit Upset
MIT Massachusetts Institute of Technology
MOS Metal Oxide Semiconductor
MOSFET Metal Oxide Semiconductor Field Effect Transistor
MRAM Magneto-resistive Random Access Memory
MUX Multiplexer
NASA National Aeronautics and Space Administration
NVM Non-Volatile Memory
OBC On-board Computer
PCB Printed Circuit Board
PHY Physical Layer
Stellenbosch University  http://scholar.sun.ac.za
NOMENCLATURE xvi
PLL Phase Locked Loop
PNPN Positive-Negative-Positive-Negative
PSU Power Supply Unit
QFP Quad Flat Pack
RAM Random Access Memory
RKA Russian Federal Space Agency
SCL Serial Clock Line
SDA Serial Data line
SDRAM Synchronous Dynamic Random Access Memory
SEB Single Event Induced Burnout
SEE Single Event Effect
SEFI Single Event Functional Interrupt
SEGR Single Event Gate Rupture
SEL Single Event Latch-up
SET Single Event Transient
SEU Single Event Upset
SoC System-on-Chip
SPI Serial Peripheral Interface
SRAM Synchronous Random Access Memory
SSC Separated Sector Cyclotron
SSTL Surrey Satellite Technology Ltd
TID Total Ionizing Dose
TTL Transistor-Transistor Logic
TMR Triple Modular Redundancy
UART Universal Asynchronous Receiver/Transmitter
UK United Kingdom
VHDL Very-High-Speed-Integrated-Circuit Hardware Descriptive Language
VHF Very High Frequency
UHF Ultra High Frequency
XML Extensible Mark-up Language
Stellenbosch University  http://scholar.sun.ac.za
Chapter 1
Introduction and Problem Description
As with most electronic systems, satellite systems are modular systems. Generally satellites
contain, among others, an Electrical Power System (EPS), an Attitude Control System
(ACS), a Communication System and an On-board Computer (OBC). To simplify the design,
the satellite is broken down into functional sub-systems which can easily be developed and
tested.
In order for the satellite to function effectively, all the subsystems need to function in
harmony. While each subsystem has its own functionality, it is the sole function of the OBC
to command and oversee all the subsystems.
To communicate with the various subsystems, a communication bus is required. With
Sunspace’s Sumbandila satellite [7], Surrey Satellite Technology Ltd’s (SSTL) SSTL-300
satellite platform [8] and Massachusetts Institute of Technology’s (MIT) F-12 flight computer
[9], the communication bus comes in the form of the Controller Area Network (CAN) bus.
For cubesats, most of the components listed on CubeSatShop [10], including the Innovative
Solutions In Space (ISIS) Very High Frequency (VHF) Downlink / Ultra High Frequency
(UHF) Uplink Full Duplex Transceiver [11], CubeComputer [12] and CubeSense [13], list
Inter-Integrated Circuit (I2C) as the applied bus interface.
When a satellite leaves the safety of the Earth’s atmosphere, it is subject to the damaging
radiation from both the sun, and other unknown cosmic entities. The radiation can have a
damaging effect on the electronic components in the satellite and even lead to the failure of
the mission. Sumbandila was launched on 17 September 2009 and suffered a failure to the
EPS and one of the Charge-Coupled Device (CCD) camera boards between the launch and
30 March 2010. This led to the loss of control over the satellite, and the loss of three of the
six spectral bands used for imaging [14].
In the event of a failure in one of the communication controllers, it could lead to the failure
of the communication bus. Without the communication bus, the OBC would not be able to
command the sub-systems, and the sub-systems will not be able to report back.
The communication bus is therefore a single point of failure on-board a satellite. Although
mitigation techniques could be applied to avoid a communication bus failure, it would still
1
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 1. INTRODUCTION AND PROBLEM DESCRIPTION 2
be possible for some sub-systems to lock the communication bus.
The goal of this project is to protect a communication node to be more resistant against
the effects of radiation. This will be done by analysing and implementing various mitig-
ation techniques on a communication controller. In order to implement these mitigation
techniques, a HDL implementation of a communication controller will be used. After im-
plementing the mitigation, the footprint usage should be less than that of Triple Mitigation
Redundancy (TMR).
By making sure that the communication node is more resistant to radiation induced upsets,
the point of failure could be moved away from the communication bus. This thesis will start
by studying literature on radiation, sub-system communication, Field Programmable Gate
Arrays (FPGAs) and upsets in FPGAs in Chapter 2. In Chapter 3, the design of a mitigated
CAN controller will be discussed, along with the development of a testing platform to test
the CAN controller’s resistance to upsets. The design and population of the Printed Circuit
Board (PCB) will be discussed in Chapter 4, followed by the alterations made to the CAN
controller. In Chapter 5 the results from simulations and radiation testing will be discussed.
Conclusions will be made in Chapter 6 and further possible work will also be covered.
Stellenbosch University  http://scholar.sun.ac.za
Chapter 2
Literature Study
In this chapter a short background will be given of the sources and effects of radiation along
with ways to protect against them. Sub-system communication in large designs will also be
discussed, followed by a discussion on the different types of FPGAs. Finally, a background
on different methods of System on Chip (SoC) communication will be given. To finish this
chapter, the simulation and testing of Single Event Effects (SEEs) and Single Event Upsets
(SEUs) will be discussed.
2.1 Radiation
While the sources and effects of radiation are well documented, a short background on the
subject will be given, followed by a discussion on known protection against the effects.
2.1.1 Sources of Radiation
The earth’s atmosphere not only serves life forms with breathable air, but it also acts as a
giant screen to filter out the dangerous radiation from the hostile space environment, along
with most of the infrared light [15]. Infrared light forms part of a wide band of energies,
called the electromagnetic spectrum [16]. This spectrum ranges from low energy radio and
microwave radiation to high energy X-rays and gamma rays.
Cosmic rays originate from beyond our solar system. These high energy particles consist of
mainly heavy ions and atomic nuclei [17]. The exact origin of cosmic rays is still unknown,
and data from the Fermi Space Telescope suggests that it originates from super novae [18].
The energy of these particles can reach up to 3 × 1020 electron-Volt (eV), and holds a real
threat to microelectronics outside the protection of the earth’s atmosphere and magnetic
field [19].
Solar events refer to radiation originating from the sun. This includes the periodic increase
and decrease in the solar wind, as well as the occasional solar flare. The sun is constantly
emitting not only light, but also a stream of charged particles, or plasma. This stream of
particles radiates outwards from the sun, and due to the rotation of the sun, forms waves
referred to as solar wind. Solar wind consists mostly of electrons and protons, with energies
3
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 4
exceeding 100 MeV [20]. While not as dangerous as cosmic rays, consistent bombardment
with these particles can also induce failures in microelectronics.
Figure 2.1 – Diagram Illustrating the Spiral Shape of the Solar Wind Due to the Rotation of
the Sun.
Solar flares occur near sunspots when stored magnetic energy is suddenly released from the
corona. These flares appear as arches on the sun’s surface and release electrons, ions and
atoms outwards. The particles have been recorded to reach energies of up to 1 MeV and
even higher [21].
The Van Allen belts are belts of radiation in the upper magnetosphere of the earth. They
are kept in place by the earth’s magnetic field, and consist of the trapped particles emitted
by the solar wind with the same energy of 100 MeV. These belts are located between the
earth’s surface and 40 000 km above the earth’s surface. While most Low Earth Orbiting
(LEO) satellites orbit below these belts, Geostationary Orbit (GEO) satellites are located
well inside of these belts at roughly 36 000km [1]. The Global Positioning System (GPS)
satellites are located between the two belts, at a height of roughly 7 600 km above the
earth’s surface.
Figure 2.2 shows Van Allen belts symmetrical around the magnetic axis of the earth rather
than the rotational axis. The upper radiation belt is located roughly 19 000 km above the
earth’s surface. It contains mainly electrons and protons, with energies up to 100MeV, which
are captured by the earth’s magnetosphere. The inner radiation belt is located roughly 4
000 km above the earth’s surface. This belt contains mainly high energy protons [1]. The
energy of the electrons in the outer belt can go up to several thousand eV, while the protons
can reach energies exceeding 100 MeV, depending of the energy of the protons in solar wind.
Figure 2.3 shows the radiation dosages at various heights above the earth’s surface due to
the Van Allen belts [1].
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 5
Figure 2.2 – Illustration of Van Allen Belts Surrounding Earth.
Figure 2.3 – Radiation Dosages Due to Van Allen Belts. Adapted From [1].
2.1.2 The Effects of Radiation
The effects of radiation on electronic components manifest itself in many ways, from a
temporary signal spike to total device failure.
2.1.2.1 Lattice Displacement
Lattice displacement is the displacement of atoms in the atomic structure of the Integrated
Circuit (IC). The high energy particle loses energy as it penetrates the semiconducting layer
inside the IC. Through Rutherford scattering and Compton interactions, the particle is
slowed as it transfers energy to particles in the lattice [22]. When the energy of the particle
is high enough, the impact with other particles can result in a particle being displaced from
its original location to form lattice vacancies, to replace another particle in the lattice or to
lodge into an empty space in the lattice. With the alteration in the electron-hole pairs, the
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 6
excess carriers can deposit a charge with undesired consequences [22].
Lattice displacement is most commonly caused by high energy particles with energies above
100 MeV. These particles include alpha, beta and gamma particles, protons, neutrons, elec-
trons and other heavy ions. Often, high temperature or annealing allows the recombination
of displaced atoms with empty locations in the lattice [23].
2.1.2.2 Ionization Effects
Ionization effects are caused when the lattice is hit by either high or low energy charged
particles. Electrons are added or removed from a neutral or partially ionized atom. Changing
the electron count of the atom results in the bond between the atoms of the molecule breaking
down, changing the chemical composition of the material [23].
2.1.2.3 Total Ionizing Dose (TID) Effects
Prolonged exposure to radiation leads to a build-up of ionization effects and damage to
the crystal lattice. The build-up of trapped charges in the Metal Oxide Semiconductor
(MOS) transistor’s silicon dioxide insulating layer escapes through tunnelling effects [24].
The tunnelling effect occurs when ions escape the insulating layer, generating a minute
current.
In Complementary Metal Oxide Semiconductor (CMOS) logic, radiation exposure leads to
the generation of electron-hole pairs in the insulating layers. When these pairs recombine, a
minute current is generated [23]. In the event of a hole being trapped in the lattice structure,
the bias of the gate gets altered, along with the threshold voltage [24].
2.1.2.4 Single Event Effects
In the event of the deposited charge being large enough, three types of Single Event Upsets
(SEUs) can occur, namely transient, permanent or static.
Transient errors occur when the excess carriers deposit a charge resulting in an asynchronous
signal propagating through the circuit. This spurious signal can either be latched into a
memory element, or be filtered out by dominant signals inside the circuit [22].
Permanent errors are destructive and irreversible leading to physical damage of the cir-
cuit. Examples of these errors are Single Event Induced Burnout (SEB) and Single Event
Gate Rupture (SEGR), which mainly occur in power transistors [22]. In parasitic Positive-
Negative-Positive-Negative (PNPN) structured devices, the ionization track of a high energy
particle is able to turn on both internal transistor structures. This results in the device cre-
ating a low resistance path between the upper and lower voltage rails, resulting in a high
current short circuit. This is known as a Single Event Latch-Up (SEL). If the fault is noticed
early enough, a power cycle can remove the SEL, preventing damage to the circuit.
Static errors occur when transients are latched into a memory element, or when a volatile
memory element is struck by a higher energy particle, changing its value. Both SEUs and
Multiple Bit Upsets (MBUs) can occur inside a circuit, but can be repaired through an
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 7
external interaction [22]. In the event of an SEU changing the control circuits leading to a
change in device state, the SEU becomes a Single Event Functional Interrupt (SEFI). These
errors can typically be corrected though a power cycle of the circuit, or through an external
interaction.
2.1.3 Radiation Hardening
The term radiation hardening is used to describe the process through which a design is
made more resistant against the effects of radiation. Several techniques exist to protect
circuits from the effects of radiation, consisting of physically protecting the circuit or building
redundancies into the circuit.
2.1.3.1 Hardening by Design
Integrated Circuits (ICs) are produced by doping, or adding impurities, to a semiconductor
wafer, usually made from silicon. To create a hardened IC, the IC is produced using insulat-
ing substrates, such as silicon dioxide or sapphire, instead of the silicon wafer. While normal
ICs can take a dose of between 5 and 20 krad, radiation hardened ICs can take a dose of
several factors higher. The 4000 series logic (RadHard) can tolerate a dose of roughly 100
to 1000 krad [25].
Another method of protecting an IC against radiation is to use a substrate with a high band
gap. The band gap is the energy gap between the valence band and the conduction band. In
insulators, the conduction band has a higher energy than the valence band. This means that
external energy is required to relocate electrons from the valance band to the conduction
band. When a particle with high enough energy collides with the insulating substrate, it
can create a conducting path through the insulator. To increase the band gap, substrates
such as silicon carbide or gallium nitrate can be used which have roughly three times higher
band gap than silicon [26].
Covering the IC in depleted boron can also reduce the effects of radiation inside the IC [27].
Depleted boron, or Boron-10, is used in Boron Neutron Capture Therapy for treating cancer
patients. Boron-10 is attached to tumours using a tumour seeking compound, where-after
it is irradiated using low energy neutrons. Boron-10 then disintegrates by absorbing the
neutrons, and emits a gamma ray, an alpha particle and a lithium ion. These destroy the
cancerous cells, leaving normal cells relatively unaffected [28].
Instead of using Synchronous Random Access Memory (SRAM) or Synchronous Dynamic
Random Access Memory (SDRAM), the use of Magneto-resistive Random Access Memory
(MRAM) is suggested as an alternative [29]. MRAM has been shown to be inherently
radiation resistant [29]. While the construction and operation of MRAM are not covered by
this project, the principle on which MRAM is based is that it does not store an electrical
charge. Instead, it uses magnetic components to store information.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 8
2.1.3.2 Dual and Triple Modular Redundancy
Duplicating a design is one of the most common methods of adding redundancy to a system.
During the development of the submarine command system for the United Kingdom (UK)
ministry of defence in 1983, it was decided that each central node should be duplicated to
create a fault tolerant system. These nodes were interconnected using dual fibre optic local
area networks [30].
While it is possible to detect differences between the two modules, selecting the correct
signal is problematic. Modern Dual Modular Redundancy (DMR) designs use self-voting
techniques to determine which signal should be used [31].
Figure 2.4 – Schematic Representation of a Traditional DMR Circuit and a Modern Imple-
mentation of a Self-Voting DMR Circuit
TMR is more resistant to upsets than DMR, but it is also more inefficient. TMR triplicates
the design and uses majority voters on the outputs, thus increasing the area usage by more
than three times. Similar to DMR, TMR can be applied on different levels of the design.
The first option is to triplicate the entire design on IC level. This is known as triple device
redundancy. It involves placing three equivalent components and using the controlling logic
as a majority voter. An example of this is can be found in commercial and military aircraft,
where certain parts of the control system are triplicated to avoid malfunctions.
Having three identical ICs on the circuit board has its drawbacks. Not only does it require
more than three times the area, but three times the weight is added and three times the
power is consumed. In a satellite environment where area, weight and power budgets are
limited, implementing TMR should be avoided.
The second option is found typically internal to an IC. This involves triplicating parts of the
device, which on their own have no useful function, but in terms of their usage are crucial
to the device. An example of this is triplicating the control registers on a processor.
Finally, individual low level gates can be triplicated. This method is the most complex and
costly in terms of area usage. The area usage will be at least four times that of the original
design, as each gate requires a majority voter.
2.1.3.3 Single Event Transient (SET) Filter
The SET filter is a mitigation technique used to filter out SET pulses using a delay element
and comparison technique to suppress the effect of the pulse [32; 3; 2].
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 9
Figure 2.5 – Schematic Representation of a Traditional TMR Circuit
Originally, the comparison was made using a guard-gate (GG) [2], where one input is con-
nected to the original source and the second is connected to the output of the delay unit.
The GG consists of four Metal Oxide Semiconductor Field Effect Transistor (MOSFETs),
with connected drain to source as shown in Figure 2.6. Inputs are connected to either the
upper two or the lower two MOSFETs, while the output is connected to the connection
between the two upper and lower two MOSFETs. Two inputs of the same value will result
in two of the four MOSFETs turning on, pulling the output either high or low. Opposite
inputs will result in a floating output, as the output is neither connected to a high or low.
...
Figure 2.6 – Diagram of the SET Filter using GG as in [2]
While this is an elegant solution, it is practically flawed because a floating output will result
in undesired behaviour in following sequential logic. Also, implementing a GG in the fabric
of the FPGA is impossible due to the architecture of most FPGAs.
A new comparison technique was developed by Farouk Smith, which involves feedback from
the output to do the voting [3]. Similar to previous filtering techniques, the delay is made
by a set of equal number logic inverters, while the comparison is done using an AND-gate,
OR-gate and a 2-port Multiplexer (MUX), illustrated in Figure 2.7 [3].
To explain the inner working of the SET filter, separate stages of the filter will be discussed
below. A logic ’0’ to either of the inputs of the AND-gate, will result in the output being
a logic ’0’. If a SET pulse of logic ’1’ was to occur on the input, it will be shifted slightly
behind the original pulse by the delay element on the second input to the AND-gate. If the
SET pulse is shorter than the delay, the pulses on the inputs will not overlap, resulting in
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 10
...
Figure 2.7 – Diagram of the SET filter as Proposed in [3]
the output remaining a logic ’0’. If the SET pulse duration is longer than the delay, the two
pulses will overlap and a short pulse will propagate though the AND gate. In Figure 2.8,
the top signal represents the case where the pulse is shorter than the delay element, while
the bottom signal is longer.
...
&
& =>
=>
Figure 2.8 – Illustration of the SET filter Implementation’s AND-gate Logic
Opposite to the AND-gate, a logic ’1’ on either of the inputs of the OR-gate, will result
in the output being a logic ’1’. Following the same argument as above, the output of the
OR-gate will remain a logic ’1’ if the SET pulse is shorter than the delay. In Figure 2.9, the
top signal represents the case where the pulse is shorter than the delay element, while the
bottom signal is longer.
...
||
|| =>
=>
Figure 2.9 – Illustration of the SET filter Implementation’s OR-gate Logic
If the input to the SET filter is a logic ’0’, both the AND-gate and the OR-gate will output a
logic ’0’. The same can be said for a logic ’1’. If no SET pulses are present, both inputs of the
MUX will be the same, and therefore the output will be the same as the input. Assuming
the input was originally a logic ’1’, a SET pulse occurs and it is shorter than the delay, the
AND-gate will output two logic ’0’ pulses, one for the original pulse and one for the delayed
pulse. Meanwhile the OR-gate will remain at a logic ’1’. Because the output was a logic
’1’ before the SET pulse occurred, the MUX is selected to use the input from the OR-gate,
which remained at a logic ’1’. If the SET pulse was longer than the delay, the AND-gate will
output a logic ’0’ from the start of the SET pulse until the end of the delayed SET pulse.
The OR-gate will output a logic ’0’ for the overlapping part of the original and delayed SET
pulse. When this happens, the output of the MUX changes to a logic ’0’, selecting the AND
gate as input. Since the AND-gate remains at a logic ’0’ until the delayed SET pulse is
passed, the full SET pulse will propagate through the SET filter.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 11
Similarly, if the input was a logic ’0’ originally, and a logic ’1’ SET pulse occurs which is
shorter than the delay, the MUX would be set to use the AND-gate, which will remain at
a logic ’0’. If a SET pulse longer than the delay occurs, the AND-gate will be a logic ’1’
for the overlapping part which will select the OR-gate as input, resulting in the SET pulse
propagating through the filter.
In the event of the SET pulse being shorter than the delay of the delay element, the SET filter
will theoretically filter out all SET pulses. A recent study on flash-based FPGAs showed
that for the Actel ProAsic3, the maximum SET pulse width was roughly 3-4 nanoseconds
[33]. The SET filter’s delay element should therefore have a delay of 5 ns or more.
2.1.3.4 Error Detection and Correction (EDAC) using Hamming Code
Error detection on data can be done by storing extra information about the data. This is
normally done using parity bits or Cyclic Redundancy Check (CRC) bits. Identifying the
wrong bit and correcting it could also be accomplished, given that enough extra information
has been stored. One of these techniques is the Hamming Code.
Hamming code is a method of detecting and correcting single bit errors within data. The
Hamming code encoding and decoding algorithm scales well over different lengths of data.
A study by IBM showed that 98% of errors are single bit errors [34], and therefore the
Hamming Code would suffice for use in this project. Since the CAN controller uses 8 bit
registers, the following content was adapted to reflect input data of 8 bits, protected with a
4 bit Hamming code [35].
Definition of data bits: The data being encoded
Definition of parity bits: Bits inserted between data bits to form the code word.
Definition of code word: Data bits and parity bits combined
To create a code word, the original data is padded with extra bits. These bits are located
at positions 2x where x = 0, 1 . . . n. If the data byte to be encoded is [d0 d1 d2 d3 d4 d5 d6
d7] the Hamming code is represented by [p0 p1 d0 p2 d1 d2 d3 p3 d5 d0 d6 d7], where dx
represents the original data bits and px represents the inserted parity bits [36; 37].
The encoded bits are allocated by the relationship between the data bits. The value of px
is given by checking the parity of selected bits. When the parity is even, the parity bit is
set to 0. When the parity is odd, the parity bit is set to 1. This results in the parity of the
data bit and parity bit always being even. The relationship between the parity and data
bits are given by Equations 2.1.1 to 2.1.4.
p0 = parity{d0, d1, d3, d4, d6} (2.1.1)
p1 = parity{d0, d2, d3, d5, d6} (2.1.2)
p2 = parity{d1, d2, d3, d7} (2.1.3)
p3 = parity{d4, d5, d6, d7} (2.1.4)
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 12
Once the parity bits are inserted, the parity of the data bits, along with the parity bit, will
always be even. This relationship is the basis of the Hamming code.
To calculate which bit is incorrect, the parity of the selected data bits and parity bit is
recalculated using Equations 2.1.5 to 2.1.8. If the parity is returned as odd, it indicates a
problem with that group. By calculating the parity for each group, the incorrect position
can be calculated using Equation 2.1.9.
e0 = parity{p0, d0, d1, d3, d4, d6} (2.1.5)
e1 = parity{p1, d0, d2, d3, d5, d6} (2.1.6)
e2 = parity{p2, d1, d2, d3, d7} (2.1.7)
e3 = parity{p3, d4, d5, d6, d7} (2.1.8)
Position =
n∑
x=0
ex· 2x (2.1.9)
Using the position given by the previous equation, the incorrect bit can be corrected. The
position of the faulty bit can be either a data bit, or a parity bit.
These mitigation techniques formed the basis from which a custom mitigation solution was
developed. During a later stage, the application of each technique will be discussed.
2.1.4 Different Units
Four units are used throughout the thesis when referring to radiation namely: electronvolt,
rad, gray (Gy) and Ampere (A). Electronvolt is used describe the energy of a particle, more
specifically, the amount of energy gained or lost by moving a single electron over an electric
potential difference of one volt. One electronvolt is equal to 1.6x10−19 joule (J) of energy.
Rad is used to describe the absorbed radiation dose and can be defined as 0.01 J/Kg of mass,
or 6.25x107 MeV/kg Rad is deprecated unit of measurement and has since been replaced
with gray, which is the equivalent to 100 rad, or 6.25x109 MeV/kg.
Finally Ampere is used to measure the amount of particles travelling though a certain cross
section of the conductor. In the case of radiation, these particles can be heavy-ions, protons
or neutrons. Depending on the absorptivity of the materials inside the IC, the amount of
particles passing through the IC and the energy of the particle, the total dose, or rad, can
be calculated.
2.2 Sub-System Communication
Communication between all sub-systems in any multi-system design is key to the function-
ality of the complete system. Several different communication protocols exist, but only one
will be used.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 13
2.2.1 Commonly Used Communication Systems
Although several network communication standards are available, only a few are employed
in the space industry.
2.2.1.1 SpaceWire
SpaceWire is a communication network developed specifically for the use in satellites. It was
developed by the European Space Agency (ESA), in collaboration with National Aeronaut-
ics and Space Administration (NASA), Japan Aerospace Exploration Agency (JAXA) and
Russian Federal Space Agency (RKA) [38]. Nodes are connected though a point to point
serial connection, with optional switching routers.
SpaceWire can reach speeds up to 200 Mbps [38]. It utilizes Low-Voltage Differential Sig-
nalling (LVDS) across a 9 pin connection [39]. Using data strobe encoding, it allows for
easy clock recovery and jitter tolerance. Data strobe encoding specifies that either the data
signal or strobe signal should change once every clock cycle. To recover the clock, the data
and strobe signals are channelled through an XOR gate.
While SpaceWire is capable of high speeds, it’s usage is limited to communication between
two devices without a router. This makes it impractical for use as a shared sub-system
communication bus.
2.2.1.2 Universal Asynchronous Receiver/Transmitter (UART)
UART converts parallel data into a serial data stream for point-to-point communication.
There are several communication standards which are used on top of UART, such as RS-
232, RS-422 and RS-485. While all these standards have different specifications in the way
communication takes place, all of them are based on UART.
UART consists of a transmission line and a receiving line. The transmission line from
one device is connected to the receiving line of another. This allows stable communication
between two devices with speeds up to 115.2 kbps. At higher frequencies, the slew rate
will start to approach the 4% maximum of bit period allowed. Due to the simple nature
of UART, both devices need to be set to exactly the same data rate to avoid corruption of
data [40].
Similar to SpaceWire, using UART to create a bus is impractical.
2.2.1.3 Serial Peripheral Interface (SPI)
SPI bus as it is called by Motorola, or Microwire trade marked by National Semiconductor, is
a full duplex serial communication bus [41]. Due to industry acceptance, SPI is currently one
of the dominant communication standards for peripheral communication. SPI is driven by a
single master at a time, with the number of slaves limited to the number of General Purpose
Inputs and Outputs (GPIO) available on the master. It is also possible for inter-processor
communication using SPI.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 14
SPI can reach a clock frequency of up to 50 MHz reliably, based on components currently
available. Higher frequencies are possible, but are limited by the production quality of the
PCB and components. It uses Transistor-Transistor Logic (TTL) over a 3-wire connection,
with an extra wire for each slave. Two single directional data wires are used for data
transmission and is synchronised using a third clock signal. For each slave device present,
an extra chip select wire is added to the interface.
SPI works well for communication between a controller and the peripherals attached to it.
To implement an SPI bus between controllers would seem impractical, as there always needs
to be a master controller. Having a single component in control of the bus could lead to the
loss of all sub-system communication, should it fail.
2.2.1.4 I2C
I2C is a communication bus developed by Phillips in 1982 to connect low speed devices
to microcontrollers [42]. Several competitors have since released products compatible with
Phillips’ I2C system, which led to the reduction of licensing fees on the patent. A fee is still
payable in order to get a formal address for a device from Phillips. Several revisions of I2C
have since been released, the latest being version 4.0, which is able to reach speeds of up to
5MHz [42].
I2C consists of a Serial Data Line (SDA) and Serial Clock Line (SCL), which are both
implemented using open-drain circuitry. These lines are pulled up to the voltage level used
by the microcontroller using resistors, and pulled low by the I2C controller when transmitting
a logic ’0’.
Communication takes place between two devices, where one acts as the master and the other
acts as the slave. The master generates the clock signal for the SCL line and sends a start
bit to the bus. The master then writes the address on the SDA line, and then expects an
acknowledgement from the slave. The final bit of the address specifies whether a read or
write transaction will follow. During a write transaction, the data is written to the bus by
the master, and then waits for an acknowledgement from the slave. For a read transaction,
the slave writes the data to the bus and sends an acknowledgement to the master. When
the transaction is completed, the master will send a stop bit, releasing the bus. The number
of data bytes written can continue until the sender decides to release the bus.
In the event of two I2C controllers starting transmission at the same time, each controller
will check whether it has control over the bus or not. Since each I2C controller can only
drive the bus down to a logic ’0’, the first controller to detect a logic ’0’ on the bus when
transmitting a logic ’1’ will stop transmission, as it has lost control over the bus.
2.2.1.5 CAN
CAN is a communication bus developed for use inside of motor vehicles. The goal was to
develop a communication bus which allows several sub-systems to communicate without a
single host. It was developed by Robert Bosch GmbH in 1983, and released in 1986 [43].
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 15
CAN is a message based communication standard where every node can transmit and receive
messages with up to eight bytes of data. CAN 2.0 A specifies that each message contains an
11 bit Identification (ID) which is used to determine which CAN controller should accept
the message. The ID is also used to arbitrate which CAN controller has control over the
bus. CAN 2.0 B offers an extended mode where the IDs of 29 bits can be transmitted.
Bus activity can be represented by either a recessive state, or logic ’1’, or a dominant
state, or logic ’0’. In the recessive state, the bus is not driven by any logic, as opposed
to the dominant state where the transceiver is pulling the bus low. In the event of two
CAN controllers transmitting at the same time, the first to transmit a recessive state, loses
arbitration and backs off from transmitting.
To compensate for phase shifts between different sub systems, each bit is divided into four
segments. The first segment is used to indicate a sync period. If there is a mismatch between
the bus and the CAN controller, the CAN controller will delay extra cycles in the second
segment to make up for the shift in phase. The last two segments are used to determine the
duration of each bit, as well as where, relative to the end of the bit transmission, the bit
should be sampled.
At a range of 40 meters, the maximum speed of CAN is roughly 1 Mbps. At higher rates
reflections in the cables start to distort the signal, making it harder to determine the correct
bus value.
2.2.1.6 Comparison of Sub-System Communication Methods
While most of the aforementioned communication standards have their advantages and
disadvantages, each of them has a unique application. Table 2.1 lists a summary of all the
communication networks.
For communication between two devices, either SpaceWire or UART could be used, UART
being the most simplistic, offering slow speeds and no form of data protection. SpaceWire
can reach speeds up to 400 times greater than UART. Using data strobing allows SpaceWire
to work across different domains by making the clock easily available. Unfortunately, neither
of these have the potential to form a practical communication bus.
SPI can also be considered a point-to-point communication bus, as the number of connections
increases as the number of peripherals increases. If the chip selects are taken away, SPI boils
down to be similar to both SpaceWire and UART. With SPI, the shared data lines and
higher speeds make it an almost viable solution. Unfortunately, having a single master in
control of the bus, results in a single point of failure which could bring down all sub-system
communication.
The only two viable options remaining are I2C and CAN. Both these buses allow the con-
nection of multiple devices with multiple masters. While I2C is capable of reaching 4 times
the speed of CAN, I2C messages are directed to a single device. With CAN, a message can
be sent to multiple devices.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 16
Communication Wires Type Speed Pros Cons
SpaceWire 9 P-P 200 Mbps Fast, noise im-
mune (LVDS),
jitter resistant,
clock recovery
Point to point,
extra logic to
convert to bus
UART 2 P-P 115.2 kbps Simple Slow, point to
point, clock
sensitive
SPI 3+n Bus 50 MHz Fast, bus Master depend-
ant, bus width
grows as nodes
grow, node fail-
ure can cause
bus failure
I2C 2 Bus 5 MHz Fast, bus, arbit-
ration
Node failure can
cause bus failure
CAN 2 Bus 1 Mbps Noise immune
(LVDS), arbit-
ration, CRC,
phase shift
protection
Requires some
form or pro-
cessor, requires
transceiver
Table 2.1 – Summary of different sub-system communication networks
Both I2C and CAN make use of arbitration to avoid bus contention. Arbitration is the
process through which bus nodes determine which has control over the bus. Since I2C
controllers can only drive the bus down to a logic ’0’, the first controller which reads a logic
’0’ on the bus when transmitting a logic ’1’, has lost arbitration. With CAN, arbitration is
done using the ID, allowing more important message to pass through.
With I2C, any number of data bytes can be transferred to and from a single address. With
CAN, the data bytes are limited to eight. Where CAN gains the advantage, is the added
protection of CRC bits on each message.
In summary:
• CAN transmits messages to multiple devices, were I2C transmits to a single device.
• CAN has built in CRC to confirm message data, I2C does not.
• CAN compensates for phase shifts by resynchronizing at each bit.
• The differential CAN signals are immune to noise.
From the above mentioned reasons, it is clear that CAN is the bus of choice for use sub-
system communication. It has already been adopted into the automotive industry as the de
facto communication bus and is already used on many satellites.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 17
2.2.2 CAN in Hardware
As with any novel device, the CAN controller was initially implemented on a single device,
which could be added to almost any design. With interfaces varying from SPI to 8051
bus, it could connect to most microcontrollers. These devices could function separate from
other hardware, and in the event of failure, be switched off. Protecting these devices, either
involves placing multiple buses on the design, or changing the design of the device completely.
To change the design access to Intellectual Property (IP) would be required and the cost
involved of having a device manufactured is more than the budget of this project.
With the advances in the construction of integrated circuits, devices such as the CAN
controller can now be implemented directly on the microcontroller itself.
While both the above implementations add CAN to the sub-module of a project, protecting
these implementations from the effects of radiation is costly, not only footprint wise, but
financially as well.
The only way to protect these implementations is through DMR or TMR, increasing the
area usage on the PCB which is problematic for both the power and weight budget of a
satellite project. Another option is to improve the design of the chip itself, replacing the
substrate with a more resistant one. Not only will this cost be prohibitive, but most vendors
will probably not allow access to the design of the die.
An alternative would be to implement the CAN controller in an FPGA, where the design
can be customized to fit the budgets of the project, while adding radiation resistance to the
design.
2.2.3 SJA1000 CAN Controller from OpenCores.org
Igor Mohor, a developer at OpenCores.org, has already implemented the SJA1000 CAN
controller in Verilog. This project comes complete with a test bench to validate the working
of most of the internal parts of the CAN controller. The Verilog implementation was also
verified using the Bosch Very high speed Hardware Descriptive Language (VHDL) reference
system to be CAN compliant.
The internal structure of the CAN controller is customizable using configuration files in
which different interfaces can be specified, First-In-First-Out (FIFO) memory implement-
ation and a memory diagnostic stream. The memory diagnostic stream is used when the
FIFO is implemented in actual Random Access Memory (RAM), rather than in the fabric
of the FPGA.
2.3 FPGAs
There are several suppliers of FPGAs, each using different technologies to implement the
FPGA circuitry. Each of the technologies and suppliers have their strong and weak points,
and choosing the right one is crucial to the design.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 18
2.3.1 Different Types of FPGA
There are two main types of reconfigurable FPGAs namely, SRAM and flash based FPGAs.
SRAM based FPGAs are based on static memory. These need to be reprogrammed by
an external boot device on power-up. These devices are normally faster than flash based
FPGAs, while also using less power. Unfortunately, the memory in which the configuration
is stored is susceptible to upsets from radiation. If such an upset occurs, the device needs to
be reprogrammed resulting in system downtime. Apart from the FPGA which is susceptible
to upsets, the circuitry required to program the FPGA is also susceptible, therefore adding
extra complication to any design.
Flash based FPGAs store their configuration in flash memory. As opposed to SRAM based
FPGAs, these are live at power-up and require no re-programming. The flash memory
storing the configuration is resistant to upsets, as per interview with Niki Steenkamp and
[44]. A recent radiation test using the same device as chosen in the design has shown that
the configuration is not totally immune to upsets [45]. The downside is that the Flash
memory uses more power.
There are also FPGAs that are one-time programmable. These are based on antifuse tech-
nology. As opposed to a fuse, antifuse starts with a high resistance, which turns into a short
circuit if the voltage across it rises higher than the threshold. The problem with this fixed
configuration is that it is not re-programmable. These are not practical during a research
project, but are useful in satellites where reprogramming is not an issue.
2.3.2 Actel FPGA Comparison
Actel is currently the only manufacturer developing flash based FPGAs. They offer a wide
range of FPGAs, each with its own application [46].
2.3.2.1 Igloo
The Igloo range of Actel devices is known for their low power consumption, low cost and small
footprint. The Igloo nano range has the lowest power usage and smallest size FPGA available
of all the Actel devices. With the new Igloo2 range of FPGAs released by Microsemi, the
exact details surrounding the device operation is not yet known. The Igloo Plus is a low
power FPGA with enhanced input-output functionality. Finally, the Igloo E range of FPGAs
has the same low power consumption but with a larger die size. The Igloo range also offers
small amounts of internal SRAM and Non-Volatile Memory (NVM). The Igloo E also offers
a Cortex M1 enabled version of the FPGA.
The Igloo range of FPGAs is a candidate device for the space environment. While the low
power usage and small IC footprint is ideal for both power and weight budgets, the small
gate count could be problematic. For a device with a high enough gate count, the footprint
will be limited to a Ball Grid Array (BGA). As will be discussed later, the BGA footprint
is not ideal for usage in space, or for use on projects that require debugging.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 19
2.3.2.2 ProASIC3
The ProASCI3 FPGAs are typically larger and use more power, but also offer higher operat-
ing speeds than the Igloo range of FPGAs. The ProAsic3 range offers embedded dual-port
SRAM and FIFO blocks, advanced I/O and high speed operation. The ProAsic3L device
offers low power consumption compared to the other ProAsic3 devices. The ProAsic3 nano
range is smaller than the other ProAsic3 devices in both gate count and footprint. The
ProAsic3E devices are larger than other devices and require more power. Both the ProAsic3
E and L devices offer a Cortex-M1 enabled version of the FPGA [47].
The ProAsic3 range of FPGAs uses roughly 200 times more power than the Igloo range, but
offers faster operation. A study has also shown that where the ProAsic3 has SET pulses of
up to 4 nano seconds, the Igloo range can have SET pulses of up to 9 nano seconds [33].
2.3.2.3 Fusion
The Fusion range of FPGAs combines analogue blocks, large flash memory blocks and clock
management circuitry on a single device. The aim of the Fusion range of FPGAs is to
implement an entire system-on-chip[48].
In 2010 Actel, now Microsemi, also created a SmartFusion range of FPGAs which differs from
other FPGAs. Instead of having one large programmable FPGA fabric, the SmartFusion has
a similar structure to a microcontroller. The SmartFusion range of FPGAs offers peripherals
such as Ethernet Media Access Control (MAC), I2C controllers, SPI controllers, Analogue to
Digital Converters (ADCs) and Digital to Analogue Converters (DACs). During the design
process, certain blocks are activated and routed similarly to the FPGA fabric. These blocks
can interface with a smaller FPGA fabric where the user can develop his own hardware [49].
2.4 SoC Intercommunication
SOC intercommunication refers to the communication between components, more specific-
ally, between a microprocessor and peripherals.
2.4.1 Wishbone Interconnect
The Wishbone Interconnect was developed to reduce system-on-chip integration issues in-
volving the connection of IP cores. The objective was to create a common interface for all
IP cores which was portable and reusable. Wishbone is not copyrighted and can be used
royalty-free in any design, making it the common interface when developing custom IP cores
[50].
The Wishbone Interconnect offers two types of connections namely, point-to-point and bus
connection. Point-to-point is used when connecting two IP cores directly to one another,
while the bus connection requires a bus management system to connect multiple IP cores
[51]. A list of the Wishbone Interconnect signals is listed in Table 2.2.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 20
The Wishbone Interconnect is flexible and can be customized for the user’s needs while
still maintaining a robust standard. The well documented specification makes it easy to
develop a Wishbone interface for an IP Core, allowing rapid development of IP Cores and
SoC designs.
2.4.2 8051
The 8051 interface used on the SJA1000 CAN controller is not a formal bus definition;
instead it is an adaptation of the internal bus interface used to communicate with internal
memory. The internal bus specifies separate data, address and control buses which are used
for data transfer. In the Intel 8051 each data transfer takes 6 clock cycles, with the address
loaded on the third cycle and data read or written on the fifth and sixth cycles [52].
Adapting the above 8051 interface to communicate with external devices resulted in the
8051 bus was formed. The external 8051 bus consists of a shared 8-bit address and data
bus, with several control signals.
When a read or write operation is initiated, the master loads the address on the PORT_I/O
Signal Name Purpose
CLK_I Clock Signal
RST_I Reset Signal
TGD_I/O Tag Bus Signal (Unused in most designs)
DATA_I/O Data bus of width 8, 16, 24 or 32 bits
ACK_I/O Acknowledges completion of bus cycle
ADR_I/O Address bus of width 2 to 32 bits
CYC_I/O Indicates a valid bus cycle is in progress
STALL_I/O Indicates slave is not able to accept a transfer
ERR_I/O Indicates invalid bus cycle termination
LOCK_I/O Indicates current bus cycle is uninterruptible
SEL_I/O Device select signals
RTY_I/O Indicates interface is busy and cycle should be retried
STB_I/O Indicates a valid bus cycle
TGA_I/O Address tag signal
TGC_I/O Cycle tag signal
WE_I/O Write enable signal
Table 2.2 – List of Signals Used in the Wishbone Interconnect [6]
Signal Name Purpose
RST_I Device Reset Signal
CLK_I Device Clock Signal
ALE_I Address Latch Enable Signal
RD_I Read Signal
WE_I Write Signal
PORT_I/O Data and Address Bus
CS_I Chip Select Signal
Table 2.3 – List of Signals Used in the 8051 Bus
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 21
bus, and asserts the ALE_I signal. Assertion refers to driving a signal to a logic ’0’. The
slave devices then clock in the address into its register. Depending on the read or write
operation, the master then puts the PORT_I/O bus either in a high impedance state, or
loads the data onto the bus. At this time, either the RD_I or the WE_I is asserted.
This interface can be used on many different microcontrollers due to its simplicity, but due
to the address latching process the processor is slowed down while interfacing with other
devices.
2.4.3 AMBA
AMBA is an interface developed and patented by ARM Limited. The AMBA protocol is
an open standard which is used in the SoC development. When it was first developed in
1996, it consisted only of the Advanced System Bus (ASB) [53]. The ASB was used to
connect multiple processors and controllers on the same bus, while slower peripherals were
connected to the Advanced Peripheral Bus (APB). In revision 2 of the AMBA interface, the
AMBA High-Performance Bus (AHB) was introduced which replaced the ASB [54]. The
main change was the increase in speed of the AHB bus, which was now a single-edge protocol
[54]. This meant that interactions with the bus could take place in a single clock cycle.
Although AMBA has now reached revision 4.0, revision 2.0 will be applied in this project.
Microsemi’s Libero software uses both AMBA 2 and 3 in their designs, but for simplicity it
was decided to use AMBA 2.
The AHB bus can consist of multiple masters, multiple slaves, an arbiter and a decoder. To
ensure that only one master has control of the bus, the arbiter blocks all interactions from
other masters, once a master has initiated a transaction. To select which slave the master
is communicating with, the decoder decodes the address and selects the correct device. The
AHB bus is mainly used to connect high speed devices such as microcontrollers, memory
interfaces and Direct Memory Access (DMA) devices.
The APB bus consists of all the lower speed peripherals, and connects to the AHB via
a AHB-to-APB bridge. While memory and high speed controllers normally have a wide
addressing range, smaller and slower peripherals have a much narrower range. This allows
a single APB bus to be connected to a single address range on the AHB bus, with multiple
peripherals connected to the APB bus.
Both the AHB and APB buses consist of an address, data-in and data-out buses, as well
as several control signals. The address signal is automatically decoded to enable the slave
device, while a single write-not-read signal allows for the selection of read or write operations.
2.5 Simulation of SEEs
To simulate a Hardware Descriptive Language (HDL) file, a simulator is required. There are
several simulation packages available, such as: Verilog-XL, NCVerilog, VCS, Aldec, Finsim,
Icarus Verilog, ISE Simulator and Modelsim. Modelsim is bundled with Microsemi Libero
software and supports all Actel devices. During the design of a project using the Libero
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 22
software, the user can simulate the design at three stages in the design process: pre-synthesis,
post-synthesis and post-layout.
Pre-synthesis simulation simulates the basic functionality of the design, without taking any
delays into account. This is handy to confirm the logic behind the design. Post-synthesis
simulation adds an estimated delay to each gate generated by the synthesis of the design.
This helps to confirm time-critical functionality when delays are introduced to the system.
Post-layout adds more accurate delays to each gate, as well as delays in the routing of internal
connections. Post-layout simulation is the most accurate model of the final implementation
in hardware.
The simulation of SEEs involves injecting transients or upsets into the circuit during sim-
ulation. For SETs, this involves changing a wire’s value for a few hundred pico seconds.
For SEUs, the content of a register needs to be changed. When simulating SEEs, several
questions should be posed: What is the failure rate prediction and quantification? What is
the recovery time on failure? What is the difficulty of recovery? What is the difficulty of
system validation after mitigation [55]?
2.6 SEU Testing Using a Particle Beam
Radiation testing will be done at iThemba Laboratory for Accelerator Based Sciences
(LABS) using the A-Line scatter chamber as shown in Figure 2.10. The Separated Sector
Cyclotron (SSC) used at iThemba LABS is the most powerful accelerator in the southern
hemisphere [4]. It is used for proton and neutron therapy, as well as isotope production and
various other beams for nuclear physics research. The SSC is used to accelerate protons to
an energy of 200 MeV on Mondays and Fridays, and 66 MeV during the remainder of the
week [56].
Radiation testing involves the generation of high energy particles, such as heavy ions, protons
and neutrons, in a controlled environment. This is accomplished using the SSC which
accelerates the particles while under vacuum to increase the energy of the particles. Since
the SCS functions under vacuum, all the connecting channels and testing chambers should
be under vacuum. For this reason, the A-Line scatter chamber will be under vacuum when
testing for this project is done. The particles are then guided towards the Device Under
Test (DUT) using quadruple electromagnets. While protons and electrons are used for TID
testing, with Co-60 and X-Rays as the preferred irradiation source [57], protons and heavy
ions are used for SEE testing [58].
The number of generated particles passing through the DUT is measured in Ampere, and is
usually in the 1×10−9 A range. Since most protons are charged, using Coulomb’s constant,
the number of particles can be calculated. The current, when using a charged particle beam,
is measured through current measurement, but when neutral particles are used the capturing
sensors, like scintillation detectors, are used to count the particles, after which the current
can be calculated. During testing a proton beam will be used. For a proton beam, the
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 2. LITERATURE STUDY 23
Figure 2.10 – Floor plan of iThemba LABS’ Separated-Sector Cyclotron Facility [4]
current is measured and the particle count can be calculated. For a beam of 1nA, a total of
6, 242× 109 particles pass through the DUT each second as given by Equation 2.6.1.
N = I
Q
= 1× 10
−9
1.60217657× 10−19 = 6, 242× 10
9 (2.6.1)
At iThemba LABS, the beam cross-section is roughly 1 mm x 1 mm prior to the entry
point into the vacuum chamber, and can be defocussed (or focussed) using electro magnets.
Depending on the size of the die inside the DUT, the beam size should be changed to cover
the entire die.
Figure 2.11 – Illustration of Beam Defocussing
While a total of 6, 242 × 109 particles are entering the vacuum chamber, not all of these
particles will pass through the die. Some of these particles will miss the die because of the
difference in area between the die and the beam. Depending on the quality of the electro
magnets used in the facility, the shape of the defocussed beam can also vary.
Stellenbosch University  http://scholar.sun.ac.za
Chapter 3
Design
In this chapter, the partially successful attempt at translating the Verilog implementation
of the CAN controller to VHDL will be discussed. Following on, the CAN controller will
be dissected into functional units and analysed. The hardware required to test the CAN
controller will be designed. An overview of the changes to the CAN controller will be given,
followed by the design of the mitigation schemes. Finally, the final implementation and
testing of the design will be covered.
3.1 CAN controller Verilog to VHDL translation
The HDL implementation of the SJA1000 CAN controller was written in Verilog. Although
it is similar to VHDL, differences in the language result in different implementations. An
attempt was made to translate the CAN controller from Verilog to VHDL.
3.1.1 Motivation for Translation
Both Verilog and VHDL have their advantages and disadvantages, and which to use is
a personal preference. At the beginning of the project, the author was conversant with
VHDL only. It was desirable to obtain a VHDL implementation of a CAN controller, but
unfortunately most are protected by IP or are not completely functional. Currently, most
FPGA designs in this research group are based on VHDL.
After researching, a Verilog implementation of the SJA1000 CAN controller was found on
OpenCores.org. A VHDL translation of this CAN controller was also found in the LEON
Project by Gaisler Research. The LEON project is an open source project using the LEON
SPARC processor. The goal of the LEON project is to create a customizable VHDL processor
with sub-components. This design will also be radiation resistant and SEU free [59]. It was
decided to use this translation, and continue from there.
3.1.2 Problems
After analysing the files from the LEON project, the translation seemed to be intact. How-
ever, when attempting to use the VHDL version in a test-bench, the behaviour differed from
24
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 25
the Verilog version.
After closer inspection, it was found that several of the files had blocks of code that were
missing. Comparing it to the Verilog source revealed that all the missing blocks were sur-
rounded by IFDEF statements. IFDEF statements are used in Verilog to customize source
code to be compiled using predefined constants. Whereas this functionality is available in
Verilog, it is however not available in VHDL. Unlike Verilog, VHDL does not have a pre-
compiler which deals with the IFDEF statements. VHDL has a similar function, called
generate, which can generate components according to parameters. Unfortunately, it does
not have the same power as the IFDEF in Verilog.
Not knowing the full extent of the damage to the translation, it was decided to rather start
from scratch and since the VHDL does not have the IFDEF functionality, the customizability
of the Verilog version had to be sacrificed to translate it. This will result in the CAN
controller having a fixed interface, with the FIFO being implemented in the fabric of the
FPGA, rather than using internal or external SRAM.
During the translation, files were constantly compared to the Verilog version. Starting with
the smaller register files, the translation seemed easy enough as comparing both functionality
and the synthesis results seemed to match the Verilog version. But when it came to bigger
files such as the can_bsp, there were minor differences in the number of gates it used. There
seemed to be radical changes in design of the resulting circuit from Synthesis. The differences
in the resulting circuit raised concerns about internal differences, even though both Verilog
and VHDL functioned similarly.
Upon completion of the translation, there was roughly a 4% logic cell usage difference on
the 5500 logic cell design, with the resulting circuits differing functionally. These differences
were considered to be minor and simply the effect of the difference between the Verilog and
VHDL compilers.
Further testing of the translation again delivered undesirable results. When comparing
a specific block translation from Verilog to VHDL, the functionality and resulting circuit
matched. However, the bigger the file being translated, the bigger the differences in the
resulting circuit.
Finally, the translation was abandoned due to large discrepancies between the translations
which can be ascribed to the differences in the compilers. Attempts were made to use some
of Synopsis’ compiler directives to stop all optimizations, but with no success.
While the translation failed, much was learned from the translations. Translating each file
revealed extensive detail about the inner-workings and construction of the CAN controller,
as well as the differences and pros & cons of Verilog and VHDL.
3.2 SJA1000 CAN controller Breakdown
To understand the working of the SJA1000 CAN controller, it will be dissected down into
several small components, each with an important role in the functionality of the CAN
controller.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 26
3.2.1 Visual Breakdown
Figure 3.1 shows the functional breakdown of the CAN controller. The Bit Timing Logic
(BTL) interacts with the scaled clock and CAN bus, under control of the Bit Stream Pro-
cessor (BSP). The BSP uses data from the control registers and reports the status back to
the controlling device, while controlling the BTL.
Figure 3.1 – Functional Breakdown of the SJA1000 CAN Controller [5]
Figure 3.2 shows the hierarchical design of the Verilog files of the CAN controller.
Figure 3.2 – HDL Structural Design of the SJA1000 CAN Controller
The can_top file is the top level file of the CAN controller. This file declares the interface
between the CAN controller and the microprocessor. The can_top block is responsible for
latching in the address and data before writing or reading to or from the internal components.
It is also responsible for selecting when to read from the internal FIFO buffer or registers.
Finally, it also initiates all the sub-components.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 27
All the configuration registers are implemented in the can_registers block. There are three
types of registers: registers without reset, registers with an asynchronous reset and registers
with both asynchronous and synchronous resets.
According to the design, registers like the acceptance code and mask, transmit buffer, inter-
rupt enable and bus timing data should not change on reset. These registers are all instances
of can_register.
Registers such as the error warning register, mode register and clock divider registers, should
reset to fixed values in the event of a reset. This is to reset the CAN controller into a known
state when the reset occurred. These registers are all instances of can_register_asyn.
The command register and the least significant bit of the mode register need to be changed
not only on an incoming reset, but also due to certain conditions in the CAN controller.
The command register should be cleared as soon as the command is executed, and in the
event of an error, the mode register should reset the CAN controller into a reset mode. To
do this, can_register_asyn_syn. is used.
The three types of registers are all generic register files which require one or two parameters
when they are instantiated: The width specifies the number of bytes required by the register,
and the Reset Value specifies the value to which the register should reset.
Not only does can_registers house all the registers, it also generates an external clock for
lower clock devices, generates an interrupt signal from signals coming in from other sub-
components and multiplexes data when a read is requested.
The can_btl block contains the bit timing logic from Figure 3.1. The timing logic scales
down the input clock to the value required when sampling data by the Baud Rate Pre-scaler
(BRP). Equation 3.2.1 is used to scale down the clock frequency to the appropriate bus
frequency.
fscl =
fCLK
2(BRP + 1) (3.2.1)
Each bit of a CAN message consists of three timing sections. Firstly, there is a synchroniza-
tion segment, which is used to synchronize phase shifts between CAN controllers. The phase
shift is the result of unmatched clock signals from different areas of the CAN network. The
second is timing segment 1. This is the delay until the bit should be sampled. It is followed
by timing segment 2 which is the time lapsed until the end of the current bit transmission.
The timing of these three sections are calculated using Equation 3.2.2 to 3.2.4
tSY NCSEG =
1
fscl
(3.2.2)
tTSEG1 =
TSEG1 + 1
fscl
(3.2.3)
tTSEG2 =
TSEG2 + 1
fscl
(3.2.4)
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 28
The baud rate of the CAN bus can be calculated by adding these sections together.
fbus =
1
tSY NCSEG + tTSEG1 + tTSEG2
(3.2.5)
fbus =
fCLK
(3 + TSEG1 + TSEG2)· 2· (BRP + 1) (3.2.6)
For a clock input of 20 MHz and a desired bus frequency of 125 kbps, the BRP value should
be 7, TSEG1 = 2 and TSEG2 = 5. Refer to Equation 3.2.7
fbus =
20MHz
(3 + 2 + 5)· 2· (7 + 1) = 125kbps (3.2.7)
Together with the above information and input states from the bit stream processor, the
can_btl samples bits from the CAN bus, and sends them to the can_bsp for processing.
The can_bsp block contains the bit stream processor seen in Figure 3.1. The bit stream
processor uses the output from the bit timing logic in combination with an internal state
machine, to process the bit stream. The state machine is used to determine which bit to
sample next in the can message, as well as which bit to send next from the transmit buffer.
The can_bsp block also initiates the acceptance filter, which is used to determine whether an
incoming message is meant for the specific controller. The can_acf block contains sequential
logic to determine which filtering technique to use, and generates an id_ok signal to allow
the message to be received or ignored.
The can_fifo block is also initiated in the BSP. The FIFO buffer initialises the memory
required to implement the FIFO buffer. The user has the option to choose between device
specific RAM modules or implementing the FIFO in FPGA fabric. Using RAM modules
reduces the required FPGA fabric and can increase the maximum frequency of the device.
The can_bsp block manages data flow between itself, can_top and can_fifo, as well as
generating all the errors and error counters for user debugging.
The interconnection of the sub-components forms a rather complex nest of wires not easily
representable on paper. When implementing mitigation most of these connections will be
severed to allow the required mitigation logic to be inserted.
3.2.2 Registers and Sequential Logic
After synthesis, the CAN controller used a total of 1 497 D-flip-flops and 3 694 sequential
logic elements. Using Table 3.1, the exact usage of each component can be calculated.
Depending on the nature of each component, the appropriate mitigation techniques could
be inserted.
From the breakdown in Table 3.1, each sub-component can be analysed in terms of com-
plexity, logic types and susceptibility to SEEs.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 29
Module name and unit count Register
count
Logic
Count
I/O
Count
Max Freq
can_top 1 497 3 694 19 55.8 MHz
1x can_bsp 1 190 2 821 287 57 MHz
1x can_acf 1 195 123 NA
1x can_crc 15 37 19 177.4 MHz
1x can_fifo 879 1 251 37 72.7 MHz
3x can_ibo 0 0 16 NA
1x can_btl 30 155 36 101.0 MHz
1x can_registers 242 660 291 117.4 MHz
200x can_register 1 0 4 NA
20x can_register_asyn 1 0 5 NA
6x can_register_asyn_syn 1 2 6 NA
Table 3.1 – Breakdown of FPGA Usage of the Original CAN Controller Post-Synthesis
1. can_acf
The Acceptance Filter (ACF) contains only 1 register to latch the id_ok signal. The
high logic count makes it susceptible to SETs that could be converted to SEUs if
latched into the register.
2. can_crc
The CRC module is relatively small, but performs a crucial function. The low register
and logic count makes it susceptible to both SETs and SEUs.
3. can_fifo
The FIFO contains most of the registers in the design as it used to store incoming
data the FPGA fabric. The FIFO’s high count of both registers and logic units makes
it susceptible to both SEUs and SETs.
4. can_ibo
The Bit Order Inverters (IBO) used contains no logic units and is used as routing
block to rotate the bit order from 0 - 8 to 8 - 0. It does not pose any risk to SETs and
SEUs.
5. can_bsp
The BSP itself contains a few registers with mainly sequential logic. Most logic units
of any of the components are contained herein and is susceptible to both SEUs and
SETs.
6. can_btl
The BTL consists of a few registers and some sequential logic. It is susceptible to both
SEUs and SETs.
7. can_registers
The registers module consists of mostly sequential logic with the registers being located
in individual files. The registers themselves are susceptible to SEUs. The sequential
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 30
logic is mainly used to generate the write enable signals for registers and is susceptible
to SETs only.
3.3 Hardware Design
To test the resistance to SEEs of the design, it had to be programmed into an FPGA and
then be radiated. While there are development kits available, the layout and construction
of these kits make them less than ideal for the use in radiation testing. For testing to deliver
useful data, the FPGA containing the design needed to be isolated from other hardware. A
custom testing PCB had to be developed that suited the needs of this project.
A fellow student, Fancois Nolte, also worked on a similar project. His goal was to implement
a radiation resistant soft-core processor in an FPGA, applying similar mitigation techniques
to those in this project. To save cost and development time on both projects, a hardware
collaboration was suggested. The distribution of the workload is discussed in Appendix A.
3.3.1 Hardware Requirements
Before the hardware design process could commence, all hardware requirements had to be
listed.
3.3.1.1 Device Under Test
The DUT is an FPGA which will be radiated using a particle beam to simulate the space
radiation environment. It should support both designs, but not simultaneously.
After synthesis of the CAN controller, it used roughly 5 200 logic units of FPGA fabric. To
implement full TMR would typically triple the device usage, and add extra overhead for the
voting logic. Therefore, an FPGA with a minimum of 16 000 logic units should be enough.
Francois’s design consisted of an OpenRisc soft-core processor, as found at OpenCores.org.
Unmitigated, it consisted of roughly 15 000 logic units. While a full TMR would be ideal, it
would not be viable as all components needed to be triplicated, including memory. Instead,
a limit of 35 000 logic units was put on his design.
Production capabilities also had to be kept in mind when performing device selection. While
Ball Grid Array (BGA) devices have a small footprint, debugging them using probes can be
difficult as opposed to Quad Flat Pack (QFP) devices. When soldering BGA devices, the
only way to confirm a solid connection on each pad, is to perform an X-ray analysis on the
device. A report by NASA [60] documents the proper procedure to use BGAs in a space
environment. One of the many factors that make BGAs so hard to mount, is the lifetime
of the joints between the device and the PCB. Due to expanding and contraction of the
PCB due to extreme temperature fluctuations, the joints are subjected high levels of stress.
These stresses eventually lead to a failure on either the device or the PCB.
Since this PCB is only a prototype, a QFP package will be used. This will facilitate easier
soldering and debugging.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 31
To accommodate both designs, the Microsemi ProAsic3E 1500 (A3PE1500) [61] device was
selected, since it also offers a QFP package. It offers a total of 38 400 logic units, which
is sufficient for the OpenRisc soft-core processor and extra interfacing logic. Since multiple
designs will be programmed to the FPGA, the re-programmability of this FPGA is a ne-
cessity. It offers both projects a familiar developing environment, as it is the same as the
Actel Fusion development kit’s environment. The same FPGA is also used in one of the
OpenRisc development kits and sample designs could be downloaded from the OpenRisc
website and adapted for this hardware setup. The FPGA is also based on flash technology,
which is more resistant to upsets than SRAM based technology. These devices are avail-
able from Asic Design Services, a local supplier, with whom this research group has a good
partnership.
3.3.1.2 DUT Assisting Hardware
For either designs to operate effectively, several external hardware components are required.
For the CAN controller to be able to communicate with other CAN devices, a transceiver
is required. This changes the signals from transistor-transistor logic (TTL) to a differential
voltage signal. The voltage level of this signal is determined by the highest voltage device
on the bus and can rise to 42V in both directions. For this design, the SN65HVD233 CAN
Transceiver [62] from Texas Instruments was chosen.
Since the FPGA size is more than double that of a full TMR CAN controller, it is desirable
to run two CAN controllers in the same design, allowing more SEEs to manifest. Since more
than one CAN controller will be used, it was opted to use two transceivers.
In order for the OpenRisc soft-core processor to function, it required both SDRAM and
SPI Flash components. Due to the popularity of the OpenRisc project, several hardware
platforms have already been developed as development kits for the project. Co-incidentally
the same FPGA was used in one of these boards. This development kit uses an AMIC
A43L4616AV-7F SDRAM IC [63], along with the Micron M25P10-AVMN6P [64] SPI Flash
IC. Since only the FPGA is going to be radiated, the use of components without space
heritage was acceptable.
3.3.1.3 Controller
At the Electronic Systems Laboratory (ESL), access to the Actel Fusion Embedded devel-
opment kit is possible. This kit consists of a Fusion FPGA, external SRAM and other
peripherals.
During the course of this project, the web-server example project was used to test the CAN
controller. The FPGA was Cortex-M1 enabled and it was used as the soft-core processor
in the design. The Cortex-M1 served as a web-server, transmitting data over an Ethernet
port. It sampled data from the analogue block of the FPGA, and delivered it in the form
of a web-page. See Figure 3.3 for a block diagram showing the IP cores used to implement
the web-server example in the Fusion development kit.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 32
Figure 3.3 – Block Diagram Showing the IP Cores of Web-Server Implementation in the
Fusion Development Kit
To save time on the designing of hardware, it was opted to use the Cortex-M1 processor
as the interface controller between the computer and the DUT. Several Cortex-M1 enabled
FPGAs can be found in Microsemi’s catalogue. Unfortunately, the local supplier has a
minimum order quantity of 20 units on all FPGAs. For this reason, it was decided to use
the same FPGA as for the DUT, and both will be Cortex-M1 enabled. The Cortex-M1 will
not be used on the DUT since no processing power is required.
3.3.1.4 Controller Assisting Hardware
Since the ProAsic3E FPGA does not have an analogue block or internal flash memory,
external memory and ADCs are required for application memory storage and the sampling
of voltages and currents on the PCB.
The support software for the FPGA offers a flexible interface between the Cortex-M1 and its
external memory. This interface consists of 32 data bits and 19 addressing bits. Most SRAM
and flash chips only have 8 or 16 bit data configurations. To accomplish the required 32 bits,
2 ICs were used in parallel. The IDT IDT71V416L10PHGI [65] was used for the SRAM
and Micron M29W160EB70N6F [66] for the flash memory, since these were immediately
available from a local supplier.
While serial communication would suffice for basic data collection, a higher transfer rate
would be more desirable. One of the useful features of the Fusion development kit, is the
10/100 Ethernet interface. The web-server example also uses this interface to communicate
with a computer. The schematics of the required components to implement the Ethernet
interface can be found on the freely available schematics of the Fusion development kit.
The implementation of the Ethernet interface requires an Ethernet Physical Layer (PHY)
IC, which is available from several suppliers. For this design, the DP83848 [67] from Texas
Instruments was chosen.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 33
3.3.1.5 General hardware accessories
During testing, the health of the hardware should be monitored to ensure the correct oper-
ation of all components on the PCB. It would therefore be beneficial to have both current
and voltage monitoring available on the board. This data would be fed into the controller,
which will then report back to the computer for data logging. The current will be measured
using an INA169 Current Shunt Monitor [68], which will be sampled by a MAX1038 ADC
[69].
Damage to the FPGA due to radiation, can show up in several ways. Latch-ups and physical
damage to the FPGA will result in higher power consumption. While it might be noticeable
on the current monitor, the device could also heat up. It would therefore also be useful
to have temperature monitoring on the board. The temperature will be sampled using a
AT30TS75 Digital Temperature Sensor [70]. Two of these sensors are to be placed on the
board: one below the power supply and another between the two FPGAs.
If there is an indication of a fault in the FPGA itself, it would be beneficial to be able
to power cycle the DUT, without having to enter the radiation test chamber. Therefore,
separate power supplies will be used for both the controller and the DUT. The controller
will then be able to switch off the supply to the DUT using voltage switches in the power
supply.
3.3.1.6 Limitations of the Layout
It should be noted that during the radiation experiments, only the device under test is
radiated. To protect the other components, a keep-out zone needs to be placed around the
FPGA.
The radiation beam will be perpendicular to the PCB surface and pass through both PCB
and components. To obtain accurate results, only the FPGA should be in the path of
the beam. Passive components, such as headers, capacitors and resistors are allowed to be
radiated, since upsets are not expected in these components. A report on the effects of
radiation on capacitors and resistors showed that capacitors will have a drop of about 10%
in its capacitance after 345 kGy, while resistors did not show any change below 1 MHz [71].
A two-layer limitation was also placed on the PCB to save on production cost. There should
also be several test points for debugging with big ground pads for the probes to connect to.
3.3.1.7 Component Selection for Vacuum Environment
Not all components on a PCB function correctly in vacuum. These include, but are not
limited to, electrolytic capacitors and light emitting diodes (LED).
Electrolytic capacitors consist of two layers which are isolated from one another, and then
rolled up to form a large capacitive layer. For aluminium capacitors, the aluminium foil is
coated in an insulating oxide layer, which forms the capacitor. If a small air pocket exists in
the rolled up foil, the difference in air pressure could lead to the expansion of the size of the
air pocket. In other designs, a liquid is used to create a better capacitance to volume ratio.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 34
When placing these in a vacuum, the liquid can start to boil. In both cases, a decrease in
capacitance can be expected, or even a total physical or functional failure.
To avoid these risks, all capacitors should be either ceramic or tantalum capacitors. Normal
small value capacitors are made from several layers of metal which are isolated with a
ceramic material to form the capacitor. Tantalum capacitors consist of a small ball of
tantalum, which is covered in an oxide layer to isolate it from the surrounding conducting
material. Tantalum capacitors offer higher capacitance than ceramic capacitors, but are also
more expensive and larger in size.
The bodies of LEDs are made out of an epoxy to form the lens. Impurities and minute air
bubbles in the epoxy can pose a threat in a vacuum environment. Similar to electrolytic
capacitors, the difference in pressure can cause the epoxy to form cracks due to the expansion
of these bubbles which can lead to device failure as a result of movement close to the
substrate.
The LEDs are a luxury during debugging and do not add a functional purpose to the PCB.
The fact that the content of the chamber is barely visible through a web-cam means that
the LEDs will not be of any assistance during testing. To avoid the problem of failure of
the LEDs damaging other circuits, the LEDs will be placed on removable PCBs which can
be removed prior to radiation testing.
3.3.1.8 Testing Chamber
The tank in which testing will be done consists of a vacuum chamber, two mechanical arms
and several holes for custom connectors.
Figure 3.4 – Image Showing Detail of a Vacuum Connector and the Inside of the Scattering
Chamber
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 35
To obtain optimum results, the radiation beam will be defocused, as to cover the entire die
of the FPGA. While the exact size of the die is not known (due to intellectual property by
Microsemi), the beam will be defocused to cover most of the chip, while not touching the
other components. The hardware will be placed on one of the two mechanical arms, as to
move it in and out of the beam. The other arm will be used to hold a calibration disc to
help with the defocussing of the beam. As a safety precaution, all cables to and from the
board, will be long enough to reach from the hardware, to the centre of the tank, and then
to the sidewall. This is to avoid damage from the movement of the arms.
The sidewall has holes with a diameter of 95mm to house a custom connection plug to
connect internal to external cables. This plug should be populated with vacuum rated panel
mount connectors. From the hardware design, we need several connections. An Ethernet
to USB hub will be placed inside the tank, providing 4 USB connections. Two will be used
for the FlashPro programmers, one for serial communication with the DUT and one for a
moving platform. Table 3.2 lists the proposed connectors to be used.
Connection Proposed Connector Description
Ethernet DB9 Communication with hardware
Power Coaxial 5V supply for the hardware
Ethernet DB9 Communication with Ethernet to USB hub
CAN DB9 Monitoring of CAN bus
Table 3.2 – List of Connections to the Hardware
To monitor the hardware visually, an Ethernet web-cam will be placed above the beam entry
point into the tank. Looking through a clear Perspex window, any damage to the hardware
or cables can be observed remotely via the web-cam.
A power supply will be placed outside the tank to provide the required 5V for the hardware.
The power supply and Ethernet to USB hub will be shielded using a brass block.
For safety purposes the control room is located far from the test chamber. The only con-
nections available between the two are an Ethernet cable, a 220V AC power line and several
coaxial connections. Since there are more Ethernet devices than cables, a network switch
will also be required next to the tank.
3.3.1.9 Control Room
Due to the distance between testing chamber and the control room, the stability of the
Ethernet connection could be questionable. To overcome this, a second switch will be
located in the test chamber to re-condition the signals.
The control room plays host to all the required components to manipulate the radiation
beam, vacuum and arm movements inside the tank. Besides the already in position com-
ponents, two additional computing stations will also be required. One of these will be used
to manipulate the moving platform on which the hardware is mounted and to monitor the
web-cam, the other will be used to interface with the DUT.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 36
3.3.2 Summary of Requirements
From the previous sections, a complete list of the hardware requirements can now be com-
piled and is shown in Table 3.3. Combining these requirements, along with the controlling
FPGA and DUT FPGA designs, a system diagram can be constructed and is shown in
Figure 3.5.
PCB Rationale
Keep out area Only DUT to be radiated
2-layer PCB Cost saving
Test points Probing of trace signals
PCB - controller
2x SRAM ICs 32-bit wide program memory for Cortex-M1
2x FLASH ICs 32-bit wide code memory for Cortex-M1
Ethernet PHY IC Communication between Cortex-M1 and computer
I2C ADC Monitoring of current and voltages
I2C Temperature Sensors Monitoring of PCB temperatures
Voltage switches Power cycle of DUT
PCB - DUT
SDRAM IC 16-bit wide program memory for OpenRisc
SPI FLASH IC 8-bit wide code memory for OpenRisc
2x CAN transceiver ICs Communication between CAN controller and CAN Bus
GPIO header Testing of OpenRisc
SPI header External Programming of SPI Flash
Separate power supply Power Cycle of DUT by controller
Test Chamber
Power supply To supply power to testing hardware
Ethernet switch Switching of Ethernet signals
Ethernet web-cam Remote visual monitoring of hardware
Ethernet to USB hub Remotely control USB devices
2x FlashPro Programmers Programming of FPGAs
Control Room
Ethernet switch Reconditioning of Ethernet signals
2x laptops Control of testing hardware
Table 3.3 – List of Hardware Requirements
3.3.3 Top Level design
Figure 3.6 shows a diagram of the test environment. Based on the design above and the
hardware requirements listed in Table 3.3, the PCB was designed. Figures B.1 to B.10 in
Appendix B show schematics of the experimental PCB, while Figure B.13 shows schematics
of the quad channel UART daughter-board.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 37
Figure 3.5 – Diagram of the Top Level Design of the Experimental PCB
Figure 3.6 – Diagram of the Complete Test Environment
3.4 Modifications to Original CAN controller
The original Verilog implementation of the CAN controller needed certain adjustments to
make it usable for this project. This required a change in the interface, as well as a re-
arrangement to make it more editable.
3.4.1 Interface
The original version of the CAN controller, as found on OpenCores.org, is easily customizable
using parameters in one of the source files. One of these options is to select which interface
the user wants to use to interface with the CAN controller. The available interfaces are
limited to the Wishbone Interconnect and the 8051 interface. To ensure a stable design, the
design was based on a Cortex-M1 soft-core processor. Unfortunately, the Cortex-M1 does
not have access to either of these interfaces.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 38
It is possible to use the GPIO IP Core and bit-bang to the CAN controller, but this would
involve extensive coding and would have added a big strain on Cortex M1. For this reason,
an AMBA interface was added to the design. Table 3.4 lists the connections used by both
the AMBA interface and the external interface of the CAN controller.
AMBA CAN controller Description
PADDR addr Addressing signals
PWRITE we Write not Read signal
PSEL cs Device Select signal
PENABLE Device Enable signal
PWDATA data_in Master to Slave data
PRDATA data_out Slave to Master data
Table 3.4 – List of Connections for AMBA Master to CAN controller
The implementation of the APB bus has a data input signal for every sub-module. This
allows the CAN controller to output data constantly on its data output pin. The CAN
controller only reads data from its input pins on the rising clock edge, if both the Write
Not Read (WE) and Device Select (CS) signals are high. The APB bus pulls both CS and
WE high one clock cycle before pulling the Enable pin high. The missing Enable pin on
the CAN controller is important to the design, as without it, the CAN controller will clock
in the same data twice, causing the CAN controller to perform certain tasks twice, such as
releasing the received data buffer. To avoid this problem, the PENABLE pin can simply
replace the PSEL signal on the CS pin on the CAN controller.
3.4.2 Flattening of the CAN controller Tree
Two problems became evident when studying the CAN controller hierarchy. If the BSP or
registers module is protected using TMR, all of the lower modules will also be triplicated.
This is problematic as any protection on the lowest module will also be triplicated. If both
the FIFO buffer and the BSP are protected using TMR, the FIFO buffer will in effect be
replicated 9 times.
Similarly, all of the configuration registers as well as the transmit buffer are implemented us-
ing three single generic files, can_register_asyn_syn, can_register_asyn, can_register.
Editing one of the registers would result in all the other registers using the same file to be
altered.
It was for these two reasons that the design of the CAN controller was flattened out so that
all instances of all files are instantiated in the top level of the design.
3.5 Mitigation Schemes
To make a CAN controller, utilizing mitigation by design, more viable for implementation
in an FPGA, the area usage of the circuit should be as low as possible. Using full TMR
uses three times the area of the original design excluding the voting logic required. For
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 39
this reason, several techniques will be combined to lower the footprint of the device, yet
maintaining a high resistance to upsets.
3.5.1 SET Filter
The entire idea behind the SET filter is to avoid Single Event Transients latching into a
memory element and becoming a Single Event Upset. Therefore, the ideal place for the SET
filter is prior to a memory element. The filter should not only be placed before the data
input, but also in front of all the enable signals of the memory element.
To determine where the SET filters should be placed, the net-list should be analysed to
determine the number of gates prior to the input pins, as well as the longest route to a
previous memory element or FPGA input pin.
The longest route will assist to give an idea of the impact the specific SET filter will have
on the maximum attainable clock frequency of the design. If one inserts the SET filter on
the longest paths, it may slow down the design.
The number of gates prior to a specific memory element will show the likelihood of an upset
in this region. The more gates there are the more probable it will be that an upset will occur.
If the SET filter is inserted in front of a pin with few elements prior to it, it actually increases
the overall likelihood of a SET occurring. If there is a fifty-fifty relationship between the
SET filter gate count and the number of gates prior to the input pin, there is a 50 percent
chance of the SET actually occurring in the filter itself. While the SET filter can filter SETs
in previous elements, it is not able to fully filter out SETs inside itself.
3.5.2 TMR
Triple modular redundancy will be implemented on two different levels in this design.
Firstly, at gate level. For this technique, TMR will be applied to the memory elements and
sequential logic. This will mostly be applied to memory elements as an upset will most
likely remain in the system, if it occurred in a memory element.
Figure 3.7 shows a simple triple module redundancy D Flip Flop (DFF). In the figure, all
inputs are connected to matching ports of the DFF. Outputs are connected to a majority
voter. The majority voting can be done in Microsemi FPGAs using a single versatile using
the MAJ3 macro.
To detect when an error has occurred, the three outputs can be combined using an XOR
gate, which will only output a logic ’1’ when the inputs are not the same value. To recover
from an error, the error signal is combined with the input enable pin. A logic ’1’ on either
of these pins will force the DFF to clock in data. The write enable pin is used as a data
select signal. If the write enable pin is low, data will be fed back from the output of the
majority voter. If the write enable pin is high, new data is about to be clocked in. This will
enable recovery, unless new data is to be clocked in. Figure 3.8 shows this implementation.
To use the above method on an 8 bit register, each bit is approached as a single register.
Each bit will have its own triplicated DFFs, majority voters and data MUX. To detect an
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 40
Figure 3.7 – Diagram of the Traditional TMR
error, all the error signals are combined using OR gates. If any of the bits are corrupt, all
the bits will be re-written. This uses fewer gates than re-writing individual bits, since the
eight bits share the same enable line.
Figure 3.8 – Diagram of the Single Bit TMR With Recovery
Most of the registers being protected using TMR and recovery are not on the critical path.
The addition of the MUX at the data input and the majority voter at the output should
not have a noticeable effect on the maximum operating frequency.
For sub-modules being protected using TMR, only the majority voter at the output can
affect the maximum operating frequency. The single majority voter should add a single
ignorable delay.
3.5.3 EDAC using Hamming Code
Implementing the Hamming code’s parity checks in hardware as per §2.1.3.4 can be done
by using XOR-gates, as shown in Equations 3.5.1 to 3.5.4.
p0 = {d0 ⊕ {d1 ⊕ {d3 ⊕ {d4 ⊕ d6}}}} (3.5.1)
p1 = {d0 ⊕ {d2 ⊕ {d3 ⊕ {d5 ⊕ d6}}}} (3.5.2)
p2 = {d1 ⊕ {d2 ⊕ {d3 ⊕ d7}}} (3.5.3)
p3 = {d4 ⊕ {d5 ⊕ {d6 ⊕ d7}}} (3.5.4)
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 41
For an eight bit data byte, a total of 14 XOR-gates are required to implement the Hamming
code encoding, as shown in Figure 3.9. The Hamming Code word is produced by routing
the data bits and parity bits to the correct position.
Figure 3.9 – Diagram of the Hamming Code Encoder’s Parity Calculator
In order for the decoder to calculate which bit was upset, the parity bits first need to be
recalculated. Comparing the new parity bits to the stored ones will give the corresponding
position of the faulty bit, as shown in Figure 3.10. In the event that a data bit is flipped, the
flip can be repaired using an XOR-gate. Using AND gates with inverted inputs, the exact
combination of position bits will result in the faulty bit being flipped, as shown in Figure
3.11.
Figure 3.10 – Diagram of the Hamming Code Decoder’s Wrong Bit Identification
To implement the decoder for an eight bit data type, a second encoder is required to recal-
culate the parity bits, along with 28 more gates. This results in a total of 42 gates for the
decoder.
3.5.4 Mitigation Scheme Design
Following the analysis of the CAN controller in §3.2 and weighing the effects of different
mitigation techniques on the original circuit, a combination of mitigation schemes were
applied to different parts of the CAN controller.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 42
Figure 3.11 – Diagram of the Hamming Code Decoder’s Bit Flip Mechanism
3.5.4.1 CAN TOP
The can_top file mainly consists of the instantiation of all the sub-modules, but also declares
the connections to the controller. For this project, the CAN controller is not located on the
same FPGA as the processor. The traces, I/O pins and I/O buffers are all susceptible to
upsets. All I/Os to the CAN controller will therefore be protected with SET filters.
3.5.4.2 CAN BSP
The can_bsp file is the core of the CAN controller. This file contains the state machine for
sampling the data and error generation. Due to the high importance of the state machine,
this BSP module will be protected using TMR. While a full TMR of the BSP module is suf-
ficient, it is possible for all three state machines to break. The possibility of interconnecting
the state machine should also be investigated.
3.5.4.3 CAN FIFO
The can_fifo file consists of three FIFO buffers, each 64 bytes in length. Due to their large
size, neither DMR nor TMR is appropriate. The can_fifo file makes up roughly 40% of
the CAN controller. Data inside the FIFO buffer will remain constant for long periods of
time and are not crucial to the functionality of the CAN controller. While the controller
should not let the data sit in the FIFO buffer for a long time, it should be kept safe. Using
Hamming code, the data bytes and information nibbles will be protected against single bit
upsets. Should an upset occur between the time a message is received, and the FIFO is
serviced, a single bit per byte can still be repaired. The repair occurs during the read clock
cycle and since there is no other sequential logic between the register output and the output
MUX, the delay added should be minimal. The data buffer will be protected using Hamming
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 43
code {12, 8}, while the information buffer will be protected using Hamming code {9, 5}.
3.5.4.4 CAN CRC
The can_crc file consists of a CRC encoding module, which is used to check whether the
data received is valid. As it only consists of 52 logic cells, while having a important function,
it will be protected using TMR.
3.5.4.5 CAN ACF
The can_acf file consists of several combination logic cells, converging into a single output.
It is possible to protect this section with a single SET Filter.
3.5.4.6 CAN BTL
The can_btl file consists of all the logic required for synchronizing and sampling the CAN
bus. It amounts to 192 logic cells, but is one of the most important components of the design
and needs superior protection. Since the BTL is a time critical circuit, it will be protected
using TMR to avoid any timing issues.
3.5.4.7 CAN Registers
The can_registers component consists of mainly long-term configuration registers, with a
few short term registers. Most of the short term registers pertain to the generation of an
interrupt. Reading the interrupt register will release the interrupt. In the event of an upset
in the interrupt register, investigation by the processor should show that it was incorrect and
that it can be ignored. While a misplaced interrupt will not interfere with the functionality
of the device, it will cause some overhead in the processor, as the processor needs to check
the source of the interrupt.
The long term registers should remain fixed at all times during operation. A single upset
to the bus timing will result in the CAN controller going out of sync. Once out of sync,
it will miss all the messages and another device could hold the CAN bus in a busy state.
Therefore, the long term registers should be protected.
The following registers will be protected using full TMR with recovery:
Acceptance Code 0 to 3 - Important for message accepting
Acceptance Mask 0 to 3 - Important for message accepting
Bus timing 0 and 1 - Important for BTL
Clock divider bit 7 - Basic/Extended mode selection
Error warning - Exceeding error count can put device in reset
Interrupt enable - Missed interrupts can flood device
Mode - Reset device etc.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 44
The following registers will not be protected:
Clock divider lower bits - The external clock generation is not important in
the FPGA environment. For the SJA1000 IC, the
external clock can be used to drive slower
peripherals. Scaling down the FPGA clock can
easily be done using the internal
Phase-Locked-Loops (PLLs) of the FPGA.
Command - Since it will be cleared within the following few clock cycles
Transmission data - Since the controller should not store the data for a long
time before transmitting
Full TMR and recovery as in §3.5.2 will allow the protected registers to be reconfigured if
an error is detected.
3.6 Final Implementation
Applying the mitigation schemes to the CAN controller will undoubtedly increase the foot-
print of the design. To make the solution viable, the area usage on the PCB needs to be as
small as possible to replace a separate CAN controller with an FPGA.
3.6.1 Logic Cells Required
It is not only important that the CAN controller fits on the FPGA, but some control logic
should also be added. An estimation of the area usage of the CAN controller is roughly
200% of the original, the usage is expected to be roughly 11 000 logic cells. To communicate
with the CAN controller using a microprocessor, an interface needs to be implemented. If
the CAN controller is used to connect a sensor to the CAN bus, a state machine needs to
be implemented which can initialise and control the CAN controller and interface with the
sensor. A rough target for the CAN controller and control logic would be around 15 000
logic cells.
3.6.2 Possible FPGAs
Possible FPGAs to consider when implementing the mitigated CAN controller in a final
satellite system design include the Actel Igloo/e, Igloo 2 and ProASIC3 range of FPGAs.
All of these FPGAs are flash-based and include the basic required physical attributes to
implement the CAN controller.
In the Igloo/e range of FPGAs, the smallest footprint possible for an FPGA with enough
logic cells is the FG144. This footprint is a BGA of 12 x 12 pins requiring a total of 13
mm x 13 mm of area on the board. The M1/AGL600 has 13 824 logic cells, which will fit
a minimalistic design. The M1/AGL1000 has 24 576 logic cells, which will accommodate a
CAN controller and controlling logic comfortably.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 45
In the new Igloo 2 range of FPGAs, the smallest footprint is the VF400. This is a pinned
packaged requiring 17 mm x 17 mm of PCB area. The M2GL025 has 27 696 logic cells.
Microsemi is currently developing a smaller form factor package and they are aiming at sub
14 mm x 14 mm PCB footprints.
Other possible devices include the ProASIC3 A3P1000 or A3P1000L. Both these devices
offer a total of 24 576 logic cells, on a FG144 footprint. The ProASIC range of FPGAs do
however use more power, but can attain a much higher operating frequency.
While the maximum frequency for the original CAN controller is roughly 55 MHz in a
ProASIC3E A3PE1500 FPGA, the mitigated design will undoubtedly be slower. Imple-
menting the same design in the Igloo AGL1000 FPGA results in the maximum frequency
dropping to roughly 38 MHz. In this design the clock frequency used will be 20 MHz. If the
Igloo is to be used, the maximum frequency of the CAN controller after mitigation could
fall below the clock input. This will result in unpredictable behaviour.
3.7 Testing the Design
There are various ways to test for SEUs. This section covers the design of the tests as to
detect SEUs in as many areas of the CAN controller as possible.
3.7.1 Radiation Testing
Ideally, all the testing will be done inside a radiation chamber using the designed hardware.
Two boards will be manufactured: one for this project and another for Francois’ project.
Although two boards are available, the time it takes to replace the board in the vacuum tank
is too long and is therefore the last resort. After a round of test for this project, Francois
will reprogram the board to suit his tests.
Each project will have it’s own individually developed testing software. The software for this
project will be written in C using QT Creator. This application will utilize the Ethernet
connection to control the soft-core microprocessor and query the CAN controllers. The
following sections will describe the two test designs proposed.
3.7.1.1 Configuration Hold Test
In this test, all writable registers will be given a known bit pattern. All readable registers will
be read periodically, storing the values for both future analysis and comparison to the next
read value. In the event of sequential values having different values, an error has occurred.
3.7.1.2 Operation Test
In this test, all CAN controllers will be set to extended mode and will conduct normal com-
munication. All devices will send and receive messages of random lengths containing random
data, while monitoring all configuration registers and error registers for abnormalities, which
will indicate radiation induced errors.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 46
3.7.2 Simulated Testing
At a late stage in the project, beam scheduling changes and test set-up problems occurred
resulting in radiation testing being delayed to close to the submission deadline. As a pre-
caution, it was decided to focus more on simulated testing, specifically including detailed
error injection simulations.
3.7.2.1 Injecting SEEs
The simplest way to inject SETs into the design is using the simulation test-bench. Using the
design hierarchy, sub-modules’ wires and registers can be accessed and manipulated inside
the test-bench. Out of previous experience, this method of injecting only works during pre-
synthesis simulation. All simulation needs to be done at least post synthesis, but ideally
post layout.
When running a design pre-synthesis, no timing information is available. The Verilog is
translated into a functional model, and all simulated signals are based on this model. With
post synthesis, the Verilog is translated into physical elements. The delay for each element
is known and can therefore be used in the simulation. This allows the simulation to show
whether or not the design will have timing issues, depending on the maximum frequency
at which the design can be run at. Post layout takes this one step further. After layout,
the software calculates the length of each trace used inside the FPGA, and adds the delays
accordingly. It also adds delays for routing elements. When all this information is available,
the simulations are an accurate representation of what should be happening in the FPGA
after programming. The only factor that cannot be included is the die quality. The way the
software compensates for this, is to have the user select which grade device he wants to use.
For the selectable grades, the worst case timing delays are used in the simulation.
The other method of injecting faults is using the run.do file generated for the simulation.
It is essentially a list of commands which is sent to the simulating software. Using the
commands listed in Listing 3.1 prior to it calling run -all, will force the simulation into
performing tasks which are not possible through the test-bench. 
1 force [-cancel [@]<time\_info >]
<signal\_name > <signal\_value > <time\_info >
add wave <signal\_name > 
Listing 3.1 – Possible commands for run.do
Using force, the value of any register or wire can be forcefully changed at a specific time.
The forced value remains until the noforce command is performed. If a -cancel parameter is
defined, the force command will expire after the given time [72]. Using add wave, only the
signals required by the user can be added to the simulation window [72].
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 3. DESIGN 47
3.7.2.2 EDAC on FIFO
To verify the working of the EDAC encoders on both buffers, several SEUs need to be injected
to simulate different events. For this test, bit flips in both directions will be performed on
both the data and Hamming code bits. Starting with one bit at a time, and eventually
ending with two bits being flipped.
Theoretically, independent of the bit changed and the direction of the flip, the data output
from the FIFO should remain correct. In the event of two bits being changed, the output
should be incorrect. This is the result of the Single Bit Correction of the Hamming code.
For this test, only the data FIFO buffer was tested. Using the AMBA interface, data can
be read from the FIFO. The information FIFO cannot be read as easily, as it is only used
when releasing data from the data FIFO.
3.7.2.3 TMR on Registers
Several of the registers were protected using a full TMR and recovery block. Testing the
implementation on one of these registers should confirm the functionality of the TMR and
recovery, as well as the implementation thereof.
To verify the functionality, the value of one of the three bits needs to be changed. The
majority voter would then emit the correct value, while the recovery logic detects a fault.
This fault is then combined with the write enable signal to route data from the output of
the majority voter, back to the input of the register. The faulty bit will then be overwritten
on the next rising edge of the clock.
Writing to the register will write to all three bits. Theoretically, the value of the register
should not change. In the event of two faults in one clock cycle, the value should change as
the majority voter will vote on the two faulty values. However, simultaneous faults in two
different logic cells are highly unlikely.
Stellenbosch University  http://scholar.sun.ac.za
Chapter 4
Implementation
In this chapter, the detailed implementation of the hardware design will be discussed. This
involves the hardware layout, population and testing of components, as well as the devel-
opment required due to changes in the design. Once the hardware is completed, the FPGA
design and improvement, implementation and analysis of the mitigation schemes will be dis-
cussed, followed by the implementation of the mitigation schemes inside the CAN controller.
This chapter will finish off by discussing the testing of the CAN controller and mitigation
schemes, both in simulation and radiation testing, using the developed simulations and
testing software.
4.1 PCB design
This section describes the design of the PCB as shown in Figure 4.1. Subsections of this
image will be discussed.
Figure 4.1 – Diagram of the Experimental PCB Design
48
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 49
4.1.1 Device Under Test
As per Table 3.3, the DUT is required to have SDRAM and SPI Flash for Francois’ OpenRisc
processor. Figure 4.2 shows the SDRAM chip at the bottom and the SPI Flash at the top.
The GPIO header, which can be used to interface with the DUT FPGA, can be seen on the
left. The DUT FPGA and GPIO’s schematics can be found in Figure B.2 and the SDRAM’s
schematics in Figure B.9 in Appendix B.
Figure 4.2 – DUT With SPI Flash, SDRAM and GPIO Header
The header to the left of the SPI Flash disconnects the signals to the SPI Flash. For normal
operation, jumpers will be set to connect the pins to one another. For initial debugging
an external SPI programmer can be connected to the header. The SDRAM was incorrectly
labelled DUT_SRAM in both the schematics and on the PCB.
Since this is a high speed design, all traces were spaced with the same amount of spacing to
minimize crosstalk. All de-coupling capacitors are placed as close to the pins as possible to
reduce noise on the power supply from interfering with the operation of the IC. Since the
capacitors are passive components, they are allowed inside the keep-out zone.
To prevent the size of the PCB from becoming too large, the SDRAM IC was moved slightly
into the keep-out zone. The keep-out zone is not an exact indication of where the beam will
radiate. It is therefore acceptable for pins of the SDRAM to overlap with the keep-out zone.
The DUT also requires two CAN transceivers according to the requirements listed in Table
3.3. Figure 4.3 shows the CAN transceivers above the FPGA, with the schematics listed in
Figure B.6.
Since the CAN signals are differential signals, the traces are symmetrical around the centre
of the transceiver and the header. Although these traces are quite short, it is good practice
to keep differential signals the same length to avoid possible timing issues.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 50
Figure 4.3 – DUT With CAN Transceivers
Between the FPGA and transceivers a header can be seen which selects with which FPGA
the second CAN transceiver communicates. This is to allow the controlling FPGA to inter-
act with the CAN bus, using an unmitigated CAN controller. This will be useful to send
and receive CAN messages from a reliable source. In theory, the CAN controller on the con-
trolling FPGA will not be influenced by the radiation. The jumpers can also be configured
to connect a CAN controller on the DUT to one on the controlling FPGA.
4.1.2 Controller
In Table 3.3, the controller requires two SRAM and flash chips to run the Cortex-M1 pro-
cessor. These need to use the same address bus, but the data bus will be divided into upper
and lower 16 bits. The schematic for the controlling FPGA is shown in Figure B.3, while
the memory is shown in Figure B.10 in Appendix B.
The lower 16 bits’ flash and SRAM ICs are located to the right of the FPGA, while the
upper 16 bits’ ICs are located to the left in Figure 4.4.
Figure 4.4 – Controller With 2x SRAM and 2x Flash
Similar to the memory of the DUT, all the traces where placed with the same amount of
spacing where possible. This is to minimize crosstalk and to keep the inductance as low as
possible and will hopefully avoid corruption of the data signals.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 51
4.1.3 Power Supply and Monitoring
A separate Power Supply Unit (PSU) is required for the DUT to allow the user to switch
off the DUT as per the requirements in Table 3.3. The schematics for the power supplies
are shown in Figure B.4, with the monitoring schematics in Figure B.5 in Appendix B.
The input to the board is run through a sense resistor, which is monitored by an INA169
IC to measure the current. The output from the INA169 is first sent through a buffering
op-amp, before connecting it to an I2C ADC. The input is also connected through a voltage
divider to the ADC to measure the voltage. Similarly, the outputs from both regulators for
the DUT are also measured, since no voltage divider was added.
The ADC was based on the 5 V version of the ADC. Once the design was completed the
3.3 V ADC’s data sheet was consulted and the rail voltage was changed to 3.3 V. This means
that the maximum voltage readable is slightly less than 3.3 V and that the 3.3 V line cannot
be accurately measured.
4.1.4 Populating and Testing the PCB
To confirm that the design of the PCB is working properly the components were populated
and tested in several phases.
4.1.4.1 Phase 1: Power
This phase consisted of populating all the components required to supply, regulate and
filter power to the board. These components are populated separately from any other
active components. Since the voltage regulators have the same footprints, the voltages need
to be confirmed prior to populating active components. It is also required to mount the
sensing resistors from the monitoring phase in order for power to be supplied to the voltage
regulators.
To enable the testing of these components a multi-meter can be used to measure the voltages
on the test points. It should also be noted that the voltage switches might be switched off.
To force them on or off a voltage should be applied to TP3_6.
Measure Point Value
TP3_1 Voltage from source
TP3_2 3.3V
TP3_3 3.3V (when TP3_6 is pulled high)
TP3_4 1.5V
TP3_5 1.5V (when TP3_6 is pulled high)
TP3_6 Floating
Table 4.1 – List of Measurements at the End of Phase 1
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 52
4.1.4.2 Phase 2: Controller FPGA
This phase consists of populating the controlling FPGA, oscillator and programming header.
For stability of the FPGA, or any other IC for that matter, decoupling capacitors need to
be added near every supply pin. Due to the large size and complexity of the ProAsic3
A3PE1500 device, it requires eighteen 3.3 V and nine 1.5 V supply pins. A single error on
one of these capacitors could damage a FPGA, costing roughly R1 600.
To test whether the controlling FPGA is working correctly, a simple design was created
which scales down the 100 MHz clock and toggles LEDs on the daughter-board.
4.1.4.3 Phase 3: Controller Memory
This phase consists of populating the controlling FPGA’s memory, to run the Cortex M1.
Once the FPGA is confirmed to be operating as required, all the extra components can be
added to complete the functionality of the controller. This includes the SRAM and flash
ICs.
To test whether the controlling FPGA is working correctly, a design with the Cortex-M1
was created that should run code from the flash memory. At this stage, it was discovered
that the FPGA was not Cortex-M1 enabled. For this reason it was not possible to use the
Cortex-M1 processor. Instead, the Core8051s processor was used as alternative. Whilst the
Cortex-M1 uses the AHB bus to interface with memory, the Core8051s does not, but it has
its own custom memory interface. To apply it in this hardware design, a memory interface
had to be developed. See §4.2.1 for a detailed discussion on the change to the Core8051s
and the custom memory interface.
With the new Core8051s programming the flash memory is more complicated. Loading the
program memory into the flash memory is done by debugging the soft-core processor using
SoftConsole. With the Cortex M1, CoreMemoryManagement handles the memory interface.
The Core8051s processor manages its own memory. SoftConsole uses a programming Sprite,
which is an Extensible Mark-up Language (XML) script, to control the soft-core processor
and program the memory. Since this design is not based on the same memory as featured
on the development kits, a custom programming Sprite had to be developed. See §4.2.2 for
a detailed discussion on the Sprite development.
Due to this change, the test project was adapted for the Core8051s. Using CoreGPIO, a C
program was written which toggles the LEDs. This verifies that the flash memory stores
the program and the SRAM stores the variables during execution.
4.1.4.4 Phase 4: Monitoring
This phase consists of populating and testing the components required to monitor the
voltages, currents and temperatures on the board.
As specified in Table 3.3 there will be an ADC converter to sample the voltages and currents.
The power input to the PCB goes through a 0.1 Ohm resistor. If the board draws 1A of
current, the voltage drop over this resistor will be 0.1V. While normal 0805 surface mount
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 53
resistors have a rating of 0.25 W, sensing resistors need a higher rating. For this reason a 5
W 2512 resistor was used.
To measure the current, an INA169 current shunt monitor was placed over the resistor. The
current measurement can be calculated using Equation 4.1.1.
Vo =
Is·Rs·Rl
1000 (4.1.1)
The Rl resistor is located between the output and ground of the INA169. Placing a 33
kOhm resistor results in a gain of roughly 3.3 V/A. This means that for every 1 A flowing
through the sensing resistor, the INA169 will output 3.3 V.
Due to the fact that all input pins to any component have an internal resistance, the output
from the INA169 needs to be buffered. Since the three different currents will be measured,
the buffer was implemented using a quad channel operational amplifier. Using negative
feedback and connecting the output to the positive pin of the op-amp, a unit gain buffer
was implemented. This INA169 along with the buffer circuit can be seen in Figure B.5 in
Appendix B.
4.1.4.5 Phase 5: Ethernet Interface
Because of the change from Cortex-M1 to Core8051s processors, it was no longer possible
to use Core10100Apb from the Libero library. The Core10100APB connects to both the
AHB and APB buses. The AHB bus is used to interface directly with the memory, while
the APB bus is used for communication between the processor and Core10100Apb.
The driver for the Core10100Apb initializes buffers in the memory of the processor. The
start address and length of these buffers are then passed to the Core10100Apb through the
APB bus. Whenever a message is received from the Ethernet PHY it is stored directly in
memory. Similarly, when a message is transmitted, the data is read directly from memory.
Since the AHB bus is no longer present, there is no way to connect the Core10100Apb to the
Core8051s’ memory. This makes the use of the Ethernet impossible and although attempts
were made to circumvent this problem in §4.2.3, it was not successful.
To communicate with the board a new interface had to be created. For debugging purposes a
header was connected to each FPGA to allow removable LEDs to be plugged in. A separate
PCB design was made that uses the FT4232H [73] quad channel USB to UART IC for
communication between the computer and the PCB. This PCB uses female headers at the
bottom to connect to the FPGA PCB and male headers at top to connect to the removable
LEDs. This allows the stacking of the LED boards on top of the UART boards.
4.1.4.6 Phase 6: DUT
The test for the DUT is similar to the test of the controller as described in §4.1.4.2. The
only addition is that the controller should toggle power to the FPGA.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 54
During testing it was found that the LEDs did not completely switch off when the power
to the DUT was disconnected. Measuring the voltages on TP3_3 and TP3_5 revealed that
there was still voltage being supplied on these lines. Upon inspection, it was found that the
DUT FPGA was being back-powered by the bus from the controlling FPGA.
To achieve this the bus signals were pulled low whenever the controller’s DUT_POWER_DOWN
pin was pulled low. A simple AND gate between the
DUT_POWER_DOWN and the each signal internal to the FPGA was sufficient to fix this
problem.
4.1.4.7 Phase 7: DUT Memory
To test the DUT memory, Francois used a simple UART to SPI programmer in the fabric
of the DUT FPGA to write data to and from the SPI flash memory. Once the SPI flash
memory was found to be working, the OpenRisc soft-core processor was programmed onto
the DUT FPGA. Using code which was written to the SPI flash, the OpenRisc processor
was able to execute the code and toggle the LEDs.
4.1.4.8 Phase 8: DUT Transceivers
To test the transceivers two CAN controllers were programmed onto the DUT FPGA. The
controlling FPGA used the bus between the two FPGAs to interface with the CAN controller
and commanded them to transmit data. The CAN bus was then monitored using a PCAN
device which converts CAN to USB.
An inconsistency was found when the CAN controllers were transmitting, as the bus re-
mained in an inactive state. Closer inspection showed that the jumpers used to route the
transmission and reception lines to the transceiver were not making contact. The contacts
inside the jumpers where simply bent closer to ensure a better connection and the problem
was solved.
4.1.4.9 Completed Board
Once the design was completed the issue of possible overheating was investigated. To ensure
that long test runs would be possible, the PCB had to stay within the operating temperature
range of the components. To determine whether additional cooling was required for the
power supply, the PCB was placed in a vacuum. For this test, the vacuum was created
using only a rotary vacuum pump and a vacuum of 1.5· 10−4 mbar was reached. By
removing the air from the vacuum chamber, convection cooling of the PCB is no longer
possible. Ambient temperature at the time of test was 14oC.
To take temperature readings the board was operated without the LED daugther-boards
attached and while running the Core8051s on the main FPGA. Two CAN controllers where
programmed to the DUT FPGA to send messages to one another.
From Figure 4.5 it is evident that the PCB temperature will not rise more than 16oC degrees
above ambient temperature. While the actual temperatures of the voltage regulators may
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 55
Figure 4.5 – Plot of Temperatures During Temperature Tests
Figure 4.6 – Plot of Voltages and Currents During Temperature Tests
be slightly higher, these will not be more than 5oC warmer than the PCB. Since the testing
rooms at iThemba Labs are air conditioned to 20oC, the maximum temperature that the
PCB will reach is roughly 36oC. This is well below the maximum operating temperature of
all the components on the PCB which is 70oC.
Using values from Figure 4.6 the power dissipation can be calculated. With an input voltage
of 6.294 V, the voltage drop inside the 3.3 V and 1.5 V regulators are 2.994 V and 4.794 V
respectively. With a current of 27 mA and 12 mA respectively flowing through the DUT’s
regulators, 154 mA is flowing through the controller’s regulators. Assuming the same current
flows through the 1.5 V regulator of the controller, then 142 mA flows through the 3.3 V
regulator. This assumption can be made only because the FPGA core draws current from
the 1.5V line. The total power dissipated is summarized in Table 4.2.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 56
Regulator Voltage Drop Current Power Dissipated
Con 3.3V 2.994V 142mA 0.425W
Con 1.5V 4.794V 12mA 0.058W
DUT 3.3V 2.994V 27mA 0.081W
DUT 1.5V 4.794V 12mA 0.058W
Total DUT On 0.622W
Total DUT Off 0.483W
Table 4.2 – Power Dissipation
4.2 Required Development Due to Changes in Design
Due to changes in the design during the implementation, further developments had to be
made.
4.2.1 Custom Memory Interface
Since the Core8051s uses its own memory interface rather than CoreMemControl like the
Cortex-M1, a custom memory interface had to be developed.
The Flash and SRAM used on the board use active low signals for writing and reading,
while the Core8051s uses active high signals.
Because there is no easy way to determine whether the SRAM or Flash is busy, the acknow-
ledge signals for the Core8051s had to be faked. In the configuration, the Core8051s was set
up not to wait for these acknowledge signals, but to wait for a fixed number of clock cycles
before reading the data from the bus.
The SRAM and flash ICs have chip select, chip enable and read-not-write signals, as opposed
to the read and write signals of the Core8051s. To perform a write operation, both a chip
select and a write enable signal had to be pulled low. Since the Core8051s was designed
for a single Flash and SRAM chip, it did not have a chip select for either of the two chips.
To create a chip select signal, the read and write signals to each chip were combined. The
write and read signals also had to be clocked in after the chip select was driven low. To
accomplish this, the signals were first clocked into a register and only clocked into the SRAM
or flash one clock cycle later. An extra wait state also had to be added to configuration of
the Core8051s.
The address and data bus widths of the Core8051s are 16 and 8 bits wide respectively. For
the Cortex-M1, these were designed to be 19 and 32 bits each. The address and data buses
therefore had to be trimmed and padded to avoid any undesired behaviour.
4.2.2 Programming Sprite
While writing to SRAM is a trivial task; writing to flash memory is not as simple. Because
a flash cell requires a high current to program, the programming unit of the flash memory
IC needs to know prior to the write operation of the intention to write to it. During this
time a charge pump accumulates charge to provide the required high current burst.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 57
Address Data
0x0555 0xAA
0x02AA 0x55
0x0555 0xA0
Table 4.3 – Commands for Writing a Byte to the Flash device
Address Data
0x0555 0xAA
0x02AA 0x55
0x0555 0x80
0x0555 0xAA
0x02AA 0x55
0x0555 0x10
Table 4.4 – Commands for Completely Erasing the Flash device
To start the charging process several commands need to be sent to the flash chip. For
the specific flash chip used, the command structure is shown in Table 4.3 and Table 4.4.
When writing to the device using Table 4.3 two address bytes and one data byte should be
sent immediately after the command. While these commands are not the same on all flash
devices, mostly all flash devices have this form of programming and erasing.
To program the flash memory using the debug interface on the Core8051s, SoftConsole uses
a Sprite which controls the Core8051s during debugging. SoftConsole only provides Sprites
for the devices which are used by Actel in the development kits. Since non-standard memory
was used, none of the Sprites were usable.
The Sprite has the form of an XML document. Certain parameters and functions are defined
inside. Such parameters include the device and manufacturer IDs, memory block sizes,
counters, programming commands and erasing commands. Functions include programming,
block & device erasing and device locking and unlocking. For simplicity, only programming
and device erasing functions were implemented with only the essential functionality thereof.
Refer to the Sprite’s source code in Listing C.1 in Appendix C.
4.2.2.1 Erasing
To keep the Sprite simple the flash memory device will always be completely erased prior
to programming. When the programming data is generated by SoftConsole, any difference
to the previously programmed data will trigger a complete device erase.
To erase the device the six commands for erasing are sent. To avoid the Sprite continuing
with programming while the device is still busy erasing, data is constantly being read from
the flash device. During any operation on the flash device reading data will return a status
byte which can be used to monitor the process, independent of the address specified. While
it may be important to monitor this procedure, for this exercise it is only important to
wait for the completion of the erase process. No error checking will be done. After the
device is completely erased, all data fields will be set to 0xFF. To see whether the device
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 58
has finished erasing, the data is read back until the Sprite receives 0xFF. There is also a
time-out attached to this process to inform the user in the event of a failure. In the event
of a failure the flash device will remain in this erase process and a power cycle will reset the
device to normal waiting operation.
According to the data sheet of the memory, the erase procedure should take roughly 20
seconds for a new device. As the device deteriorates over time the duration of the erase
process will increase. For the current device, the device erase takes roughly 25 seconds.
4.2.2.2 Programming
When programming the device, SoftConsole sends packets of data to the Sprite to program
individual bytes. Prior to programming individual bytes, the three programming commands
need to be sent. When the Sprite receives a block of bytes to write, a FOR-loop is entered
where a counter will count the number of bytes programmed and exit when the transfer of
the block of bytes has completed.
Another way to achieve this is to unlock the device, after which it will remain in a write
mode and will require one command less to program a byte. Although this will speed up
the programming of the device, accomplishing this with limited knowledge of Sprites is
complicated.
Because of all the extra commands being sent and the Sprite programming individual bytes,
the programming procedure takes a long time. This could be shortened using the previously
mentioned technique or by using a burst write mode. Once again, the complexity of the
task was not worth the effort. Current programming of the devices takes roughly 50 seconds
to complete.
4.2.2.3 Usage
To use the newly developed Sprite, it was placed in the SoftConsole/Sourcery-G++/share/sprite/flash
directory. To tell the SoftConsole compiler to use this sprite, a text file is placed in the root
of the project. This file contains a command telling SoftConsole to use the above created
Sprite, as well as the origin and length of the data to send to the sprite. The user also needs
to specify that the Memory Map Generator should use the Spritefile in the SoftConsole
project when compiling the project.
4.2.3 Attempts at Fixing the Ethernet
Due to the change in processor as discussed in §4.2.1 the AHB bus was removed and using
the Core10100APB was no longer possible. Two attempts were made to circumvent this
problem.
The first attempt was to create a new interface for the Core8051s so that it connects to the
AHB rather than directly to the memory as in Figure 4.7. The problem with this was that
Core8015s has the ability to wait for the memory on the read command, it does not wait
when writing data.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 59
Figure 4.7 – Diagram of the Dummy Interface Between Core8051s and AHB Bus
The second attempt involved using FPGA fabric to implement a buffer to which the
Core10100APB could write the data as in Figure 4.8. When an interrupt is generated the
Core8051s uses the slower APB bus to then read from this buffer. Due to the complexity
and fast approaching deadlines, this attempt was abandoned. Instead, a quad channel USB
to UART board was developed and used to interface with the board.
Figure 4.8 – Diagram of the Dummy Memory for Core10100
4.3 Vacuum Connector
According to the initial design, the vacuum connector required three DB9 connectors and
one coaxial connector, as listed in Table 3.2. Since the Ethernet connection is no longer
available on the PCB, the DB9 connection for the Ethernet was removed.
During testing, it was also found that the USB hub does not support the FlashPro pro-
grammer. When connecting a FlashPro programmer to the USB hub, the software reported
that the programmer is a high bandwidth device and that it will not be able to connect to
it. It was decided to place the programmers outside of tank and programming will be done
inside the testing room. Two DB15 connections are required for the programming cables
necessary to reconfigure the board.
Arno Barnard was kind enough to develop the vacuum connector. The connector consists
of a solid aluminium body, with holes cut out for the DB9, DB15 and Coaxial connectors.
To allow the vacuum connector to be used again later, it was decided that the connector
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 60
will host four DB9, three DB15 and two coaxial connectors using Joint Test Action Group
(JTAG) connections.
To save cost, off-the-shelf connectors were used along with a slow curing resin to create the
vacuum safe connections. The cost of vacuum rated connectors was estimated at roughly
R8 000 according to the engineers at iThemba LABS. The connectors were soldered and
inserted into the slotted holes. They were then glued in place to ensure that the resin will
not escape through the hole. A slow curing resin was then poured into the holes, and the
connector was placed in a vacuum chamber to remove all air bubbles from the resin while
curing.
When the vacuum connector was first placed on the side of the scattering chamber, the
chamber failed to reach the target vacuum pressure. It was found that the DB9 and DB15
connectors had minor leaks between the plastic insert and the pins connecting the connector
to the wires. The coaxial connector had a major leak, and it was found that air was sucked
through the cable, between the centre and the outer shields. To stop these leaks, the coaxial
connectors were filled with resin, the DB9 and DB15 connectors were sprayed with liquid
silicon glue and a high quality Prestik was placed around all the connectors. This Prestik is
very clean with very small molecules, resulting in a much better seal than normal Prestik.
The connector, along with the fixes, are shown in Figure 4.9.
Figure 4.9 – Image of the Vacuum Connector Showing the Modifications
Connection Proposed Connector Description
USB DB9 Communication with quad channel UART
Power Coaxial 5V supply for the hardware
JTAG 2x DB15 Programming of the FPGAs
Table 4.5 – Altered List of Connections to the Hardware
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 61
4.4 Firmware Design
After the hardware was populated and tested the final firmware designs could be implemen-
ted and programmed onto the FPGAs.
4.4.1 Controller Libero Design
Figure D.2 in Appendix D shows the final Libero design for the controlling FPGA. The
design consists of the Core8051s processor, connected to the external memory via the custom
memory interface as described in §4.2.1. The Core8051s is also connected to the APB bus
on which it is the master. Several slaves are connected to the APB bus:
1. CoreI2C
Used for communication with the on-board sensors.
2. 2x CoreTimer
Used to generate interrupts for time based functions, such as data sampling and UART
servicing.
3. CoreWatchdog
Used to detect faults in the Core8051s.
4. CoreInterrupt
Used to connect multiple interrupts to the two single interrupt channels on the Core8051s.
5. 2x Original CAN Controller
Used to communicate with the CAN Controllers on the Device Under Test, while the
second is used to acknowledge all messages sent on the CAN bus.
6. 2x CoreUARTapb
Used for communication with the computer.
7. CoreGPIO
Used to power down the DUT, manage the CAN bus, reset the CAN controllers and
toggle LEDs during diagnostics.
8. AMBAencoder
Used to route the APB bus signals over the inter-FPGA bus to allow the CAN con-
trollers on the DUT FPGA to connect to the APB bus.
The I2C signals coming from the CoreI2C are connected to a tri-state buffer which combines
them into the I2C bus signals. The I2C bus is connected to the two temperature sensors on
the board, as well as the ADC.
The GPIO signal which resets the CAN controllers are connected through an AND gate to
allow both reset signals to pass through. Since the design uses an active high reset, a low
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 62
signal on either of the reset lines will result in the CAN controllers being reset. The GPIO
is also used to toggle LEDs when debugging the software design.
4.4.2 DUT Libero Design
Figure D.1 in Appendix D shows the final Libero design for the Device Under Test. The
DUT dummy package is used to connect unconnected signals in the design to the pins of
the FPGA. Since Libero version 10, if a pin is unconnected in the top level design, the
pin is removed from the pin mapping. This dummy package prevents the pin mapper from
removing these pins. It also prevents any operations from randomly occurring on either
SDRAM or flash due to floating connections.
The signals coming from the controlling FPGA are reconstructed into the APB bus signals.
These are then manually connected to the two CAN controllers by exposing individual
signals from the bus interface. Similar to the controlling FPGA, the DUT also uses a CAN
encoder to connect both CAN controllers to a single transceiver.
The DUT dummy package contains no logic units and is not connected to any of the internal
circuitry, and therefore does not require any protection against the effects of radiation. The
CAN encoder was developed with TMR and is already protected against the effects of
radiation. The AMBA decoder contains only a few multiplexors to route the outgoing data
over a single 8 bit bus. It was decided not to implement any protection on the decoder as to
avoid any unnecessary logic and subsequent delays being inserted on the inter-FPGA bus.
4.4.3 Controller Firmware Design
The Core8051s acts as an interface between the software running on the computer and the
hardware.
The program running on the Core8051s starts by initiating all the components connected
to the APB bus. After initialisation is completed, it goes into a listening state, waiting
for commands from the computer. The timers are set up to produce interrupts for two
functions.
The first of these functions is to service the UART buffers. For this design a buffer size
of 128 bytes was used. With a baud rate of 115 200 bps, a total of 11 520 bytes can be
received every second. This means that the FIFO could be filled 90 times each second. To
avoid the buffer being overrun, an interrupt is generated every 5 milliseconds to service the
buffer. Although the required time is 11.1 milliseconds, extra time was allocated to allow
the Core8051s to process the buffer completely before the next interrupt.
The second function is the sampling of data. There are a total of eight readings taken from
the board which consists of three voltage readings and three current readings, as well as two
temperature readings. To avoid heavy usage on the Core8051s, the data is sent back once
a second. An interrupt is generated every 125 milliseconds, at which time one of the eight
sensors is read and the data transmitted over UART.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 63
The program also features a command buffer, which contains instructions to be sent to
the CAN controllers. The software running on the computer sends a list of commands
and the Core8051s loads them into the buffer. After receiving a flushBuffer command, the
Core8051s empties the buffer by performing the instructions. This is required to trigger two
CAN controllers to start transmitting at the same time, to test whether the CAN controller
correctly backs off when a conflict is detected.
4.5 Mitigation Scheme Implementation
In §3.5 several mitigation schemes and their possible implementation were discussed. In this
section, the implementation and improvements of those techniques will be discussed.
4.5.1 Implementation of the TMR circuit
During the simulation of the TMR and recovery circuit it was found that the XOR3 gate
does not function as expected. The definition of exclusive OR states that the output is
true whenever the inputs differ. This was not the case for the XOR3 input gate of the
Microsemi device. Instead, they followed the more generalized approached, which states
that the output is true if an odd number of the inputs are true.
The correct gate that should be used is the ZOR3I gate. The ZOR3 gate outputs a logic ’1’
whenever all the inputs are the same. The ZOR3I is similar to the ZOR3 gate, only with
an inverted output.
Figure 4.10 – Diagram of the TMR with Recovery Using ZOR3I
4.5.2 Improvement on the Hamming code design
After simulating the XOR3 gate it was found that it can also be used to calculate parity
between the input bits. The implementation can therefore be reduced to a total of 8 gates
for the encoder.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 64
Figure 4.11 – Diagram of the Hamming Code Encoder
It also became clear that the decoding of the Hamming code could be improved on. Instead
of recalculating the Hamming code parity bits and comparing them to the stored bits, the
parity of each group was calculated, making the faulty bit position available immediately.
Figure 4.12 – Diagram of the Hamming Code Decoder’s Wrong Bit Identification
4.5.3 SET Filter
Implementing the SET filter is as simple as using the Microsemi AND2, OR2, INV and MX2
macros to create the SET Filter.
4.5.3.1 SET Filter Component
The code from Listing 4.1 will create an SET filter component which can be inserted into
the design.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 65
 
1 INV INV_1_instance (.A(in), .Y(chain_0_w ));
INV INV_2_instance (.A(chain_0_w), .Y(chainout ));
AND2 AND2_instance (.A(in), .B(chainout), .Y(andout ));
OR2 OR2_instance (.A(in), .B(chainout), .Y(orout ));
MX2 MX2_instance (.A(andout), .B(orout), .S(out),
6 .Y(out)); 
Listing 4.1 – Verilog for SET Filter
The problem with this method is that it is nearly impossible to place the SET filter precisely
in the design without the compiler interfering by optimizing the design. To avoid this
problem, the SET filters will be injected directly into the net list post-synthesis.
4.5.3.2 SET Filter Injection
To place the SET filter exactly where it is desired without Actel’s Synthesis software altering
the design, a post-synthesis SET Filter injector was developed.
To insert the SET filter in the correct place, the post-synthesis design needed to be analysed.
A recursive Python analysis program was developed to locate register instances and trace
the input pins back to either another register instance, or to an I/O pin. The program
counts the number of logic gates in series in the longest route from register input to output
or I/O pin, as well as the number of logic units between the input and all the dependant
outputs and I/Os.
Using the above mentioned information the SET filter can intelligently be placed with full
knowledge of the effected circuit. Inserting a SET filter when there are a few gates prior
to the register increases the risk of a SET occurring. Inserting a SET filter where the prior
logic count is high could significantly lower the maximum operating frequency.
The SET filter injection program was written in C/C++ using QT. It is able to read the
output from the Python analysis program and depending on defined parameters, insert SET
filters according to the result of the analysis. The application performs a lookup of every
register in the analysis, and severs the input connection. It then instantiates the required
logic units to form the SET filter, as well as the required nets to connect them. From Figure
4.15 and Figure 4.16, the effect of SET injector can be confirmed.
4.5.3.3 Alteration to SET Filter Structure
Due to advances in the FPGA fabric buffer cells are no longer limited to input and output
cells and clock signals, but can now also be used as part of the FPGA fabric. Where, with
the previous method, the delay element size is limited to factors of two inverter gates, using
buffers, we are now able to use factors of one. This not only results in a finer detection resol-
ution of SET pulses, but also allows a better optimized curve between the SET suppression
length and delays introduced.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 66
Figure 4.13 – Flow-diagram of the SET Filter Injector
Figure: 4.17 shows the number of SETs which propagate through the filter plotted against
the duration of the SET pulse. For the top two graphs the blue line on the left represents
a single buffer in the delay chain, while the red line on the right represents ten buffers. For
the lower two graphs the blue line on the left represents two inverters in the delay chain,
while the purple line on the right represents ten inverters.
The test for the buffer consisted of a set of 44 SET filters of which the delay element length
is increased one at a time up to ten times, while the inverter test consisted of a set of 88
SET filters of sizes two, four, six, eight and ten. Microsemi Designer was given the freedom
to place the components anywhere on the FPGA, as to simulate similar behaviour when the
final design will be mitigated.
When the delay unit contains more than five elements, the results start to become distorted.
This is due to the Place-and-Route process of the Microsemi Designer having to place
inverters or buffers away from one another to optimize the area usage, power usage or
timing to improve the device performance. While it is possible to turn these optimizations
off, a well spread layout is desired for the final test along with optimum timing to ensure
that there are no timing issues.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 67
Figure 4.14 – Screen-shot of the SET Filter Injector
D PADD
Q_pad
OUTBUF
QPAD Y
D_pad
INBUF
Q
CLK
D
DFN1_0
DFN1PAD Y
CLK_pad
INBUF
CLK Y
VCC_i
VCC
Y
GND_i
GND
Figure 4.15 – Register Before SET Filter Injection
Q
CLK
D
DFN1_0
DFN1
QPADD
Q_pad
OUTBUF
A
Y
B
DFN1_0_portd_or
OR2 S
Y
B
A
DFN1_0_portd_mux
MX2
YA
DFN1_0_portd_inv_1
INV
YA
DFN1_0_portd_inv_0
INV
D PAD Y
D_pad
INBUF
CLK
Y
VCC_i
VCC
PAD Y
CLK_pad
INBUF Y
GND_i
GND
A
B
Y
DFN1_0_portd_and
AND2
Figure 4.16 – Register after SET Filter Injection
4.5.3.4 SET Capture and delays
With both the inverter and buffer chains, a significant decrease in the maximum frequency
of the CAN controller was noticed. This dencrease in maximum frequency is due to the
delay of each element in the SET filter, as well as delays in the routing inside the FPGA.
To see the extent of the delays caused by different lengths of delay chains, 400 SET filters
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 68
0 2000 4000 6000 8000
0
20
40
60
80
100
Propogation)of)Logic)d1d)SET)in)Buffer)Chain
Duration)of)SET)(ps)
%
)S
E
Ts
)P
ro
pg
at
ed
0 2000 4000 6000 8000
0
20
40
60
80
100
Propogation)of)Logic)d0d)SET)in)Buffer)Chain
Duration)of)SET)(ps)
%
)S
E
Ts
)P
ro
pg
at
ed
0 2000 4000 6000 8000
0
20
40
60
80
100
Propogation)of)Logic)d0d)SET)in)Inverter)Chain
Duration)of)SET)(ps)
%
)S
E
Ts
)P
ro
pg
at
ed
0 2000 4000 6000 8000
0
20
40
60
80
100
Propogation)of)Logic)d1d)SET)in)Inverter)Chain
Duration)of)SET)(ps)
%
)S
E
Ts
)P
ro
pg
at
ed
Figure 4.17 – Comparison Between Buffer and Inverter Based SET Filters of Different Lengths
were placed in a design and simulated post-layout. This will take into account both the
delays in each element, as well as the delay for different routes. The same device was used
for simulation, but with a different IC footprint. This allows the simulation to use more I/O
pins, while the results are still applicable to the FPGA used in this design.
Figure 4.18 shows the delay of each instance of the SET filter for different delay chain
lengths. At the bottom, a zero element delay chain was used as baseline to get the delay
from the voting circuit, as well as input buffers and routing effects. The post-synthesis
layout simulation treats the simulation as if it was running on an FPGA. This results in
both input and output buffers adding to the delay, along with the routing paths from the
voting logic to a valid I/O.
Table 4.6 shows the average delays of each chain, as well as the increase between different
delay chain lengths.
4.5.3.5 Longest Path and Maximum Frequency
The estimated maximum frequency of the CAN controller is roughly 55 MHz, as per the
synthesis results. This frequency is calculated by adding the delays of all the cells in the
longest path between two memory cells, such as DFF, latches, inputs or outputs. This is
referred to as a pipeline. With a maximum frequency of 55 MHz for the ProASIC A3PE1500
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 69
0 50 100 150 200 250 300 350 400
0.6
0.8
1
1.2
1.4
1.6
1.8
2
x(104
SET(Filter(Instance(Number
S
E
T(
Fi
lte
r(D
el
ay
((p
s)
Delay(of(SET(Filter(Chains
0(Inverter(Chain
2(Inverter(Chain
4(Inverter(Chain
6(Inverter(Chain
8(Inverter(Chain
10(Inverter(Chain
Figure 4.18 – Average Delays of SET Filters of Different Chain Lengths
device the longest pipeline is roughly 18.18 ns.
The voting logic of the SET filter adds on average 7 256 ps to the design as per Figure 4.18,
while each increment of the delay chain adds an average of 1 400 ps as per Table 4.6.
If, in the worst case, each SET filter adds about 7 ns delay and about 700 ps delay per
inverter to the design, then the new maximum frequency of the device can be calculated
using Equation 4.5.1. The results are listed in Table: 4.7.
fmaxnew = (fmax−1 + 7256ps+ n× 700ps)−1 (4.5.1)
From the results summarised in Table 4.7 it is evident that the use of the SET filter severely
compromises the maximum frequency of the design. With SETs reaching pulse widths of up
4 ns in documented cases [33], a total of 8 inverters are required to block the SET. While the
SET filter is a novel idea, the practical application has a negative impact on the operating
frequency of the design.
Inverters
per SET
Filter
Average
delay of
SET Filter
(ps)
Delay
of Delay
Chain (ps)
Increase
(ps)
0 7256
2 8821 1565 1565
4 10358 3102 1537
6 11635 4379 1277
8 13012 5756 1377
10 14257 7001 1245
Table 4.6 – Average Delay for Different SET Filter Lengths
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 70
Inverters per SET Filter New max frequency
2 37.26 MHz
4 35.42 MHz
6 33.74 MHz
8 32.22 MHz
10 30.83 MHz
Table 4.7 – Maximum Frequency of CAN controller Due to Delays inside SET Filters
4.6 CAN Controller Implementation
This section covers the implementation of alterations and mitigation techniques to the CAN
controller.
4.6.1 Removal of Non-Reset Registers
After the correct interface was added in §3.4.1 it was found that running post-synthesis
simulations resulted in abnormal device performance, even though it operated normally in
hardware. Even after testing the 8051 and Wishbone interfaces on the same test-bench, the
problem persisted. Inspection of the signals in some of the lower level peripherals showed
that somewhere between the release of the reset signal to the device, and removal of the
reset mode flag, internal signals went into an unknown state and was unable to exit. One
of the signals that went into an unknown state, was tx_point. 
1 tx_point <=#Tp ~tx_point & seg2 &
( clk_en & (quant_cnt [2:0] == time_segment2)
| (clk_en | clk_en_q) & (resync | hard_sync) ); 
Listing 4.2 – tx_point signal assignment
From Listing 4.2 it is clear that tx_point is assigning itself, along with other signals, to
itself. If, at any stage, any of the other signals enter an unknown state, the unknown state
will remain in tx_point. It just so happens that some of the configuration registers have
no action coupled to the reset pin. This resulted in time_segment_2 being unknown until
data is written to it.
The reason some of the registers do not have a reset action coupled to it, is because the
CAN controller was designed to be a replica of the SJA1000 CAN controller developed by
Phillips. Some of the configuration registers keep their value even through a full reset.
Because hardware only knows a logic ’1’ or ’0’, it is unable to produce an unknown state.
This is why the Verilog CAN controller worked in hardware, but post-synthesis simulation
resulted in unexpected performance. The solution was to replace all configuration registers
that do not have a reset action coupled to it with a register that clears its contents when
reset is active.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 71
4.6.2 Flattening of the CAN Controller
To avoid the nine times instantiation when implementing TMR on a hierarchical design as
mentioned in §3.4.2, the design of the CAN controller had to be flattened out. This involved
removing instantiations from the sub-modules of the CAN controller and placing them in
the top level.
It initially seemed a trivial process to move registers from the registers module to the top
level. The data input to the registers were all connected to the data input of the CAN
controller. The write-enable signals where all generated at the top of the registers module,
and could simply be changed from wires to outputs. For the registers requiring alternative
reset signals to the reset input of the CAN controller, a similar process as the write-enable
signals was followed.
When it came to larger components such as the FIFO and acceptance filter, however, some
additional inputs and outputs had to be created or removed, making the process more com-
plicated. In some cases, the connections to the lower level modules where connected directly
to signals coming from other modules in the top level. These could be connected directly and
the matching inputs and outputs from the bit stream processor could be removed. In other
cases, these signals were generated inside the bit stream processor and had to be converted
to output signals. In some cases, these signals were connected to registers, and in other
cases it was connected to sequential logic. To maintain the same functionality, additional
outputs were created and the outputs from the registers were assigned to the output ports.
4.6.3 Protecting the registers
Each register was synthesized to find exactly which logic cells were used. Based on this, the
TMR was implemented in the file.
4.6.3.1 Register With Asynchronous Reset
Registers containing an asynchronous reset signal can be instantiated using the DFN1E1C1
macro. To protect the register using TMR and implement automatic recovery, the code in
Listing 4.3 was used.
data_out<0>
we
PADD
data_out_pad[0]
OUTBUFPAD Y
we_pad
INBUF
Q
CLR
E
CLK
D
data_out[0]
DFN1E1C1PAD Y
rst_pad
INBUF
rst
data_in<0>
Y
VCC_i
VCC
PAD Y
data_in_pad[0]
INBUF
Y
GND_i
GNDPAD Y
clk_pad
INBUF
clk
Figure 4.19 – Register Prior to TMR and Recovery
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 72
 
1 MX2 data_in_mx_0_i (.A(data_out), .B(data_in), .S(we),
2 .Y(data_in_mx ));
DFN1E1C1 data_out_0_1_i (.D(data_in_mx), .E(reg_enable),
.CLK(clk), .CLR(rst), .Q(data_out_bank_1 ));
DFN1E1C1 data_out_0_2_i (.D(data_in_mx), .E(reg_enable),
.CLK(clk), .CLR(rst), .Q(data_out_bank_2 ));
7 DFN1E1C1 data_out_0_3_i (.D(data_in_mx), .E(reg_enable),
.CLK(clk), .CLR(rst), .Q(data_out_bank_3 ));
MAJ3 data_out_maj_0_i (.A(data_out_bank_1),
.B(data_out_bank_2),
.C(data_out_bank_3), .Y(data_out ));
12 ZOR3I error_0_i (.A(data_out_bank_1), .B(data_out_bank_2),
.C(data_out_bank_3), .Y(error ));
OR2 error_enable (.A(we), .B(error), .Y(reg_enable )); 
Listing 4.3 – TMR and Recovery implemented on a single bit register
Listing 4.3 instantiates three register components as well as the required voting and repair
logic, as designed in Figure 3.8. This results in the circuit in Figure 4.19 changing to the
circuit in Figure 4.20.
data_in PAD Y
data_in_pad
INBUF
Y
VCC_i
VCC
Y
A
B
C
error_T_i
ZOR3I
Q
CLR
E
CLK
D
data_out_T_3_i
DFN1E1C1
Q
CLR
E
CLK
D
data_out_T_2_i
DFN1E1C1
rst
S
Y
B
A
data_in_mx_T_i
MX2
A
Y
B
error_enable
OR2
PAD Y
rst_pad
INBUF
Q
CLR
E
CLK
D
data_out_T_1_i
DFN1E1C1
Y
C
B
A data_out_maj_T_i
MAJ3
YPAD
clk_pad
CLKBUF
clk
PAD Y
we_pad
INBUF
data_out
Y
GND_i
GND
we
PADD
data_out_pad
OUTBUF
Figure 4.20 – Register After TMR and Recovery
4.6.4 Protecting the FIFO module
To implement the Hamming Code encoders and decoders, four individual blocks were cre-
ated. This includes an encoder and decoder for both five and eight bit data. The blocks for
five bit data is the same as that of the eight bit data, only scaled down.
The 8 bit data encoder can be created using the code in Listing 4.4.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 73
 
1 XOR3 PAR_1_GEN_1_i (.A(data_in [0]), .B(data_in [1]),
.C(data_in [3]), .Y(e0_w ));
XOR3 PAR_1_GEN_2_i (.A(e0_w), .B(data_in [4]),
.C(data_in [6]), .Y(hamm_out [0]));
XOR3 PAR_2_GEN_1_i (.A(data_in [0]), .B(data_in [2]),
6 .C(data_in [3]), .Y(e1_w ));
XOR3 PAR_2_GEN_2_i (.A(e1_w), .B(data_in [5]),
.C(data_in [6]), .Y(hamm_out [1]));
XOR3 PAR_3_GEN_1_i (.A(data_in [1]), .B(data_in [2]),
.C(data_in [3]), .Y(e2_w ));
11 XOR2 PAR_3_GEN_2_i (.A(e2_w), .B(data_in [7]),
.Y(hamm_out [2]));
XOR3 PAR_4_GEN_1_i (.A(data_in [4]), .B(data_in [5]),
.C(data_in [6]), .Y(e3_w ));
XOR2 PAR_4_GEN_2_i (.A(e3_w), .B(data_in [7]),
16 .Y(hamm_out [3]));
assign word_out [0] = hamm_out [0];
assign word_out [1] = hamm_out [1];
assign word_out [2] = data_in [0];
21 assign word_out [3] = hamm_out [2];
assign word_out [4] = data_in [1];
assign word_out [5] = data_in [2];
assign word_out [6] = data_in [3];
assign word_out [7] = hamm_out [3];
26 assign word_out [8] = data_in [4];
assign word_out [9] = data_in [5];
assign word_out [10] = data_in [6];
assign word_out [11] = data_in [7]; 
Listing 4.4 – Hamming Code encoder for 8 bit data
The 8 bit data decoder can be created using the code in Listing 4.5. The code in Listing
4.5 only determines which bit should be flipped.
4.6.5 Protecting the CRC module
In some cases it is easier to implement the TMR directly inside the module, instead of
triplicating the entire module. In the case of the CRC module, a single clock sensitive
process was defined which is used to calculate the CRC code. To implement the TMR all
registers where defined a second and third time. The clock sensitive process was then copied
twice. The register containing the CRC code was then put through a majority voter to vote
on the correct code.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 74
 
1 XOR3 PAR_1_MIS_1_i (.A(data_in [0]), .B(data_in [1]),
.C(data_in [3]), .Y(e0_w ));
XOR3 PAR_1_MIS_2_i (.A(e0_w), .B(data_in [4]),
.C(data_in [6]), .Y(e1_w ));
XOR2 PAR_1_MIS_3_i (.A(hamm_in [0]), .B(e1_w),
6 .Y(position [0]));
XOR3 PAR_2_MIS_1_i (.A(data_in [0]), .B(data_in [2]),
.C(data_in [3]), .Y(e2_w ));
XOR3 PAR_2_MIS_2_i (.A(e2_w), .B(data_in [5]),
.C(data_in [6]), .Y(e3_w ));
11 XOR2 PAR_2_MIS_3_i (.A(hamm_in [1]), .B(e3_w),
.Y(position [1]));
XOR3 PAR_4_MIS_1_i (.A(data_in [1]), .B(data_in [2]),
.C(data_in [3]), .Y(e4_w ));
XOR3 PAR_4_MIS_2_i (.A(e4_w), .B(data_in [7]),
16 .C(hamm_in [2]), .Y(position [2]));
XOR3 PAR_8_MIS_1_i (.A(data_in [4]), .B(data_in [5]),
.C(data_in [6]), .Y(e5_w ));
XOR3 PAR_8_MIS_2_i (.A(e5_w), .B(data_in [7]),
.C(hamm_in [3]), .Y(position [3])); 
Listing 4.5 – Hamming Code decoder for 8 bit data
4.6.6 Protecting the ACF module
To insert the SET Filter, the assignment to the ID_OK register should be intercepted. The
conditional assignment was replaced with a single wire assignment, where the assignment
to the wire was now conditional to the filter configuration.
The SET filter was inserted and a significant drop in the estimated frequency was observed.
Because of this, TMR was considered as a better alternative to maintain a higher operating
frequency.
Triplication of the ACF module showed an even worse estimated frequency. While this does
not make any sense, it should be the safer option. There is far less sequential logic in series
with the TMR circuit than with the SET filter.
While the TMR implementation showed a worse estimated frequency, from theory it should
not be so. The exact cause of the discrepancy is unknown, as a visual inspection of the
longest path clearly showed that it is shorter than when using the SET filter. Given the
higher expected protection and comparative operating frequency TMR was chosen over an
SET filter to protect the ACF module.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 75
4.6.7 Protecting the BTL and BSP modules
To protect the BTL module using TMR, the BTL module instantiation was modified. The
shell of the BTL module was kept, while inside three BTL module instances were defined.
The inputs were all mapped to the input of the shell while the outputs where mapped to
newly declared wires. Majority voters were then used to vote on the correct output. The
same process was used for the BSP module.
4.7 Hardware Test Design
4.7.1 Controlling Software
Since the Ethernet interface was no longer implementable a UART interface was developed.
It has a much lower bandwidth than the Ethernet and usage will be limited. Since two of
the four UART channels are connected to the controller, one will be used to monitor the
board, while the other will be used to perform tests. Both of these interfaces use the same
command structure.
Byte no Read Write
1 ’;’ ’:’
2 Address Address
3 Data
Table 4.8 – Command Structure of PC-to-PCB Communication
1 2 3 Description
’:’ 0xEC ’0’ DUT Power Off
’:’ 0xEC ’1’ DUT Power On
’:’ 0xFF 0x01 Flush Command Buffer
’:’ 0xFF 0x02 Release CAN Bus
’:’ 0xFF 0x04 Pull CAN Bus Low
’:’ 0xFF 0x08 Ping Request, Send Ping Back
’:’ 0xFF 0x10 Set Reset Signal to CAN Controller
’:’ 0xFF 0x20 Remove Reset Signal From CAN Controllers
’:’ 0x00 + ADDR Data Insert Write Command Into Command Buffer 0
’:’ 0x20 + ADDR Data Insert Write Command Into Command Buffer 1
’:’ 0x40 + ADDR Data Insert Write Command Into Command Buffer 2
’;’ 0x00 + ADDR Insert Read Command Into Command Buffer 0
’;’ 0x20 + ADDR Insert Read Command Into Command Buffer 1
’;’ 0x40 + ADDR Insert Read Command Into Command Buffer 2
Table 4.9 – List of Commands of PC-to-PCB Communication
Both the PC software and board firmware used the same command structure. While the
board may not request a read operation, a write operation will write the register value for
the accompanying address field.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 76
To monitor the DUT’s health, the board samples the voltages, currents and temperatures
every 125 ms and sends back one of the values. This transaction has a ping-like functionality,
informing the user that the board is still active.
Figure 4.21 – Screen-shot of the Monitor Interface
Starting at the top left Figure 4.21, the Monitor Interface offers some configuration options.
The user should select the correct communication port as well as the baud rate. The
software should then be able to connect to the DUT when the user initiates the connection
by pressing the Connect button. The Status field shows the status of the connection. The
Enable Streams check box offers the user the ability to deactivate the display of the incoming
and outgoing data streams. Then it shows the voltages and currents of the DUT power
supply as well as the total power supply to the board. For logging purposes, there are some
buttons which mimic a physical action. The Move to Beam button logs that the control
room operator has now initiated a movement on the arm to place the board in the radiation
beam. Similarly, the Beam On button logs that the control room operator has now turned
on the radiation beam. The Power Off button sends a command to the board to turn off
the DUT’s power supply. Finally, there is a session log on the right hand side showing
events with the corresponding time at which they occurred. All information in this window
is logged, as well as every packet coming in or going out of the communication port.
This application serves as a template for all the testing software that will be developed.
4.7.2 Implemented Tests
More tests on a smaller scale will give a better idea of the working of each sub-component in
the CAN controller. Due to the shift in focus from physical radiation testing to simulation
only a few tests were designed.
4.7.3 Operational Test
The operational test simulates normal CAN bus activity. The firmware consists of four
CAN controllers. The first CAN Controller is used to send and receive message on the CAN
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 77
bus, while remaining isolated from the DUT. The second CAN controller is the unmitigated
version located on the DUT. The third CAN controller is the mitigated version, also located
on the DUT, while the fourth CAN controller is located on the controlling FPGA. The latter
is used to acknowledge all messages sent on the CAN bus.
Initially, all the devices were configured to use the same 125 kbps bus speed, with different
acceptance codes and masks. This will allow each of the first three CAN controllers to have
unique IDs, while the fourth accepts all messages. Thereafter, the configuration is read back
to the computer and compared to the stored values. After a short delay data will be loaded
into one of the CAN controllers and a transmission request will be sent. Each of the two
CAN controllers in the DUT will send a message to the first CAN controller. The first CAN
controller will also send a message to each of the CAN controllers on the DUT.
This process is repeated 10 times, to form a short 2 minute test. During this test, all
incoming data to the communication port will be logged. A test log will also be created
which contains comments on the actions taken by the testing software. Finally, an error log
will log all the mismatches in the registers along with the theoretical values.
4.7.4 Configuration Hold Test
The configuration hold test follows a similar methodology as the operational test. A default
configuration is loaded into the CAN controller, and is read back every second using a time-
out. Whenever a register’s value differs from the one stored after an initial read, an SEU
has occurred. If any of the interrupt or error registers change, it is also an indication of an
SEU, since all CAN controllers are idle. The test sequence can be described as follows:
1. Hard reset the CAN controllers
2. Force Reset Mode on all Can controllers
3. Load Control, ACF, BT, CLKDIV with values
4. Switch to operating mode
5. Load Transmit Buffer
6. Switch to Reset Mode
7. Switch to Extended Mode
8. Load Mode, IE, EWL, RXEC, TXEC, ACF with values
9. Perform Initial read of all registers
10. Switch on beam and move board into beam.
11. Repetitively switch between modes and read values
Due to the various delays prior to the radiation testing this test was abandoned and priority
was given to the simulations and operational test.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 78
Figure 4.22 – Flow Diagram of the Operational Test
Figure 4.23 – Screen-shot of the Operational Test’s Software Interface
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 4. IMPLEMENTATION 79
4.8 Simulated Test Design
To verify the working of the CAN controller with the implemented mitigation techniques,
the CAN controller was simulated and the mitigated areas monitored.
4.8.1 Error Detection and Correction on FIFO block
The Hamming code implemented on the FIFO block is straight forward. When a message
is received on the CAN bus, it is stored in a temporary buffer. The data stays in this buffer
for the duration of the CAN message.
Once reception is complete, the data is moved from the temporary buffer to the FIFO
buffer. After data was written to the FIFO buffer, the information regarding the length of
the message and status of the FIFO buffer is stored in a second FIFO buffer. The temporary
buffer is located in the BSP, which is protected using TMR and data coming in to the FIFO
buffer can be assumed correct.
Since the encoder is only 14 gates in size, the chances of an upset occurring when writing
data to the FIFO buffer can be considered minute. Thus, it only needs to be verified that
the decoder is working correctly, given both correct and incorrect data. To simulate this, a
message of 8 bytes will be transmitted on the CAN bus. Once received, the data will be read
back to the Verilog test-bench. After the data is read back, the data in the FIFO buffer will
be altered. Single data and Hamming Code bits will be changed in both directions, followed
by a two bit upset.
If the Hamming Code is working correctly, the data should remain intact for all cases, except
when more than one bit is altered.
4.8.2 TMR and Recovery on Registers
Since TMR is basically three registers with the same input signals, not much can go wrong.
A majority voter votes on the outputs of these registers, to give the correct output. When
an error occurs in one of the registers, the output should remain the same.
In the case of the recovery circuitry, an error in one of the registers will trigger a re-write
on all registers. Data will be fed back using a multiplexer, only if new data is not written
to the registers.
To confirm that the TMR and recovery is working correctly, data will be loaded into all
configuration registers of the CAN controller. The data will be read back into the test-
bench a few seconds after it being written. Once the data is read back, the value of the
output signal of one of the registers will be altered through the test-bench.
If the TMR and recovery circuits are working correctly, the output of the majority voter
should remain the same, and the write enable signal should be triggered to all the registers.
Stellenbosch University  http://scholar.sun.ac.za
Chapter 5
Results
In this chapter, the results from the simulations and radiation testing will be discussed.
The simulations of the CAN controller focusses on the EDAC using Hamming Codes on the
FIFO buffer, as well as TMR with recovery for the long term registers. The radiation testing
focusses on the behaviour of the entire CAN controller, specifically looking for upsets in the
available registers.
5.1 Mitigation Results
Table 5.1 shows the result of the mitigation techniques. Comparing Table 5.1 with Table 3.1,
the increase in area usage and decrease in speed is clearly visible for most of the components.
The area usage of the CAN controller as a whole went up from 5 191 to 11 234 logic cells,
which is an increase of 116%. The total number of registers used went up from 1 497 to 2
887 which equals an increase of 93%. The increase in registers is due to the triplication of
both registers and sub-modules of the CAN controller. The sequential logic cells used went
up from 3 694 to 8 347, which is an increase of 126%. The increase in sequential logic cells is
mainly due to the triplication of sub-modules and the addition of majority voting logic. The
maximum operating frequency also went down by 7%, from 55.8 MHz to 51.9 MHz. This is
due to insertion of voting logic in the longest path of the CAN controller. This decrease in
operating frequency is acceptable and will not have a negative impact on the performance
of the CAN controller or the processor.
5.2 Simulations
Due to continual unforeseen delays in the scheduled physical radiation test appointments at
iThemba LABS outside the author’s control, it was decided to do more thorough simulations
to verify expected response from SETs/SEUs in the controller.
5.2.1 Error Detection and Correction on FIFO
After modification to the two FIFO buffers, each had its own Hamming code encoders and
decoders. To simulate the working of these units inside the CAN controller, the original
80
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 5. RESULTS 81
Module name and unit count Register
count
Logic
Count
I/O
Count
Max Freq
mitigated_can_top 2887 8347 34 51.9 MHz
1x can_bsp 1041 4204 343 52.8 MHz
1x can_acf 3 591 123 362.2 MHz
1x can_crc 45 128 19 177.4 MHz
1x can_fifo 1398 1841 37 58.3 MHz
1x can_btl 93 478 36 96.8 MHz
1x can_registers 24 638 336 180.4 MHz
4x ACCEPTANCE_MASK 24 29 19 168.3 MHz
4x ACCEPTANCE_CODE 24 29 19 168.3 MHz
13x TX_DATA_REG 8 0 19 NA
1x MODE_REG0 3 6 6 318.9 MHz
1x MODE_REG_BASIC 12 15 11 180.5 MHz
1x MODE_REG_EXT 9 11 13 218.6 MHz
1x IRQ_EN_REG 24 29 19 168.3 MHz
1x BUS_TIMING_0_REG 24 29 19 168.3 MHz
1x BUS_TIMING_1_REG 24 29 19 168.3 MHz
1x COMMAND_REG0 1 2 6 NA
1x COMMAND_REG1 1 2 6 NA
1x COMMAND_REG 2 3 8 NA
1x COMMAND_REG4 1 2 6 NA
1x ERROR_WARNING_REG 8 0 19 NA
1x CLOCK_DIVIDER_REG_7 3 4 5 315.1 MHz
1x CLOCK_DIVIDER_REG_3 1 0 5 NA
1x CLOCK_DIVIDER_REG_LOW 5 0 9 NA
Table 5.1 – Breakdown of FPGA Usage of the Mitigated CAN Controller Post-Synthesis
and mitigated CAN controllers were connected in a single design. A message was then
transmitted from the original CAN controller to the mitigated CAN controller. Once the
message was copied into the FIFO buffer, the data was read back. To facilitate the injection
errors the run.do file generated for the simulation was modified to change the values of the
outputs of the registers.
Addr Original
Data
Changed
Data
Word
Bit
Flip
Data
Bit
Flip
Parity
Bit
Flip
Flip
0x14 111011011011 111011011111 3 1 0 ⇒ 1
0x15 001011001001 001011011001 5 2 0 ⇒ 1
0x16 010100110001 010100100001 5 2 1 ⇒ 0
0x17 011111001011 011110001011 7 4 1 ⇒ 0
0x18 100101011011 100101011010 1 1 0 ⇒ 1
0x19 101111101010 101111101000 2 2 0 ⇒ 1
0x1A 110111110010 110101110010 8 4 1 ⇒ 0
0x1B 111100001000 111100001010 2 2 1 ⇒ 0
0x1C 000001111111 000101111110 1, 9 5 1 Both
0x1D 111011101111 111011101111
Table 5.2 – Contents of the CAN FIFO
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 5. RESULTS 82
Figure E.1 in Appendix E shows the waveform diagram of this simulation. Since each
read transaction on the AMBA bus took two clock cycles to complete, the data was forced
to change one clock cycle after the address was put on the address bus. The fifo signal
represents the word coming from the FIFO buffer. Halfway through the read operation, the
change in data can be observed. The data_out_fifo signal represents the data coming out
of the FIFO after being decoded. The Hamming code is able to correct one bit in the word.
From Figure E.1 it is clear that the decoded data from the Hamming code decoder is correct
whenever a single bit is flipped. At address 0x1C, two bits were flipped which resulted in
the data coming from the FIFO buffer being incorrect.
The position[x] signals at the bottom of the simulation represent which bit in the word
is incorrect. From Figure E.1 the position of the changed bit matches that in Table 5.2,
except in the case of address 0x1C. Since the Hamming code can only correct 1 bit, the two
incorrect bits resulted in the wrong bit being corrected. The incorrect bit was identified as
bit 8 in the word.
The bit_x_pos_match signals represent which data bit is incorrect. These signals correctly
flip the correct data bit when they are flagged as incorrect. At address 0x1C, the error in
data bit 5 was not detected and resulted in the incorrect bit going out of the FIFO buffer.
Since both the data FIFO buffer and length FIFO buffer use Hamming code encoders and
decoders, this proof confirms both FIFO buffers are operating correctly.
5.2.2 Triple Modular Redundancy on Registers
After mitigation of the CAN controller several registers had a triplicated design with recovery
functionality. Simulation of the CAN controller’s Bus Timing 0 register can be found in
Figure E.2 in Appendix E.
Initially a value of 01000011 was loaded into the Bus Timing 0 register, and after it was
written, it was read back unchanged. When another read operation was initiated, the
first of the three registers was forced to a value of 01000010. The error_bank_0_w signal
was raised, indicating that there was an error with the last bit. After combining all the
error signals, the error_combined indicated that there was a fault in the memory. This
triggered the reg_enable signal to go high, forcing the data to be re-written. The effect can
unfortunately not be seen, as the value was forced to a 0 value by the test-bench. Although
the value of the single register has changed, the output remains correct.
A third read operation was then initiated with two of the three registers being forced to
01000010. Similar to the previous case, all the error signals triggered correctly. This time,
due to the majority voter voting that the incorrect signal is actually correct, it changed its
output. On the next rising edge of the clock signal, the reg_enable signal was already high
and the new value was clocked into the registers. This is verified by the third of the three
registers changing its value, since it was not forced to a value. When the data was clocked
into the registers the error signals immediately lowered, indicating that there was a match
in the data. When the forced signals where released, all three registers have assumed the
new correct value.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 5. RESULTS 83
5.2.3 Mitigated CAN Controller
Using the developed test-bench, both the mitigated and the unmitigated CAN controllers
behaved exactly the same when simulating the mitigated CAN controller along with the
original CAN controller.
Figure E.3 in Appendix E shows the simulation during which both unmitigated and mitig-
ated CAN controllers transmit and receive a message. The simulation starts off by initiating
both CAN controllers to the same configuration, with the exception of the acceptance fil-
ters. First, the unmitigated CAN controller transmits a message to which the mitigated
CAN controller acknowledges receipt of the message. The unmitigated CAN controller then
signals an interrupt that it has completed transmission, while the mitigated CAN controller
signals an interrupt that it has received a message. Comparing the transmitted message to
the received one showed that the values are the same.
The same process was then repeated, with reversed roles with the same results. This shows
that the mitigated CAN controller functions the same as the original CAN controller.
5.3 Radiation Testing
Since the radiation tests were done at a late stage of this project, it was limited to a single
sequence of tests.
5.3.1 Pre Radiation Tests
Prior to the actual testing, two tests were run to check the functionality of everything prior
to the DUT being radiated. At this time, the radiation beam was in the process of being
defocussed. To do this, the beam was set to a 2 nA particle current, and directed through
a crystal. Using a camera mounted above the beam entrance hole, the crystal could be
monitored which would glow when radiated.
Figure 5.1 – Image of Defocussed Beam as seen in the Control Room
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 5. RESULTS 84
Figure 5.1 was taken from the monitor in the control room. The hole in the middle of the
crystal has a diameter of 3 mm. The beam is estimated to be defocused to a diameter of
roughly 13 mm. While this radius is not bigger than the FPGA package, it should be bigger
than the die, which was estimated as roughly 5 mm x 5 mm square from a picture [74]. A
later dissection of the FPGA revealed that the size is actually 8 mm x 8 mm as in Figure
5.2. Once the beam was defocused, actual testing could begin.
Figure 5.2 – X-Ray Image of ProASIC3 A3PE1500 FPGA Showing the Die Size
While the operators were busy defocusing the beam, the FPGA was positioned at a distance
of roughly 30 cm from the beam, parallel to it. In theory, scattering of particles could
influence the FPGA at this stage, but the possibility of it happening was low. When
defocusing the beam during Francois’ tests, only 1.18 nA was measured at the output of
the vacuum chamber when applying a 2 nA beam current. The other 40% was lost due to
scattering.
During the first 90 seconds of the first test, a few reading errors occurred when reading
the ID 0 register from the local CAN controller. At the 90 second mark, multiple errors
occurred. When inspecting the log files, it became clear that the command to put all the
CAN controllers into reset had not gone through. Thus, reading back the acceptance codes
and masks, returned the values of the current window in the receive buffer. A similar error
occurred a few seconds later. None of these errors can be considered as being upsets, since the
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 5. RESULTS 85
DUT was not being radiated. During the second test similar errors occurred. These errors
can be attributed to crosstalk on the FPGA bus, interrupts on the Core8051s overriding
other interrupts, errors on the serial communication connection or memory corruption of
the software running on the computer.
5.3.2 Actual Radiation Test
The required radiation test time was predetermined to roughly two minutes, as this is the
period which it takes for each CAN controller to transmit and receive ten messages using the
test software. For radiation testing, the initial beam current was set to 0.1 nA as this was
the lowest current possible that could be delivered while staying stable to within a variation
of about 10%. As with the preliminary tests, some errors were logged by the testing software
that turned out not to be errors. See Table F.1 and Table F.2 in Appendix F for a log of
the radiation testing.
When confirming the receive buffer for the message that was transmitted, it was found
that the message sequence was incorrect. In the second test, the local CAN controller,
mitigated CAN controller and unmitigated CAN controller responded with the contents of
their receive buffers. The log from the communication port showed that the addresses sent
from the computer, matched the incoming addresses from the CAN controllers. It can be
concluded that there was some form of corruption in the test program. Because of this,
most of the random errors were ignored.
Another frequent occurring error was the mismatch of the ID 1 register. This error showed
up in all tests and occurred mostly in the local CAN controller. This error can be ignored,
because the local CAN controller was not radiated.
During the third test errors on all three devices were noticed. Initially it was thought that
one of the CAN controllers held the bus in contention or that one of the transceivers had
failed. Inspection of the logs showed that the status register of each of the CAN controllers
indicated that transmission was completed and that there was data in the FIFO buffers. The
possibility that all three CAN controllers show the same errors is low. The only conclusion
that can be made is that the controlling FPGA had been upset. For this reason, a power
cycle was performed to reset the controlling FPGA.
During the fourth test a similar trend was noticed. The failures started with mixed data
being logged by the test program when reading the local CAN controller’s receive buffer.
This was followed by errors in all the CAN controllers, with no common cause. Data varied
with changes of more than four bits and in more than 30% of the cases the value zero was
read.
During the fifth test functionality seemed to have returned to normal. At the beginning of
the test, an upset occurred in the mode register of the unmitigated CAN controller. This
upset remained in the CAN controller for the remainder of the tests. The error on the ID 0
register also returned, but in total, the errors were about 80% less than the previous tests.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 5. RESULTS 86
For the sixth test the beam current was increased to 0.2 nA to determine if there was any
change in the upset rate. A significant increase in upsets in the unmitigated CAN controller
was noticed.
Register Init R1 R2 R3 R4 R5 R6 R7 R8 R9
Interrupt Enable 255 255 255 191 191 39 39 39 38 32
Bus Timing 0 199 199 199 135 199 199 199 134 134 4
Bus Timing 1 37 37 37 37 37 39 39 37 2 0
Acceptance Code 0 167 5 5 4 4 4 4 4 4 0
Acceptance Code 1 160 168 166 166 166 36 36 36 36 4
Acceptance Code 2 18 176 176 176 160 160 160 160 132 4
Acceptance Code 3 48 138 138 138 136 136 136 128 128 0
Acceptance Mask 0 0 103 103 38 38 38 38 38 38 32
Acceptance Mask 1 255 172 172 172 172 38 38 46 38 36
Acceptance Mask 2 255 183 186 186 170 162 170 170 170 36
Acceptance Mask 3 255 173 173 172 172 166 174 174 174 40
RX Error Count 0 0 0 135 133 5 5 4 4 4
TX Error Count 0 0 0 168 168 168 168 128 128 128
Table 5.3 – Unmitigated CAN Controller Register Values
Register Init R1 R2 R3 R4 R5 R6 R7 R8 R9
Interrupt Enable 255 255 255 255 255 255 255 255 255 255
Bus Timing 0 199 199 199 199 199 199 199 199 199 199
Bus Timing 1 37 37 37 37 37 37 37 37 37 37
Acceptance Code 0 168 168 168 168 168 168 168 168 168 168
Acceptance Code 1 160 160 160 160 160 160 160 160 160 160
Acceptance Code 2 18 18 18 18 18 18 18 18 18 18
Acceptance Code 3 48 048 48 48 48 48 48 48 48 48
Acceptance Mask 0 0 0 0 0 0 0 0 0 0 0
Acceptance Mask 1 255 255 255 255 255 255 255 255 255 255
Acceptance Mask 2 255 255 255 255 255 255 255 255 255 255
Acceptance Mask 3 255 255 255 255 255 255 255 255 255 255
RX Error Count 0 0 0 0 0 0 0 0 0 0
TX Error Count 0 0 0 0 0 0 0 0 0 0
Table 5.4 – Mitigated CAN Controller Register Values
Table 5.3 shows the register values for the unmitigated CAN controller after each round
during the final test, while Table 5.3 shows the register values for the mitigated CAN
controller. The headings, R1 to R9 represents the reading taken at the end of each round
of messaging during the final test. From the table it is clear that the upset rate of the
unmitigated CAN controller has increased significantly. In previous tests a single upset
was noticed, but after a total of 8 minutes and 27 seconds of radiation using a 0.1 nA
beam current, the increase in beam current to 0.2 nA proved fatal for the unmitigated
CAN controller. A total of 102 single bit upsets were identified during the 2 minute test.
Significantly, no upsets were noticed in the mitigated CAN controller. This is conclusive
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 5. RESULTS 87
proof that the use of a combination of mitigation techniques led to a more resistant CAN
controller, while still maintaining a smaller footprint than TMR.
5.3.3 Post Radiation Tests
Immediately after completion of the tests, Francois attempted to reconfigured the board for
his tests. Before reconfiguration started, the current supplied to the core of the DUT FPGA
was around 26 mA, more than double the original 11 mA. With prior TID tests on a similar
FPGA, the core current went up to 6 times the original current, before the FPGA itself
started to fail. One can come to the conclusion that the device was damaged by radiation,
but probably not to the point of failure.
Attempting to program the DUT FPGA failed during the erase phase. Trying to read back
and verify the design after the erase failed, showing that the previous programmed design
had been altered. In the data sheet of the FPGA, Actel suggests that the programming
circuitry be tied to ground to avoid damage to the charge pumps. Since the board needed
to be reconfigured without breaking the vacuum, the programming circuitry had to remain
connected to the power source. During Francois’ tests using a second PCB, the charge
pumps failed between 1 and 4 minutes of radiation time.
It was decided to run a few tests to see whether the design was still functional. From the
first second of the test, the mitigated CAN controller was unresponsive. All attempts at
reading the registers returned 0 on the data bus. Meanwhile, the unmitigated CAN controller
responded when reading the configuration registers, but seemed to have some blocks missing,
as it was unable to receive a message correctly. This shows that the attempt to reprogram
the device started out correctly, with the charge pumps failing somewhere during the erase
process meaning that the charge pumps were merely weakened by the radiation, and failed
only when stress was applied.
5.3.4 Summary
Many errors were logged during radiation testing. While the serial port logs indicated
that the data was mainly intact, the only conclusion that can be made is that there was a
problem with the integrity of the software running on the controlling FPGA or computer.
The randomness of the errors is not indicative of a specific problem.
From the results of the first 5 tests, it is not clear that there is much difference in the upset
resistance of the CAN controllers. Test 6, however, clearly showed continuous upsets in the
unmitigated CAN controller, indicating that the mitigated CAN controller is more resistant
to SEEs.
Stellenbosch University  http://scholar.sun.ac.za
Chapter 6
Conclusions
In this chapter, conclusions about the results of testing will be made. Possible further
work that can to be done if this project is used as the base for future projects, will also be
discussed.
6.1 Overview
After thorough analysis of the requirements for both the collaborative projects, a suitable
test rig was developed. Despite several challenges, the board eventually offered the required
testing capabilities.
Stemming from the SET filter using GG, the SET filter as developed by Dr. Farouk Smith,
offered a simple solution to filter out single event transients. Through analysis and simu-
lation, it was found that the number of delay elements required to filter out all transients
significantly slowed down the maximum operating frequency of the FPGA design.
Hamming codes proved to be an efficient way to protect large amounts of memory. A low
footprint asynchronous implementation was developed which encoded and decoded the data
as it was being written to or read from memory. Through simulation it was shown that the
implementation worked with a minimal delay being added.
Triple modular redundancy remains the best mitigation technique to protect against the
effects of radiation. A self-recovering TMR circuit was developed for registers which hold
data for long periods of time. Using simulation, the recovery circuit proved to be successful
in repairing faulty register values.
Using a combination of the above techniques, the Verilog implementation of the Phillips
SJA1000 CAN controller was sufficiently protected from radiation. SET Filters were used
to filter out single event transients entering the CAN controller on all input pins. Hamming
codes were used to protect the FIFO buffer which stores incoming messages. Self-recovering
triple modular redundancy was used to protect configuration registers, while normal triple
modular redundancy was used to protect several crucial sub-components of the CAN con-
troller. The logic cell usage was slightly above the 200% target set out at the beginning of
the project, at 216%.
88
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 6. CONCLUSIONS 89
Through simulation it was proven that the self-recovering triple modular redundant registers
were capable of recovering from a register upset without having any impact on the behaviour
of the CAN controller. Similarly, the Hamming code implementation which was used to
protect the FIFO buffer, proved successful.
Through actual testing in a radiation environment, it was found that the CAN controller
was more resistant to upsets, once it was mitigated.
6.2 Further Work
Despite all the work done, there is still room for improvement. It would be possible to
decrease area usage further, and implement it on a more resistant FPGA.
6.2.1 Practical Solution
To improve the viability of a CAN controller in an FPGA, it should occupy a small footprint,
and offer a high level of resistance. Two solutions are suggested below.
6.2.1.1 Implement Design on a Smaller IC
The M1/AGL1000 FPGA is available on the FG144 package, offering 13 824 logic cells on
a 13mm x 13mm BGA. It is the smallest FPGA available that could host a mitigated CAN
controller.
This FPGA is Cortex-M1 enabled and has enough extra logic to implement a soft-core
processor or at least a small state machine. Together with the transceiver, the footprint will
be quite small and could actually become a viable solution for use inside a satellite.
6.2.1.2 Implement Design on a Radiation Hardened IC
Microsemi also offers a range of radiation hardened FPGAs [75] which have a high resistance
to SEEs. These have an SEU rate of less than 1E-10 errors per bit per day. These readings
are for worst case in geostationary orbit satellites.
The Microsemi RTAX2000S/SL FPGA has a footprint of roughly 32.5 mm by 32.5 mm in
a BGA package. It offers 10 752 register elements and 21 504 combinational elements.
While more than four times the area of the smaller IC suggested previously, the extra
resistance against SEEs may be required.
6.2.2 Optimization of design
To fit the design onto the smallest FPGA, the design of the CAN controller can further be
optimized. Some components can be removed and some altered to create a more efficient
design capable of running on a smaller FPGA that consumes less power.
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 6. CONCLUSIONS 90
6.2.2.1 Internal SRAM with EDAC
Both the M1/AGL1000 and the RTAX2000S/SL have more than 50 kbit of internal RAM.
It would be possible, after some modification, to use the internal RAM modules instead of
implementing the register elements in the FPGA fabric. Not only will this speed up the
design, but the fixed width of these modules make it ideal for implementing EDAC. While
Hamming codes were used in this project, other encoding schemes such as Reed-Solomon or
Convolutional code could also be investigated.
6.2.2.2 Decrease size of the Information FIFO
While the data FIFO is 64 bytes in size, the 64 byte size of the length FIFO is unnecessary.
For every CAN message, the message ID and all the data is stored. The message header
will always consist of two header bytes or more, containing the ID, RTR and Data bytes
count. Therefore, the data buffer should be at least twice the size of the length buffer. It
is therefore possible to decrease the size of the length FIFO, should a smaller design be
required.
6.2.2.3 Removal of External Clock Generator
For the SJA1000 CAN controller as a physical IC, the external clock could be used for slow
speed peripherals requiring a clock signal. For the FPGA implementation however, this is
not required. Most FPGAs have access to a Phase Locked Loop (PLL), used to condition
the clock signal input to the FPGA. These PLLs often have more than one output that can
be configured at different frequencies. Even if there is no PLL present, building a counter
to scale down the input clock is a trivial task. As the external clock output from the CAN
controller is not used internally, it can safely be removed, reducing the required area for the
CAN controller.
6.2.3 Alterations to FPGA Radiation Test Board
Should the hardware design of this project be used as the basis for similar future projects,
certain alterations should be made to the design.
6.2.3.1 Use of Cortex-M1 Enabled Device
During the design of the FPGA radiation test board, it was chosen to use a Cortex-M1
enabled FPGA to simplify the design by making a processor available which does not use
logic cells. Since the FPGAs used were not Cortex-M1 enabled, the processor could not be
used. Although a solution has been created, it is inefficient and use of the Cortex-M1 is
strongly suggested.
The Core8051s only uses one bank of the flash and SRAM ICs added to the board, and does
not use the full amount of memory available. It also inserts a wait state when reading from
the memory, decreasing the operating frequency of the Core8051s. Since the Core8051s
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 6. CONCLUSIONS 91
does not have access to the AHB bus, the use of the Ethernet controller proved hard to
accomplish.
These drawbacks should prove that it is of the utmost importance that the FPGAs, when
ordered, are indeed Cortex-M1 enabled.
6.2.4 Minor alterations to the board
While the board was able to function correctly, some minor changes to the design are
suggested.
1. Pull reset line high to the Controller 3.3V line, instead of to the DUT.
This was a simple design error. When the controller turns the DUT off, the reset line
is also pulled low, resetting the controller.
2. Separate the write, read, and chip select lines to each memory bank.
Should the Core8051s be used in future designs, having two separate memory banks
could be beneficial. It would allow an AHB bus to be inserted with the Core10100APB
as its master, allowing the Ethernet controller access to SRAM memory.
3. Use a four layer PCB instead of two.
The use of a multilayer board could help with the crosstalk problems experienced when
interfacing between the two FPGAs. It could also help decrease the size of the PCB
by allowing more optimized routing.
4. Add current measuring to the controller PSU
An increase in the 1.5 V current measurements will give an indication whether the
controlling FPGA has been negatively affected by the radiation.
5. Add voltage dividers to all voltages going to the ADC
The ADC is only able to sample relative to its supply voltage. With the current design,
the ADC draws power from the 3.3 V line, while trying to sample 3.3 V from the DUT
PSU. This results in the ADC saturating.
6.2.5 JTAG Chain and Programming Safety
From the data sheet of the Actel range of FPGAs and from results of tests in this project, it
is clear that the charge pump used to erase the device is a volatile component of the FPGA.
Actel suggests connecting the supply pins of the charge pumps to ground when the FPGA is
not being programmed. To prevent damage to the device, the supply to the charge pumps
should be configurable.
It would also be beneficial to create a JTAG chain between the devices. This would allow
a single programmer to be used through a single connection to the testing chamber. To
ensure that programming succeeds, the controlling FPGA should be connected last in the
Stellenbosch University  http://scholar.sun.ac.za
CHAPTER 6. CONCLUSIONS 92
JTAG chain. When using Actel’s FlashPro software to program a chain of FPGAs, the last
FPGA is programmed first. Should programming of a device fail, FlashPro will stop the
entire process and slave devices will not be programmed.
When using a chain between FPGAs to program, the supply can easily be connected to
ground by inserting a dummy connector into the external connection. If programming is
required, external power can be used to power the charge pumps. This will probably protect
the charge pumps from being damaged by radiation.
6.2.6 Alterations to mitigation scheme applied to the CAN controller
After radiation testing was completed, an issue surrounding the mitigation scheme applied
was raised.
6.2.6.1 Protection of the command register
During the writing of the thesis, the issue surrounding the protection of the command
register was raised. While commands are cleared shortly after being written, an upset is
able to trigger a command. The command register is only cleared if a command has been
written to the register.
To avoid an upset from triggering a command, the register should be duplicated, and the
output of the two registers should be combined with an AND gate. The likelihood of two
registers experiencing the same upset is unlikely. If a command is being written to the
command register, both registers would contain a logic ’1’. The AND gate will ensure that
the command only passes through when a command has been written to the register. An
XOR gate can also be used in combination with an OR gate to clear the command
Stellenbosch University  http://scholar.sun.ac.za
Bibliography
[1] NASA: Space Math - The Deadly Van Allen Belts. Available at: http://spacemath.
gsfc.nasa.gov/weekly/3Page7.pdf, [2013, November 18], .
[2] Balasubramanian, A., Bhuva, B.L., Black, J.D. and Massengill, L.W.: RHBD
Techniques for Mitigating Effects of Single-Event Hits Using Guard-Gates. Nuclear
Science, IEEE Transactions, vol. 52, no. 6, pp. 2531–2535, December 2005.
[3] Smith, F.: A new methodology for single event transient suppression in flash FPGAs.
ELSEVIER Microprocessors and Microsystems, vol. 37, no. 3, pp. 313–318, May 2013.
[4] Bark, R.: Radioactive Beam Proposal for iThemba LABS. Available at: http://www.
tlabs.ac.za/pdf/RIB/RobWorkshop2011.pdf, [2013, November 27], 2011.
[5] Mohor, I.: CAN Protocol Controller. Available at: http://opencores.org/project,
can, [2013, November 06], March 2009.
[6] Herveille, R.: Wishbone B3: WISHBONE System-on-Chip (SoC) Interconnection
Architecture for Portable IP Cores. Tech. Rep., OpenCores, 2010.
[7] Mostert, S.: Sumbandilasat - An operational technology demonstrator. Acta Astro-
nautica, vol. 63, pp. 1273–1282, December 2008.
[8] Surrey Satellite Technology US LLC: SSTL-300 Satellite Platform. Available at: http:
//rsdo.gsfc.nasa.gov/images/catalog2010/SSTL300.pdf, [2013, November 18].
[9] MIT Satellite Team: Avionics. Available at: http://satellite.mit.edu/avionics.
php, [2013, November 18].
[10] ISIS: CubeSatShop. Available at: http://www.cubesatshop.com, [2013, November
18], .
[11] ISIS: CubeSatShop - ISIS VHF downlink / UHF uplink Full Duplex Transceiver.
Available at: http://www.cubesatshop.com/index.php?page=shop.product_
details&flypage=flypage.tpl&product_id=73&category_id=5&keyword=
i2c&option=com_virtuemart&Itemid=67, [2013, November 18], .
[12] ISIS: CubeSatShop - CubeComputer. Available at: http://www.cubesatshop.
com/index.php?page=shop.product_details&flypage=flypage.tpl&product_
93
Stellenbosch University  http://scholar.sun.ac.za
BIBLIOGRAPHY 94
id=106&category_id=8&keyword=i2c&option=com_virtuemart&Itemid=75, [2013,
November 18], .
[13] ISIS: CubeSatShop - CubeSense. Available at: http://www.cubesatshop.com/
index.php?page=shop.product_details&flypage=flypage.tpl&product_id=
107&category_id=7&keyword=i2c&option=com_virtuemart&Itemid=69, [2013,
November 18], .
[14] SunSpace: Sumbandilasat Mission Blog. Available at: http://sumbandilamission.
blogspot.com/, [2013, November 18], March 2010.
[15] NASA: The Atmospheric Filter. Available at: http://er.jsc.nasa.gov/seh/Space_
Astronomy_Teacher_Guide_Part_2.pdf, [2013, October 17], .
[16] NASA: Space Based Astronomy. Available at: http://er.jsc.nasa.gov/seh/Space_
Astronomy_Teacher_Guide_Part_1.pdf, [2013, October 17], .
[17] Sharma: Atomic and Nuclear Physics. Pearson Education India, 2008.
[18] Ackermann, M.: Detection of Characteristic Pion-Decay Signature in Supernova
Remnants. American Association of the Advancement of Science, vol. 339, pp. 807–811,
2013.
[19] Nerlich, S.: Astronomy Without A Telescope - Oh-My-God Particles. June 2011.
[20] Bothmer, V.: Solar Corona, Solar Wind Structure and Solar Particle Events. Avail-
able at: http://www.esa-spaceweather.net/spweather/workshops/proceedings_
w1/SESSION3/bothmer_solar.pdf, [2013, November 18], August 2005.
[21] Reames, D.V.: Solar Energetic Particle Variations. Tech. Rep., NASA, 2003.
[22] Peterson, E.: Single Event Effects in Aerospace. Wiley, 2011.
[23] Holbert, K.E.: Radiation Effects and Damage. Available at: http://holbert.
faculty.asu.edu/eee560/RadiationEffectsDamage.pdf, [2013, November 21].
[24] CERN: Radiation Hardness Assurance. Available at: http://lhcb-elec.web.cern.
ch/lhcb-elec/html/radiation_hardness.htm, [2013, November 21], 2011.
[25] Leppälä, K. & Verkasalo, R.: Protection of Instrument Control Computers against Soft
and Hard Errors and Cosmic Ray Effects. Tech. Rep., Technical Research Centre of
Finland, 1989.
[26] Neudeck, P.G.: Silicon Carbide Technology. Available at: http://www.grc.nasa.gov/
WWW/SiC/publications/CRCChapter2ndEd.pdf, [2013, November 27], October 2006.
[27] Danchenko, V.: Radiation hardening of MOS devices by boron. Available at: http:
//adsabs.harvard.edu/abs/1975nasa.reptQ....D, [2013, November 27].
Stellenbosch University  http://scholar.sun.ac.za
BIBLIOGRAPHY 95
[28] MIT: The Basics of Boron Neutron Capture Therapy. Available at: http://web.mit.
edu/nrl/www/bnct/info/description/description.html, [2013, November 27].
[29] Sinclair, R.: High Speed, Radiation Hard MRAM Buffer. Available at: http://www.
nve.com/Downloads/sinclair-11-02.pdf, [2013, November 27], November 2002.
[30] Wikipedia: Submarine Command System. Available at: http://en.wikipedia.org/
wiki/Submarine_Command_System, [2013, November 21].
[31] Teifel, J.: Self-Voting Dual-Modular-Redundancy Circuits for Single-Event-Transient
Mitigation. IEEE Transactions on Nuclear Science, vol. 55, pp. 3435–3439, 2008.
[32] Rezgui, S., Wang, J., Tung, E.C., Cronquist, B. and McCollum, J.: New Methodologies
for SET Characterization and Mitigation in Flash-Based FPGAs. Nuclear Science,
IEEE Transactions, vol. 54, no. 6, pp. 2512–2524, December 2007.
[33] Rezgui, S.: Configuration and Routing Effects on the SET Propagation in Flash-Based
FPGAs. IEEE Transactions on Nuclear Science, vol. 55, pp. 3328–3335, 2008.
[34] IBM: Fault Tolerance Decision in DRAM Applications. Tech. Rep., International Busi-
ness Machines Corp, 1997.
[35] Palsetia, D.: Error Detection and Correction. Available at: http://www.cis.upenn.
edu/~palsetia/cit595s08/Lectures08/ErrorCD.pdf, [2013, October 14], 2008.
[36] Downey, T.: Calculating the Hamming Code. Available at: http://users.cis.fiu.
edu/~downeyt/cop3402/hamming.html, [2013, September 08], 2000.
[37] Fiedler, J.: Hamming Codes. Available at: http://orion.math.iastate.edu/
linglong/Math690F04/HammingCodes.pdf, [2013, September 08], 2004.
[38] European Space Agency: Space Introduction. Available at: http://www.spacewire.
esa.int/content/Home/HomeIntro.php, [2013, November 21].
[39] European Cooperation for Space Standardization: Space Engineering - SpaceWire
- Links, Nodes, Routers, and Networks. Available at: http://snebulos.mit.
edu/projects/reference/NASA-Generic/ECSS-E-40-12A.pdf, [2013, November 21],
January 2003.
[40] Maxim Integrated: Determining Clock Accuracy Requirements for UART
Communications. Available at: http://www.maximintegrated.com/app-notes/
index.mvp/id/2141, [2013, November 21], August 2003.
[41] Schwerdtfeger, M.: SPI - Serial Peripheral Interface. Available at: http://www.mct.
net/faq/spi.html, [2013, November 21], 2006.
[42] NXP Semiconductors: I2C-bus specification and user manual. Available at: http:
//www.nxp.com/documents/other/UM10204_v5.pdf, [2013, November 20], October
2012.
Stellenbosch University  http://scholar.sun.ac.za
BIBLIOGRAPHY 96
[43] CiA: CAN History. Available at: http://www.can-cia.de/index.php?id=161, [2013,
November 20].
[44] Microsemi: Neutron-induced single event upset (seu) faq. Online, August 2011.
[45] Mountain, R.: FPGA IRRADIATION @ NPTC-MGH. Available at:
http://indico.cern.ch/getFile.py/access?contribId=3&resId=1&materialId=
slides&confId=140340, [2013, November 20], July 2011.
[46] Electronics Weekly: Is Flash FPGA A Good Idea. Avail-
able at: http://www.electronicsweekly.com/mannerisms/markets/
is-flash-fpga-a-good-idea-2009-10/, [2013, November 21], October 2009.
[47] Microsemi Corporation: ProASIC3 FPGA Overview. Available at: http://
www.microsemi.com/products/fpga-soc/fpga/proasic3-overview, [2013, Novem-
ber 21], 2013.
[48] Microsemi Corporation: Fusion Mixed Signal FPGAs. Available at: http://www.
microsemi.com/products/fpga-soc/fpga/fusion, [2013, November 21], 2013.
[49] Microsemi Corporation: SmarFFPGAs SoC FPGAs. Available at: http://www.
microsemi.com/products/fpga-soc/soc-fpga/smartfusion, [2013, November 21],
2013.
[50] OpenCores: Soc Interconnection: Wishbone. Available at: http://opencores.org/
opencores,wishbone, [2013, October 24], June 2010.
[51] Herveille, R.: Combining WISHBONE Interface Signals. Tech. Rep., OpenCores, 2001.
[52] Intel: MCS-51 Family of Single Chip Microcomputers User’s Manual. Intel Corporation,
1981.
[53] ARM: AMBA Test Interface Driver. Available at: http://infocenter.arm.com/help/
topic/com.arm.doc.ddi0046c/DDI0046_amba_ti_driver_ds.pdf, [2013, November
20], 1996.
[54] ARM: AMBA Specification (Rev 2.0). Tech. Rep., ARM, 1999.
[55] LaBel, K.A.: Trade Space Involved with Single Event Upset (SEU) and Transient (SET)
handling of Field Programmable Gate Array (FPGA) Based Systems. In: NASA. 2006.
[56] iThemba LABS: Accelerators Overview. Available at: http://www.tlabs.ac.za/
accel.htm, [2013, November 21].
[57] F.Sturesson: Total Ionizing Dose (TID) Testing. Available at: http:
//space.epfl.ch/webdav/site/space/shared/industry_media/04%20TID%
20Testing%20F.Sturesson.pdf, [2013, November 21], June 2009.
Stellenbosch University  http://scholar.sun.ac.za
BIBLIOGRAPHY 97
[58] F.Sturesson: Single Event Effect (SEE) Testing. Available at: http:
//space.epfl.ch/webdav/site/space/shared/industry_media/08%20SEE%
20testing%20%20F.Sturesson.pdf, [2013, November 21], June 2009.
[59] Gaisler, J.: LEON SPARC Processor The past, present and future. Available at:
http://ramp.eecs.berkeley.edu/Publications/LEON3%20SPARC%20Processor,
%20The%20Past%20Present%20and%20Future.pdf, [2013, October 27].
[60] Young, R.: NASA GUIDELINES FOR BALL GRID ARRAY SELECTION AND
USE. Available at: https://nepp.nasa.gov/files/16205/05_014a%20Strickland%
20Report%201%20BGA%20Guidelines%20090706.doc, [2013, October 27], 06 2011.
[61] Microsemi Corporation: ProASIC3E Flash Family FPGAs. Avail-
able at: http://www.microsemi.com/document-portal/doc_download/
130701-proasic3e-flash-family-fpgas-datasheet, [2013, February 25].
A3PE1500.
[62] Texas Instruments: 3.3-V CAN TRANSCEIVERS. Available at: http://www.ti.com/
lit/ds/slls557f/slls557f.pdf, [2013, February 25], . SN65HVD233.
[63] AMIC Technology Corporation: 2M x 16 Bit x 4 Banks Synchronous DRAM. Available
at: http://www.amictechnology.com/datasheets/A43L3616A.pdf, [2013, February
25]. A43L4616AV7F.
[64] Micron Technology Incorporated: Parallel NOR Flash Embedded Memory. Avail-
able at: http://www.micron.com/~/media/Documents/Products/Data%20Sheet/
NOR%20Flash/Serial%20NOR/M25P/M25P32.pdf, [2013, February 25], . M25P32-
VMF6P.
[65] Integrated Device Technology Incorporated: 3.3V CMOS Static RAM. Available
at: http://www.micron.com/~/media/Documents/Products/Data%20Sheet/DRAM/
128mb_x32_sdram.pdf, [2013, February 25]. IDT71V416L10PHGI.
[66] Micron Technology Incorporated: Parallel NOR Flash Embedded Memory. Available
at: http://www.micron.com/~/media/Documents/Products/Data%20Sheet/NOR%
20Flash/Parallel/M29W/M29W160E.pdf, [2013, February 25], . M29W160EB70N6F.
[67] Texas Instruments: DP83848C PHYTER Commercial Temperature Single Port 10/100
Mb/s Ethernet Physical Layer Transceiver. Available at: http://www.ti.com/lit/ds/
symlink/dp83848c.pdf, [2013, March 5], . DP83848C.
[68] Texas Instruments: High-Side Measurement CURRENT SHUNT MONITOR. Avail-
able at: http://www.ti.com/lit/ds/symlink/ina169.pdf, [2013, February 25], .
INA169.
[69] Maxim Integrated Products: 2.7V to 3.6V and 4.5V to 5.5V, Low-Power, 4-/12-Channel
2-Wire Serial 8-Bit ADCs. Available at: http://datasheets.maximintegrated.com/
en/ds/MAX1036-MAX1039M.pdf, [2013, February 25]. MAX1038EEE+.
Stellenbosch University  http://scholar.sun.ac.za
BIBLIOGRAPHY 98
[70] Atmel Corporation: 9- to 12-bit Selectable, 0.5oC Accurate Digital
Temperature Sensor. Available at: http://www.atmel.com/Images/
Atmel-8748-DTS-AT30TS75-Datasheet.pdf, [2013, February 25]. AT30TS75-SS8-B.
[71] Yaselli, I.: Report on the Effect of Radiation on Resistors and Capacitors for the HV
filter circuit of the Endcap VPT. Tech. Rep., Department of Electronic and Computing
Engineering Brunel University, 2004.
[72] Mentor Graphics Corporation: ModelSim SE Reference Manual. Avail-
able at: https://ece.uwaterloo.ca/~ece327/protected/modelsim/htmldocs/
modelsim_se_ref/nsmgchelp.htm, [2013, October 14], 2011.
[73] Future Technology Devices International Limited: Quad High Speed USB to
Multipurpose UART/MPSSE IC. Available at: http://www.ftdichip.com/Support/
Documents/DataSheets/ICs/DS_FT4232H.pdf, [2013, July 5]. FT4232H.
[74] Actel: Radiation-Tolerant ProASIC3 FPGAs Radiation Effects.
Available at: www.microsemi.com/document-portal/doc_download/
131374-radiation-tolerant-proasic3-fpgas-radiation-effects-report, [2013,
November 25], April 2010.
[75] Microsemi Corporation: RTAX-S/SL FPGAs. Available at: http://www.microsemi.
com/products/fpga-soc/radtolerant-fpgas/rtax-s-sl#overview, [2013, October
14], 2013.
Stellenbosch University  http://scholar.sun.ac.za
Appendices
99
Stellenbosch University  http://scholar.sun.ac.za
Appendix A
Work Distribution
As part of the combined effort in implementing the hardware, the work load was distributed
as in Table A.1.
Task Party
List initial hardware requirements Mr. E.J. Thesnaar
List additional hardware requirements for his project Mr. F.A. Nolte
Layout of PCB Mr. E.J. Thesnaar
Manufacture of PCB Trax Interconnect
Populating of PCB Mr. J. Arendse
Testing of most of first PCB during population Mr. E.J. Thesnaar
Design and implementation of Libero project for controlling
FPGA, including memory interface
Mr. E.J. Thesnaar
Development of the programming sprite Mr. E.J. Thesnaar
Testing of additional hardware for his project Mr. F.A. Nolte
Testing of second PCB during population Mr. F.A. Nolte
Design and manufacture of vacuum connector Mr. A. Barnard
Design and testing of testing environment set-up Mr. E.J. Thesnaar
Table A.1 – Distribution of tasks
100
Stellenbosch University  http://scholar.sun.ac.za
Appendix B
PCB Schematics
This page has been left blank intentionally.
101
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 102
11
22
33
44
D
D
C
C
B
B
A
A
Ti
tle
N
um
be
r
R
ev
is
io
n
Si
ze A
4
D
at
e:
20
14
/0
2/
05
Sh
ee
t  
  o
f
Fi
le
:
C
:\D
ro
pb
ox
\..
\T
O
P.
Sc
hD
oc
D
ra
w
n 
B
y:
B
U
S_
[5
0.
.0
]
C
A
N
_2
_T
X
C
A
N
_2
_R
X
C
A
N
_1
_T
X
_1
C
A
N
_1
_R
X
_1
FL
A
SH
_H
O
LD
n
FL
A
SH
_C
Sn
SP
I_
D
A
TA
IN
SP
I_
C
LK
SP
I_
D
A
TA
O
U
T
FL
A
SH
_W
Pn
SD
_[
15
..0
]
SA
_[
12
..0
]
W
En
C
A
Sn
R
A
Sn
C
Sn
C
K
E
C
LK
D
Q
M
L
D
Q
M
H
B
S0
B
S1
D
U
T
1_
D
U
T.
Sc
hD
oc
B
U
S_
[5
0.
.0
]
D
U
T_
PO
W
_E
N
A
B
LE
ET
H
[2
1.
.1
]
SD
A
SC
L
SR
A
M
_C
E_
N
SR
A
M
_W
E_
N
SR
A
M
_O
E_
N
SR
A
M
_S
R
B
S0
_N
SR
A
M
_S
R
B
S1
_N
SR
A
M
_S
R
B
S2
_N
SR
A
M
_S
R
B
S3
_N
FL
A
SH
_C
E_
N
FL
A
SH
_W
E_
N
FL
A
SH
_O
E_
N
FL
A
SH
_R
ST
_N
D
at
a_
[3
1.
.0
]
A
dd
r_
[1
9.
.0
]
C
A
N
_1
_T
X
_2
C
A
N
_1
_R
X
_2
C
O
N
2_
C
on
tro
lle
r.S
ch
D
oc
B
U
S_
[5
0.
.0
]
D
U
T_
PO
W
_E
N
A
B
LE
PO
W
3_
PO
W
ER
.S
ch
D
oc
SD
A
SC
L
M
O
N
4_
M
on
ito
rin
g.
Sc
hD
oc
C
A
N
_2
_T
X
C
A
N
_2
_R
X
C
A
N
_1
_T
X
_1
C
A
N
_1
_R
X
_1
CAN_1_TX_2
CAN_1_RX_2
X
V
R
5_
Tr
an
sc
ie
ve
rs
.S
ch
D
oc
ET
H
[2
1.
.1
]
IN
F
6_
In
te
rf
ac
e.
Sc
hD
oc
ET
H
[2
1.
.1
]
LE
D
7_
LE
D
.S
ch
D
oc
FL
A
SH
_C
Sn
SP
I_
D
A
TA
IN
SP
I_
C
LK
SP
I_
D
A
TA
O
U
T
FL
A
SH
_H
O
LD
n
FL
A
SH
_W
Pn
SD
_[
15
..0
]
SA
_[
12
..0
]
D
Q
M
L
W
En
C
A
Sn
R
A
Sn
C
Sn
C
K
E
C
LK
D
Q
M
H
B
S0
B
S1
M
EM
8_
M
em
or
y.
Sc
hD
oc
SR
A
M
_C
E_
N
SR
A
M
_W
E_
N
SR
A
M
_O
E_
N
SR
A
M
_S
R
B
S0
_N
SR
A
M
_S
R
B
S1
_N
SR
A
M
_S
R
B
S2
_N
SR
A
M
_S
R
B
S3
_N
FL
A
SH
_C
E_
N
FL
A
SH
_W
E_
N
FL
A
SH
_O
E_
N
FL
A
SH
_R
ST
_N
D
at
a_
[3
1.
.0
]
A
dd
r_
[1
9.
.0
]
9_
C
O
N
_M
EM
C
O
N
_M
EM
.S
ch
D
oc
SD
_[
15
..0
]
SA
_[
12
..0
] FP
G
A
 R
ad
ia
tio
n 
Te
st
 B
oa
rd
Em
ile
 T
he
sn
aa
r
10
1
V
1.
0
15
41
69
09
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
BU
S0
05
00
00
0
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
ET
H0
21
00
10
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SA
00
12
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
NL
SD
00
15
00
00
Figure B.1 – Connection of Sub-Parts of the Schematics
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 103
11
22
33
44
D
D
C
C
B
B
A
A
Ti
tle
N
um
be
r
R
ev
is
io
n
Si
ze A
4
D
at
e:
20
14
/0
2/
05
Sh
ee
t  
  o
f
Fi
le
:
C
:\D
ro
pb
ox
\..
\1
_D
U
T.
Sc
hD
oc
D
ra
w
n 
B
y:
G
N
D 0.
1u
F
C
1_
1
0.
1u
F
C
1_
2
0.
1u
F
C
1_
3
0.
1u
F
C
1_
4
0.
1u
F
C
1_
5
0.
1u
F
C
1_
6
0.
1u
F
C
1_
7
0.
1u
F
C
1_
8
0.
1u
F
C
1_
9
0.
1u
F
C
1_
10
0.
1u
F
C
1_
11
0.
1u
F
C
1_
12
0.
1u
F
C
1_
13
0.
1u
F
C
1_
14
0.
1u
F
C
1_
15
0.
1u
F
C
1_
16
0.
1u
F
C
1_
17
0.
1u
F
C
1_
18
0.
1u
F
C
1_
19
0.
1u
F
C
1_
20
0.
1u
F
C
1_
21
0.
1u
F
C
1_
22
0.
1u
F
C
1_
23
0.
1u
F
C
1_
24
G
N
D
G
N
D
0.
01
uF
C
1_
25
0.
33
uF
C
1_
26
F1
_T
C
K
F1
_T
D
I
F1
_T
M
S
F1
_V
PU
M
P
F1
_T
D
O
F1
_T
R
ST
F1
_V
JT
A
G
G
N
D
G
N
D
F1
_T
C
K
F1
_T
D
I
F1
_T
M
S
F1
_V
PU
M
P
F1
_T
D
O
F1
_T
R
ST
F1
_V
JT
A
G
0.
1u
F
C
1_
27
1KR
1_
3
1KR
1_
2
G
N
D
Li
nk
R
1_
1
Li
nk
R
1_
4
B
U
S_
8
B
U
S_
9
B
U
S_
10
B
U
S_
11
B
U
S_
12
B
U
S_
13
B
U
S_
14
B
U
S_
15
B
U
S_
16
B
U
S_
18
B
U
S_
19
B
U
S_
20
B
U
S_
21
B
U
S_
22
B
U
S_
23
B
U
S_
27
B
U
S_
28
B
U
S_
29
B
U
S_
30
B
U
S_
31
B
U
S_
32
B
U
S_
33
B
U
S_
34
B
U
S_
35
B
U
S_
36
B
U
S_
37
B
U
S_
38
B
U
S_
39
B
U
S_
41
B
U
S_
42
B
U
S_
43
B
U
S_
44
B
U
S_
45
B
U
S_
46
B
U
S_
47
B
U
S_
48
B
U
S_
49
B
U
S_
50
G
N
D
1_
C
LK
_1
00
M
H
z
1_
C
LK
_1
00
M
H
z
C
A
N
_2
_T
X
C
A
N
_2
_R
X
IO
 B
A
N
K
 3
G
A
B
2/
IO
22
0P
4
G
A
A
2/
IO
22
1P
5
IO
22
1N
6
IO
21
9N
8
G
A
C
2/
IO
21
9P
7
IO
21
2N
12
IO
20
8P
13
IO
20
8N
14
IO
20
4P
15
IO
20
0P
19
IO
20
0N
20
IO
21
5P
9
IO
21
5N
10
IO
19
6P
21
G
FC
1/
IO
19
2P
22
G
FB
1/
IO
19
1P
23
G
FB
0/
IO
19
1N
24
G
FA
0/
IO
19
0N
26
G
FA
2/
IO
18
9P
30
G
FA
1/
IO
19
0P
28
IO
18
8N
34
IO
18
7N
35
IO
18
4P
37
IO
18
4N
38
IO
18
0P
39
IO
18
9N
31
G
FC
2/
IO
18
7P
33
IO
17
6P
42
G
EC
0/
IO
16
9N
45
G
EB
1/
IO
16
8P
46
G
EA
1/
IO
16
7P
47
G
EB
0/
IO
16
8N
48
G
EA
0/
IO
16
7N
49
IO
17
6N
43
G
EC
1/
IO
16
9P
44
IO
21
2P
11
G
FB
2/
IO
18
8P
32
FP
G
A
1_
1C
A
3P
E1
50
0-
PQ
20
8
IO
 B
A
N
K
 2
IO
16
6N
55
G
EA
2/
IO
16
6P
56
IO
16
5N
57
G
EB
2/
IO
16
5P
58
G
EC
2/
IO
16
4P
60
IO
16
4N
59
IO
15
7N
66
IO
15
3N
67
IO
15
3P
68
IO
14
9N
69
IO
14
9P
70
IO
14
5N
73
IO
16
3P
61
IO
16
1P
63
IO
14
5P
74
IO
14
3N
75
IO
14
3P
76
IO
13
7N
77
IO
13
7P
78
IO
13
5P
80
IO
13
5N
79
IO
12
9P
85
IO
12
7N
86
IO
12
7P
87
IO
12
1N
90
IO
12
1P
91
IO
13
1N
82
IO
12
9N
84
IO
11
9N
92
G
D
C
2/
IO
11
3P
95
IO
11
2N
96
G
D
B
2/
IO
11
2P
98
G
D
A
2/
IO
11
1P
99
IO
11
9P
93
IO
11
3N
94
IO
15
7N
64
IO
13
1P
83
FP
G
A
1_
1D
A
3P
E1
50
0-
PQ
20
8
IO
 B
A
N
K
 1
G
D
A
0/
IO
11
0N
11
2
G
D
B
0/
IO
10
9N
11
3
G
D
A
1/
IO
11
0P
11
4
G
D
C
0/
IO
08
N
P
11
6
G
D
C
1/
IO
10
8P
11
7
G
D
B
1/
IO
10
9P
11
5
IO
10
1P
12
1
G
C
C
2/
IO
90
P
12
4
G
C
B
2/
IO
89
P
12
5
IO
88
N
12
7
G
C
A
2/
IO
88
P
12
8
G
C
A
1/
IO
87
P
12
9
IO
10
5N
11
8
IO
10
5P
11
9
G
C
A
0/
IO
87
N
13
2
G
C
B
0/
IO
86
N
13
4
G
C
B
1/
IO
86
P
13
5
IO
83
N
13
7
G
C
C
1/
IO
85
P
13
6
IO
73
P
14
4
IO
71
N
14
5
IO
71
P
14
6
IO
67
N
14
7
IO
67
P
14
8
IO
83
P
13
8
IO
73
N
14
3
IO
65
N
14
9
G
B
A
2/
IO
58
P
15
2
G
B
B
2/
IO
59
P
15
3
IO
65
P
15
0
G
B
C
2/
IO
60
P
15
1
IO
10
1N
12
0
IO
81
P
13
9
FP
G
A
1_
1E
A
3P
E1
50
0-
PQ
20
8
IO
 B
A
N
K
 0
G
B
A
1/
IO
57
P
15
9
G
B
A
0/
IO
57
N
16
0
G
B
B
1/
IO
56
P
16
1
G
B
B
0/
IO
56
N
16
3
G
B
C
0/
IO
55
N
16
5
G
B
C
1/
IO
55
P
16
4
IO
47
N
16
9
IO
43
P
17
2
IO
41
P
17
3
IO
41
N
17
4
IO
35
P
17
5
IO
35
N
17
6
IO
51
P
16
6
IO
51
N
16
7
IO
31
P
17
7
IO
31
N
17
9
IO
29
P
18
0
IO
29
N
18
1
IO
27
P
18
2
IO
23
P
18
4
IO
27
N
18
3
IO
15
P
19
0
IO
15
N
19
1
IO
12
P
19
2
IO
11
P
19
3
IO
11
N
19
4
IO
23
N
18
5
IO
18
N
18
9
IO
08
P
19
6
IO
05
N
19
9
G
A
C
1/
IO
02
P
20
1
G
A
C
0/
IO
02
N
20
2
G
A
B
1/
IO
01
P
20
3
G
A
B
0/
IO
01
N
20
4
IO
08
N
19
7
IO
05
P
19
8
IO
47
P
16
8
IO
18
P
18
8
G
A
A
1/
IO
00
P
20
5
G
A
A
0/
IO
00
N
20
6
FP
G
A
1_
1F
A
3P
E1
50
0-
PQ
20
8
B
U
S_
40
G
N
D
1
G
N
D
17
V
C
O
M
PL
F
25
G
N
D
29
G
N
D
41
G
N
D
Q
51
G
N
D
52
G
N
D
65
G
N
D
81
G
N
D
97
G
N
D
Q
10
0
G
N
D
10
5
G
N
D
Q
10
7
G
N
D
12
2
G
N
D
13
0
G
N
D
Q
15
5
G
N
D
15
6
G
N
D
16
2
G
N
D
17
8
G
N
D
19
5
G
N
D
Q
20
7
V
C
C
16
V
C
C
IB
7
18
V
C
C
PL
F
27
V
C
C
36
V
C
C
IB
6
40
V
M
V
6
50
V
M
V
5
53
V
C
C
IB
5
62
V
C
C
71
V
C
C
IB
5
72
V
C
C
88
V
C
C
IB
4
89
V
C
C
IB
3
12
3
V
C
C
IB
2
14
0
V
C
C
14
2
V
C
C
IB
1
17
0
V
C
C
17
1
V
C
C
IB
0
18
6
V
C
C
18
7
V
C
C
IB
0
20
0
V
M
V
0
20
8
V
M
V
2
15
4
V
M
V
1
15
7
V
M
V
4
10
4
1V
5
3V
3
G
ro
un
d
Po
w
er
G
N
D
Q
15
8
G
N
D
14
1
V
C
O
M
PL
C
13
3
G
N
D
Q
54
G
N
D
Q
2
V
M
V
7
3
V
M
V
3
11
1
V
C
C
13
1
FP
G
A
1_
1A A
3P
E1
50
0-
PQ
20
8
TC
K
10
1
TD
I
10
2
TM
S
10
3
V
PU
M
P
10
6
TD
O
10
8
TR
ST
10
9
V
JT
A
G
11
0
JT
A
G
FP
G
A
1_
1B
A
3P
E1
50
0-
PQ
20
8
0.
1u
F
C
1_
28
0.
1u
F
C
1_
29
0.
1u
F
C
1_
30
1_
C
LK
_1
00
M
H
z
G
N
D
U
A
R
T_
2_
R
X
U
A
R
T_
2_
TX
U
A
R
T_
3_
R
X
U
A
R
T_
3_
TX
LE
D
1_
5
LE
D
1_
6
LE
D
1_
7
LE
D
1_
8
U
A
R
T_
2_
R
X
U
A
R
T_
2_
TX
U
A
R
T_
3_
R
X
U
A
R
T_
3_
TX
LE
D
1_
5
LE
D
1_
6
LE
D
1_
7
LE
D
1_
8
EN
1
G
N
D
2
3V
3
4
C
LK
3
X
1_
1
10
0M
H
z 
X
o
TP
1_
1
Te
st
Po
in
t
TC
K
1
G
N
D
2
TD
O
3
N
C
4
TM
S
5
V
jta
g
6
V
pu
m
p
7
TR
ST
8
TD
I
9
G
N
D
10
JP
1_
1
FL
A
SH
Pr
o3
1
1
2
2
3
3
4
4
5
5
6
6
7
7
8
8
9
9
10
10
JP
1_
2
2x
5
FL
A
SH
_H
O
LD
n
FL
A
SH
_C
Sn
SP
I_
D
A
TA
O
U
T
SP
I_
C
LK
SP
I_
D
A
TA
IN
FL
A
SH
_W
Pn
SA
_1
0
SA
_0
SA
_1
SA
_2
SD
_[
15
..0
]
SA
_[
12
..0
]
W
En
C
A
Sn
R
A
Sn
C
Sn
C
K
E
C
LK
SA
_[
12
..0
]
SD
_[
15
..0
]
SA
_3
SA
_4
SA
_5
SA
_6
SA
_7
SA
_8
SA
_9
SD
_1
4
SD
_1
3
SD
_1
2
SD
_1
1
SD
_1
0
SD
_9
SD
_1
5
SD
_7
SD
_6
SD
_5
SD
_4
SD
_3
SD
_2
SD
_1
SD
_0
SD
_8
SA
_1
1
B
U
S_
3
B
U
S_
4
B
U
S_
5
B
U
S_
6
B
U
S_
7
B
U
S_
0
B
U
S_
1
B
U
S_
2
B
U
S_
24
B
U
S_
25
B
U
S_
26 C
A
N
_1
_T
X
_1
C
A
N
_1
_R
X
_1
D
Q
M
L
D
Q
M
H
B
S0
B
S1
SA
_1
2
1
1
2
2
3
3
4
4
5
5
6
6
7
7
8
8
9
9
10
10
11
11
12
12
13
13
14
14
15
15
16
16
JP
1_
3
1x
16
G
N
D
G
N
D
1
2
PB
1_
1
Pu
sh
B
ut
to
n
1KR
1_
5
G
N
D
BUS_50
1V
5_
D
U
T
3V
3_
D
U
T
3V
3_
D
U
T
1V
5_
D
U
T
3V
3_
D
U
T
3V
3_
D
U
T
3V
3_
D
U
T
3V
3_
D
U
T
3V
3_
D
U
T
B
U
S_
17
B
U
S_
[5
0.
.0
]
B
U
S_
[5
0.
.0
]
D
ev
ic
e 
U
nd
er
 T
es
t
Em
ile
 T
he
sn
aa
r
10
2
V
1.
0
15
41
69
09
PIC10101PIC10102
CO
C1
01
PIC10201PIC10202
CO
C1
02
PIC10301PIC10302
CO
C1
03
PIC10401PIC10402
CO
C1
04
PIC10501PIC10502
CO
C1
05
PIC10601PIC10602
CO
C1
06
PIC10701PIC10702
CO
C1
07
PIC10801PIC10802
CO
C1
08
PIC10901PIC10902
CO
C1
09
PIC101001PIC101002
CO
C1
01
0
PIC101101PIC101102
CO
C1
01
1
PIC101201PIC101202
CO
C1
01
2
PIC101301PIC101302
CO
C1
01
3
PIC101401PIC101402
CO
C1
01
4
PIC101501PIC101502
CO
C1
01
5
PIC101601PIC101602
CO
C1
01
6
PIC101701PIC101702
CO
C1
01
7
PIC101801PIC101802
CO
C1
01
8
PIC101901PIC101902
CO
C1
01
9
PIC102001PIC102002
CO
C1
02
0
PIC102101PIC102102
CO
C1
02
1
PIC102201PIC102202
CO
C1
02
2
PIC102301PIC102302
CO
C1
02
3
PIC102401PIC102402
CO
C1
02
4
PIC102501PIC102502
CO
C1
02
5
PIC102601PIC102602
CO
C1
02
6
PIC
102
701
PIC
102
702CO
C1
02
7
PIC102801PIC102802
CO
C1
02
8
PIC102901PIC102902
CO
C1
02
9
PIC103001PIC103002
CO
C1
03
0
PI
FP
GA
10
10
1
PI
FP
GA
10
10
2
PI
FP
GA
10
10
3
PI
FP
GA
10
10
16
PI
FP
GA
10
10
17
PI
FP
GA
10
10
18
PI
FP
GA
10
10
25
PI
FP
GA
10
10
27
PI
FP
GA
10
10
29
PI
FP
GA
10
10
36
PI
FP
GA
10
10
40
PI
FP
GA
10
10
41
PI
FP
GA
10
10
50
PI
FP
GA
10
10
51
PI
FP
GA
10
10
52
PI
FP
GA
10
10
53
PI
FP
GA
10
10
54
PI
FP
GA
10
10
62
PI
FP
GA
10
10
65
PI
FP
GA
10
10
71
PI
FP
GA
10
10
72
PI
FP
GA
10
10
81
PI
FP
GA
10
10
88
PI
FP
GA
10
10
89
PI
FP
GA
10
10
97
PI
FP
GA
10
10
10
0
PI
FP
GA
10
10
10
4
PI
FP
GA
10
10
10
5
PI
FP
GA
10
10
10
7
PI
FP
GA
10
10
11
1
PI
FP
GA
10
10
12
2
PI
FP
GA
10
10
12
3
PI
FP
GA
10
10
13
0
PI
FP
GA
10
10
13
1
PI
FP
GA
10
10
13
3
PI
FP
GA
10
10
14
0
PI
FP
GA
10
10
14
1
PI
FP
GA
10
10
14
2
PI
FP
GA
10
10
15
4
PI
FP
GA
10
10
15
5
PI
FP
GA
10
10
15
6
PI
FP
GA
10
10
15
7
PI
FP
GA
10
10
15
8
PI
FP
GA
10
10
16
2
PI
FP
GA
10
10
17
0
PI
FP
GA
10
10
17
1
PI
FP
GA
10
10
17
8
PI
FP
GA
10
10
18
6
PI
FP
GA
10
10
18
7
PI
FP
GA
10
10
19
5
PI
FP
GA
10
10
20
0
PI
FP
GA
10
10
20
7
PI
FP
GA
10
10
20
8
CO
FP
GA
10
1A
PI
FP
GA
10
10
10
1
PI
FP
GA
10
10
10
2
PI
FP
GA
10
10
10
3
PI
FP
GA
10
10
10
6
PI
FP
GA
10
10
10
8
PI
FP
GA
10
10
10
9
PI
FP
GA
10
10
11
0
CO
FP
GA
10
1B
PI
FP
GA
10
10
4
PI
FP
GA
10
10
5
PI
FP
GA
10
10
6
PI
FP
GA
10
10
7
PI
FP
GA
10
10
8
PI
FP
GA
10
10
9
PI
FP
GA
10
10
10
PI
FP
GA
10
10
11
PI
FP
GA
10
10
12
PI
FP
GA
10
10
13
PI
FP
GA
10
10
14
PI
FP
GA
10
10
15
PI
FP
GA
10
10
19
PI
FP
GA
10
10
20
PI
FP
GA
10
10
21
PI
FP
GA
10
10
22
PI
FP
GA
10
10
23
PI
FP
GA
10
10
24
PI
FP
GA
10
10
26
PI
FP
GA
10
10
28
PI
FP
GA
10
10
30
PI
FP
GA
10
10
31
PI
FP
GA
10
10
32
PI
FP
GA
10
10
33
PI
FP
GA
10
10
34
PI
FP
GA
10
10
35
PI
FP
GA
10
10
37
PI
FP
GA
10
10
38
PI
FP
GA
10
10
39
PI
FP
GA
10
10
42
PI
FP
GA
10
10
43
PI
FP
GA
10
10
44
PI
FP
GA
10
10
45
PI
FP
GA
10
10
46
PI
FP
GA
10
10
47
PI
FP
GA
10
10
48
PI
FP
GA
10
10
49
CO
FP
GA
10
1C
PI
FP
GA
10
10
55
PI
FP
GA
10
10
56
PI
FP
GA
10
10
57
PI
FP
GA
10
10
58
PI
FP
GA
10
10
59
PI
FP
GA
10
10
60
PI
FP
GA
10
10
61
PI
FP
GA
10
10
63
PI
FP
GA
10
10
64
PI
FP
GA
10
10
66
PI
FP
GA
10
10
67
PI
FP
GA
10
10
68
PI
FP
GA
10
10
69
PI
FP
GA
10
10
70
PI
FP
GA
10
10
73
PI
FP
GA
10
10
74
PI
FP
GA
10
10
75
PI
FP
GA
10
10
76
PI
FP
GA
10
10
77
PI
FP
GA
10
10
78
PI
FP
GA
10
10
79
PI
FP
GA
10
10
80
PI
FP
GA
10
10
82
PI
FP
GA
10
10
83
PI
FP
GA
10
10
84
PI
FP
GA
10
10
85
PI
FP
GA
10
10
86
PI
FP
GA
10
10
87
PI
FP
GA
10
10
90
PI
FP
GA
10
10
91
PI
FP
GA
10
10
92
PI
FP
GA
10
10
93
PI
FP
GA
10
10
94
PI
FP
GA
10
10
95
PI
FP
GA
10
10
96
PI
FP
GA
10
10
98
PI
FP
GA
10
10
99
CO
FP
GA
10
1D
PI
FP
GA
10
10
11
2
PI
FP
GA
10
10
11
3
PI
FP
GA
10
10
11
4
PI
FP
GA
10
10
11
5
PI
FP
GA
10
10
11
6
PI
FP
GA
10
10
11
7
PI
FP
GA
10
10
11
8
PI
FP
GA
10
10
11
9
PI
FP
GA
10
10
12
0
PI
FP
GA
10
10
12
1
PI
FP
GA
10
10
12
4
PI
FP
GA
10
10
12
5
PI
FP
GA
10
10
12
7
PI
FP
GA
10
10
12
8
PI
FP
GA
10
10
12
9
PI
FP
GA
10
10
13
2
PI
FP
GA
10
10
13
4
PI
FP
GA
10
10
13
5
PI
FP
GA
10
10
13
6
PI
FP
GA
10
10
13
7
PI
FP
GA
10
10
13
8
PI
FP
GA
10
10
13
9
PI
FP
GA
10
10
14
3
PI
FP
GA
10
10
14
4
PI
FP
GA
10
10
14
5
PI
FP
GA
10
10
14
6
PI
FP
GA
10
10
14
7
PI
FP
GA
10
10
14
8
PI
FP
GA
10
10
14
9
PI
FP
GA
10
10
15
0
PI
FP
GA
10
10
15
1
PI
FP
GA
10
10
15
2
PI
FP
GA
10
10
15
3
CO
FP
GA
10
1E
PI
FP
GA
10
10
15
9
PI
FP
GA
10
10
16
0
PI
FP
GA
10
10
16
1
PI
FP
GA
10
10
16
3
PI
FP
GA
10
10
16
4
PI
FP
GA
10
10
16
5
PI
FP
GA
10
10
16
6
PI
FP
GA
10
10
16
7
PI
FP
GA
10
10
16
8
PI
FP
GA
10
10
16
9
PI
FP
GA
10
10
17
2
PI
FP
GA
10
10
17
3
PI
FP
GA
10
10
17
4
PI
FP
GA
10
10
17
5
PI
FP
GA
10
10
17
6
PI
FP
GA
10
10
17
7
PI
FP
GA
10
10
17
9
PI
FP
GA
10
10
18
0
PI
FP
GA
10
10
18
1
PI
FP
GA
10
10
18
2
PI
FP
GA
10
10
18
3
PI
FP
GA
10
10
18
4
PI
FP
GA
10
10
18
5
PI
FP
GA
10
10
18
8
PI
FP
GA
10
10
18
9
PI
FP
GA
10
10
19
0
PI
FP
GA
10
10
19
1
PI
FP
GA
10
10
19
2
PI
FP
GA
10
10
19
3
PI
FP
GA
10
10
19
4
PI
FP
GA
10
10
19
6
PI
FP
GA
10
10
19
7
PI
FP
GA
10
10
19
8
PI
FP
GA
10
10
19
9
PI
FP
GA
10
10
20
1
PI
FP
GA
10
10
20
2
PI
FP
GA
10
10
20
3
PI
FP
GA
10
10
20
4
PI
FP
GA
10
10
20
5
PI
FP
GA
10
10
20
6
CO
FP
GA
10
1F
P
I
JP
10
10
1
P
I
JP
10
10
2
P
I
JP
10
10
3
P
I
JP
10
10
4
P
I
JP
10
10
5
P
I
JP
10
10
6
P
I
JP
10
10
7
P
I
JP
10
10
8
P
I
JP
10
10
9
PI
JP
10
10
10
CO
JP
101
P
I
J
P
1
0
2
0
1
P
I
J
P
1
0
2
0
2
P
I
J
P
1
0
2
0
3
P
I
J
P
1
0
2
0
4
P
I
J
P
1
0
2
0
5
P
I
J
P
1
0
2
0
6
P
I
J
P
1
0
2
0
7
P
I
J
P
1
0
2
0
8
P
I
J
P
1
0
2
0
9
P
I
J
P
10
20
10
CO
JP
10
2
P
I
J
P
1
03
01
P
I
J
P
1
03
02
P
I
J
P
1
03
03
P
I
J
P
1
03
04
P
I
J
P
1
03
05
P
I
J
P
1
03
06
P
I
J
P
1
03
07
P
I
J
P
1
03
08
P
I
J
P
1
03
09
P
I
JP
10
30
10
P
I
JP
10
30
11
P
I
JP
10
30
12
P
I
JP
10
30
13
P
I
JP
10
30
14
P
I
JP
10
30
15
P
I
JP
10
30
16
CO
JP
103
P
I
P
B
10
10
1
P
I
P
B
10
10
2
CO
PB
10
1
PIR
101
01
PIR
101
02CO
R1
01
PIR
102
01
PIR
102
02CO
R1
02
PIR10301PIR10302 C
OR
10
3
PIR10401PIR10402 C
OR
10
4
PIR
105
01
PIR
105
02
CO
R1
05
P
I
T
P
10
10
1
CO
TP
10
1 PI
X
1
0
1
0
1
P
I
X
1
0
1
0
2
P
I
X
1
0
1
0
3
P
I
X
1
0
1
0
4
CO
X1
01
PI
FP
GA
10
10
11
2
P
I
T
P
10
10
1
P
I
X
1
0
1
0
3
NL
10
CL
K0
10
0M
Hz
PIC101702
PIC101802
PIC101902
PIC102002
PIC102102
PIC102202
PIC102302
PIC102402
PIC103002
PI
FP
GA
10
10
16
PI
FP
GA
10
10
27
PI
FP
GA
10
10
36
PI
FP
GA
10
10
71
PI
FP
GA
10
10
88
PI
FP
GA
10
10
13
1
PI
FP
GA
10
10
14
2
PI
FP
GA
10
10
17
1
PI
FP
GA
10
10
18
7
PIC10102
PIC10202
PIC10302
PIC10402
PIC10502
PIC10602
PIC10702
PIC10802
PIC10902
PIC101002
PIC101102
PIC101202
PIC101302
PIC101402
PIC101502
PIC101602
PIC102802
PIC102902
PI
FP
GA
10
10
3
PI
FP
GA
10
10
18
PI
FP
GA
10
10
40
PI
FP
GA
10
10
50
PI
FP
GA
10
10
53
PI
FP
GA
10
10
62
PI
FP
GA
10
10
72
PI
FP
GA
10
10
89
PI
FP
GA
10
10
10
4
PI
FP
GA
10
10
11
1
PI
FP
GA
10
10
12
3
PI
FP
GA
10
10
14
0
PI
FP
GA
10
10
15
4
PI
FP
GA
10
10
15
7
PI
FP
GA
10
10
17
0
PI
FP
GA
10
10
18
6
PI
FP
GA
10
10
20
0
PI
FP
GA
10
10
20
8
P
I
J
P
10
20
10
PIR
101
01
PIR10402
PIR
105
02
P
I
X
1
0
1
0
4
PI
FP
GA
10
10
10
1
P
I
JP
10
10
1
PIR
102
02
NL
F1
0T
CK
PI
FP
GA
10
10
10
2
P
I
JP
10
10
9
NL
F1
0T
DI
PI
FP
GA
10
10
10
8
P
I
JP
10
10
3
NL
F1
0T
DO
PI
FP
GA
10
10
10
3
P
I
JP
10
10
5
NL
F1
0T
MS
PI
FP
GA
10
10
10
9
P
I
JP
10
10
8
PIR10302
NL
F1
0T
RS
T
PIC
102
702
PI
FP
GA
10
10
11
0
P
I
JP
10
10
6
PIR
101
02
NL
F1
0V
JT
AG
PIC102502
PIC102602
PI
FP
GA
10
10
10
6
P
I
JP
10
10
7
PIR10401
NL
F1
0V
PU
MP
PIC10101
PIC10201
PIC10301
PIC10401
PIC10501
PIC10601
PIC10701
PIC10801
PIC10901
PIC101001
PIC101101
PIC101201
PIC101301
PIC101401
PIC101501
PIC101601
PIC101701
PIC101801
PIC101901
PIC102001
PIC102101
PIC102201
PIC102301
PIC102401
PIC102501
PIC102601
PIC
102
701
PIC102801
PIC102901
PIC103001
PI
FP
GA
10
10
1
PI
FP
GA
10
10
2
PI
FP
GA
10
10
17
PI
FP
GA
10
10
25
PI
FP
GA
10
10
29
PI
FP
GA
10
10
41
PI
FP
GA
10
10
51
PI
FP
GA
10
10
52
PI
FP
GA
10
10
54
PI
FP
GA
10
10
65
PI
FP
GA
10
10
81
PI
FP
GA
10
10
97
PI
FP
GA
10
10
10
0
PI
FP
GA
10
10
10
5
PI
FP
GA
10
10
10
7
PI
FP
GA
10
10
12
2
PI
FP
GA
10
10
13
0
PI
FP
GA
10
10
13
3
PI
FP
GA
10
10
14
1
PI
FP
GA
10
10
15
5
PI
FP
GA
10
10
15
6
PI
FP
GA
10
10
15
8
PI
FP
GA
10
10
16
2
PI
FP
GA
10
10
17
8
PI
FP
GA
10
10
19
5
PI
FP
GA
10
10
20
7
P
I
JP
10
10
2
PI
JP
10
10
10
P
I
J
P
1
0
2
0
9
P
I
J
P
1
03
01
P
I
JP
10
30
16
P
I
P
B
10
10
1
PIR
102
01
PIR10301
P
I
X
1
0
1
0
2
PI
FP
GA
10
10
11
8
P
I
J
P
1
0
2
0
5
NL
LE
D1
05
PI
FP
GA
10
10
11
7
P
I
J
P
1
0
2
0
6
NL
LE
D1
06
PI
FP
GA
10
10
12
0
P
I
J
P
1
0
2
0
7
NL
LE
D1
07
PI
FP
GA
10
10
11
9
P
I
J
P
1
0
2
0
8
NL
LE
D1
08
PI
FP
GA
10
10
4
P
I
J
P
1
03
02
PI
FP
GA
10
10
5
P
I
J
P
1
03
03
PI
FP
GA
10
10
6
P
I
J
P
1
03
04
PI
FP
GA
10
10
7
P
I
J
P
1
03
05
PI
FP
GA
10
10
8
P
I
J
P
1
03
06
PI
FP
GA
10
10
9
P
I
J
P
1
03
07
PI
FP
GA
10
10
10
P
I
J
P
1
03
08
PI
FP
GA
10
10
11
P
I
J
P
1
03
09
PI
FP
GA
10
10
12
P
I
JP
10
30
10
PI
FP
GA
10
10
13
P
I
JP
10
30
11
PI
FP
GA
10
10
14
P
I
JP
10
30
12
PI
FP
GA
10
10
15
P
I
JP
10
30
13
PI
FP
GA
10
10
19
P
I
JP
10
30
14
PI
FP
GA
10
10
20
P
I
JP
10
30
15
PI
FP
GA
10
10
21
PI
FP
GA
10
10
22
PI
FP
GA
10
10
23
PI
FP
GA
10
10
24
PI
FP
GA
10
10
26
PI
FP
GA
10
10
28
PI
FP
GA
10
10
30
PI
FP
GA
10
10
31
PI
FP
GA
10
10
32
PI
FP
GA
10
10
33
PI
FP
GA
10
10
34
PI
FP
GA
10
10
35
PI
FP
GA
10
10
37
PI
FP
GA
10
10
38
PI
FP
GA
10
10
39
PI
FP
GA
10
10
42
PI
FP
GA
10
10
43
PI
FP
GA
10
10
67
P
O
D
Q
M
H
PI
FP
GA
10
10
68
P
O
C
L
K
PI
FP
GA
10
10
69
P
O
C
K
E
PI
FP
GA
10
10
80
P
O
D
Q
M
L
PI
FP
GA
10
10
82
P
O
W
E
n
PI
FP
GA
10
10
83
P
O
C
A
S
n
PI
FP
GA
10
10
84
P
O
R
A
S
n
PI
FP
GA
10
10
85
P
O
C
S
n
PI
FP
GA
10
10
86
P
O
B
S
0
PI
FP
GA
10
10
87
P
O
B
S
1
PI
FP
GA
10
10
95
PI
FP
GA
10
10
96
PI
FP
GA
10
10
98
PI
FP
GA
10
10
99
PI
FP
GA
10
10
19
2 P
O
S
P
I
0D
AT
AO
UT
PI
FP
GA
10
10
19
3 P
O
S
P
I
0
C
L
K
PI
FP
GA
10
10
19
4 P
O
F
L
A
S
H
0H
OL
Dn
PI
FP
GA
10
10
19
6 P
O
F
L
A
S
H
0
W
P
n
PI
FP
GA
10
10
19
7 P
O
S
P
I
0
D
A
T
A
I
N
PI
FP
GA
10
10
19
8 P
O
F
L
A
S
H
0
C
S
n
PI
FP
GA
10
10
19
9
PI
FP
GA
10
10
20
1
PI
FP
GA
10
10
20
2
PI
FP
GA
10
10
20
3 P
O
C
A
N
0
1
0
R
X
0
1
PI
FP
GA
10
10
20
4 P
O
C
A
N
0
1
0
T
X
0
1
PI
FP
GA
10
10
20
5 P
O
C
A
N
0
2
0
R
X
PI
FP
GA
10
10
20
6 P
O
C
A
N
0
2
0
T
X
P
I
JP
10
10
4
P
I
X
1
0
1
0
1
PI
FP
GA
10
10
11
4
P
I
J
P
1
0
2
0
1
NL
UA
RT
02
0R
X
PI
FP
GA
10
10
11
3
P
I
J
P
1
0
2
0
2
NL
UA
RT
02
0T
X
PI
FP
GA
10
10
11
6
P
I
J
P
1
0
2
0
3
NL
UA
RT
03
0R
X
PI
FP
GA
10
10
11
5
P
I
J
P
1
0
2
0
4
NL
UA
RT
03
0T
X
PI
FP
GA
10
10
19
1
NL
BU
S0
05
00
00
0
NL
BU
S0
0 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
19
0
NL
BU
S0
05
00
00
0
NL
BU
S0
1 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
18
9
NL
BU
S0
05
00
00
0
NL
BU
S0
2 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
18
8
NL
BU
S0
05
00
00
0
NL
BU
S0
3 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
18
5
NL
BU
S0
05
00
00
0
NL
BU
S0
4 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
18
4
NL
BU
S0
05
00
00
0
NL
BU
S0
5 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
18
3
NL
BU
S0
05
00
00
0
NL
BU
S0
6 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
18
2
NL
BU
S0
05
00
00
0
NL
BU
S0
7 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
18
1
NL
BU
S0
05
00
00
0
NL
BU
S0
8 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
18
0
NL
BU
S0
05
00
00
0
NL
BU
S0
9 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
17
9
NL
BU
S0
05
00
00
0
NL
BU
S0
10 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
17
7
NL
BU
S0
05
00
00
0
NL
BU
S0
11 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
17
6
NL
BU
S0
05
00
00
0
NL
BU
S0
12 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
17
5
NL
BU
S0
05
00
00
0
NL
BU
S0
13 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
17
4
NL
BU
S0
05
00
00
0
NL
BU
S0
14 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
17
3
NL
BU
S0
05
00
00
0
NL
BU
S0
15 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
17
2
NL
BU
S0
05
00
00
0
NL
BU
S0
16 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
16
9
NL
BU
S0
05
00
00
0
NL
BU
S0
17 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
16
8
NL
BU
S0
05
00
00
0
NL
BU
S0
18 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
16
7
NL
BU
S0
05
00
00
0
NL
BU
S0
19 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
16
6
NL
BU
S0
05
00
00
0
NL
BU
S0
20 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
16
5
NL
BU
S0
05
00
00
0
NL
BU
S0
21 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
16
4
NL
BU
S0
05
00
00
0
NL
BU
S0
22 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
16
3
NL
BU
S0
05
00
00
0
NL
BU
S0
23 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
16
1
NL
BU
S0
05
00
00
0
NL
BU
S0
24 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
16
0
NL
BU
S0
05
00
00
0
NL
BU
S0
25 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
15
9
NL
BU
S0
05
00
00
0
NL
BU
S0
26 PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
15
3
NL
BU
S0
05
00
00
0
NL
BU
S0
27
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
15
2
NL
BU
S0
05
00
00
0
NL
BU
S0
28
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
15
1
NL
BU
S0
05
00
00
0
NL
BU
S0
29
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
15
0
NL
BU
S0
05
00
00
0
NL
BU
S0
30
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
14
9
NL
BU
S0
05
00
00
0
NL
BU
S0
31
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
14
8
NL
BU
S0
05
00
00
0
NL
BU
S0
32
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
14
7
NL
BU
S0
05
00
00
0
NL
BU
S0
33
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
14
6
NL
BU
S0
05
00
00
0
NL
BU
S0
34
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
14
5
NL
BU
S0
05
00
00
0
NL
BU
S0
35
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
14
4
NL
BU
S0
05
00
00
0
NL
BU
S0
36
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
14
3
NL
BU
S0
05
00
00
0
NL
BU
S0
37
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
13
9
NL
BU
S0
05
00
00
0
NL
BU
S0
38
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
13
8
NL
BU
S0
05
00
00
0
NL
BU
S0
39
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
13
7
NL
BU
S0
05
00
00
0
NL
BU
S0
40
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
13
6
NL
BU
S0
05
00
00
0
NL
BU
S0
41
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
13
5
NL
BU
S0
05
00
00
0
NL
BU
S0
42
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
13
4
NL
BU
S0
05
00
00
0
NL
BU
S0
43
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
13
2
NL
BU
S0
05
00
00
0
NL
BU
S0
44
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
12
9
NL
BU
S0
05
00
00
0
NL
BU
S0
45
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
12
8
NL
BU
S0
05
00
00
0
NL
BU
S0
46
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
12
7
NL
BU
S0
05
00
00
0
NL
BU
S0
47
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
12
5
NL
BU
S0
05
00
00
0
NL
BU
S0
48
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
12
4
NL
BU
S0
05
00
00
0
NL
BU
S0
49
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
12
1
P
I
P
B
10
10
2PIR
105
01
NL
BU
S0
05
00
00
0
NLBUS050
PO
BU
S0
05
00
00
0
PI
FP
GA
10
10
91
NL
SA
00
12
00
00
NL
SA
00
PO
SA
00
12
00
00
PI
FP
GA
10
10
92
NL
SA
00
12
00
00
NL
SA
01
PO
SA
00
12
00
00
PI
FP
GA
10
10
93
NL
SA
00
12
00
00
NL
SA
02
PO
SA
00
12
00
00
PI
FP
GA
10
10
94
NL
SA
00
12
00
00
NL
SA
03
PO
SA
00
12
00
00
PI
FP
GA
10
10
79
NL
SA
00
12
00
00
NL
SA
04
PO
SA
00
12
00
00
PI
FP
GA
10
10
78
NL
SA
00
12
00
00
NL
SA
05
PO
SA
00
12
00
00
PI
FP
GA
10
10
77
NL
SA
00
12
00
00
NL
SA
06
PO
SA
00
12
00
00
PI
FP
GA
10
10
76
NL
SA
00
12
00
00
NL
SA
07
PO
SA
00
12
00
00
PI
FP
GA
10
10
75
NL
SA
00
12
00
00
NL
SA
08
PO
SA
00
12
00
00
PI
FP
GA
10
10
74
NL
SA
00
12
00
00
NL
SA
09
PO
SA
00
12
00
00
PI
FP
GA
10
10
90
NL
SA
00
12
00
00
NL
SA
01
0
PO
SA
00
12
00
00
PI
FP
GA
10
10
73
NL
SA
00
12
00
00
NL
SA
01
1
PO
SA
00
12
00
00
PI
FP
GA
10
10
70
NL
SA
00
12
00
00
NL
SA
01
2
PO
SA
00
12
00
00
PI
FP
GA
10
10
44
NL
SD
00
15
00
00
NL
SD
00
PO
SD
00
15
00
00
PI
FP
GA
10
10
45
NL
SD
00
15
00
00
NL
SD
01
PO
SD
00
15
00
00
PI
FP
GA
10
10
46
NL
SD
00
15
00
00
NL
SD
02
PO
SD
00
15
00
00
PI
FP
GA
10
10
47
NL
SD
00
15
00
00
NL
SD
03
PO
SD
00
15
00
00
PI
FP
GA
10
10
48
NL
SD
00
15
00
00
NL
SD
04
PO
SD
00
15
00
00
PI
FP
GA
10
10
49
NL
SD
00
15
00
00
NL
SD
05
PO
SD
00
15
00
00
PI
FP
GA
10
10
55
NL
SD
00
15
00
00
NL
SD
06
PO
SD
00
15
00
00
PI
FP
GA
10
10
56
NL
SD
00
15
00
00
NL
SD
07
PO
SD
00
15
00
00
PI
FP
GA
10
10
66
NL
SD
00
15
00
00
NL
SD
08
PO
SD
00
15
00
00
PI
FP
GA
10
10
64
NL
SD
00
15
00
00
NL
SD
09
PO
SD
00
15
00
00
PI
FP
GA
10
10
63
NL
SD
00
15
00
00
NL
SD
01
0
PO
SD
00
15
00
00
PI
FP
GA
10
10
61
NL
SD
00
15
00
00
NL
SD
01
1
PO
SD
00
15
00
00
PI
FP
GA
10
10
60
NL
SD
00
15
00
00
NL
SD
01
2
PO
SD
00
15
00
00
PI
FP
GA
10
10
59
NL
SD
00
15
00
00
NL
SD
01
3
PO
SD
00
15
00
00
PI
FP
GA
10
10
58
NL
SD
00
15
00
00
NL
SD
01
4
PO
SD
00
15
00
00
PI
FP
GA
10
10
57
NL
SD
00
15
00
00
NL
SD
01
5
PO
SD
00
15
00
00
P
O
B
S
0
P
O
B
S
1
P
O
B
U
S
0
0
P
O
B
U
S
0
1
P
O
B
U
S
0
2
P
O
B
U
S
0
3
P
O
B
U
S
0
4
P
O
B
U
S
0
5
P
O
B
U
S
0
6
P
O
B
U
S
0
7
P
O
B
U
S
0
8
P
O
B
U
S
0
9
P
O
B
U
S
0
1
0
P
O
B
U
S
0
1
1
P
O
B
U
S
0
1
2
P
O
B
U
S
0
1
3
P
O
B
U
S
0
1
4
P
O
B
U
S
0
1
5
P
O
B
U
S
0
1
6
P
O
B
U
S
0
1
7
P
O
B
U
S
0
1
8
P
O
B
U
S
0
1
9
P
O
B
U
S
0
2
0
P
O
B
U
S
0
2
1
P
O
B
U
S
0
2
2
P
O
B
U
S
0
2
3
P
O
B
U
S
0
2
4
P
O
B
U
S
0
2
5
P
O
B
U
S
0
2
6
P
O
B
U
S
0
2
7
P
O
B
U
S
0
2
8
P
O
B
U
S
0
2
9
P
O
B
U
S
0
3
0
P
O
B
U
S
0
3
1
P
O
B
U
S
0
3
2
P
O
B
U
S
0
3
3
P
O
B
U
S
0
3
4
P
O
B
U
S
0
3
5
P
O
B
U
S
0
3
6
P
O
B
U
S
0
3
7
P
O
B
U
S
0
3
8
P
O
B
U
S
0
3
9
P
O
B
U
S
0
4
0
P
O
B
U
S
0
4
1
P
O
B
U
S
0
4
2
P
O
B
U
S
0
4
3
P
O
B
U
S
0
4
4
P
O
B
U
S
0
4
5
P
O
B
U
S
0
4
6
P
O
B
U
S
0
4
7
P
O
B
U
S
0
4
8
P
O
B
U
S
0
4
9
P
O
B
U
S
0
5
0
PO
BU
S0
05
00
00
0
P
O
C
A
N
0
1
0
R
X
0
1
P
O
C
A
N
0
1
0
T
X
0
1
P
O
C
A
N
0
2
0
R
X
P
O
C
A
N
0
2
0
T
X
P
O
C
A
S
N
P
O
C
K
E
P
O
C
L
K
P
O
C
S
N
P
O
D
Q
M
H
P
O
D
Q
M
L
P
O
F
L
A
S
H
0
C
S
N
P
O
F
L
A
S
H
0H
OL
DN
P
O
F
L
A
S
H
0
W
P
N
P
O
R
A
S
N
P
O
S
A
0
0
P
O
S
A
0
1
P
O
S
A
0
2
P
O
S
A
0
3
P
O
S
A
0
4
P
O
S
A
0
5
P
O
S
A
0
6
P
O
S
A
0
7
P
O
S
A
0
8
P
O
S
A
0
9
P
O
S
A
0
1
0
P
O
S
A
0
1
1
P
O
S
A
0
1
2
PO
SA
00
12
00
00
P
O
S
D
0
0
P
O
S
D
0
1
P
O
S
D
0
2
P
O
S
D
0
3
P
O
S
D
0
4
P
O
S
D
0
5
P
O
S
D
0
6
P
O
S
D
0
7
P
O
S
D
0
8
P
O
S
D
0
9
P
O
S
D
0
1
0
P
O
S
D
0
1
1
P
O
S
D
0
1
2
P
O
S
D
0
1
3
P
O
S
D
0
1
4
P
O
S
D
0
1
5
PO
SD
00
15
00
00
P
O
S
P
I
0
C
L
K
P
O
S
P
I
0
D
A
T
A
I
N
P
O
S
P
I
0D
AT
AO
UT
P
O
W
E
N
Figure B.2 – Schematic of the Device Under Test FPGA showing I/O Connections, Crystal,
Decoupling Capacitor and Headers
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 104
11
22
33
44
D
D
C
C
B
B
A
A
Ti
tle
N
um
be
r
R
ev
is
io
n
Si
ze A
4
D
at
e:
20
14
/0
2/
05
Sh
ee
t  
  o
f
Fi
le
:
C
:\D
ro
pb
ox
\..
\2
_C
on
tro
lle
r.S
ch
D
oc
D
ra
w
n 
B
y:
0.
01
uF
C
2_
25
0.
33
uF
C
2_
26
F2
_T
C
K
F2
_T
D
I
F2
_T
M
S
F2
_V
PU
M
P
F2
_T
D
O
F2
_T
R
ST
F2
_V
JT
A
G
G
N
D
0.
1u
F
C
2_
27
1KR
2_
3
1KR
2_
2
G
N
D
Li
nk
R
2_
1
Li
nk
R
2_
4
G
N
D
F2
_T
C
K
F2
_T
D
I
F2
_T
M
S
F2
_V
PU
M
P
F2
_T
D
O
F2
_T
R
ST
F2
_V
JT
A
G
G
N
D
G
N
D
0.
1u
F
C
2_
1
0.
1u
F
C
2_
2
0.
1u
F
C
2_
3
0.
1u
F
C
2_
4
0.
1u
F
C
2_
5
0.
1u
F
C
2_
6
0.
1u
F
C
2_
7
0.
1u
F
C
2_
8
0.
1u
F
C
2_
9
0.
1u
F
C
2_
10
0.
1u
F
C
2_
11
0.
1u
F
C
2_
12
0.
1u
F
C
2_
13
0.
1u
F
C
2_
14
0.
1u
F
C
2_
15
0.
1u
F
C
2_
16
0.
1u
F
C
2_
17
0.
1u
F
C
2_
18
0.
1u
F
C
2_
19
0.
1u
F
C
2_
20
0.
1u
F
C
2_
21
0.
1u
F
C
2_
22
0.
1u
F
C
2_
23
0.
1u
F
C
2_
24
G
N
D
B
U
S_
8
B
U
S_
9
B
U
S_
10
B
U
S_
11
B
U
S_
12
B
U
S_
13
B
U
S_
14
B
U
S_
15
B
U
S_
16
B
U
S_
17
B
U
S_
18
B
U
S_
19
B
U
S_
20
B
U
S_
21
B
U
S_
22
3V
3_
1
SD
A
SD
A
SC
L
SC
L
G
N
D
2_
C
LK
_1
00
M
H
z
2_
C
LK
_1
00
M
H
z
DUT_POW_ENABLE
G
N
D
1
G
N
D
17
V
C
O
M
PL
F
25
G
N
D
29
G
N
D
41
G
N
D
Q
51
G
N
D
52
G
N
D
65
G
N
D
81
G
N
D
97
G
N
D
Q
10
0
G
N
D
10
5
G
N
D
Q
10
7
G
N
D
12
2
G
N
D
13
0
G
N
D
Q
15
5
G
N
D
15
6
G
N
D
16
2
G
N
D
17
8
G
N
D
19
5
G
N
D
Q
20
7
V
C
C
16
V
C
C
IB
7
18
V
C
C
PL
F
27
V
C
C
36
V
C
C
IB
6
40
V
M
V
6
50
V
M
V
5
53
V
C
C
IB
5
62
V
C
C
71
V
C
C
IB
5
72
V
C
C
88
V
C
C
IB
4
89
V
C
C
IB
3
12
3
V
C
C
IB
2
14
0
V
C
C
14
2
V
C
C
IB
1
17
0
V
C
C
17
1
V
C
C
IB
0
18
6
V
C
C
18
7
V
C
C
IB
0
20
0
V
M
V
0
20
8
V
M
V
2
15
4
V
M
V
1
15
7
V
M
V
4
10
4
1V
5
3V
3
G
ro
un
d
Po
w
er
G
N
D
Q
15
8
G
N
D
14
1
V
C
O
M
PL
C
13
3
G
N
D
Q
54
G
N
D
Q
2
V
M
V
7
3
V
M
V
3
11
1
V
C
C
13
1
FP
G
A
2_
1A A
3P
E1
50
0-
PQ
20
8
TC
K
10
1
TD
I
10
2
TM
S
10
3
V
PU
M
P
10
6
TD
O
10
8
TR
ST
10
9
V
JT
A
G
11
0
JT
A
G
FP
G
A
2_
1B
A
3P
E1
50
0-
PQ
20
8
IO
 B
A
N
K
 3
G
A
B
2/
IO
22
0P
4
G
A
A
2/
IO
22
1P
5
IO
22
1N
6
IO
21
9N
8
G
A
C
2/
IO
21
9P
7
IO
21
2N
12
IO
20
8P
13
IO
20
8N
14
IO
20
4P
15
IO
20
0P
19
IO
20
0N
20
IO
21
5P
9
IO
21
5N
10
IO
19
6P
21
G
FC
1/
IO
19
2P
22
G
FB
1/
IO
19
1P
23
G
FB
0/
IO
19
1N
24
G
FA
0/
IO
19
0N
26
G
FA
2/
IO
18
9P
30
G
FA
1/
IO
19
0P
28
IO
18
8N
34
IO
18
7N
35
IO
18
4P
37
IO
18
4N
38
IO
18
0P
39
IO
18
9N
31
G
FC
2/
IO
18
7P
33
IO
17
6P
42
G
EC
0/
IO
16
9N
45
G
EB
1/
IO
16
8P
46
G
EA
1/
IO
16
7P
47
G
EB
0/
IO
16
8N
48
G
EA
0/
IO
16
7N
49
IO
17
6N
43
G
EC
1/
IO
16
9P
44
IO
21
2P
11
G
FB
2/
IO
18
8P
32
FP
G
A
2_
1C
A
3P
E1
50
0-
PQ
20
8
IO
 B
A
N
K
 2
IO
16
6N
55
G
EA
2/
IO
16
6P
56
IO
16
5N
57
G
EB
2/
IO
16
5P
58
G
EC
2/
IO
16
4P
60
IO
16
4N
59
IO
15
7N
66
IO
15
3N
67
IO
15
3P
68
IO
14
9N
69
IO
14
9P
70
IO
14
5N
73
IO
16
3P
61
IO
16
1P
63
IO
14
5P
74
IO
14
3N
75
IO
14
3P
76
IO
13
7N
77
IO
13
7P
78
IO
13
5P
80
IO
13
5N
79
IO
12
9P
85
IO
12
7N
86
IO
12
7P
87
IO
12
1N
90
IO
12
1P
91
IO
13
1N
82
IO
12
9N
84
IO
11
9N
92
G
D
C
2/
IO
11
3P
95
IO
11
2N
96
G
D
B
2/
IO
11
2P
98
G
D
A
2/
IO
11
1P
99
IO
11
9P
93
IO
11
3N
94
IO
15
7N
64
IO
13
1P
83
FP
G
A
2_
1D
A
3P
E1
50
0-
PQ
20
8
IO
 B
A
N
K
 1
G
D
A
0/
IO
11
0N
11
2
G
D
B
0/
IO
10
9N
11
3
G
D
A
1/
IO
11
0P
11
4
G
D
C
0/
IO
08
N
P
11
6
G
D
C
1/
IO
10
8P
11
7
G
D
B
1/
IO
10
9P
11
5
IO
10
1P
12
1
G
C
C
2/
IO
90
P
12
4
G
C
B
2/
IO
89
P
12
5
IO
88
N
12
7
G
C
A
2/
IO
88
P
12
8
G
C
A
1/
IO
87
P
12
9
IO
10
5N
11
8
IO
10
5P
11
9
G
C
A
0/
IO
87
N
13
2
G
C
B
0/
IO
86
N
13
4
G
C
B
1/
IO
86
P
13
5
IO
83
N
13
7
G
C
C
1/
IO
85
P
13
6
IO
73
P
14
4
IO
71
N
14
5
IO
71
P
14
6
IO
67
N
14
7
IO
67
P
14
8
IO
83
P
13
8
IO
73
N
14
3
IO
65
N
14
9
G
B
A
2/
IO
58
P
15
2
G
B
B
2/
IO
59
P
15
3
IO
65
P
15
0
G
B
C
2/
IO
60
P
15
1
IO
10
1N
12
0
IO
81
P
13
9
FP
G
A
2_
1E
A
3P
E1
50
0-
PQ
20
8
IO
 B
A
N
K
 0
G
B
A
1/
IO
57
P
15
9
G
B
A
0/
IO
57
N
16
0
G
B
B
1/
IO
56
P
16
1
G
B
B
0/
IO
56
N
16
3
G
B
C
0/
IO
55
N
16
5
G
B
C
1/
IO
55
P
16
4
IO
47
N
16
9
IO
43
P
17
2
IO
41
P
17
3
IO
41
N
17
4
IO
35
P
17
5
IO
35
N
17
6
IO
51
P
16
6
IO
51
N
16
7
IO
31
P
17
7
IO
31
N
17
9
IO
29
P
18
0
IO
29
N
18
1
IO
27
P
18
2
IO
23
P
18
4
IO
27
N
18
3
IO
15
P
19
0
IO
15
N
19
1
IO
12
P
19
2
IO
11
P
19
3
IO
11
N
19
4
IO
23
N
18
5
IO
18
N
18
9
IO
08
P
19
6
IO
05
N
19
9
G
A
C
1/
IO
02
P
20
1
G
A
C
0/
IO
02
N
20
2
G
A
B
1/
IO
01
P
20
3
G
A
B
0/
IO
01
N
20
4
IO
08
N
19
7
IO
05
P
19
8
IO
47
P
16
8
IO
18
P
18
8
G
A
A
1/
IO
00
P
20
5
G
A
A
0/
IO
00
N
20
6
FP
G
A
2_
1F
A
3P
E1
50
0-
PQ
20
8
0.
1u
F
C
2_
28
0.
1u
F
C
2_
29
0.
1u
F
C
2_
30
ETH[21..1]
ET
H
[2
1.
.1
]
ET
H
18
ET
H
20
ET
H
1
ET
H
2
ET
H
3
ET
H
4
ET
H
5
ET
H
6
ET
H
7
ET
H
8
ET
H
9
ET
H
10
ET
H
11
ET
H
12
ET
H
13
ET
H
14
ET
H
15
ET
H
16
ET
H
17
ET
H
19
ET
H
21
2_
C
LK
_1
00
M
H
z
G
N
D
U
A
R
T_
0_
R
X
U
A
R
T_
0_
TX
U
A
R
T_
1_
R
X
U
A
R
T_
1_
TX
LE
D
2_
5
LE
D
2_
6
LE
D
2_
7
LE
D
2_
8
EN
1
G
N
D
2
3V
3
4
C
LK
3
X
2_
1
10
0M
H
z 
X
o
TP
2_
1
Te
st
Po
in
t
TP
2_
2
Te
st
Po
in
t
TP
2_
4
Te
st
Po
in
t
TC
K
1
G
N
D
2
TD
O
3
N
C
4
TM
S
5
V
jta
g
6
V
pu
m
p
7
TR
ST
8
TD
I
9
G
N
D
10
JP
2_
1
FL
A
SH
Pr
o3
1
1
2
2
3
3
4
4
5
5
6
6
7
7
8
8
9
9
10
10
JP
2_
2
2x
5
TP
2_
5
Te
st
Po
in
t
TP
2_
6
Te
st
Po
in
t
SD
A
SC
L
SR
A
M
_C
E_
N
SR
A
M
_W
E_
N
SR
A
M
_O
E_
N
SR
A
M
_S
R
B
S0
_N
SR
A
M
_S
R
B
S1
_N
SR
A
M
_S
R
B
S2
_N
SR
A
M
_S
R
B
S3
_N
FL
A
SH
_C
E_
N
FL
A
SH
_W
E_
N
FL
A
SH
_O
E_
N
FL
A
SH
_R
ST
_N
D
at
a_
[3
1.
.0
]
A
dd
r_
[1
9.
.0
]
A
dd
r_
[1
9.
.0
]
D
at
a_
[3
1.
.0
]
1KR
2_
5
1KR
2_
6
1KR
2_
7
1KR
2_
8
SD
A
SC
L
D
at
a_
16
D
at
a_
17
D
at
a_
18
D
at
a_
19
D
at
a_
20
D
at
a_
21
D
at
a_
22
D
at
a_
23
D
at
a_
24
D
at
a_
25
D
at
a_
26
D
at
a_
27
D
at
a_
28
D
at
a_
29
D
at
a_
30
D
at
a_
31
D
at
a_
0
D
at
a_
1
D
at
a_
2
D
at
a_
3
D
at
a_
4
D
at
a_
5
D
at
a_
6
D
at
a_
7
D
at
a_
8
D
at
a_
9
D
at
a_
10
D
at
a_
11
D
at
a_
12
D
at
a_
13
D
at
a_
14
D
at
a_
15
LE
D
2_
5
LE
D
2_
6
LE
D
2_
7
LE
D
2_
8
U
A
R
T_
0_
R
X
U
A
R
T_
0_
TX
U
A
R
T_
1_
R
X
U
A
R
T_
1_
TX
B
U
S_
0
B
U
S_
1
B
U
S_
2
B
U
S_
3
B
U
S_
4
B
U
S_
5
B
U
S_
6
B
U
S_
7
C
A
N
_1
_T
X
_2
C
A
N
_1
_R
X
_2
A
dd
r_
0
A
dd
r_
1
A
dd
r_
2
A
dd
r_
3
A
dd
r_
4
A
dd
r_
5
A
dd
r_
6
A
dd
r_
7
A
dd
r_
8
A
dd
r_
9
A
dd
r_
10
A
dd
r_
11
A
dd
r_
12
A
dd
r_
13
A
dd
r_
14
A
dd
r_
15
A
dd
r_
16
A
dd
r_
17
A
dd
r_
18
A
dd
r_
19
B
U
S_
23
B
U
S_
27
B
U
S_
28
B
U
S_
29
B
U
S_
30
B
U
S_
31
B
U
S_
32
B
U
S_
33
B
U
S_
34
B
U
S_
35
B
U
S_
36
B
U
S_
37
B
U
S_
38
B
U
S_
39
B
U
S_
41
B
U
S_
42
B
U
S_
43
B
U
S_
44
B
U
S_
45
B
U
S_
46
B
U
S_
47
B
U
S_
48
B
U
S_
49
B
U
S_
50
B
U
S_
40
B
U
S_
26
B
U
S_
25
B
U
S_
24
B
U
S_
[5
0.
.0
]
B
U
S_
[5
0.
.0
]
B
U
S_
25
B
U
S_
24
B
U
S_
24
B
U
S_
25
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
13V
3_
1
3V
3_
1
1V
5_
11V
5_
1
C
on
tro
lle
r
Em
ile
 T
he
sn
aa
r
10
3
V
1.
0
15
41
69
09
PIC20101PIC20102
CO
C2
01
PIC20201PIC20202
CO
C2
02
PIC20301PIC20302
CO
C2
03
PIC20401PIC20402
CO
C2
04
PIC20501PIC20502
CO
C2
05
PIC20601PIC20602
CO
C2
06
PIC20701PIC20702
CO
C2
07
PIC20801PIC20802
CO
C2
08
PIC20901PIC20902
CO
C2
09
PIC201001PIC201002
CO
C2
01
0
PIC201101PIC201102
CO
C2
01
1
PIC201201PIC201202
CO
C2
01
2
PIC201301PIC201302
CO
C2
01
3
PIC201401PIC201402
CO
C2
01
4
PIC201501PIC201502
CO
C2
01
5
PIC201601PIC201602
CO
C2
01
6
PIC201701PIC201702
CO
C2
01
7
PIC201801PIC201802
CO
C2
01
8
PIC201901PIC201902
CO
C2
01
9
PIC202001PIC202002
CO
C2
02
0
PIC202101PIC202102
CO
C2
02
1
PIC202201PIC202202
CO
C2
02
2
PIC202301PIC202302
CO
C2
02
3
PIC202401PIC202402
CO
C2
02
4
PIC202501PIC202502
CO
C2
02
5
PIC202601PIC202602
CO
C2
02
6
PIC
202
701
PIC
202
702CO
C2
02
7
PIC202801PIC202802
CO
C2
02
8
PIC202901PIC202902
CO
C2
02
9
PIC203001PIC203002
CO
C2
03
0
PI
FP
GA
20
10
1
PI
FP
GA
20
10
2
PI
FP
GA
20
10
3
PI
FP
GA
20
10
16
PI
FP
GA
20
10
17
PI
FP
GA
20
10
18
PI
FP
GA
20
10
25
PI
FP
GA
20
10
27
PI
FP
GA
20
10
29
PI
FP
GA
20
10
36
PI
FP
GA
20
10
40
PI
FP
GA
20
10
41
PI
FP
GA
20
10
50
PI
FP
GA
20
10
51
PI
FP
GA
20
10
52
PI
FP
GA
20
10
53
PI
FP
GA
20
10
54
PI
FP
GA
20
10
62
PI
FP
GA
20
10
65
PI
FP
GA
20
10
71
PI
FP
GA
20
10
72
PI
FP
GA
20
10
81
PI
FP
GA
20
10
88
PI
FP
GA
20
10
89
PI
FP
GA
20
10
97
PI
FP
GA
20
10
10
0
PI
FP
GA
20
10
10
4
PI
FP
GA
20
10
10
5
PI
FP
GA
20
10
10
7
PI
FP
GA
20
10
11
1
PI
FP
GA
20
10
12
2
PI
FP
GA
20
10
12
3
PI
FP
GA
20
10
13
0
PI
FP
GA
20
10
13
1
PI
FP
GA
20
10
13
3
PI
FP
GA
20
10
14
0
PI
FP
GA
20
10
14
1
PI
FP
GA
20
10
14
2
PI
FP
GA
20
10
15
4
PI
FP
GA
20
10
15
5
PI
FP
GA
20
10
15
6
PI
FP
GA
20
10
15
7
PI
FP
GA
20
10
15
8
PI
FP
GA
20
10
16
2
PI
FP
GA
20
10
17
0
PI
FP
GA
20
10
17
1
PI
FP
GA
20
10
17
8
PI
FP
GA
20
10
18
6
PI
FP
GA
20
10
18
7
PI
FP
GA
20
10
19
5
PI
FP
GA
20
10
20
0
PI
FP
GA
20
10
20
7
PI
FP
GA
20
10
20
8
CO
FP
GA
20
1A
PI
FP
GA
20
10
10
1
PI
FP
GA
20
10
10
2
PI
FP
GA
20
10
10
3
PI
FP
GA
20
10
10
6
PI
FP
GA
20
10
10
8
PI
FP
GA
20
10
10
9
PI
FP
GA
20
10
11
0
CO
FP
GA
20
1B
PI
FP
GA
20
10
4
PI
FP
GA
20
10
5
PI
FP
GA
20
10
6
PI
FP
GA
20
10
7
PI
FP
GA
20
10
8
PI
FP
GA
20
10
9
PI
FP
GA
20
10
10
PI
FP
GA
20
10
11
PI
FP
GA
20
10
12
PI
FP
GA
20
10
13
PI
FP
GA
20
10
14
PI
FP
GA
20
10
15
PI
FP
GA
20
10
19
PI
FP
GA
20
10
20
PI
FP
GA
20
10
21
PI
FP
GA
20
10
22
PI
FP
GA
20
10
23
PI
FP
GA
20
10
24
PI
FP
GA
20
10
26
PI
FP
GA
20
10
28
PI
FP
GA
20
10
30
PI
FP
GA
20
10
31
PI
FP
GA
20
10
32
PI
FP
GA
20
10
33
PI
FP
GA
20
10
34
PI
FP
GA
20
10
35
PI
FP
GA
20
10
37
PI
FP
GA
20
10
38
PI
FP
GA
20
10
39
PI
FP
GA
20
10
42
PI
FP
GA
20
10
43
PI
FP
GA
20
10
44
PI
FP
GA
20
10
45
PI
FP
GA
20
10
46
PI
FP
GA
20
10
47
PI
FP
GA
20
10
48
PI
FP
GA
20
10
49
CO
FP
GA
20
1C
PI
FP
GA
20
10
55
PI
FP
GA
20
10
56
PI
FP
GA
20
10
57
PI
FP
GA
20
10
58
PI
FP
GA
20
10
59
PI
FP
GA
20
10
60
PI
FP
GA
20
10
61
PI
FP
GA
20
10
63
PI
FP
GA
20
10
64
PI
FP
GA
20
10
66
PI
FP
GA
20
10
67
PI
FP
GA
20
10
68
PI
FP
GA
20
10
69
PI
FP
GA
20
10
70
PI
FP
GA
20
10
73
PI
FP
GA
20
10
74
PI
FP
GA
20
10
75
PI
FP
GA
20
10
76
PI
FP
GA
20
10
77
PI
FP
GA
20
10
78
PI
FP
GA
20
10
79
PI
FP
GA
20
10
80
PI
FP
GA
20
10
82
PI
FP
GA
20
10
83
PI
FP
GA
20
10
84
PI
FP
GA
20
10
85
PI
FP
GA
20
10
86
PI
FP
GA
20
10
87
PI
FP
GA
20
10
90
PI
FP
GA
20
10
91
PI
FP
GA
20
10
92
PI
FP
GA
20
10
93
PI
FP
GA
20
10
94
PI
FP
GA
20
10
95
PI
FP
GA
20
10
96
PI
FP
GA
20
10
98
PI
FP
GA
20
10
99
CO
FP
GA
20
1D
PI
FP
GA
20
10
11
2
PI
FP
GA
20
10
11
3
PI
FP
GA
20
10
11
4
PI
FP
GA
20
10
11
5
PI
FP
GA
20
10
11
6
PI
FP
GA
20
10
11
7
PI
FP
GA
20
10
11
8
PI
FP
GA
20
10
11
9
PI
FP
GA
20
10
12
0
PI
FP
GA
20
10
12
1
PI
FP
GA
20
10
12
4
PI
FP
GA
20
10
12
5
PI
FP
GA
20
10
12
7
PI
FP
GA
20
10
12
8
PI
FP
GA
20
10
12
9
PI
FP
GA
20
10
13
2
PI
FP
GA
20
10
13
4
PI
FP
GA
20
10
13
5
PI
FP
GA
20
10
13
6
PI
FP
GA
20
10
13
7
PI
FP
GA
20
10
13
8
PI
FP
GA
20
10
13
9
PI
FP
GA
20
10
14
3
PI
FP
GA
20
10
14
4
PI
FP
GA
20
10
14
5
PI
FP
GA
20
10
14
6
PI
FP
GA
20
10
14
7
PI
FP
GA
20
10
14
8
PI
FP
GA
20
10
14
9
PI
FP
GA
20
10
15
0
PI
FP
GA
20
10
15
1
PI
FP
GA
20
10
15
2
PI
FP
GA
20
10
15
3
CO
FP
GA
20
1E
PI
FP
GA
20
10
15
9
PI
FP
GA
20
10
16
0
PI
FP
GA
20
10
16
1
PI
FP
GA
20
10
16
3
PI
FP
GA
20
10
16
4
PI
FP
GA
20
10
16
5
PI
FP
GA
20
10
16
6
PI
FP
GA
20
10
16
7
PI
FP
GA
20
10
16
8
PI
FP
GA
20
10
16
9
PI
FP
GA
20
10
17
2
PI
FP
GA
20
10
17
3
PI
FP
GA
20
10
17
4
PI
FP
GA
20
10
17
5
PI
FP
GA
20
10
17
6
PI
FP
GA
20
10
17
7
PI
FP
GA
20
10
17
9
PI
FP
GA
20
10
18
0
PI
FP
GA
20
10
18
1
PI
FP
GA
20
10
18
2
PI
FP
GA
20
10
18
3
PI
FP
GA
20
10
18
4
PI
FP
GA
20
10
18
5
PI
FP
GA
20
10
18
8
PI
FP
GA
20
10
18
9
PI
FP
GA
20
10
19
0
PI
FP
GA
20
10
19
1
PI
FP
GA
20
10
19
2
PI
FP
GA
20
10
19
3
PI
FP
GA
20
10
19
4
PI
FP
GA
20
10
19
6
PI
FP
GA
20
10
19
7
PI
FP
GA
20
10
19
8
PI
FP
GA
20
10
19
9
PI
FP
GA
20
10
20
1
PI
FP
GA
20
10
20
2
PI
FP
GA
20
10
20
3
PI
FP
GA
20
10
20
4
PI
FP
GA
20
10
20
5
PI
FP
GA
20
10
20
6
CO
FP
GA
20
1F
P
I
JP
20
10
1
P
I
JP
20
10
2
P
I
JP
20
10
3
P
I
JP
20
10
4
P
I
JP
20
10
5
P
I
JP
20
10
6
P
I
JP
20
10
7
P
I
JP
20
10
8
P
I
JP
20
10
9
PI
JP
20
10
10
CO
JP
201
P
I
J
P
2
0
2
0
1
P
I
J
P
2
0
2
0
2
P
I
J
P
2
0
2
0
3
P
I
J
P
2
0
2
0
4
P
I
J
P
2
0
2
0
5
P
I
J
P
2
0
2
0
6
P
I
J
P
2
0
2
0
7
P
I
J
P
2
0
2
0
8
P
I
J
P
2
0
2
0
9
P
I
J
P
20
20
10
CO
JP
20
2
PIR
201
01
PIR
201
02CO
R2
01
PIR
202
01
PIR
202
02CO
R2
02
PIR20301PIR20302 C
OR
20
3
PIR20401PIR20402 C
OR
20
4
PIR20501 PIR20502C
OR
20
5
PIR20601 PIR20602C
OR
20
6
PIR20701PIR20702 C
OR
20
7
PIR20801PIR20802 C
OR
20
8
P
I
T
P
20
10
1
CO
TP
20
1 PI
T
P
20
20
1
CO
TP
20
2
P
I
T
P
20
40
1
CO
TP
20
4
P
I
T
P
20
50
1
CO
TP
20
5 PI
T
P
20
60
1
CO
TP
20
6
P
I
X
2
0
1
0
1
P
I
X
2
0
1
0
2
P
I
X
2
0
1
0
3
P
I
X
2
0
1
0
4
CO
X2
01
PIC201702
PIC201802
PIC201902
PIC202002
PIC202102
PIC202202
PIC202302
PIC202402
PIC203002
PI
FP
GA
20
10
16
PI
FP
GA
20
10
27
PI
FP
GA
20
10
36
PI
FP
GA
20
10
71
PI
FP
GA
20
10
88
PI
FP
GA
20
10
13
1
PI
FP
GA
20
10
14
2
PI
FP
GA
20
10
17
1
PI
FP
GA
20
10
18
7
PI
FP
GA
20
10
32
P
I
T
P
20
40
1
P
I
X
2
0
1
0
3
NL
20
CL
K0
10
0M
Hz
PIC20102
PIC20202
PIC20302
PIC20402
PIC20502
PIC20602
PIC20702
PIC20802
PIC20902
PIC201002
PIC201102
PIC201202
PIC201302
PIC201402
PIC201502
PIC201602
PIC202802
PIC202902
PI
FP
GA
20
10
3
PI
FP
GA
20
10
18
PI
FP
GA
20
10
40
PI
FP
GA
20
10
50
PI
FP
GA
20
10
53
PI
FP
GA
20
10
62
PI
FP
GA
20
10
72
PI
FP
GA
20
10
89
PI
FP
GA
20
10
10
4
PI
FP
GA
20
10
11
1
PI
FP
GA
20
10
12
3
PI
FP
GA
20
10
14
0
PI
FP
GA
20
10
15
4
PI
FP
GA
20
10
15
7
PI
FP
GA
20
10
17
0
PI
FP
GA
20
10
18
6
PI
FP
GA
20
10
20
0
PI
FP
GA
20
10
20
8
P
I
J
P
20
20
10
PIR
201
01
PIR20402
PIR20501
PIR20601
PIR20702
PIR20802
P
I
X
2
0
1
0
4
NL
3V
30
1
PI
FP
GA
20
10
10
1
P
I
JP
20
10
1
PIR
202
02
NL
F2
0T
CK
PI
FP
GA
20
10
10
2
P
I
JP
20
10
9
NL
F2
0T
DI
PI
FP
GA
20
10
10
8
P
I
JP
20
10
3
NL
F2
0T
DO
PI
FP
GA
20
10
10
3
P
I
JP
20
10
5
NL
F2
0T
MS
PI
FP
GA
20
10
10
9
P
I
JP
20
10
8
PIR20302
NL
F2
0T
RS
T
PIC
202
702
PI
FP
GA
20
10
11
0
P
I
JP
20
10
6
PIR
201
02
NL
F2
0V
JT
AG
PIC202502
PIC202602
PI
FP
GA
20
10
10
6
P
I
JP
20
10
7
PIR20401
NL
F2
0V
PU
MP
PIC20101
PIC20201
PIC20301
PIC20401
PIC20501
PIC20601
PIC20701
PIC20801
PIC20901
PIC201001
PIC201101
PIC201201
PIC201301
PIC201401
PIC201501
PIC201601
PIC201701
PIC201801
PIC201901
PIC202001
PIC202101
PIC202201
PIC202301
PIC202401
PIC202501
PIC202601
PIC
202
701
PIC202801
PIC202901
PIC203001
PI
FP
GA
20
10
1
PI
FP
GA
20
10
2
PI
FP
GA
20
10
17
PI
FP
GA
20
10
25
PI
FP
GA
20
10
29
PI
FP
GA
20
10
41
PI
FP
GA
20
10
51
PI
FP
GA
20
10
52
PI
FP
GA
20
10
54
PI
FP
GA
20
10
65
PI
FP
GA
20
10
81
PI
FP
GA
20
10
97
PI
FP
GA
20
10
10
0
PI
FP
GA
20
10
10
5
PI
FP
GA
20
10
10
7
PI
FP
GA
20
10
12
2
PI
FP
GA
20
10
13
0
PI
FP
GA
20
10
13
3
PI
FP
GA
20
10
14
1
PI
FP
GA
20
10
15
5
PI
FP
GA
20
10
15
6
PI
FP
GA
20
10
15
8
PI
FP
GA
20
10
16
2
PI
FP
GA
20
10
17
8
PI
FP
GA
20
10
19
5
PI
FP
GA
20
10
20
7
P
I
JP
20
10
2
PI
JP
20
10
10
P
I
J
P
2
0
2
0
9
PIR
202
01
PIR20301
P
I
X
2
0
1
0
2
PI
FP
GA
20
10
92
P
I
J
P
2
0
2
0
5
NL
LE
D2
05
PI
FP
GA
20
10
98
P
I
J
P
2
0
2
0
6
NL
LE
D2
06
PI
FP
GA
20
10
91
P
I
J
P
2
0
2
0
7
NL
LE
D2
07
PI
FP
GA
20
10
99
P
I
J
P
2
0
2
0
8
NL
LE
D2
08
PI
FP
GA
20
10
13
9
PODUT0POW0ENABLE
PI
FP
GA
20
10
16
5
PO
SR
AM
0S
RB
S3
0N
PI
FP
GA
20
10
16
6
PO
SR
AM
0S
RB
S2
0N
PI
FP
GA
20
10
17
4
P
O
S
R
A
M
0
W
E
0
N
PI
FP
GA
20
10
18
1
P
O
S
R
A
M
0
C
E
0
N
PI
FP
GA
20
10
18
4
P
O
F
L
A
S
H
0R
ST
0N
PI
FP
GA
20
10
18
8
P
O
F
L
A
S
H
0
W
E
0
N
PI
FP
GA
20
10
19
7
P
OS
RA
M0
SR
BS
00
N
PI
FP
GA
20
10
19
8
P
OS
RA
M0
SR
BS
10
N
PI
FP
GA
20
10
19
9
P
O
S
R
A
M
0
O
E
0
N
PI
FP
GA
20
10
20
1
P
O
F
L
A
S
H
0
O
E
0
N
PI
FP
GA
20
10
20
2
P
O
F
L
A
S
H
0
C
E
0
N
P
I
JP
20
10
4
P
I
X
2
0
1
0
1
PI
FP
GA
20
10
20
PIR20602
PIR20801
P
I
T
P
20
60
1
NL
SC
L
P
O
S
C
LPIF
PG
A2
01
01
9
PIR20502
PIR20701
P
I
T
P
20
50
1
NL
SD
A
P
O
S
D
A
PI
FP
GA
20
10
94
P
I
J
P
2
0
2
0
1
NL
UA
RT
00
0R
X
PI
FP
GA
20
10
95
P
I
J
P
2
0
2
0
2
NL
UA
RT
00
0T
X
PI
FP
GA
20
10
93
P
I
J
P
2
0
2
0
3
NL
UA
RT
01
0R
X
PI
FP
GA
20
10
96
P
I
J
P
2
0
2
0
4
NL
UA
RT
01
0T
X
PI
FP
GA
20
10
17
5 NL
Ad
dr
00
19
00
00
NL
Ad
dr
00
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
17
6 NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
17
7 NL
Ad
dr
00
19
00
00
NL
Ad
dr
02
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
17
9 NL
Ad
dr
00
19
00
00
NL
Ad
dr
03
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
18
0 NL
Ad
dr
00
19
00
00
NL
Ad
dr
04
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
16
7 NL
Ad
dr
00
19
00
00
NL
Ad
dr
05
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
16
8 NL
Ad
dr
00
19
00
00
NL
Ad
dr
06
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
16
9 NL
Ad
dr
00
19
00
00
NL
Ad
dr
07
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
17
2 NL
Ad
dr
00
19
00
00
NL
Ad
dr
08
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
17
3 NL
Ad
dr
00
19
00
00
NL
Ad
dr
09
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
18
9 NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
0
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
19
0 NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
1
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
19
1 NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
2
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
19
2 NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
3
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
19
3 NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
4
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
19
4 NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
5
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
19
6 NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
6
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
18
2 NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
7
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
18
3 NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
8
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
18
5 NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
9
PO
Ad
dr
00
19
00
00
PI
FP
GA
20
10
21
NL
BU
S0
05
00
00
0
NL
BU
S0
0
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
22
NL
BU
S0
05
00
00
0
NL
BU
S0
1
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
23
NL
BU
S0
05
00
00
0
NL
BU
S0
2
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
24
NL
BU
S0
05
00
00
0
NL
BU
S0
3
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
26
NL
BU
S0
05
00
00
0
NL
BU
S0
4
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
28
NL
BU
S0
05
00
00
0
NL
BU
S0
5
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
30
NL
BU
S0
05
00
00
0
NL
BU
S0
6
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
31
NL
BU
S0
05
00
00
0
NL
BU
S0
7
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
33
NL
BU
S0
05
00
00
0
NL
BU
S0
8
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
34
NL
BU
S0
05
00
00
0
NL
BU
S0
9
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
35
NL
BU
S0
05
00
00
0
NL
BU
S0
10
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
37
NL
BU
S0
05
00
00
0
NL
BU
S0
11
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
38
NL
BU
S0
05
00
00
0
NL
BU
S0
12
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
39
NL
BU
S0
05
00
00
0
NL
BU
S0
13
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
42
NL
BU
S0
05
00
00
0
NL
BU
S0
14
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
43
NL
BU
S0
05
00
00
0
NL
BU
S0
15
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
44
NL
BU
S0
05
00
00
0
NL
BU
S0
16
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
45
NL
BU
S0
05
00
00
0
NL
BU
S0
17
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
46
NL
BU
S0
05
00
00
0
NL
BU
S0
18
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
47
NL
BU
S0
05
00
00
0
NL
BU
S0
19
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
48
NL
BU
S0
05
00
00
0
NL
BU
S0
20
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
49
NL
BU
S0
05
00
00
0
NL
BU
S0
21
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
55
NL
BU
S0
05
00
00
0
NL
BU
S0
22
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
56
NL
BU
S0
05
00
00
0
NL
BU
S0
23
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
57
P
I
T
P
20
10
1
NL
BU
S0
05
00
00
0
NL
BU
S0
24
PO
BU
S0
05
00
00
0
P
OC
AN
01
0T
X0
2
PI
FP
GA
20
10
58
P
I
T
P
20
20
1
NL
BU
S0
05
00
00
0
NL
BU
S0
25
PO
BU
S0
05
00
00
0
P
OC
AN
01
0R
X0
2
PI
FP
GA
20
10
59
NL
BU
S0
05
00
00
0
NL
BU
S0
26
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
60
NL
BU
S0
05
00
00
0
NL
BU
S0
27
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
61
NL
BU
S0
05
00
00
0
NL
BU
S0
28
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
63
NL
BU
S0
05
00
00
0
NL
BU
S0
29
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
64
NL
BU
S0
05
00
00
0
NL
BU
S0
30
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
66
NL
BU
S0
05
00
00
0
NL
BU
S0
31
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
67
NL
BU
S0
05
00
00
0
NL
BU
S0
32
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
68
NL
BU
S0
05
00
00
0
NL
BU
S0
33
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
69
NL
BU
S0
05
00
00
0
NL
BU
S0
34
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
70
NL
BU
S0
05
00
00
0
NL
BU
S0
35
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
73
NL
BU
S0
05
00
00
0
NL
BU
S0
36
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
74
NL
BU
S0
05
00
00
0
NL
BU
S0
37
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
75
NL
BU
S0
05
00
00
0
NL
BU
S0
38
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
76
NL
BU
S0
05
00
00
0
NL
BU
S0
39
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
77
NL
BU
S0
05
00
00
0
NL
BU
S0
40
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
78
NL
BU
S0
05
00
00
0
NL
BU
S0
41
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
79
NL
BU
S0
05
00
00
0
NL
BU
S0
42
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
80
NL
BU
S0
05
00
00
0
NL
BU
S0
43
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
82
NL
BU
S0
05
00
00
0
NL
BU
S0
44
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
83
NL
BU
S0
05
00
00
0
NL
BU
S0
45
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
84
NL
BU
S0
05
00
00
0
NL
BU
S0
46
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
85
NL
BU
S0
05
00
00
0
NL
BU
S0
47
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
86
NL
BU
S0
05
00
00
0
NL
BU
S0
48
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
87
NL
BU
S0
05
00
00
0
NL
BU
S0
49
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
90
NL
BU
S0
05
00
00
0
NL
BU
S0
50
PO
BU
S0
05
00
00
0
PI
FP
GA
20
10
15
NL
Da
ta
00
31
00
00
NL
Da
ta
00
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
13
NL
Da
ta
00
31
00
00
NL
Da
ta
01
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
11
NL
Da
ta
00
31
00
00
NL
Da
ta
02
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
9
NL
Da
ta
00
31
00
00
NL
Da
ta
03
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
7
NL
Da
ta
00
31
00
00
NL
Da
ta
04
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
5
NL
Da
ta
00
31
00
00
NL
Da
ta
05
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
20
6 NL
Da
ta
00
31
00
00
NL
Da
ta
06
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
20
4 NL
Da
ta
00
31
00
00
NL
Da
ta
07
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
14
NL
Da
ta
00
31
00
00
NL
Da
ta
08
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
12
NL
Da
ta
00
31
00
00
NL
Da
ta
09
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
10
NL
Da
ta
00
31
00
00
NL
Da
ta
01
0
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
8
NL
Da
ta
00
31
00
00
NL
Da
ta
01
1
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
6
NL
Da
ta
00
31
00
00
NL
Da
ta
01
2
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
4
NL
Da
ta
00
31
00
00
NL
Da
ta
01
3
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
20
5 NL
Da
ta
00
31
00
00
NL
Da
ta
01
4
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
20
3 NL
Da
ta
00
31
00
00
NL
Da
ta
01
5
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
16
4 NL
Da
ta
00
31
00
00
NL
Da
ta
01
6
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
16
1 NL
Da
ta
00
31
00
00
NL
Da
ta
01
7
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
15
9 NL
Da
ta
00
31
00
00
NL
Da
ta
01
8
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
15
2
NL
Da
ta
00
31
00
00
NL
Da
ta
01
9
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
15
0
NL
Da
ta
00
31
00
00
NL
Da
ta
02
0
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
14
8
NL
Da
ta
00
31
00
00
NL
Da
ta
02
1
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
14
6
NL
Da
ta
00
31
00
00
NL
Da
ta
02
2
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
14
4
NL
Da
ta
00
31
00
00
NL
Da
ta
02
3
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
16
3 NL
Da
ta
00
31
00
00
NL
Da
ta
02
4
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
16
0 NL
Da
ta
00
31
00
00
NL
Da
ta
02
5
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
15
3
NL
Da
ta
00
31
00
00
NL
Da
ta
02
6
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
15
1
NL
Da
ta
00
31
00
00
NL
Da
ta
02
7
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
14
9
NL
Da
ta
00
31
00
00
NL
Da
ta
02
8
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
14
7
NL
Da
ta
00
31
00
00
NL
Da
ta
02
9
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
14
5
NL
Da
ta
00
31
00
00
NL
Da
ta
03
0
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
14
3
NL
Da
ta
00
31
00
00
NL
Da
ta
03
1
PO
Da
ta
00
31
00
00
PI
FP
GA
20
10
13
6
NLETH0210010
NL
ET
H1
PO
ET
H0
21
00
10
PI
FP
GA
20
10
13
5
NLETH0210010
NL
ET
H2
PO
ET
H0
21
00
10
PI
FP
GA
20
10
12
8
NLETH0210010
NL
ET
H3
PO
ET
H0
21
00
10
PI
FP
GA
20
10
12
5
NLETH0210010
NL
ET
H4
PO
ET
H0
21
00
10
PI
FP
GA
20
10
11
8
NLETH0210010
NL
ET
H5
PO
ET
H0
21
00
10
PI
FP
GA
20
10
11
6
NLETH0210010
NL
ET
H6
PO
ET
H0
21
00
10
PI
FP
GA
20
10
11
5
NLETH0210010
NL
ET
H7
PO
ET
H0
21
00
10
PI
FP
GA
20
10
11
4
NLETH0210010
NL
ET
H8
PO
ET
H0
21
00
10
PI
FP
GA
20
10
11
3
NLETH0210010
NL
ET
H9
PO
ET
H0
21
00
10
PI
FP
GA
20
10
11
7
NLETH0210010
NL
ET
H1
0
PO
ET
H0
21
00
10
PI
FP
GA
20
10
13
2
NLETH0210010
NL
ET
H1
1
PO
ET
H0
21
00
10
PI
FP
GA
20
10
12
4
NLETH0210010
NL
ET
H1
2
PO
ET
H0
21
00
10
PI
FP
GA
20
10
12
1
NLETH0210010
NL
ET
H1
3
PO
ET
H0
21
00
10
PI
FP
GA
20
10
12
0
NLETH0210010
NL
ET
H1
4
PO
ET
H0
21
00
10
PI
FP
GA
20
10
11
9
NLETH0210010
NL
ET
H1
5
PO
ET
H0
21
00
10
PI
FP
GA
20
10
12
7
NLETH0210010
NL
ET
H1
6
PO
ET
H0
21
00
10
PI
FP
GA
20
10
12
9
NLETH0210010
NL
ET
H1
7
PO
ET
H0
21
00
10
PI
FP
GA
20
10
13
8
NLETH0210010
NL
ET
H1
8
PO
ET
H0
21
00
10
PI
FP
GA
20
10
11
2
NLETH0210010
NL
ET
H1
9
PO
ET
H0
21
00
10
PI
FP
GA
20
10
13
7
NLETH0210010
NL
ET
H2
0
PO
ET
H0
21
00
10
PI
FP
GA
20
10
13
4
NLETH0210010
NL
ET
H2
1
PO
ET
H0
21
00
10
P
O
A
D
D
R
0
0
P
O
A
D
D
R
0
1
P
O
A
D
D
R
0
2
P
O
A
D
D
R
0
3
P
O
A
D
D
R
0
4
P
O
A
D
D
R
0
5
P
O
A
D
D
R
0
6
P
O
A
D
D
R
0
7
P
O
A
D
D
R
0
8
P
O
A
D
D
R
0
9
P
O
A
D
D
R
0
1
0
P
O
A
D
D
R
0
1
1
P
O
A
D
D
R
0
1
2
P
O
A
D
D
R
0
1
3
P
O
A
D
D
R
0
1
4
P
O
A
D
D
R
0
1
5
P
O
A
D
D
R
0
1
6
P
O
A
D
D
R
0
1
7
P
O
A
D
D
R
0
1
8
P
O
A
D
D
R
0
1
9
PO
AD
DR
00
19
00
00
P
O
B
U
S
0
0
P
O
B
U
S
0
1
P
O
B
U
S
0
2
P
O
B
U
S
0
3
P
O
B
U
S
0
4
P
O
B
U
S
0
5
P
O
B
U
S
0
6
P
O
B
U
S
0
7
P
O
B
U
S
0
8
P
O
B
U
S
0
9
P
O
B
U
S
0
1
0
P
O
B
U
S
0
1
1
P
O
B
U
S
0
1
2
P
O
B
U
S
0
1
3
P
O
B
U
S
0
1
4
P
O
B
U
S
0
1
5
P
O
B
U
S
0
1
6
P
O
B
U
S
0
1
7
P
O
B
U
S
0
1
8
P
O
B
U
S
0
1
9
P
O
B
U
S
0
2
0
P
O
B
U
S
0
2
1
P
O
B
U
S
0
2
2
P
O
B
U
S
0
2
3
P
O
B
U
S
0
2
4
P
O
B
U
S
0
2
5
P
O
B
U
S
0
2
6
P
O
B
U
S
0
2
7
P
O
B
U
S
0
2
8
P
O
B
U
S
0
2
9
P
O
B
U
S
0
3
0
P
O
B
U
S
0
3
1
P
O
B
U
S
0
3
2
P
O
B
U
S
0
3
3
P
O
B
U
S
0
3
4
P
O
B
U
S
0
3
5
P
O
B
U
S
0
3
6
P
O
B
U
S
0
3
7
P
O
B
U
S
0
3
8
P
O
B
U
S
0
3
9
P
O
B
U
S
0
4
0
P
O
B
U
S
0
4
1
P
O
B
U
S
0
4
2
P
O
B
U
S
0
4
3
P
O
B
U
S
0
4
4
P
O
B
U
S
0
4
5
P
O
B
U
S
0
4
6
P
O
B
U
S
0
4
7
P
O
B
U
S
0
4
8
P
O
B
U
S
0
4
9
P
O
B
U
S
0
5
0
PO
BU
S0
05
00
00
0
P
OC
AN
01
0R
X0
2
P
OC
AN
01
0T
X0
2
P
O
D
A
T
A
0
0
P
O
D
A
T
A
0
1
P
O
D
A
T
A
0
2
P
O
D
A
T
A
0
3
P
O
D
A
T
A
0
4
P
O
D
A
T
A
0
5
P
O
D
A
T
A
0
6
P
O
D
A
T
A
0
7
P
O
D
A
T
A
0
8
P
O
D
A
T
A
0
9
P
O
D
A
T
A
0
1
0
P
O
D
A
T
A
0
1
1
P
O
D
A
T
A
0
1
2
P
O
D
A
T
A
0
1
3
P
O
D
A
T
A
0
1
4
P
O
D
A
T
A
0
1
5
P
O
D
A
T
A
0
1
6
P
O
D
A
T
A
0
1
7
P
O
D
A
T
A
0
1
8
P
O
D
A
T
A
0
1
9
P
O
D
A
T
A
0
2
0
P
O
D
A
T
A
0
2
1
P
O
D
A
T
A
0
2
2
P
O
D
A
T
A
0
2
3
P
O
D
A
T
A
0
2
4
P
O
D
A
T
A
0
2
5
P
O
D
A
T
A
0
2
6
P
O
D
A
T
A
0
2
7
P
O
D
A
T
A
0
2
8
P
O
D
A
T
A
0
2
9
P
O
D
A
T
A
0
3
0
P
O
D
A
T
A
0
3
1
PO
DA
TA
00
31
00
00
PODUT0POW0ENABLEPOETH1POETH2POETH3POETH4POETH5POETH6POETH7POETH8POETH9POETH10POETH11POETH12POETH13POETH14POETH15POETH16POETH17POETH18POETH19POETH20POETH21POETH0210010
P
O
F
L
A
S
H
0
C
E
0
N
P
O
F
L
A
S
H
0
O
E
0
N
P
O
F
L
A
S
H
0R
ST
0N
P
O
F
L
A
S
H
0
W
E
0
N
P
O
S
C
L
P
O
S
D
A
P
O
S
R
A
M
0
C
E
0
N
P
O
S
R
A
M
0
O
E
0
N
P
OS
RA
M0
SR
BS
00
N
P
OS
RA
M0
SR
BS
10
N
PO
SR
AM
0S
RB
S2
0N
PO
SR
AM
0S
RB
S3
0N
P
O
S
R
A
M
0
W
E
0
N
Figure B.3 – Schematic of the Controlling FPGA showing I/O Connections, Crystal, De-
coupling Capacitor and Headers
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 105
11
22
33
44
D
D
C
C
B
B
A
A
Ti
tle
N
um
be
r
R
ev
is
io
n
Si
ze A
4
D
at
e:
20
14
/0
2/
05
Sh
ee
t  
  o
f
Fi
le
:
C
:\D
ro
pb
ox
\..
\3
_P
O
W
ER
.S
ch
D
oc
D
ra
w
n 
B
y:
0.
1u
F
C
3_
1
0.
1u
F
C
3_
3
0.
1u
F
C
3_
5
0.
1u
F
C
3_
7
0.
1u
F
C
3_
9
0.
1u
F
C
3_
11
G
N
D
G
N
D
G
N
D
G
N
D
G
N
D
D
U
T_
PO
W
_E
N
A
B
LE
D
U
T_
PO
W
_E
N
A
B
LE
D
U
T_
PO
W
_E
N
A
B
LE
TP
3_
1
Te
st
Po
in
t
TP
3_
2
Te
st
Po
in
t
TP
3_
3
Te
st
Po
in
t
TP
3_
4
Te
st
Po
in
t
TP
3_
5
Te
st
Po
in
t
JP
3_
1
2.
1m
m
PO
W
ER
PL
U
G
22
uF
C
3_
2
22
uF
C
3_
4
22
uF
C
3_
6
22
uF
C
3_
8
22
uF
C
3_
10
22
uF
C
3_
12
G
N
D
G
N
D
V
Su
pp
ly
V
Su
pp
ly
TP
3_
6
Te
st
Po
in
t
V
in
3
V
ou
t
2
GND
1
P3
_1
LD
10
86
D
T3
3
V
in
3
V
ou
t
2
GND
1
P3
_2
LD
10
86
D
T3
3
V
in
3
V
ou
t
2
GND
1
P3
_3
LD
10
86
D
T1
5R
V
in
3
V
ou
t
2
GND
1
P3
_4
LD
10
86
D
T1
5R
G
N
D
G
N
D
G
N
D
G
N
D
D
U
T_
PO
W
_E
N
A
B
LE
O
N
3
GND
2
V
IN
1
V
O
U
T
5
IS
ET
4
P3
_5
FP
F2
12
4
O
N
3
GND
2
V
IN
1
V
O
U
T
5
IS
ET
4
P3
_6
FP
F2
12
4
30
0
R
3_
5
30
0
R
3_
6
G
N
D
G
N
D
G
N
D
G
N
D
3V
3_
1
V
IN
V
Su
pp
ly
V
Su
pp
ly
1V
5_
1
3V
3_
2
1V
5_
2
Po
w
er
Em
ile
 T
he
sn
aa
r
10
4
V
1.
0
15
41
69
09
PIC30101PIC30102
CO
C3
01
PIC30201PIC30202
CO
C3
02
PIC30301PIC30302
CO
C3
03
PIC30401PIC30402
CO
C3
04
PIC30501PIC30502
CO
C3
05
PIC30601PIC30602
CO
C3
06
PIC30701PIC30702
CO
C3
07
PIC30801PIC30802
CO
C3
08
PIC30901PIC30902
CO
C3
09
PIC301001PIC301002
CO
C3
01
0
PIC301101PIC301102
CO
C3
01
1
PIC301201PIC301202
CO
C3
01
2
PIJ
P30
101
PIJ
P30
102
PIJ
P30
103
CO
JP
301
PIP30101
PI
P3
01
02
PI
P3
01
03C
OP
301
PIP30201
PI
P3
02
02
PI
P3
02
03C
OP
302
PIP30301
PI
P3
03
02
PI
P3
03
03C
OP
303
PIP30401
PI
P3
04
02
PI
P3
04
03C
OP
304
PI
P3
05
01
PIP30502
PI
P3
05
03
PI
P3
05
04
PI
P3
05
05
CO
P3
05
PI
P3
06
01
PIP30602
PI
P3
06
03
PI
P3
06
04
PI
P3
06
05
CO
P3
06
PIR30501PIR30502 C
OR
30
5
PIR30601PIR30602 C
OR
30
6
P
I
T
P
3
0
1
0
1CO
TP
30
1
P
I
T
P
30
20
1CO
TP
30
2
P
I
T
P
30
30
1CO
TP
30
3
P
I
T
P
30
40
1CO
TP
30
4
PI
TP
30
50
1CO
TP
30
5
P
I
T
P
30
60
1
CO
TP
30
6
PIC30902
PIC301002
PI
P3
03
02
P
I
T
P
30
40
1
PIC301102
PIC301202
PI
P3
04
02
PI
TP
30
50
1
PIC30502
PIC30602
PI
P3
01
02
P
I
T
P
30
20
1
PIC30702
PIC30802
PI
P3
02
02
P
I
T
P
30
30
1
PI
P3
05
03
PI
P3
06
03
P
I
T
P
30
60
1N
LD
UT
0P
OW
0E
NA
BL
E P
OD
UT
0P
OW
0E
NA
BL
E
PIC30101
PIC30201
PIC30301
PIC30401
PIC30501
PIC30601
PIC30701
PIC30801
PIC30901
PIC301001
PIC301101
PIC301201
PIJ
P30
102
PIP30101 PIP30201PIP30301 PIP30401
PIP30502 PIP30602
PIR30501 PIR30601
PIJ
P30
103
PI
P3
02
03
PI
P3
05
05
PI
P3
04
03
PI
P3
06
05
PI
P3
05
04 PIR30502
PI
P3
06
04 PIR30602
PIJ
P30
101
P
I
T
P
3
0
1
0
1
PIC30102
PIC30202
PIC30302
PIC30402
PI
P3
01
03
PI
P3
03
03
PI
P3
05
01
PI
P3
06
01
NL
VS
up
pl
y
P
OD
UT
0P
OW
0E
NA
BL
E
Figure B.4 – Schematic Showing the Connection of the Power Supplies
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 106
11
22
33
44
D
D
C
C
B
B
A
A
Ti
tle
N
um
be
r
R
ev
is
io
n
Si
ze A
4
D
at
e:
20
14
/0
2/
05
Sh
ee
t  
  o
f
Fi
le
:
C
:\D
ro
pb
ox
\..
\4
_M
on
ito
rin
g.
Sc
hD
oc
D
ra
w
n 
B
y:
SD
A
SD
A
SD
A
SC
L
SC
L
0.
1
R
4_
1
0.
1
R
4_
2
G
N
D
G
N
D
V
o 
= 
Is
*R
s*
R
l/1
00
0
Is
 m
ax
 =
 1
A
R
s =
 0
.1
R
l =
 3
3k
36
.5
 k
R
4_
3
36
.5
 k
R
4_
5
G
N
D
G
N
D
G
N
D
G
N
D
1V
5_
C
U
R
3V
3_
C
U
R
Vin+
3
V
+
5
G
N
D
2
Vin-
4 O
U
T
1
U
4_
2
IN
A
16
9
Vin+
3
V
+
5
G
N
D
2
Vin-
4 O
U
T
1
U
4_
3
IN
A
16
9
TP
4_
1
Te
st
Po
in
t
TP
4_
2
Te
st
Po
in
t
2 3
1
114
O
P4
_1
A
LM
32
4A
M
6 5
7
114
O
P4
_1
B
LM
32
4A
M
SC
L
1V
5_
C
U
R
3V
3_
C
U
R
A
IN
3
4
A
IN
2
3
A
IN
0
1
A
IN
1
2
A
IN
8
16
A
IN
9
15
A
IN
11
/R
EF
13
A
IN
10
14
A
IN
7
8
A
IN
6
7
A
IN
4
5
A
IN
5
6
V
D
D
12
G
N
D
11
SC
L
9
SD
A
10
U
4_
1
M
A
X
10
38
EE
E+
SD
A
1
SC
L
2
A
LE
R
T
3
G
N
D
4
A
2
5
A
1
6
A
0
7
V
C
C
8
U
4_
5
A
T3
0T
S7
5-
SS
8-
B
SD
A
1
SC
L
2
A
LE
R
T
3
G
N
D
4
A
2
5
A
1
6
A
0
7
V
C
C
8
U
4_
7
A
T3
0T
S7
5-
SS
8-
B
SD
A
SC
L
SD
A
SC
L
G
N
D
G
N
D
0.
1
R
4_
7
G
N
D
36
.5
 k
R
4_
6
G
N
D
G
N
D
SU
P_
C
U
R
9 10
8
114
O
P4
_1
C
LM
32
4A
M
SU
P_
C
U
R
TP
4_
3
Te
st
Po
in
t
6.
8K
R
4_
10
3.
3K
R
4_
11
G
N
D
V
Su
pp
ly
Vin+
3
V
+
5
G
N
D
2
Vin-
4 O
U
T
1
U
4_
4
IN
A
16
9 3V
3_
D
U
T
1V
5_
D
U
T
3V
3_
D
U
T
1V
5_
D
U
T
G
N
D
G
N
D
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1 3
V
3_
1
V
IN
V
Su
pp
ly
3V
3_
2
1V
5_
2
V
Su
p
V
ol
ta
ge
 a
nd
 C
ur
re
nt
 M
on
ito
rin
g
Em
ile
 T
he
sn
aa
r
10
5
V
1.
0
15
41
69
09
PI
OP
40
10
1
PI
OP
40
10
2
PI
OP
40
10
3
PIOP40104 PIOP401011
CO
OP
40
1A
PIOP40104
PI
OP
40
10
5
PI
OP
40
10
6
PI
OP
40
10
7
PIOP401011
CO
OP
40
1B
PIOP40104
PI
OP
40
10
8
PI
OP
40
10
9
PI
OP
40
10
10
PIOP401011
CO
OP
40
1C
PI
R40
101
PI
R40
102
CO
R4
01
PI
R40
201
PI
R40
202
CO
R4
02
PIR40301PIR40302 C
OR
40
3
PIR40501PIR40502 C
OR
40
5
PIR40601PIR40602 C
OR
40
6
PI
R40
701
PI
R40
702
CO
R4
07
PIR401001PIR401002 C
OR
40
10
PIR401101PIR401102 C
OR
40
11
PI
TP
40
10
1CO
TP
40
1
P
I
T
P
4
02
01
CO
TP
40
2
P
I
T
P
4
03
01
CO
TP
40
3
P
I
U
4
0
1
0
1
P
I
U
4
0
1
0
2
P
I
U
4
0
1
0
3
P
I
U
4
0
1
0
4
P
I
U
4
0
1
0
5
P
I
U
4
0
1
0
6
P
I
U
4
0
1
0
7
P
I
U
4
0
1
0
8
P
I
U
4
0
1
0
9
P
I
U4
01
01
0
P
I
U4
01
01
1
P
I
U4
01
01
2
P
I
U4
01
01
3
P
I
U4
01
01
4
P
I
U
4
0
1
0
1
5
P
I
U
4
0
1
0
1
6
CO
U4
01
P
I
U
4
0
2
0
1
P
I
U
4
0
2
0
2
PIU40203PI
U40204
P
I
U
4
0
2
0
5 CO
U4
02
P
I
U
4
0
3
0
1
P
I
U
4
0
3
0
2
PIU40303PIU
40304
P
I
U
4
0
3
0
5 CO
U4
03
P
I
U
4
0
4
0
1
P
I
U
4
0
4
0
2
PIU40403PIU
40404
P
I
U
4
0
4
0
5 CO
U4
04
P
I
U
4
0
5
0
1
P
I
U
4
0
5
0
2
P
I
U
4
0
5
0
3
P
I
U
4
0
5
0
4
P
I
U
4
0
5
0
5
P
I
U
4
0
5
0
6
P
I
U
4
0
5
0
7
P
I
U
4
0
5
0
8
CO
U4
05
P
I
U
4
0
7
0
1
P
I
U
4
0
7
0
2
P
I
U
4
0
7
0
3
P
I
U
4
0
7
0
4
P
I
U
4
0
7
0
5
P
I
U
4
0
7
0
6
P
I
U
4
0
7
0
7
P
I
U
4
0
7
0
8
CO
U4
07
PI
R40
101 PIU40203
PI
OP
40
10
6
PI
OP
40
10
7
PI
TP
40
10
1
P
I
U
4
0
1
0
3
NL
1V
50
CU
R
PI
R40
102
P
I
U
4
0
1
0
1
PIU40204
PIOP40104
P
I
U4
01
01
2
P
I
U
4
0
2
0
5
P
I
U
4
0
3
0
5
P
I
U
4
0
4
0
5
P
I
U
4
0
5
0
8
P
I
U
4
0
7
0
6
P
I
U
4
0
7
0
8
PI
R40
201 PIU40303
PI
OP
40
10
1
PI
OP
40
10
2
P
I
T
P
4
02
01
P
I
U
4
0
1
0
4
NL
3V
30
CU
R
PI
R40
202
P
I
U
4
0
1
0
2
PIU40304
PIOP401011
PIR40301PIR40501
PIR40601
PIR401101
P
I
U4
01
01
1
P
I
U
4
0
2
0
2
P
I
U
4
0
3
0
2
P
I
U
4
0
4
0
2
P
I
U
4
0
5
0
4
P
I
U
4
0
5
0
5
P
I
U
4
0
5
0
6
P
I
U
4
0
5
0
7
P
I
U
4
0
7
0
4
P
I
U
4
0
7
0
5
P
I
U
4
0
7
0
7
PI
OP
40
10
3
PIR40502
P
I
U
4
0
3
0
1
PI
OP
40
10
5
PIR40302
P
I
U
4
0
2
0
1
PI
OP
40
10
10
PIR40602
P
I
U
4
0
4
0
1
P
I
U
4
0
1
0
6
P
I
U
4
0
1
0
7
P
I
U
4
0
1
0
8
P
I
U4
01
01
3
P
I
U4
01
01
4
P
I
U
4
0
1
0
1
5
P
I
U
4
0
5
0
3
P
I
U
4
0
7
0
3
P
I
U
4
0
1
0
9
P
I
U
4
0
5
0
2
P
I
U
4
0
7
0
2
NL
SC
L
P
O
S
C
L
P
I
U4
01
01
0
P
I
U
4
0
5
0
1
P
I
U
4
0
7
0
1
NL
SD
A
P
O
S
D
A
PI
OP
40
10
8
PI
OP
40
10
9
P
I
T
P
4
03
01
P
I
U
4
0
1
0
5
NL
SU
P0
CU
R
PI
R40
701 PIU40403
PIR401001 PIR401102
P
I
U
4
0
1
0
1
6
NL
VS
up
PI
R40
702
PIR401002
PIU40404
NL
VS
up
pl
y
P
O
S
C
L
P
O
S
D
A
Figure B.5 – Schematic Showing the Current, Voltage and Temperature Sensors
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 107
11
22
33
44
D
D
C
C
B
B
A
A
Ti
tle
N
um
be
r
R
ev
is
io
n
Si
ze A
4
D
at
e:
20
14
/0
2/
05
Sh
ee
t  
  o
f
Fi
le
:
C
:\D
ro
pb
ox
\..
\5
_T
ra
ns
ci
ev
er
s.S
ch
D
oc
D
ra
w
n 
B
y:
C
A
N
_1
_T
X
_1
C
A
N
_1
_R
X
_1
C
A
N
_2
_T
X
C
A
N
_2
_R
X
C
A
N
_2
_T
X
C
A
N
_2
_R
X
C
A
N
_1
_T
X
_1
C
A
N
_1
_R
X
_1
C
A
N
_1
_T
X
C
A
N
_1
_R
X
C
A
N
1_
H
C
A
N
1_
L
C
A
N
_2
_T
X
C
A
N
_2
_R
X
C
A
N
2_
H
C
A
N
2_
L
G
N
D
G
N
D
G
N
D
G
N
D
0.
1u
F
C
5_
1
0.
1u
F
C
5_
2
12
0
R
5_
1
12
0
R
5_
3
C
A
N
1_
H
C
A
N
1_
L
C
A
N
2_
H
C
A
N
2_
L
G
N
D
G
N
D
1KR
5_
2
1KR
5_
4
Li
nk
R
5_
5
3V
3_
X
V
R
3V
3_
X
V
R
3V
3_
X
V
R
R
s
8
C
A
N
H
7
C
A
N
L
6
LB
K
5
TX
1
G
N
D
2
3V
3
3
R
X
4
X
V
R
5_
1
C
A
N
 T
ra
ns
ci
ev
er
R
s
8
C
A
N
H
7
C
A
N
L
6
LB
K
5
TX
1
G
N
D
2
3V
3
3
R
X
4
X
V
R
5_
2
C
A
N
 T
ra
ns
ci
ev
er
TP
5_
1
Te
st
Po
in
t
TP
5_
2
Te
st
Po
in
t
TP
5_
4
Te
st
Po
in
t
TP
5_
5
Te
st
Po
in
t
TP
5_
6
Te
st
Po
in
t
TP
5_
7
Te
st
Po
in
t
TP
5_
9
Te
st
Po
in
t
TP
5_
10
Te
st
Po
in
t
TP
5_
11
Te
st
Po
in
t
N
C
/5
V
0
1
C
A
N
_G
N
D
2
C
A
N
_L
3
C
A
N
_H
4
C
A
N
_G
N
D
5
N
C
6
N
C
7
N
C
/5
V
0
8
N
C
9
N
C
10
JP
5_
1
C
A
N N
C
/5
V
0
1
C
A
N
_G
N
D
2
C
A
N
_L
3
C
A
N
_H
4
C
A
N
_G
N
D
5
N
C
6
N
C
7
N
C
/5
V
0
8
N
C
9
N
C
10
JP
5_
2
C
A
N
IN
 1
IN
 2
O
U
T 
1
O
U
T 
2
JP
5_
3
C
A
N
 S
el
ec
to
r
IN
 1
IN
 2
O
U
T 
1
O
U
T 
2
JP
5_
4
C
A
N
 S
el
ec
to
r
C
A
N
_1
_T
X
_2
C
A
N
_1
_R
X
_2
C
A
N
_1
_T
X
_2
C
A
N
_1
_R
X
_2
C
A
N
_1
_T
X
_1
C
A
N
_1
_R
X
_1
C
A
N
_1
_R
X
_2
C
A
N
_1
_T
X
_2
C
A
N
_1
_T
X
C
A
N
_1
_R
X
_2
C
A
N
_1
_T
X
_2
C
A
N
_1
_R
X
3V
3_
D
U
T
C
A
N
 T
ra
ns
ce
iv
er
s
Em
ile
 T
he
sn
aa
r
10
6
V
1.
0
15
41
69
09
PIC50101 PIC50102
CO
C5
01
PIC50201 PIC50202
CO
C5
02
P
I
J
P
5
0
1
0
1
P
I
J
P
5
0
1
0
2
P
I
J
P
5
0
1
0
3
P
I
J
P
5
0
1
0
4
P
I
J
P
5
0
1
0
5
P
I
J
P
5
0
1
0
6
P
I
J
P
5
0
1
0
7
P
I
J
P
5
0
1
0
8
P
I
J
P
5
0
1
0
9
P
I
J
P
50
10
10
CO
JP
501
P
I
J
P
5
0
2
0
1
P
I
J
P
5
0
2
0
2
P
I
J
P
5
0
2
0
3
P
I
J
P
5
0
2
0
4
P
I
J
P
5
0
2
0
5
P
I
JP
50
20
6
P
I
JP
50
20
7
P
I
JP
50
20
8
P
I
JP
50
20
9
PI
JP
50
20
10
CO
JP
502
P
I
J
P
5
0
3
0
1
P
I
J
P
5
0
3
0
2
P
I
J
P
5
0
3
0
3
P
I
J
P
5
0
3
0
4CO
JP
50
3
P
I
J
P
5
0
4
0
1
P
I
J
P
5
0
4
0
2
P
I
J
P
5
0
4
0
3
P
I
J
P
5
0
4
0
4CO
JP
50
4
PIR50101PIR50102 C
OR
50
1
PIR50201PIR50202 C
OR
50
2
PIR50301PIR50302 C
OR
50
3
PIR50401PIR50402 C
OR
50
4
PIR
505
01
PIR
505
02
CO
R5
05
PITP50101
CO
TP
50
1 PITP50201
CO
TP
50
2
PITP50401
CO
TP
50
4 PITP50501
CO
TP
50
5
PITP50601
CO
TP
50
6 PITP50701
CO
TP
50
7
PITP50901
CO
TP
50
9 PITP501001
CO
TP
50
10
PI
TP
50
11
01
CO
TP
50
11
PI
XV
R5
01
01
PI
XV
R5
01
02
PI
XV
R5
01
03
PI
XV
R5
01
04
PI
XV
R5
01
05
PI
XV
R5
01
06
PI
XV
R5
01
07
PI
XV
R5
01
08
CO
XV
R5
01
PI
XV
R5
02
01
PI
XV
R5
02
02
PI
XV
R5
02
03
PI
XV
R5
02
04
PI
XV
R5
02
05
PI
XV
R5
02
06
PI
XV
R5
02
07
PI
XV
R5
02
08
CO
XV
R5
02
PIR
505
02
PIC50102 PIC50202
PIR
505
01
PI
TP
50
11
01
PI
XV
R5
01
03
PI
XV
R5
02
03
NL
3V
30
XV
R
P
I
J
P
5
0
1
0
4
PIR50102
PITP50401
PI
XV
R5
01
07
NL
CA
N1
0HPI
J
P
5
0
1
0
3
PIR50101
PITP50501
PI
XV
R5
01
06
NL
CA
N1
0L PI
J
P
5
0
2
0
4
PIR50302
PITP50901
PI
XV
R5
02
07
NL
CA
N2
0HPI
J
P
5
0
2
0
3
PIR50301
PITP501001
PI
XV
R5
02
06
NL
CA
N2
0L
P
I
J
P
5
0
4
0
1
PITP50201
PI
XV
R5
01
04
NL
CA
N0
10
RX
P
I
J
P
5
0
4
0
4
NL
CA
N0
10
RX
01
P
O
C
A
N
0
1
0
R
X
0
1
P
I
J
P
5
0
3
0
3
P
I
J
P
5
0
4
0
2
NL
CA
N0
10
RX
02
P
O
C
A
N
0
1
0
R
X
0
2
P
I
J
P
5
0
3
0
1
PITP50101
PI
XV
R5
01
01
NL
CA
N0
10
TX
P
I
J
P
5
0
3
0
4
NL
CA
N0
10
TX
01
P
O
C
A
N
0
1
0
T
X
0
1
P
I
J
P
5
0
3
0
2
P
I
J
P
5
0
4
0
3
NL
CA
N0
10
TX
02
P
O
C
A
N
0
1
0
T
X
0
2
PITP50701
PI
XV
R5
02
04
NL
CA
N0
20
RX
P
O
C
A
N
0
2
0
R
X
PITP50601
PI
XV
R5
02
01
NL
CA
N0
20
TX
P
O
C
A
N
0
2
0
T
X
PIC50101 PIC50201
P
I
J
P
5
0
1
0
2
P
I
J
P
5
0
1
0
5
P
I
J
P
5
0
2
0
2
P
I
J
P
5
0
2
0
5
PIR50202 PIR50402
PI
XV
R5
01
02
PI
XV
R5
02
02
P
I
J
P
5
0
1
0
1
P
I
J
P
5
0
1
0
6
P
I
J
P
5
0
1
0
7
P
I
J
P
5
0
1
0
8
P
I
J
P
5
0
1
0
9
P
I
J
P
50
10
10
P
I
J
P
5
0
2
0
1
P
I
JP
50
20
6
P
I
JP
50
20
7
P
I
JP
50
20
8
P
I
JP
50
20
9
PI
JP
50
20
10
PIR50201
PI
XV
R5
01
08 PIR50401
PI
XV
R5
02
08
PI
XV
R5
01
05
PI
XV
R5
02
05
P
O
C
A
N
0
1
0
R
X
0
1
P
O
C
A
N
0
1
0
R
X
0
2
P
O
C
A
N
0
1
0
T
X
0
1
P
O
C
A
N
0
1
0
T
X
0
2
P
O
C
A
N
0
2
0
R
X
P
O
C
A
N
0
2
0
T
X
Figure B.6 – Schematic Showing the Connection of the CAN Transceivers
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 108
11
22
33
44
D
D
C
C
B
B
A
A
Ti
tle
N
um
be
r
R
ev
is
io
n
Si
ze A
4
D
at
e:
20
14
/0
2/
05
Sh
ee
t  
  o
f
Fi
le
:
C
:\D
ro
pb
ox
\..
\6
_I
nt
er
fa
ce
.S
ch
D
oc
D
ra
w
n 
B
y:
G
N
D
1.
5K
R
6_
1
39
R
6_
2
39
R
6_
3
39
R
6_
4
39
R
6_
5
39
R
6_
6
39
R
6_
7
39
R
6_
8
39
R
6_
9
39
R
6_
10
39
R
6_
11
2.
2K
R
6_
12
39
R
6_
13
1KR
6_
14
49.9 R6_15
49.9 R6_16
49.9 R6_17
49.9 R6_18
G
N
D
G
N
D
0.
1u
F
C
6_
2
0.
1u
F
C
6_
3
0.
1u
F
C
6_
4
0.
1u
F
C
6_
14
0.
1u
F
C
6_
5
0.
1u
F
C
6_
7
0.
1u
F
C
6_
8
4.
87
k
R
6_
19
4.
87
k
R
6_
20
G
N
D
G
N
D
ET
H
1
ET
H
2
ET
H
3
ET
H
4
ET
H
5
ET
H
6
ET
H
7
ET
H
8
ET
H
9
ET
H
10
ET
H
11
ET
H
12
ET
H
13
ET
H
14
ET
H
15
ET
H
16
ET
H
17
ET
H
18
ET
H
19
ET
H
20
ET
H
21
G
N
D
0.
1u
F
C
6_
10
0.
1u
F
C
6_
9
1n
F
C
6_
13
G
N
D
G
N
D
0.
1u
F
C
6_
11
0.
1u
F
C
6_
12
G
N
D
G
N
D
G
N
D
ET
H
[2
1.
.1
]
ET
H
[2
1.
.1
]
L6
_1
In
du
ct
or
TD
+
TD
-
R
D
+
R
D
-
G
N
D
TX
_C
LK
1
TX
_E
N
2
TX
D
_0
3
TX
D
_1
4
TX
D
_2
5
TX
D
_3
/S
N
I_
M
O
D
E
6
PW
R
_D
O
W
N
/IN
T
7
R
D
-
13
R
D
+
14
A
G
N
D
15
TD
-
16
TD
+
17
PF
B
IN
1
18
A
G
N
D
19
AVDD33
22
PF
B
O
U
T
23
R
B
IA
S
24
25
M
H
z_
O
U
T
25
LE
D
_A
C
T/
C
O
L/
A
N
-E
N
26
LE
D
_S
PE
ED
/A
N
1
27
LE
D
_L
IN
K
_A
N
0
28
R
ES
ET
_N
29
M
D
IO
30
M
D
C
31
IOVDD33
32
X
2
33
X
1
34
IO
G
N
D
35
D
G
N
D
36
PF
B
IN
2
37
R
X
_C
LK
38
R
X
_D
V
/M
II_
M
O
D
E
39
C
R
S/
C
R
S_
D
V
/L
ED
_C
FG
40
R
X
_E
R
/M
D
IX
_E
N
41
C
O
L/
PH
Y
A
D
0
42
R
X
D
_0
/P
H
Y
A
D
1
43
R
X
D
_1
/P
H
Y
A
D
2
44
R
X
D
_2
/P
H
Y
A
D
3
45
R
X
D
3/
PH
Y
A
D
4
46
IO
G
N
D
47
IOVDD33
48
U
6_
1
D
P8
38
48
TD
+
1
TD
-
2
R
D
+
3
3V
3
4
3V
3
5
R
D
-
6
G
N
D
7
G
N
D
8
G
N
D
9
JP
6_
1
R
J4
5_
N
O
LE
D
22
uF
C
6_
1
22
uF
C
6_
6
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1_
ET
H
3V
3_
1_
ET
H
3V
3_
1_
ET
H
3V
3_
1_
ET
H
3V
3_
1_
ET
H
Et
he
rn
et
 B
oa
rd
 In
te
rf
ac
e Emil
e 
Th
es
na
ar
10
7
V
1.
0
15
41
69
09
PIC60101PIC60102
CO
C6
01
PIC60201PIC60202
CO
C6
02
PIC60301PIC60302
CO
C6
03
PIC60401PIC60402
CO
C6
04
PIC60501PIC60502CO
C6
05
PIC60601PIC60602CO
C6
06
PIC60701PIC60702CO
C6
07
PIC60801PIC60802CO
C6
08
PIC60901PIC60902
CO
C6
09
PIC601001PIC601002
CO
C6
01
0
PIC601101PIC601102
CO
C6
01
1
PIC601201PIC601202
CO
C6
01
2
PIC
601
301
PIC
601
302
CO
C6
01
3
PIC
601
401
PIC
601
402CO
C6
01
4
P
I
J
P
6
0
1
0
1
P
I
J
P
6
0
1
0
2
P
I
J
P
6
0
1
0
3
P
I
J
P
6
0
1
0
4
P
I
J
P
6
0
1
0
5
P
I
J
P
6
0
1
0
6
P
I
J
P
6
0
1
0
7
P
I
J
P
6
0
1
0
8
P
I
J
P
6
0
1
0
9CO
JP
601
PI
L60
101
PI
L60
102
CO
L6
01
PIR60101 PIR60102C
OR
60
1
PI
R60
201
PI
R60
202
CO
R6
02
PI
R60
301
PI
R60
302
CO
R6
03
PI
R60
401
PI
R60
402
CO
R6
04
PI
R60
501
PI
R60
502
CO
R6
05
PI
R60
601
PI
R60
602
CO
R6
06
PI
R60
701
PI
R60
702
CO
R6
07
PI
R60
801
PI
R60
802
CO
R6
08
PI
R60
901
PI
R60
902
CO
R6
09
PIR
601
001
PIR
601
002
CO
R6
01
0
PIR
601
101
PIR
601
102
CO
R6
01
1
PIR601201PIR601202 C
OR
60
12
PIR
601
301
PIR
601
302
CO
R6
01
3
PIR601401 PIR601402C
OR
60
14
PIR601501 PIR601502 COR6015
PIR601601 PIR601602 COR6016
PIR601701 PIR601702 COR6017
PIR601801 PIR601802 COR6018
PIR601901PIR601902 C
OR
60
19
PIR602001PIR602002 C
OR
60
20
P
I
U
6
0
1
0
1
P
I
U
6
0
1
0
2
P
I
U
6
0
1
0
3
P
I
U
6
0
1
0
4
P
I
U
6
0
1
0
5
P
I
U
6
0
1
0
6
P
I
U
6
0
1
0
7
P
I
U
60
10
13
P
I
U
60
10
14
P
I
U
60
10
15
P
I
U
60
10
16
P
I
U
60
10
17
P
I
U
6
0
1
0
1
8
P
I
U
60
10
19
PIU601022
P
I
U
6
0
1
0
2
3
P
I
U6
01
02
4
P
I
U
6
0
1
0
2
5
P
I
U
60
10
26
P
I
U
60
10
27
P
I
U
60
10
28
P
I
U
6
0
1
0
2
9
P
I
U
6
0
1
0
3
0
P
I
U
6
0
1
0
3
1
PIU601032
P
I
U6
01
03
3
P
I
U
6
0
1
0
3
4
PI
U6
01
03
5
PI
U6
01
03
6
P
I
U
6
0
1
0
3
7
P
I
U
6
0
1
0
3
8
P
I
U
6
0
1
0
3
9
P
I
U
6
0
1
0
4
0
P
I
U
6
0
1
0
4
1
P
I
U
6
0
1
0
4
2
P
I
U
6
0
1
0
4
3
P
I
U
6
0
1
0
4
4
P
I
U
6
0
1
0
4
5
P
I
U
6
0
1
0
4
6
P
I
U
60
10
47
PIU601048
CO
U6
01
PIC60102
PIC60202
PIC60302
PIC60402
PI
L60
102
PIR60101
PIU601032PIU601048
PIC60902
PIC601002
PIC601102
PIC601202
PIC
601
402
P
I
J
P
6
0
1
0
4
P
I
J
P
6
0
1
0
5
PI
L60
101
PIR601501
PIR601601
PIR601701
PIR601801
PIU601022
PIC60101
PIC60201
PIC60301
PIC60401
PIC60501
PIC60601
PIC60701
PIC60801
PIC60901
PIC601001
PIC601101
PIC601201
PIC
601
301
PIC
601
401
PIR601201
PIR601402
PIR601901
PIR602001
P
I
U
60
10
15
P
I
U
60
10
19
PI
U6
01
03
5
PI
U6
01
03
6
P
I
U
60
10
47
PIC60502
PIC60602
PIC60702
PIC60802
P
I
U
6
0
1
0
1
8
P
I
U
6
0
1
0
2
3
P
I
U
6
0
1
0
3
7
PIC
601
302P
I
J
P
6
0
1
0
7
P
I
J
P
6
0
1
0
8
P
I
J
P
6
0
1
0
9
PI
R60
201P
I
U
6
0
1
0
4
0
PI
R60
301P
I
U
6
0
1
0
4
2
PI
R60
401P
I
U
6
0
1
0
1
PI
R60
501P
I
U
6
0
1
0
3
8
PI
R60
601P
I
U
6
0
1
0
4
3
PI
R60
701P
I
U
6
0
1
0
4
4
PI
R60
801P
I
U
6
0
1
0
4
5
PI
R60
901P
I
U
6
0
1
0
4
6
PIR
601
001P
I
U
6
0
1
0
4
1
PIR
601
101P
I
U
6
0
1
0
3
9
PIR
601
301P
I
U
6
0
1
0
2
5
PIR601902
P
I
U6
01
02
4
P
I
U
60
10
26
P
I
U
60
10
27
P
I
U
60
10
28
P
I
U6
01
03
3
P
I
J
P
6
0
1
0
3
PIR601702
P
I
U
60
10
14
NL
RD
0
P
I
J
P
6
0
1
0
6
PIR601802
P
I
U
60
10
13
NL
RD
0
P
I
J
P
6
0
1
0
1
PIR601502
P
I
U
60
10
17
NL
TD
0
P
I
J
P
6
0
1
0
2
PIR601602
P
I
U
60
10
16
NL
TD
0
PIR60102 PIU
6
0
1
0
3
0
NL
ET
H0
21
00
10
NL
ET
H1
PO
ET
H0
21
00
10
P
I
U
6
0
1
0
3
1
NL
ET
H0
21
00
10
NL
ET
H2
PO
ET
H0
21
00
10
PI
R60
202
NL
ET
H0
21
00
10
NL
ET
H3
PO
ET
H0
21
00
10
PI
R60
302
NL
ET
H0
21
00
10
NL
ET
H4
PO
ET
H0
21
00
10
PI
R60
402
NL
ET
H0
21
00
10
NL
ET
H5
PO
ET
H0
21
00
10
P
I
U
6
0
1
0
3
NL
ET
H0
21
00
10
NL
ET
H6
PO
ET
H0
21
00
10
P
I
U
6
0
1
0
4
NL
ET
H0
21
00
10
NL
ET
H7
PO
ET
H0
21
00
10
P
I
U
6
0
1
0
5
NL
ET
H0
21
00
10
NL
ET
H8
PO
ET
H0
21
00
10
P
I
U
6
0
1
0
6
NL
ET
H0
21
00
10
NL
ET
H9
PO
ET
H0
21
00
10
P
I
U
6
0
1
0
2
NL
ET
H0
21
00
10
NL
ET
H1
0
PO
ET
H0
21
00
10
PI
R60
502
NL
ET
H0
21
00
10
NL
ET
H1
1
PO
ET
H0
21
00
10
PI
R60
602
NL
ET
H0
21
00
10
NL
ET
H1
2
PO
ET
H0
21
00
10
PI
R60
702
NL
ET
H0
21
00
10
NL
ET
H1
3
PO
ET
H0
21
00
10
PI
R60
802
NL
ET
H0
21
00
10
NL
ET
H1
4
PO
ET
H0
21
00
10
PI
R60
902
NL
ET
H0
21
00
10
NL
ET
H1
5
PO
ET
H0
21
00
10
PIR
601
002
NL
ET
H0
21
00
10
NL
ET
H1
6
PO
ET
H0
21
00
10
PIR
601
102
PIR601202
NL
ET
H0
21
00
10
NL
ET
H1
7
PO
ET
H0
21
00
10
PIR
601
302
NL
ET
H0
21
00
10
NL
ET
H1
8
PO
ET
H0
21
00
10
PIR601401
P
I
U
6
0
1
0
7
NL
ET
H0
21
00
10
NL
ET
H1
9
PO
ET
H0
21
00
10
PIR602002
P
I
U
6
0
1
0
2
9
NL
ET
H0
21
00
10
NL
ET
H2
0
PO
ET
H0
21
00
10
P
I
U
6
0
1
0
3
4
NL
ET
H0
21
00
10
NL
ET
H2
1
PO
ET
H0
21
00
10
P
O
E
T
H
1
P
O
E
T
H
2
P
O
E
T
H
3
P
O
E
T
H
4
P
O
E
T
H
5
P
O
E
T
H
6
P
O
E
T
H
7
P
O
E
T
H
8
P
O
E
T
H
9
P
O
E
T
H
1
0
P
O
E
T
H
1
1
P
O
E
T
H
1
2
P
O
E
T
H
1
3
P
O
E
T
H
1
4
P
O
E
T
H
1
5
P
O
E
T
H
1
6
P
O
E
T
H
1
7
P
O
E
T
H
1
8
P
O
E
T
H
1
9
P
O
E
T
H
2
0
P
O
E
T
H
2
1
PO
ET
H0
21
00
10
Figure B.7 – Schematic Showing the Connection of the Ethernet PHY
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 109
11
22
33
44
D
D
C
C
B
B
A
A
Ti
tle
N
um
be
r
R
ev
is
io
n
Si
ze A
4
D
at
e:
20
14
/0
2/
05
Sh
ee
t  
  o
f
Fi
le
:
C
:\D
ro
pb
ox
\..
\7
_L
ED
.S
ch
D
oc
D
ra
w
n 
B
y:
Po
w
er
_1
Ground_1
LE
D
7_
1_
L
LE
D
7_
2
LE
D
7_
3
LE
D
7_
5
LE
D
7_
6
LE
D
7_
7
LE
D
7_
8
LE
D
7_
4
1
1
2
2
3
3
4
4
5
5
6
6
7
7
8
8
9
9
10
10
JP
7_
1
2x
5
Po
w
er
_1
LE
D
7_
1
G
ro
un
d_
1
Ground_1Ground_1Ground_1
Ground_1 Ground_1 Ground_1 Ground_1
Po
w
er
_1
Po
w
er
_1
Po
w
er
_1
Po
w
er
_1
Po
w
er
_1
Po
w
er
_1
Po
w
er
_1
Po
w
er
_2
Ground_2
LE
D
7_
9_
L
LE
D
7_
10
LE
D
7_
11
LE
D
7_
13
LE
D
7_
14
LE
D
7_
15
LE
D
7_
16
LE
D
7_
12
1
1
2
2
3
3
4
4
5
5
6
6
7
7
8
8
9
9
10
10
JP
7_
2
2x
5
Po
w
er
_2
G
ro
un
d_
2
Ground_2Ground_2Ground_2
Ground_2 Ground_2 Ground_2 Ground_2
Po
w
er
_2
Po
w
er
_2
Po
w
er
_2
Po
w
er
_2
Po
w
er
_2
Po
w
er
_2
Po
w
er
_2
12
0
R
7_
1
12
0
R
7_
2
12
0
R
7_
3
12
0
R
7_
4
12
0
R
7_
5
12
0
R
7_
6
12
0
R
7_
7
12
0
R
7_
8
12
0
R
7_
9
12
0
R
7_
10
12
0
R
7_
11
12
0
R
7_
12
12
0
R
7_
13
12
0
R
7_
14
12
0
R
7_
15
12
0
R
7_
16
G
re
en
D
7_
1
G
re
en
D
7_
2
G
re
en
D
7_
3
G
re
en
D
7_
4
G
re
en
D
7_
5
G
re
en
D
7_
6
G
re
en
D
7_
7
G
re
en
D
7_
8
G
re
en
D
7_
9
G
re
en
D
7_
10
G
re
en
D
7_
11
G
re
en
D
7_
12
G
re
en
D
7_
13
G
re
en
D
7_
14
G
re
en
D
7_
15
G
re
en
D
7_
16
LE
D
7_
2
LE
D
7_
3
LE
D
7_
4
LE
D
7_
5
LE
D
7_
6
LE
D
7_
7
LE
D
7_
8
LE
D
7_
14
LE
D
7_
15
LE
D
7_
16
LE
D
7_
9
LE
D
7_
10
LE
D
7_
11
LE
D
7_
12
LE
D
7_
13
Q
7_
1
N
PN
Q
7_
2
N
PN
Q
7_
3
N
PN
Q
7_
4
N
PN
Q
7_
5
N
PN
Q
7_
6
N
PN
Q
7_
7
N
PN
Q
7_
8
N
PN
Q
7_
9
N
PN
Q
7_
10
N
PN
Q
7_
11
N
PN
Q
7_
12
N
PN
Q
7_
13
N
PN
Q
7_
14
N
PN
Q
7_
15
N
PN
Q
7_
16
N
PN
12
PB
7_
1
Pu
sh
B
ut
to
n
12
PB
7_
2
Pu
sh
B
ut
to
n
1KR
7_
17
10
K
R
7_
18
1KR
7_
19
10
K
R
7_
20
Po
w
er
_1
Po
w
er
_2
IN
 1
IN
 2
O
U
T 
1
JP
7_
3
3 
W
ay
 Ju
m
pe
r
IN
 1
IN
 2
O
U
T 
1
JP
7_
4
3 
W
ay
 Ju
m
pe
r
LE
D
7_
1
LE
D
7_
9
LE
D
7_
1_
L
LE
D
7_
9_
L
PB
_1
PB
_9
PB
_1
PB
_9
G
ro
un
d_
1
G
ro
un
d_
2
LE
D
 D
ia
gn
os
tic
 B
oa
rd
s Emi
le
 T
he
sn
aa
r
10
8
V
1.
0
15
41
69
09
PI
D7
01
01
PI
D7
01
02C
OD
70
1
PI
D7
02
01
PI
D7
02
02C
OD
70
2
PI
D7
03
01
PI
D7
03
02C
OD
70
3
PI
D7
04
01
PI
D7
04
02C
OD
70
4
PI
D7
05
01
PI
D7
05
02C
OD
70
5
PI
D7
06
01
PI
D7
06
02C
OD
70
6
PI
D7
07
01
PI
D7
07
02C
OD
70
7
PI
D7
08
01
PI
D7
08
02C
OD
70
8
PI
D7
09
01
PI
D7
09
02C
OD
70
9
PI
D7
01
00
1
PI
D7
01
00
2CO
D7
01
0
PI
D7
01
10
1
PI
D7
01
10
2CO
D7
01
1
PI
D7
01
20
1
PI
D7
01
20
2CO
D7
01
2
PI
D7
01
30
1
PI
D7
01
30
2CO
D7
01
3
PI
D7
01
40
1
PI
D7
01
40
2CO
D7
01
4
PI
D7
01
50
1
PI
D7
01
50
2CO
D7
01
5
PI
D7
01
60
1
PI
D7
01
60
2CO
D7
01
6
P
I
JP
70
10
1
P
I
JP
70
10
2
P
I
JP
70
10
3
P
I
JP
70
10
4
P
I
JP
70
10
5
P
I
JP
70
10
6
P
I
JP
70
10
7
P
I
JP
70
10
8
P
I
JP
70
10
9
PI
JP
70
10
10
CO
JP
70
1
PI
JP
70
20
1
PI
JP
70
20
2
PI
JP
70
20
3
PI
JP
70
20
4
PI
JP
70
20
5
P
I
JP
70
20
6
P
I
JP
70
20
7
P
I
JP
70
20
8
P
I
JP
70
20
9
PI
JP
70
20
10
CO
JP
702
P
I
JP
70
30
1
P
I
JP
70
30
2
P
I
JP
70
30
3CO
JP
70
3
P
I
JP
70
40
1
P
I
JP
70
40
2
P
I
JP
70
40
3CO
JP
704
PIPB70101PIPB70102 COP
B7
01
PIPB70201PIPB70202 COP
B7
02
PI
Q7
01
01
PIQ70102PIQ70103 CO
Q70
1
PI
Q7
02
01
PIQ70202PIQ70203 CO
Q70
2
PI
Q7
03
01
PIQ70302PIQ70303 CO
Q70
3
PI
Q7
04
01
PIQ70402PIQ70403 CO
Q70
4
PI
Q7
05
01
PIQ70502PIQ70503 CO
Q70
5
PI
Q7
06
01
PIQ70602PIQ70603 CO
Q70
6
PI
Q7
07
01
PIQ70702PIQ70703 CO
Q70
7
PI
Q7
08
01
PIQ70802PIQ70803 CO
Q70
8
PI
Q7
09
01
PIQ70902PIQ70903 CO
Q70
9
PI
Q7
01
00
1
PIQ701002PIQ701003 CO
Q70
10
PI
Q7
01
10
1
PIQ701102PIQ701103 CO
Q70
11
PI
Q7
01
20
1
PIQ701202PIQ701203 CO
Q70
12
PI
Q7
01
30
1
PIQ701302PIQ701303 CO
Q70
13
PI
Q7
01
40
1
PIQ701402PIQ701403 CO
Q70
14
PI
Q7
01
50
1
PIQ701502PIQ701503 CO
Q70
15
PI
Q7
01
60
1
PIQ701602PIQ701603 CO
Q70
16
PI
R7
010
1
PI
R7
010
2
CO
R7
01
PI
R7
020
1
PI
R7
020
2
CO
R7
02
PI
R7
030
1
PI
R7
030
2
CO
R7
03
PI
R7
040
1
PI
R7
040
2
CO
R7
04
PI
R7
050
1
PI
R7
050
2
CO
R7
05
PI
R7
060
1
PI
R7
060
2
CO
R7
06
PI
R7
070
1
PI
R7
070
2
CO
R7
07
PI
R7
080
1
PI
R7
080
2
CO
R7
08
PI
R70
901
PI
R7
090
2
CO
R7
09
PIR
701
001
PIR
701
002
CO
R7
01
0
PIR
701
101
PIR
701
102
CO
R7
01
1
PIR
701
201
PIR
701
202
CO
R7
01
2
PIR
701
301
PIR
701
302
CO
R7
01
3
PIR
701
401
PIR
701
402
CO
R7
01
4
PIR
701
501
PIR
701
502
CO
R7
01
5
PIR
701
601
PIR
701
602
CO
R7
01
6
PIR701701PIR701702
CO
R7
01
7
PIR701801PIR701802
CO
R7
01
8
PIR701901PIR701902
CO
R7
01
9
PIR702001PIR702002
CO
R7
02
0
P
I
JP
70
10
9
PIPB70101
PIQ70102 PIQ70202 PIQ70302 PIQ70402
PIQ70502 PIQ70602 PIQ70702 PIQ70802
NL
Gr
ou
nd
01
P
I
JP
70
20
9
PIPB70201
PIQ70902 PIQ701002 PIQ701102 PIQ701202
PIQ701302 PIQ701402 PIQ701502 PIQ701602
NL
Gr
ou
nd
02
P
I
JP
70
10
1
P
I
JP
70
30
1NL
LE
D7
01
P
I
JP
70
30
2
PI
Q7
01
01
NL
LE
D7
01
0L
P
I
JP
70
10
2
PI
Q7
02
01
NL
LE
D7
02 P
I
JP
70
10
3
PI
Q7
03
01
NL
LE
D7
03 P
I
JP
70
10
4
PI
Q7
04
01
NL
LE
D7
04 P
I
JP
70
10
5
PI
Q7
05
01
NL
LE
D7
05
P
I
JP
70
10
6
PI
Q7
06
01
NL
LE
D7
06
P
I
JP
70
10
7
PI
Q7
07
01
NL
LE
D7
07
P
I
JP
70
10
8
PI
Q7
08
01
NL
LE
D7
08
PI
JP
70
20
1
P
I
JP
70
40
1N
LL
ED
70
9
P
I
JP
70
40
2
PI
Q7
09
01
NL
LE
D7
09
0L
PI
JP
70
20
2
PI
Q7
01
00
1
NL
LE
D7
01
0 PI
JP
70
20
3
PI
Q7
01
10
1
NL
LE
D7
01
1 PI
JP
70
20
4
PI
Q7
01
20
1
NL
LE
D7
01
2 PI
JP
70
20
5
PI
Q7
01
30
1
NL
LE
D7
01
3
P
I
JP
70
20
6
PI
Q7
01
40
1
NL
LE
D7
01
4
P
I
JP
70
20
7
PI
Q7
01
50
1
NL
LE
D7
01
5
P
I
JP
70
20
8
PI
Q7
01
60
1
NL
LE
D7
01
6
PI
D7
01
02
PI
R7
010
2
PI
D7
02
02
PI
R7
020
2
PI
D7
03
02
PI
R7
030
2
PI
D7
04
02
PI
R7
040
2
PI
D7
05
02
PI
R7
050
2
PI
D7
06
02
PI
R7
060
2
PI
D7
07
02
PI
R7
070
2
PI
D7
08
02
PI
R7
080
2
PI
D7
09
02
PI
R7
090
2
PI
D7
01
00
2
PIR
701
002
PI
D7
01
10
2
PIR
701
102
PI
D7
01
20
2
PIR
701
202
PI
D7
01
30
2
PIR
701
302
PI
D7
01
40
2
PIR
701
402
PI
D7
01
50
2
PIR
701
502
PI
D7
01
60
2
PIR
701
602
PIQ70103
PI
R7
010
1
PIQ70203
PI
R7
020
1
PIQ70303
PI
R7
030
1
PIQ70403
PI
R7
040
1
PIQ70503
PI
R7
050
1
PIQ70603
PI
R7
060
1
PIQ70703
PI
R7
070
1
PIQ70803
PI
R7
080
1
PIQ70903
PI
R70
901
PIQ701003
PIR
701
001
PIQ701103
PIR
701
101
PIQ701203
PIR
701
201
PIQ701303
PIR
701
301
PIQ701403
PIR
701
401
PIQ701503
PIR
701
501
PIQ701603
PIR
701
601
PIR701702PIR701801
PIR701902PIR702001
P
I
JP
70
30
3
PIPB70102PIR701701NLPB01
P
I
JP
70
40
3
PIPB70202PIR701901NLPB09
PI
D7
01
01
PI
D7
02
01
PI
D7
03
01
PI
D7
04
01
PI
D7
05
01
PI
D7
06
01
PI
D7
07
01
PI
D7
08
01
PI
JP
70
10
10
PIR701802
NL
Po
we
r0
1
PI
D7
09
01
PI
D7
01
00
1
PI
D7
01
10
1
PI
D7
01
20
1
PI
D7
01
30
1
PI
D7
01
40
1
PI
D7
01
50
1
PI
D7
01
60
1
PI
JP
70
20
10
PIR702002
NL
Po
we
r0
2
Figure B.8 – Schematic Showing the Connection of the LED Daughter Boards
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 110
11
22
33
44
D
D
C
C
B
B
A
A
Ti
tle
N
um
be
r
R
ev
is
io
n
Si
ze A
4
D
at
e:
20
14
/0
2/
05
Sh
ee
t  
  o
f
Fi
le
:
C
:\D
ro
pb
ox
\..
\8
_M
em
or
y.
Sc
hD
oc
D
ra
w
n 
B
y:
SD
_1
SD
_2
SD
_3
SD
_4
SD
_5
SD
_6
SD
_7
SD
_8
10
K
R
8_
1
0.
1u
F
C
8_
1
0.
1u
F
C
8_
2
0.
1u
F
C
8_
3
0.
1u
F
C
8_
4
SD
_9
SD
_1
0
SD
_1
1
SD
_1
2
SD
_1
3
SD
_1
4
SD
_1
5
SD
_[
15
..0
]
SD
_[
15
..0
]
D
U
T_
SP
I_
C
LK
D
U
T_
SP
I_
D
A
TA
O
U
T
D
U
T_
FL
A
SH
_C
Sn
D
U
T_
SP
I_
D
A
TA
IN
G
N
D
0.
1u
F
C
8_
5
0.
1u
F
C
8_
6
0.
1u
F
C
8_
7
0.
1u
F
C
8_
8
G
N
D
G
N
D
SA
_0
SA
_1
1
SA
_1
0
SA
_9
SA
_8
SA
_7
SA
_6
SA
_5
SA
_4
SA
_3
SA
_2
SA
_1
SA
_[
12
..0
]
SA
_[
12
..0
]
D
Q
M
L
B
S1
B
S0
W
En
C
A
Sn
R
A
Sn
C
Sn
C
K
E
C
LK
W
En
C
A
Sn
R
A
Sn
C
Sn
C
K
E
C
LK
SD
_0
Fl
as
h
S
1
Q
2
W
3
V
ss
4
D
5
C
6
H
O
LD
7
V
cc
8
D
U
T_
FL
A
SH
FL
A
SH
_M
25
P1
0-
A
V
M
N
6P
D
U
T_
FL
A
SH
_W
Pn
D
U
T_
FL
A
SH
_H
O
LD
n
LD
Q
M
15
U
D
Q
M
39
B
S1
21
B
S0
20
A
11
35
A
10
/A
P
22
A
9
34
A
8
33
C
A
S
17
C
K
E
37
W
E
16
A
7
32
A
6
31
A
5
30
A
4
29
A
3
26
A
2
25
A
1
24
A
0
23
C
S
19
C
LK
38
D
Q
0
2
D
Q
8
42
D
Q
1
4
D
Q
9
44
D
Q
2
5
D
Q
10
45
D
Q
3
7
D
Q
11
47
D
Q
4
8
D
Q
12
48
D
Q
5
10
D
Q
13
50
D
Q
6
11
D
Q
14
51
D
Q
7
13
D
Q
15
53
SR
AM
R
A
S
18
A
12
36
D
U
T_
SR
A
M
A
SR
A
M
_A
43
L4
61
6A
V
-7
F
V
D
D
Q
9
V
D
D
1
V
D
D
Q
3
V
D
D
14
V
D
D
Q
43
V
D
D
Q
49
V
SS
28
V
SS
41
V
SS
54
V
SS
Q
6
V
SS
Q
52
V
SS
Q
46
V
SS
Q
12
V
D
D
27
D
U
T_
SR
A
M
B
SR
A
M
_A
43
L4
61
6A
V
-7
F
SA
_1
2
D
Q
M
H
D
Q
M
H
D
Q
M
L
B
S0
B
S1
0.
1u
F
C
8_
9
1
1
2
2
3
3
4
4
5
5
6
6
7
7
8
8
9
9
10
10
11
11
12
12
13
13
14
14
15
15
JP
8_
1
2x
8
G
N
D FL
A
SH
_P
W
R F
LA
SH
_P
W
R
SP
I_
C
LK
SP
I_
D
A
TA
IN
FL
A
SH
_C
Sn
SP
I_
D
A
TA
O
U
T
FL
A
SH
_C
Sn
SP
I_
D
A
TA
O
U
T
SP
I_
C
LK
SP
I_
D
A
TA
IN
FL
A
SH
_H
O
LD
n
FL
A
SH
_W
Pn
FL
A
SH
_W
Pn
FL
A
SH
_H
O
LD
n
D
U
T_
SP
I_
C
LK
D
U
T_
SP
I_
D
A
TA
O
U
T
D
U
T_
FL
A
SH
_C
Sn
D
U
T_
SP
I_
D
A
TA
IN
D
U
T_
FL
A
SH
_W
Pn
D
U
T_
FL
A
SH
_H
O
LD
n
3V
3_
D
U
T
3V
3_
D
U
T
3V
3_
D
U
T
D
U
T 
SR
A
M
 a
nd
 F
la
sh
Em
ile
 T
he
sn
aa
r
10
9
V
1.
0
15
41
69
09
PIC80101PIC80102
CO
C8
01
PIC80201PIC80202
CO
C8
02
PIC80301PIC80302
CO
C8
03
PIC80401PIC80402
CO
C8
04
PIC80501PIC80502
CO
C8
05
PIC80601PIC80602
CO
C8
06
PIC80701PIC80702
CO
C8
07
PIC80801PIC80802
CO
C8
08
PIC80901PIC80902
CO
C8
09
PI
DU
T0
FL
AS
H0
1
PI
DU
T0
FL
AS
H0
2
PI
DU
T0
FL
AS
H0
3
PI
DU
T0
FL
AS
H0
4
PI
DU
T0
FL
AS
H0
5
PI
DU
T0
FL
AS
H0
6
PI
DU
T0
FL
AS
H0
7
PI
DU
T0
FL
AS
H0
8
CO
DU
T0
FL
AS
H
PI
DU
T0
SR
AM
02
PI
DU
T0
SR
AM
04
PI
DU
T0
SR
AM
05
PI
DU
T0
SR
AM
07
PI
DU
T0
SR
AM
08
PI
DU
T0
SR
AM
01
0
PI
DU
T0
SR
AM
01
1
PI
DU
T0
SR
AM
01
3
PI
DU
T0
SR
AM
01
5
PI
DU
T0
SR
AM
01
6
PI
DU
T0
SR
AM
01
7
PI
DU
T0
SR
AM
01
8
PI
DU
T0
SR
AM
01
9
PI
DU
T0
SR
AM
02
0
PI
DU
T0
SR
AM
02
1
PI
DU
T0
SR
AM
02
2
PI
DU
T0
SR
AM
02
3
PI
DU
T0
SR
AM
02
4
PI
DU
T0
SR
AM
02
5
PI
DU
T0
SR
AM
02
6
PI
DU
T0
SR
AM
02
9
PI
DU
T0
SR
AM
03
0
PI
DU
T0
SR
AM
03
1
PI
DU
T0
SR
AM
03
2
PI
DU
T0
SR
AM
03
3
PI
DU
T0
SR
AM
03
4
PI
DU
T0
SR
AM
03
5
PI
DU
T0
SR
AM
03
6
PI
DU
T0
SR
AM
03
7
PI
DU
T0
SR
AM
03
8
PI
DU
T0
SR
AM
03
9
PI
DU
T0
SR
AM
04
2
PI
DU
T0
SR
AM
04
4
PI
DU
T0
SR
AM
04
5
PI
DU
T0
SR
AM
04
7
PI
DU
T0
SR
AM
04
8
PI
DU
T0
SR
AM
05
0
PI
DU
T0
SR
AM
05
1
PI
DU
T0
SR
AM
05
3
CO
DU
T0
SR
AM
A
PI
DU
T0
SR
AM
01
PI
DU
T0
SR
AM
03
PI
DU
T0
SR
AM
06
PI
DU
T0
SR
AM
09
PI
DU
T0
SR
AM
01
2
PI
DU
T0
SR
AM
01
4
PI
DU
T0
SR
AM
02
7
PI
DU
T0
SR
AM
02
8
PI
DU
T0
SR
AM
04
1
PI
DU
T0
SR
AM
04
3
PI
DU
T0
SR
AM
04
6
PI
DU
T0
SR
AM
04
9
PI
DU
T0
SR
AM
05
2
PI
DU
T0
SR
AM
05
4
CO
DU
T0
SR
AM
B
P
I
J
P
8
0
1
0
1
P
I
J
P
8
0
1
0
2
P
I
J
P
8
0
1
0
3
P
I
J
P
8
0
1
0
4
P
I
J
P
8
0
1
0
5
P
I
J
P
8
0
1
0
6
P
I
J
P
8
0
1
0
7
P
I
J
P
8
0
1
0
8
P
I
J
P
8
0
1
0
9
P
I
J
P
80
10
10
P
I
J
P
80
10
11
P
I
J
P
80
10
12
P
I
J
P
80
10
13
P
I
J
P
80
10
14
P
I
J
P
80
10
15
CO
JP
80
1
PI
R80
101
PI
R80
102
CO
R8
01
PIC80302
PIC80402
PIC80502
PIC80602
PIC80702
PIC80802
PIC80902
PI
DU
T0
SR
AM
01
PI
DU
T0
SR
AM
03
PI
DU
T0
SR
AM
09
PI
DU
T0
SR
AM
01
4
PI
DU
T0
SR
AM
02
7
PI
DU
T0
SR
AM
04
3
PI
DU
T0
SR
AM
04
9
P
I
J
P
8
0
1
0
9
PI
DU
T0
SR
AM
02
0
NL
BS
0
P
O
B
S
0
PI
DU
T0
SR
AM
02
1
NL
BS
1
P
O
B
S
1
PI
DU
T0
SR
AM
01
7
NL
CA
Sn
P
O
C
A
S
n
PI
DU
T0
SR
AM
03
7
NL
CK
E
P
O
C
K
E
PI
DU
T0
SR
AM
03
8
NL
CL
K
P
O
C
L
K
PI
DU
T0
SR
AM
01
9
NL
CS
n
P
O
C
S
n
PI
DU
T0
SR
AM
03
9
NL
DQ
MH
P
O
D
Q
M
H
PI
DU
T0
SR
AM
01
5
NL
DQ
ML
P
O
D
Q
M
L
PI
DU
T0
FL
AS
H0
1
P
I
J
P
8
0
1
0
2
PI
R80
102
NL
DU
T0
FL
AS
H0
CS
n
PI
DU
T0
FL
AS
H0
7
P
I
J
P
8
0
1
0
5N
LD
UT
0F
LA
SH
0H
OL
Dn
PI
DU
T0
FL
AS
H0
3
P
I
J
P
8
0
1
0
4N
LD
UT
0F
LA
SH
0W
Pn
PI
DU
T0
FL
AS
H0
6
P
I
J
P
8
0
1
0
6N
LD
UT
0S
PI
0C
LK
PI
DU
T0
FL
AS
H0
5
P
I
J
P
8
0
1
0
7N
LD
UT
0S
PI
0D
AT
AI
N
PI
DU
T0
FL
AS
H0
2
P
I
J
P
8
0
1
0
3N
LD
UT
0S
PI
0D
AT
AO
UT
P
I
J
P
80
10
10
NL
FL
AS
H0
CS
n
P
O
F
L
A
S
H
0
C
S
n
P
I
J
P
80
10
13
NL
FL
AS
H0
HO
LD
n
P
OF
LA
SH
0H
OL
Dn
PIC80102
PIC80202
PI
DU
T0
FL
AS
H0
8
P
I
J
P
8
0
1
0
1
PI
R80
101
NL
FL
AS
H0
PW
R
P
I
J
P
80
10
12
NL
FL
AS
H0
WP
n
P
O
F
L
A
S
H
0
W
P
n
PIC80101
PIC80201
PIC80301
PIC80401
PIC80501
PIC80601
PIC80701
PIC80801
PIC80901
PI
DU
T0
FL
AS
H0
4
PI
DU
T0
SR
AM
06
PI
DU
T0
SR
AM
01
2
PI
DU
T0
SR
AM
02
8
PI
DU
T0
SR
AM
04
1
PI
DU
T0
SR
AM
04
6
PI
DU
T0
SR
AM
05
2
PI
DU
T0
SR
AM
05
4
P
I
J
P
8
0
1
0
8
PI
DU
T0
SR
AM
01
8
NL
RA
Sn
P
O
R
A
S
n
P
I
J
P
80
10
14
NL
SP
I0
CL
K
P
O
S
P
I
0
C
L
K
P
I
J
P
80
10
11
NL
SP
I0
DA
TA
IN
P
O
S
P
I
0D
AT
AI
N
P
I
J
P
80
10
15
NL
SP
I0
DA
TA
OU
T
P
OS
PI
0D
AT
AO
UT
PI
DU
T0
SR
AM
01
6
NL
WE
n
P
O
W
E
n
PI
DU
T0
SR
AM
02
3
NL
SA
00
12
00
00
NL
SA
00
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
02
4
NL
SA
00
12
00
00
NL
SA
01
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
02
5
NL
SA
00
12
00
00
NL
SA
02
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
02
6
NL
SA
00
12
00
00
NL
SA
03
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
02
9
NL
SA
00
12
00
00
NL
SA
04
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
03
0
NL
SA
00
12
00
00
NL
SA
05
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
03
1
NL
SA
00
12
00
00
NL
SA
06
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
03
2
NL
SA
00
12
00
00
NL
SA
07
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
03
3
NL
SA
00
12
00
00
NL
SA
08
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
03
4
NL
SA
00
12
00
00
NL
SA
09
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
02
2
NL
SA
00
12
00
00
NL
SA
01
0
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
03
5
NL
SA
00
12
00
00
NL
SA
01
1
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
03
6
NL
SA
00
12
00
00
NL
SA
01
2
PO
SA
00
12
00
00
PI
DU
T0
SR
AM
02
NL
SD
00
15
00
00
NL
SD
00
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
04
NL
SD
00
15
00
00
NL
SD
01
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
05
NL
SD
00
15
00
00
NL
SD
02
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
07
NL
SD
00
15
00
00
NL
SD
03
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
08
NL
SD
00
15
00
00
NL
SD
04
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
01
0
NL
SD
00
15
00
00
NL
SD
05
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
01
1
NL
SD
00
15
00
00
NL
SD
06
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
01
3
NL
SD
00
15
00
00
NL
SD
07
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
04
2
NL
SD
00
15
00
00
NL
SD
08
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
04
4
NL
SD
00
15
00
00
NL
SD
09
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
04
5
NL
SD
00
15
00
00
NL
SD
01
0
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
04
7
NL
SD
00
15
00
00
NL
SD
01
1
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
04
8
NL
SD
00
15
00
00
NL
SD
01
2
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
05
0
NL
SD
00
15
00
00
NL
SD
01
3
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
05
1
NL
SD
00
15
00
00
NL
SD
01
4
PO
SD
00
15
00
00
PI
DU
T0
SR
AM
05
3
NL
SD
00
15
00
00
NL
SD
01
5
PO
SD
00
15
00
00
P
O
B
S
0
P
O
B
S
1
P
O
C
A
S
N
P
O
C
K
E
P
O
C
L
K
P
O
C
S
N
P
O
D
Q
M
H
P
O
D
Q
M
L
P
O
F
L
A
S
H
0
C
S
N
P
OF
LA
SH
0H
OL
DN
P
O
F
L
A
S
H
0
W
P
N
P
O
R
A
S
NP
O
S
A
0
0
P
O
S
A
0
1
P
O
S
A
0
2
P
O
S
A
0
3
P
O
S
A
0
4
P
O
S
A
0
5
P
O
S
A
0
6
P
O
S
A
0
7
P
O
S
A
0
8
P
O
S
A
0
9
P
O
S
A
0
1
0
P
O
S
A
0
1
1
P
O
S
A
0
1
2
PO
SA
00
12
00
00
P
O
S
D
0
0
P
O
S
D
0
1
P
O
S
D
0
2
P
O
S
D
0
3
P
O
S
D
0
4
P
O
S
D
0
5
P
O
S
D
0
6
P
O
S
D
0
7
P
O
S
D
0
8
P
O
S
D
0
9
P
O
S
D
0
1
0
P
O
S
D
0
1
1
P
O
S
D
0
1
2
P
O
S
D
0
1
3
P
O
S
D
0
1
4
P
O
S
D
0
1
5
PO
SD
00
15
00
00
P
O
S
P
I
0
C
L
K
P
O
S
P
I
0D
AT
AI
N
P
OS
PI
0D
AT
AO
UT
P
O
W
E
N
Figure B.9 – Schematic Showing the Connection of the Device Under Test FPGA’s Memory
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 111
11
22
33
44
D
D
C
C
B
B
A
A
Ti
tle
N
um
be
r
R
ev
is
io
n
Si
ze A
4
D
at
e:
20
14
/0
2/
05
Sh
ee
t  
  o
f
Fi
le
:
C
:\D
ro
pb
ox
\..
\C
O
N
_M
EM
.S
ch
D
oc
D
ra
w
n 
B
y:
A
15
42
A
14
27
A
13
26
A
12
25
A
11
24
A
10
23
A
9
22
A
8
21
W
E
17
A
17
44
A
7
20
A
6
19
A
5
18
A
4
5
A
3
4
A
2
3
A
1
2
A
0
1
C
S
6
O
E
41
I/O
0
7
I/O
8
29
I/O
1
8
I/O
9
30
I/O
2
9
I/O
10
31
I/O
3
10
I/O
11
32
I/O
4
13
I/O
12
35
I/O
5
14
I/O
13
36
I/O
6
15
I/O
14
37
I/O
7
16
I/O
15
38
A
16
43
SR
AM
VSS
34
VCC
33
VSS
12
VCC
11
NC
28B
H
E
40
B
LE
39
C
O
N
_S
R
A
M
_H
ID
T7
1V
41
6L
10
PH
G
I
A
15
42
A
14
27
A
13
26
A
12
25
A
11
24
A
10
23
A
9
22
A
8
21
W
E
17
A
17
44
A
7
20
A
6
19
A
5
18
A
4
5
A
3
4
A
2
3
A
1
2
A
0
1
C
S
6
O
E
41
I/O
0
7
I/O
8
29
I/O
1
8
I/O
9
30
I/O
2
9
I/O
10
31
I/O
3
10
I/O
11
32
I/O
4
13
I/O
12
35
I/O
5
14
I/O
13
36
I/O
6
15
I/O
14
37
I/O
7
16
I/O
15
38
A
16
43
SR
AM
VSS
34
VCC
33
VSS
12
VCC
11
NC
28B
H
E
40
B
LE
39
C
O
N
_S
R
A
M
_L
ID
T7
1V
41
6L
10
PH
G
I
A
dd
r_
0
A
dd
r_
1
A
dd
r_
2
A
dd
r_
3
A
dd
r_
4
A
dd
r_
5
A
dd
r_
6
A
dd
r_
7
A
dd
r_
8
A
dd
r_
9
A
dd
r_
10
A
dd
r_
11
A
dd
r_
12
A
dd
r_
13
A
dd
r_
14
A
dd
r_
15
A
dd
r_
16
A
dd
r_
17
A
dd
r_
0
A
dd
r_
1
A
dd
r_
2
A
dd
r_
3
A
dd
r_
4
A
dd
r_
5
A
dd
r_
6
A
dd
r_
7
A
dd
r_
8
A
dd
r_
9
A
dd
r_
10
A
dd
r_
11
A
dd
r_
12
A
dd
r_
13
A
dd
r_
14
A
dd
r_
15
A
dd
r_
16
A
dd
r_
17
A
dd
r_
0
A
dd
r_
1
A
dd
r_
2
A
dd
r_
3
A
dd
r_
4
A
dd
r_
5
A
dd
r_
6
A
dd
r_
7
A
dd
r_
8
A
dd
r_
9
A
dd
r_
10
A
dd
r_
11
A
dd
r_
12
A
dd
r_
13
A
dd
r_
14
A
dd
r_
15
A
dd
r_
16
A
dd
r_
17
A
dd
r_
0
A
dd
r_
1
A
dd
r_
2
A
dd
r_
3
A
dd
r_
4
A
dd
r_
5
A
dd
r_
6
A
dd
r_
7
A
dd
r_
8
A
dd
r_
9
A
dd
r_
10
A
dd
r_
11
A
dd
r_
12
A
dd
r_
13
A
dd
r_
14
A
dd
r_
15
A
dd
r_
16
A
dd
r_
17
A
dd
r_
18
A
dd
r_
19
A
dd
r_
18
A
dd
r_
19
D
at
a_
0
D
at
a_
1
D
at
a_
2
D
at
a_
3
D
at
a_
4
D
at
a_
5
D
at
a_
6
D
at
a_
7
D
at
a_
8
D
at
a_
9
D
at
a_
10
D
at
a_
11
D
at
a_
12
D
at
a_
13
D
at
a_
14
D
at
a_
15
D
at
a_
16
D
at
a_
17
D
at
a_
18
D
at
a_
19
D
at
a_
20
D
at
a_
21
D
at
a_
22
D
at
a_
23
D
at
a_
24
D
at
a_
25
D
at
a_
26
D
at
a_
27
D
at
a_
28
D
at
a_
29
D
at
a_
30
D
at
a_
31
D
at
a_
16
D
at
a_
17
D
at
a_
18
D
at
a_
19
D
at
a_
20
D
at
a_
21
D
at
a_
22
D
at
a_
23
D
at
a_
24
D
at
a_
25
D
at
a_
26
D
at
a_
27
D
at
a_
28
D
at
a_
29
D
at
a_
30
D
at
a_
31
D
at
a_
0
D
at
a_
1
D
at
a_
2
D
at
a_
3
D
at
a_
4
D
at
a_
5
D
at
a_
6
D
at
a_
7
D
at
a_
8
D
at
a_
9
D
at
a_
10
D
at
a_
11
D
at
a_
12
D
at
a_
13
D
at
a_
14
D
at
a_
15
G
N
D
G
N
D
G
N
D
G
N
D
SR
A
M
_C
E_
N
SR
A
M
_W
E_
N
SR
A
M
_O
E_
N
SR
A
M
_S
R
B
S0
_N
SR
A
M
_S
R
B
S1
_N
SR
A
M
_S
R
B
S2
_N
SR
A
M
_S
R
B
S3
_N
SR
A
M
_S
R
B
S3
_N
SR
A
M
_S
R
B
S2
_N
SR
A
M
_S
R
B
S1
_N
SR
A
M
_S
R
B
S0
_N
SR
A
M
_O
E_
N
SR
A
M
_W
E_
N
SR
A
M
_C
E_
N
SR
A
M
_S
R
B
S1
_N
SR
A
M
_S
R
B
S0
_N
SR
A
M
_S
R
B
S3
_N
SR
A
M
_S
R
B
S2
_N
SR
A
M
_O
E_
N
SR
A
M
_W
E_
N
SR
A
M
_C
E_
N
SR
A
M
_O
E_
N
SR
A
M
_W
E_
N
SR
A
M
_C
E_
N
FL
A
SH
_C
E_
N
FL
A
SH
_W
E_
N
FL
A
SH
_O
E_
N
FL
A
SH
_O
E_
N
FL
A
SH
_W
E_
N
FL
A
SH
_C
E_
N
FL
A
SH
_R
ST
_N
FL
A
SH
_R
ST
_N
FL
A
SH
_O
E_
N
FL
A
SH
_W
E_
N
FL
A
SH
_C
E_
N
FL
A
SH
_R
ST
_N
FL
A
SH
_O
E_
N
FL
A
SH
_W
E_
N
FL
A
SH
_C
E_
N
FL
A
SH
_R
ST
_N
D
at
a_
[3
1.
.0
]
A
dd
r_
[1
9.
.0
]
A
dd
r_
[1
9.
.0
]
D
at
a_
[3
1.
.0
]
0.
1u
F
C
9_
1
0.
1u
F
C
9_
2
0.
1u
F
C
9_
3
0.
1u
F
C
9_
4
0.
1u
F
C
9_
5
0.
1u
F
C
9_
6
G
N
D
A
15
1
A
14
2
A
13
3
A
12
4
A
11
5
A
10
6
A
9
7
A
8
8
A
19
9
W
E
11
R
B
15
A
18
16
A
17
17
A
7
18
A
6
19
A
5
20
A
4
21
A
3
22
A
2
23
A
1
24
A
0
25
C
E
26
O
E
28
D
Q
0
29
D
Q
8
30
D
Q
1
31
D
Q
9
32
D
Q
2
33
D
Q
10
34
D
Q
3
35
D
Q
11
36
D
Q
4
38
D
Q
12
39
D
Q
5
40
D
Q
13
41
D
Q
6
42
D
Q
14
43
D
Q
7
44
A
16
48
Fl
as
h
D
Q
15
A
-1
45
VSS
27
VCC
37
VSS
46
R
P
12
B
Y
TE
47
N
C
10
N
C
13
N
C
14
C
O
N
_F
LA
SH
_H
M
29
W
16
0E
B
70
N
6F
A
15
1
A
14
2
A
13
3
A
12
4
A
11
5
A
10
6
A
9
7
A
8
8
A
19
9
W
E
11
R
B
15
A
18
16
A
17
17
A
7
18
A
6
19
A
5
20
A
4
21
A
3
22
A
2
23
A
1
24
A
0
25
C
E
26
O
E
28
D
Q
0
29
D
Q
8
30
D
Q
1
31
D
Q
9
32
D
Q
2
33
D
Q
10
34
D
Q
3
35
D
Q
11
36
D
Q
4
38
D
Q
12
39
D
Q
5
40
D
Q
13
41
D
Q
6
42
D
Q
14
43
D
Q
7
44
A
16
48
Fl
as
h
D
Q
15
A
-1
45
VSS
27
VCC
37
VSS
46
R
P
12
B
Y
TE
47
N
C
10
N
C
13
N
C
14
C
O
N
_F
LA
SH
_L
M
29
W
16
0E
B
70
N
6F
1KR
9_
1
1KR
9_
2
FL
A
SH
_R
ST
_N
FL
A
SH
_C
E_
N
3V
3_
1
G
N
D
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1
3V
3_
1
C
on
tro
lle
r S
R
A
M
 a
nd
 F
la
sh
Em
ile
 T
he
sn
aa
r
10
10
V
1.
0
15
41
69
09
PIC90101PIC90102
CO
C9
01
PIC90201PIC90202
CO
C9
02
PIC90301PIC90302
CO
C9
03
PIC90401PIC90402
CO
C9
04
PIC90501PIC90502
CO
C9
05
PIC90601PIC90602
CO
C9
06
PI
CO
N0
FL
AS
H0
H0
1
PI
CO
N0
FL
AS
H0
H0
2
PI
CO
N0
FL
AS
H0
H0
3
PI
CO
N0
FL
AS
H0
H0
4
PI
CO
N0
FL
AS
H0
H0
5
PI
CO
N0
FL
AS
H0
H0
6
PI
CO
N0
FL
AS
H0
H0
7
PI
CO
N0
FL
AS
H0
H0
8
PI
CO
N0
FL
AS
H0
H0
9
PI
CO
N0
FL
AS
H0
H0
10
PI
CO
N0
FL
AS
H0
H0
11
PI
CO
N0
FL
AS
H0
H0
12
PI
CO
N0
FL
AS
H0
H0
13
PI
CO
N0
FL
AS
H0
H0
14
PI
CO
N0
FL
AS
H0
H0
15
PI
CO
N0
FL
AS
H0
H0
16
PI
CO
N0
FL
AS
H0
H0
17
PI
CO
N0
FL
AS
H0
H0
18
PI
CO
N0
FL
AS
H0
H0
19
PI
CO
N0
FL
AS
H0
H0
20
PI
CO
N0
FL
AS
H0
H0
21
PI
CO
N0
FL
AS
H0
H0
22
PI
CO
N0
FL
AS
H0
H0
23
PI
CO
N0
FL
AS
H0
H0
24
PI
CO
N0
FL
AS
H0
H0
25
PI
CO
N0
FL
AS
H0
H0
26
PICON0FLASH0H027
PI
CO
N0
FL
AS
H0
H0
28
PI
CO
N0
FL
AS
H0
H0
29
PI
CO
N0
FL
AS
H0
H0
30
PI
CO
N0
FL
AS
H0
H0
31
PI
CO
N0
FL
AS
H0
H0
32
PI
CO
N0
FL
AS
H0
H0
33
PI
CO
N0
FL
AS
H0
H0
34
PI
CO
N0
FL
AS
H0
H0
35
PI
CO
N0
FL
AS
H0
H0
36
PICON0FLASH0H037
PI
CO
N0
FL
AS
H0
H0
38
PI
CO
N0
FL
AS
H0
H0
39
PI
CO
N0
FL
AS
H0
H0
40
PI
CO
N0
FL
AS
H0
H0
41
PI
CO
N0
FL
AS
H0
H0
42
PI
CO
N0
FL
AS
H0
H0
43
PI
CO
N0
FL
AS
H0
H0
44
PI
CO
N0
FL
AS
H0
H0
45
PICON0FLASH0H046
PI
CO
N0
FL
AS
H0
H0
47
PI
CO
N0
FL
AS
H0
H0
48
CO
CO
N0
FL
AS
H0
H
PI
CO
N0
FL
AS
H0
L0
1
PI
CO
N0
FL
AS
H0
L0
2
PI
CO
N0
FL
AS
H0
L0
3
PI
CO
N0
FL
AS
H0
L0
4
PI
CO
N0
FL
AS
H0
L0
5
PI
CO
N0
FL
AS
H0
L0
6
PI
CO
N0
FL
AS
H0
L0
7
PI
CO
N0
FL
AS
H0
L0
8
PI
CO
N0
FL
AS
H0
L0
9
PI
CO
N0
FL
AS
H0
L0
10
PI
CO
N0
FL
AS
H0
L0
11
PI
CO
N0
FL
AS
H0
L0
12
PI
CO
N0
FL
AS
H0
L0
13
PI
CO
N0
FL
AS
H0
L0
14
PI
CO
N0
FL
AS
H0
L0
15
PI
CO
N0
FL
AS
H0
L0
16
PI
CO
N0
FL
AS
H0
L0
17
PI
CO
N0
FL
AS
H0
L0
18
PI
CO
N0
FL
AS
H0
L0
19
PI
CO
N0
FL
AS
H0
L0
20
PI
CO
N0
FL
AS
H0
L0
21
PI
CO
N0
FL
AS
H0
L0
22
PI
CO
N0
FL
AS
H0
L0
23
PI
CO
N0
FL
AS
H0
L0
24
PI
CO
N0
FL
AS
H0
L0
25
PI
CO
N0
FL
AS
H0
L0
26
PICON0FLASH0L027
PI
CO
N0
FL
AS
H0
L0
28
PI
CO
N0
FL
AS
H0
L0
29
PI
CO
N0
FL
AS
H0
L0
30
PI
CO
N0
FL
AS
H0
L0
31
PI
CO
N0
FL
AS
H0
L0
32
PI
CO
N0
FL
AS
H0
L0
33
PI
CO
N0
FL
AS
H0
L0
34
PI
CO
N0
FL
AS
H0
L0
35
PI
CO
N0
FL
AS
H0
L0
36
PICON0FLASH0L037
PI
CO
N0
FL
AS
H0
L0
38
PI
CO
N0
FL
AS
H0
L0
39
PI
CO
N0
FL
AS
H0
L0
40
PI
CO
N0
FL
AS
H0
L0
41
PI
CO
N0
FL
AS
H0
L0
42
PI
CO
N0
FL
AS
H0
L0
43
PI
CO
N0
FL
AS
H0
L0
44
PI
CO
N0
FL
AS
H0
L0
45
PICON0FLASH0L046
PI
CO
N0
FL
AS
H0
L0
47
PI
CO
N0
FL
AS
H0
L0
48
CO
CO
N0
FL
AS
H0
L
PI
CO
N0
SR
AM
0H
01
PI
CO
N0
SR
AM
0H
02
PI
CO
N0
SR
AM
0H
03
PI
CO
N0
SR
AM
0H
04
PI
CO
N0
SR
AM
0H
05
PI
CO
N0
SR
AM
0H
06
PI
CO
N0
SR
AM
0H
07
PI
CO
N0
SR
AM
0H
08
PI
CO
N0
SR
AM
0H
09
PI
CO
N0
SR
AM
0H
01
0
PICON0SRAM0H011 PICON0SRAM0H012
PI
CO
N0
SR
AM
0H
01
3
PI
CO
N0
SR
AM
0H
01
4
PI
CO
N0
SR
AM
0H
01
5
PI
CO
N0
SR
AM
0H
01
6
PI
CO
N0
SR
AM
0H
01
7
PI
CO
N0
SR
AM
0H
01
8
PI
CO
N0
SR
AM
0H
01
9
PI
CO
N0
SR
AM
0H
02
0
PI
CO
N0
SR
AM
0H
02
1
PI
CO
N0
SR
AM
0H
02
2
PI
CO
N0
SR
AM
0H
02
3
PI
CO
N0
SR
AM
0H
02
4
PI
CO
N0
SR
AM
0H
02
5
PI
CO
N0
SR
AM
0H
02
6
PI
CO
N0
SR
AM
0H
02
7
PICON0SRAM0H028P
IC
ON
0S
RA
M0
H0
29
PI
CO
N0
SR
AM
0H
03
0
PI
CO
N0
SR
AM
0H
03
1
PI
CO
N0
SR
AM
0H
03
2
PICON0SRAM0H033 PICON0SRAM0H034
PI
CO
N0
SR
AM
0H
03
5
PI
CO
N0
SR
AM
0H
03
6
PI
CO
N0
SR
AM
0H
03
7
PI
CO
N0
SR
AM
0H
03
8
PI
CO
N0
SR
AM
0H
03
9
PI
CO
N0
SR
AM
0H
04
0
PI
CO
N0
SR
AM
0H
04
1
PI
CO
N0
SR
AM
0H
04
2
PI
CO
N0
SR
AM
0H
04
3
PI
CO
N0
SR
AM
0H
04
4
CO
CO
N0
SR
AM
0H
PI
CO
N0
SR
AM
0L
01
PI
CO
N0
SR
AM
0L
02
PI
CO
N0
SR
AM
0L
03
PI
CO
N0
SR
AM
0L
04
PI
CO
N0
SR
AM
0L
05
PI
CO
N0
SR
AM
0L
06
PI
CO
N0
SR
AM
0L
07
PI
CO
N0
SR
AM
0L
08
PI
CO
N0
SR
AM
0L
09
PI
CO
N0
SR
AM
0L
01
0
PICON0SRAM0L011 PICON0SRAM0L012
PI
CO
N0
SR
AM
0L
01
3
PI
CO
N0
SR
AM
0L
01
4
PI
CO
N0
SR
AM
0L
01
5
PI
CO
N0
SR
AM
0L
01
6
PI
CO
N0
SR
AM
0L
01
7
PI
CO
N0
SR
AM
0L
01
8
PI
CO
N0
SR
AM
0L
01
9
PI
CO
N0
SR
AM
0L
02
0
PI
CO
N0
SR
AM
0L
02
1
PI
CO
N0
SR
AM
0L
02
2
PI
CO
N0
SR
AM
0L
02
3
PI
CO
N0
SR
AM
0L
02
4
PI
CO
N0
SR
AM
0L
02
5
PI
CO
N0
SR
AM
0L
02
6
PI
CO
N0
SR
AM
0L
02
7
PICON0SRAM0L028P
IC
ON
0S
RA
M0
L0
29
PI
CO
N0
SR
AM
0L
03
0
PI
CO
N0
SR
AM
0L
03
1
PI
CO
N0
SR
AM
0L
03
2
PICON0SRAM0L033 PICON0SRAM0L034
PI
CO
N0
SR
AM
0L
03
5
PI
CO
N0
SR
AM
0L
03
6
PI
CO
N0
SR
AM
0L
03
7
PI
CO
N0
SR
AM
0L
03
8
PI
CO
N0
SR
AM
0L
03
9
PI
CO
N0
SR
AM
0L
04
0
PI
CO
N0
SR
AM
0L
04
1
PI
CO
N0
SR
AM
0L
04
2
PI
CO
N0
SR
AM
0L
04
3
PI
CO
N0
SR
AM
0L
04
4
CO
CO
N0
SR
AM
0L
PIR90101PIR90102 C
OR
90
1
PIR90201PIR90202 C
OR
90
2
PIC90102
PIC90202
PIC90302
PIC90402
PIC90502
PIC90602
PICON0FLASH0H037
PI
CO
N0
FL
AS
H0
H0
47
PICON0FLASH0L037
PI
CO
N0
FL
AS
H0
L0
47
PICON0SRAM0H011PICON0SRAM0H033
PICON0SRAM0L011PICON0SRAM0L033
PIR90202NL
3V
30
1
PI
CO
N0
FL
AS
H0
H0
26
PI
CO
N0
FL
AS
H0
L0
26
PIR90201
NL
FL
AS
H0
CE
0N
P
O
F
L
A
S
H
0
C
E
0
N
PI
CO
N0
FL
AS
H0
H0
28
PI
CO
N0
FL
AS
H0
L0
28
NL
FL
AS
H0
OE
0N
P
O
F
L
A
S
H
0
O
E
0
N
PI
CO
N0
FL
AS
H0
H0
12
PI
CO
N0
FL
AS
H0
L0
12
PIR90102
NL
FL
AS
H0
RS
T0
N
P
O
F
L
A
S
H
0R
ST
0N
PI
CO
N0
FL
AS
H0
H0
11
PI
CO
N0
FL
AS
H0
L0
11
NL
FL
AS
H0
WE
0N
P
O
F
L
A
S
H
0
W
E
0
N
PIC90101
PIC90201
PIC90301
PIC90401
PIC90501
PIC90601
PICON0FLASH0H027PICON0FLASH0H046
PICON0FLASH0L027PICON0FLASH0L046
PICON0SRAM0H012
PICON0SRAM0H028
PICON0SRAM0H034
PICON0SRAM0L012
PICON0SRAM0L028
PICON0SRAM0L034
PIR90101
PI
CO
N0
FL
AS
H0
H0
10
PI
CO
N0
FL
AS
H0
H0
13
PI
CO
N0
FL
AS
H0
H0
14
PI
CO
N0
FL
AS
H0
H0
15
PI
CO
N0
FL
AS
H0
L0
10
PI
CO
N0
FL
AS
H0
L0
13
PI
CO
N0
FL
AS
H0
L0
14
PI
CO
N0
FL
AS
H0
L0
15
PI
CO
N0
SR
AM
0H
06
PI
CO
N0
SR
AM
0L
06
NL
SR
AM
0C
E0
N
P
O
S
R
A
M
0
C
E
0
N
PI
CO
N0
SR
AM
0H
04
1
PI
CO
N0
SR
AM
0L
04
1
NL
SR
AM
0O
E0
N
P
O
S
R
A
M
0
O
E
0
N
PI
CO
N0
SR
AM
0H
03
9
NL
SR
AM
0S
RB
S0
0N
P
OS
RA
M0
SR
BS
00
N
PI
CO
N0
SR
AM
0H
04
0
NL
SR
AM
0S
RB
S1
0N
P
OS
RA
M0
SR
BS
10
N
PI
CO
N0
SR
AM
0L
03
9
NL
SR
AM
0S
RB
S2
0N
P
OS
RA
M0
SR
BS
20
N
PI
CO
N0
SR
AM
0L
04
0
NL
SR
AM
0S
RB
S3
0N
P
OS
RA
M0
SR
BS
30
N
PI
CO
N0
SR
AM
0H
01
7
PI
CO
N0
SR
AM
0L
01
7
NL
SR
AM
0W
E0
N
P
O
S
R
A
M
0
W
E
0
N
PI
CO
N0
FL
AS
H0
H0
25
PI
CO
N0
FL
AS
H0
L0
25
PI
CO
N0
SR
AM
0H
01
PI
CO
N0
SR
AM
0L
01
NL
Ad
dr
00
19
00
00
NL
Ad
dr
00
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
24
PI
CO
N0
FL
AS
H0
L0
24
PI
CO
N0
SR
AM
0H
02
PI
CO
N0
SR
AM
0L
02
NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
23
PI
CO
N0
FL
AS
H0
L0
23
PI
CO
N0
SR
AM
0H
03
PI
CO
N0
SR
AM
0L
03
NL
Ad
dr
00
19
00
00
NL
Ad
dr
02
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
22
PI
CO
N0
FL
AS
H0
L0
22
PI
CO
N0
SR
AM
0H
04
PI
CO
N0
SR
AM
0L
04
NL
Ad
dr
00
19
00
00
NL
Ad
dr
03
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
21
PI
CO
N0
FL
AS
H0
L0
21
PI
CO
N0
SR
AM
0H
05
PI
CO
N0
SR
AM
0L
05
NL
Ad
dr
00
19
00
00
NL
Ad
dr
04
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
20
PI
CO
N0
FL
AS
H0
L0
20
PI
CO
N0
SR
AM
0H
01
8
PI
CO
N0
SR
AM
0L
01
8
NL
Ad
dr
00
19
00
00
NL
Ad
dr
05
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
19
PI
CO
N0
FL
AS
H0
L0
19
PI
CO
N0
SR
AM
0H
01
9
PI
CO
N0
SR
AM
0L
01
9
NL
Ad
dr
00
19
00
00
NL
Ad
dr
06
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
18
PI
CO
N0
FL
AS
H0
L0
18
PI
CO
N0
SR
AM
0H
02
0
PI
CO
N0
SR
AM
0L
02
0
NL
Ad
dr
00
19
00
00
NL
Ad
dr
07
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
8
PI
CO
N0
FL
AS
H0
L0
8
PI
CO
N0
SR
AM
0H
02
1
PI
CO
N0
SR
AM
0L
02
1
NL
Ad
dr
00
19
00
00
NL
Ad
dr
08
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
7
PI
CO
N0
FL
AS
H0
L0
7
PI
CO
N0
SR
AM
0H
02
2
PI
CO
N0
SR
AM
0L
02
2
NL
Ad
dr
00
19
00
00
NL
Ad
dr
09
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
6
PI
CO
N0
FL
AS
H0
L0
6
PI
CO
N0
SR
AM
0H
02
3
PI
CO
N0
SR
AM
0L
02
3
NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
0
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
5
PI
CO
N0
FL
AS
H0
L0
5
PI
CO
N0
SR
AM
0H
02
4
PI
CO
N0
SR
AM
0L
02
4
NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
1
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
4
PI
CO
N0
FL
AS
H0
L0
4
PI
CO
N0
SR
AM
0H
02
5
PI
CO
N0
SR
AM
0L
02
5
NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
2
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
3
PI
CO
N0
FL
AS
H0
L0
3
PI
CO
N0
SR
AM
0H
02
6
PI
CO
N0
SR
AM
0L
02
6
NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
3
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
2
PI
CO
N0
FL
AS
H0
L0
2
PI
CO
N0
SR
AM
0H
02
7
PI
CO
N0
SR
AM
0L
02
7
NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
4
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
1
PI
CO
N0
FL
AS
H0
L0
1
PI
CO
N0
SR
AM
0H
04
2
PI
CO
N0
SR
AM
0L
04
2
NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
5
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
48
PI
CO
N0
FL
AS
H0
L0
48
PI
CO
N0
SR
AM
0H
04
3
PI
CO
N0
SR
AM
0L
04
3
NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
6
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
17
PI
CO
N0
FL
AS
H0
L0
17
PI
CO
N0
SR
AM
0H
04
4
PI
CO
N0
SR
AM
0L
04
4
NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
7
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
16
PI
CO
N0
FL
AS
H0
L0
16
NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
8
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
9
PI
CO
N0
FL
AS
H0
L0
9
NL
Ad
dr
00
19
00
00
NL
Ad
dr
01
9
P
OA
dd
r0
01
90
00
0
PI
CO
N0
FL
AS
H0
H0
29
PI
CO
N0
SR
AM
0H
07
NL
Da
ta
00
31
00
00
NL
Da
ta
00
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
31
PI
CO
N0
SR
AM
0H
08
NL
Da
ta
00
31
00
00
NL
Da
ta
01
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
33
PI
CO
N0
SR
AM
0H
09
NL
Da
ta
00
31
00
00
NL
Da
ta
02
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
35
PI
CO
N0
SR
AM
0H
01
0
NL
Da
ta
00
31
00
00
NL
Da
ta
03
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
38
PI
CO
N0
SR
AM
0H
01
3
NL
Da
ta
00
31
00
00
NL
Da
ta
04
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
40
PI
CO
N0
SR
AM
0H
01
4
NL
Da
ta
00
31
00
00
NL
Da
ta
05
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
42
PI
CO
N0
SR
AM
0H
01
5
NL
Da
ta
00
31
00
00
NL
Da
ta
06
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
44
PI
CO
N0
SR
AM
0H
01
6
NL
Da
ta
00
31
00
00
NL
Da
ta
07
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
30
PI
CO
N0
SR
AM
0H
02
9
NL
Da
ta
00
31
00
00
NL
Da
ta
08
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
32
PI
CO
N0
SR
AM
0H
03
0
NL
Da
ta
00
31
00
00
NL
Da
ta
09
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
34
PI
CO
N0
SR
AM
0H
03
1
NL
Da
ta
00
31
00
00
NL
Da
ta
01
0
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
36
PI
CO
N0
SR
AM
0H
03
2
NL
Da
ta
00
31
00
00
NL
Da
ta
01
1
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
39
PI
CO
N0
SR
AM
0H
03
5
NL
Da
ta
00
31
00
00
NL
Da
ta
01
2
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
41
PI
CO
N0
SR
AM
0H
03
6
NL
Da
ta
00
31
00
00
NL
Da
ta
01
3
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
43
PI
CO
N0
SR
AM
0H
03
7
NL
Da
ta
00
31
00
00
NL
Da
ta
01
4
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
H0
45
PI
CO
N0
SR
AM
0H
03
8
NL
Da
ta
00
31
00
00
NL
Da
ta
01
5
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
29
PI
CO
N0
SR
AM
0L
07
NL
Da
ta
00
31
00
00
NL
Da
ta
01
6
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
31
PI
CO
N0
SR
AM
0L
08
NL
Da
ta
00
31
00
00
NL
Da
ta
01
7
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
33
PI
CO
N0
SR
AM
0L
09
NL
Da
ta
00
31
00
00
NL
Da
ta
01
8
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
35
PI
CO
N0
SR
AM
0L
01
0
NL
Da
ta
00
31
00
00
NL
Da
ta
01
9
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
38
PI
CO
N0
SR
AM
0L
01
3
NL
Da
ta
00
31
00
00
NL
Da
ta
02
0
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
40
PI
CO
N0
SR
AM
0L
01
4
NL
Da
ta
00
31
00
00
NL
Da
ta
02
1
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
42
PI
CO
N0
SR
AM
0L
01
5
NL
Da
ta
00
31
00
00
NL
Da
ta
02
2
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
44
PI
CO
N0
SR
AM
0L
01
6
NL
Da
ta
00
31
00
00
NL
Da
ta
02
3
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
30
PI
CO
N0
SR
AM
0L
02
9
NL
Da
ta
00
31
00
00
NL
Da
ta
02
4
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
32
PI
CO
N0
SR
AM
0L
03
0
NL
Da
ta
00
31
00
00
NL
Da
ta
02
5
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
34
PI
CO
N0
SR
AM
0L
03
1
NL
Da
ta
00
31
00
00
NL
Da
ta
02
6
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
36
PI
CO
N0
SR
AM
0L
03
2
NL
Da
ta
00
31
00
00
NL
Da
ta
02
7
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
39
PI
CO
N0
SR
AM
0L
03
5
NL
Da
ta
00
31
00
00
NL
Da
ta
02
8
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
41
PI
CO
N0
SR
AM
0L
03
6
NL
Da
ta
00
31
00
00
NL
Da
ta
02
9
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
43
PI
CO
N0
SR
AM
0L
03
7
NL
Da
ta
00
31
00
00
NL
Da
ta
03
0
P
OD
at
a0
03
10
00
0
PI
CO
N0
FL
AS
H0
L0
45
PI
CO
N0
SR
AM
0L
03
8
NL
Da
ta
00
31
00
00
NL
Da
ta
03
1
P
OD
at
a0
03
10
00
0
P
O
A
D
D
R
0
0
P
O
A
D
D
R
0
1
P
O
A
D
D
R
0
2
P
O
A
D
D
R
0
3
P
O
A
D
D
R
0
4
P
O
A
D
D
R
0
5
P
O
A
D
D
R
0
6
P
O
A
D
D
R
0
7
P
O
A
D
D
R
0
8
P
O
A
D
D
R
0
9
P
O
A
D
D
R
0
1
0
P
O
A
D
D
R
0
1
1
P
O
A
D
D
R
0
1
2
P
O
A
D
D
R
0
1
3
P
O
A
D
D
R
0
1
4
P
O
A
D
D
R
0
1
5
P
O
A
D
D
R
0
1
6
P
O
A
D
D
R
0
1
7
P
O
A
D
D
R
0
1
8
P
O
A
D
D
R
0
1
9
P
OA
DD
R0
01
90
00
0
P
O
D
A
T
A
0
0
P
O
D
A
T
A
0
1
P
O
D
A
T
A
0
2
P
O
D
A
T
A
0
3
P
O
D
A
T
A
0
4
P
O
D
A
T
A
0
5
P
O
D
A
T
A
0
6
P
O
D
A
T
A
0
7
P
O
D
A
T
A
0
8
P
O
D
A
T
A
0
9
P
O
D
A
T
A
0
1
0
P
O
D
A
T
A
0
1
1
P
O
D
A
T
A
0
1
2
P
O
D
A
T
A
0
1
3
P
O
D
A
T
A
0
1
4
P
O
D
A
T
A
0
1
5
P
O
D
A
T
A
0
1
6
P
O
D
A
T
A
0
1
7
P
O
D
A
T
A
0
1
8
P
O
D
A
T
A
0
1
9
P
O
D
A
T
A
0
2
0
P
O
D
A
T
A
0
2
1
P
O
D
A
T
A
0
2
2
P
O
D
A
T
A
0
2
3
P
O
D
A
T
A
0
2
4
P
O
D
A
T
A
0
2
5
P
O
D
A
T
A
0
2
6
P
O
D
A
T
A
0
2
7
P
O
D
A
T
A
0
2
8
P
O
D
A
T
A
0
2
9
P
O
D
A
T
A
0
3
0
P
O
D
A
T
A
0
3
1
P
OD
AT
A0
03
10
00
0
P
O
F
L
A
S
H
0
C
E
0
N
P
O
F
L
A
S
H
0
O
E
0
N
P
O
F
L
A
S
H
0R
ST
0N
P
O
F
L
A
S
H
0
W
E
0
N
P
O
S
R
A
M
0
C
E
0
N
P
O
S
R
A
M
0
O
E
0
N
P
OS
RA
M0
SR
BS
00
N
P
OS
RA
M0
SR
BS
10
N
P
OS
RA
M0
SR
BS
20
N
P
OS
RA
M0
SR
BS
30
N
P
O
S
R
A
M
0
W
E
0
N
Figure B.10 – Schematic Showing the Connection of the Controlling FPGA’s Memory
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 112
PAC101
01
PAC101
02
CO
C1
01
PAC102
01
PAC102
02
CO
C1
02
PAC103
01
PAC103
02
CO
C1
03
PAC104
01
PAC104
02 COC104
PAC105
01
PAC105
02 COC105
PAC106
01
PAC106
02 COC106
PAC107
01
PAC107
02 COC107
PAC108
01
PAC108
02 COC108
PAC109
01
PAC109
02
CO
C1
09
PAC101
001
PAC101
002
CO
C1
01
0
PAC101
101
PAC101
102
CO
C1
01
1
PAC101
201
PAC101
202COC1012
PAC101
301
PAC101
302COC1013
PAC101
401
PAC101
402COC1014
PAC101
501
PAC101
502COC1015
PAC101
601
PAC101
602COC1016
PAC101
701
PAC101
702
CO
C1
01
7
PAC101
801
PAC101
802
CO
C1
01
8
PAC101
901
PAC101
902
CO
C1
01
9
PAC102
001
PAC102
002 COC1020
PAC102
101
PAC102
102 COC1021
PAC102
201
PAC102
202
CO
C1
02
2
PAC102
301
PAC102
302COC1023
PAC102
401
PAC102
402COC1024
PAC102
501
PAC102
502
CO
C1
02
5
PAC102
601
PAC102
602 COC1026
PAC1027
01
PAC1027
02
CO
C1
02
7
PAC102
801
PAC102
802
CO
C1
02
8
PAC102
901
PAC102
902COC1029
PAC103
001
PAC103
002
CO
C1
03
0
PAC20
102
PAC201
01
COC201
PAC202
02
PAC202
01
CO
C2
02
PAC203
02
PAC203
01
CO
C2
03
PAC204
02
PAC204
01
CO
C2
04
PAC205
02
PAC205
01
CO
C2
05
PAC206
02
PAC206
01 COC206
PAC207
02
PAC207
01 COC207
PAC208
02
PAC208
01 CO
C2
08PAC209
02
PAC209
01
CO
C2
09
PAC201
002
PAC201
001
CO
C2
01
0
PAC201
102
PAC201
101
CO
C2
01
1
PAC201
202
PAC201
201COC2012
PAC201
302
PAC201
301COC2013
PAC201
402
PAC201
401COC2014
PAC201
502
PAC201
501
CO
C2
01
5
PAC201
602
PAC201
601COC2016
PAC201
702
PAC201
701
CO
C2
01
7
PAC201
802
PAC201
801
CO
C2
01
8
PAC201
902
PAC201
901
CO
C2
01
9
PAC202
002
PAC202
001 COC2020
PAC202
102
PAC202
101 COC2021
PAC202
202
PAC202
201
CO
C2
02
2
PAC202
302
PAC202
301COC2023
PAC202
402
PAC202
401COC2024
PAC202
502
PAC202
501CO
C2
02
5
PAC202
602
PAC202
601
COC2026
PAC202
702
PAC202
701
CO
C2
02
7
PAC202
801
PAC202
802
CO
C2
02
8
PAC202
901
PAC202
902
CO
C2
02
9
PAC203
001
PAC203
002
CO
C2
03
0
PAC301
01
PAC301
02
COC301
PAC30202
PAC30201
COC302
PAC303
01
PAC303
02
CO
C3
03
PAC
304
02
PAC
304
01
CO
C3
04
PAC305
01
PAC305
02
CO
C3
05
PAC30602
PAC30601C
OC
30
6
PAC307
01
PAC307
02
CO
C3
07
PAC30802
PAC30801
CO
C3
08
PAC309
01
PAC309
02
COC309
PAC
301
002
PAC
3010
01
CO
C3
01
0
PAC3011
01
PAC3011
02
COC3011
PAC301202
PAC301201
COC3012
PAC501
02
PAC501
01
CO
C5
01
PAC50
202
PAC502
01
CO
C5
02
PAC
601
02
PAC
601
01
CO
C6
01
PAC602
01
PAC602
02
CO
C6
02
PAC603
01
PAC603
02
CO
C6
03
PAC604
01
PAC604
02COC604
PAC605
01
PAC605
02
COC605
PAC
606
02
PAC
606
01
CO
C6
06
PAC607
01
PAC607
02
CO
C6
07
PAC608
01
PAC608
02
CO
C6
08
PAC609
01
PAC609
02
COC609
PAC601
001
PAC601
002
CO
C6
01
0
PAC601
101
PAC601
102
CO
C6
01
1
PAC601
201
PAC601
202
CO
C6
01
2
PAC601
301
PAC601
302
COC6013
PAC601
401
PAC601
402
CO
C6
01
4
PAC80
101
PAC801
02
CO
C8
01
PAC80
201
PAC802
02
CO
C8
02
PAC803
02
PAC803
01
CO
C8
03
PAC804
02
PAC804
01COC804
PAC805
02
PAC805
01COC805
PAC80
602
PAC806
01COC806
PAC807
02
PAC807
01COC807
PAC808
02
PAC808
01COC808
PAC809
02
PAC809
01COC809
PAC901
01
PAC901
02
CO
C9
01
PAC902
01
PAC902
02
CO
C9
02
PAC903
01
PAC903
02CO
C9
03
PAC904
01
PAC904
02
CO
C9
04
PAC905
01
PAC905
02
CO
C9
05
PAC906
01
PAC906
02
COC906
PA
CO
N0F
LAS
H0H
01
PAC
ON0F
LASH
0H02
PA
CO
N0F
LAS
H0H
03
PA
CO
N0F
LAS
H0H
04
PAC
ON0F
LASH
0H05
PA
CO
N0F
LAS
H0H
06
PAC
ON0F
LASH
0H07
PA
CO
N0F
LAS
H0H
08
PA
CO
N0F
LAS
H0H
09
PACO
N0FL
ASH0
H010
PA
CON
0FL
ASH
0H0
11
PA
CON
0FL
ASH
0H0
12
PACO
N0FL
ASH0
H013
PA
CON
0FL
ASH
0H0
14
PA
CON
0FL
ASH
0H0
15
PACO
N0FL
ASH0
H016
PA
CON
0FL
ASH
0H0
17
PACO
N0FL
ASH0
H018
PA
CON
0FL
ASH
0H0
19
PA
CON
0FL
ASH
0H0
20
PACO
N0FL
ASH0
H021
PA
CON
0FL
ASH
0H0
22
PA
CON
0FL
ASH
0H0
23
PACO
N0FL
ASH0
H024
PA
CON
0FL
ASH
0H0
48
PACO
N0FL
ASH0
H047
PA
CON
0FL
ASH
0H0
46
PA
CON
0FL
ASH
0H0
45
PACO
N0FL
ASH0
H044
PA
CON
0FL
ASH
0H0
43
PACO
N0FL
ASH0
H042
PA
CON
0FL
ASH
0H0
41
PA
CON
0FL
ASH
0H0
40
PACO
N0FL
ASH0
H039
PA
CON
0FL
ASH
0H0
38
PA
CON
0FL
ASH
0H0
37
PACO
N0FL
ASH0
H036
PA
CON
0FL
ASH
0H0
35
PA
CON
0FL
ASH
0H0
34
PACO
N0FL
ASH0
H033
PA
CON
0FL
ASH
0H0
32
PACO
N0FL
ASH0
H031
PA
CON
0FL
ASH
0H0
30
PA
CON
0FL
ASH
0H0
29
PACO
N0FL
ASH0
H028
PA
CON
0FL
ASH
0H0
27
PA
CON
0FL
ASH
0H0
26
PACO
N0FL
ASH0
H025
CO
CO
N0
FL
AS
H0
H
PACON0FLASH0L01PACON0FLASH0L02PACON0FLASH0L03PACON0FLASH0L04PACON0FLASH0L05PACON0FLASH0L06PACON0FLASH0L07PACON0FLASH0L08PACON0FLASH0L09PACON0FLASH0L010PACON0FLASH0L011PACON0FLASH0L012PACON0FLASH0L013PACON0FLASH0L014PACON0FLASH0L015PACON0FLASH0L016PACON0FLASH0L017PACON0FLASH0L018PACON0FLASH0L019PACON0FLASH0L020PACON0FLASH0L021PACON0FLASH0L022PACON0FLASH0L023PACON0FLASH0L024
PACON0FLASH0L048PACON0FLASH0L047PACON0FLASH0L046PACON0FLASH0L045PACON0FLASH0L044PACON0FLASH0L043PACON0FLASH0L042PACON0FLASH0L041PACON0FLASH0L040PACON0FLASH0L039PACON0FLASH0L038PACON0FLASH0L037PACON0FLASH0L036PACON0FLASH0L035PACON0FLASH0L034PACON0FLASH0L033PACON0FLASH0L032PACON0FLASH0L031PACON0FLASH0L030PACON0FLASH0L029PACON0FLASH0L028PACON0FLASH0L027PACON0FLASH0L026PACON0FLASH0L025C
OC
ON
0F
LA
SH
0L
PACON0SRAM0H022PACON0SRA
M0H021PACON0SRAM0H020
PACON0SRAM0H019PACON0SRAM0H01
8PACON0SRAM0H017PACON
0SRAM0H016PACON0SRAM0H015
PACON0SRAM0H014PACON0SRAM0H01
3PACON0SRAM0H012PACO
N0SRAM0H011PACON0SRAM0H010
PACON0SRAM0H09PACON0SRAM0H0
8PACON0SRAM0H07PACO
N0SRAM0H06PACON0SRAM0H05
PACON0SRAM0H04PACON0SRA
M0H03PACON0SRAM0H02
PACON0SRAM0H01
PACON0SRAM0H023PACON0SRA
M0H024
PACON0SRAM0H044PACON0SRAM0H043PACON0SRAM0H042PACON0SRAM0H041PACON0SRAM0H040PACON0SRAM0H039PACON0SRAM0H038PACON0SRAM0H037PACON0SRAM0H036PACON0SRAM0H035PACON0SRAM0H034PACON0SRAM0H033PACON0SRAM0H032PACON0SRAM0H031PACON0SRAM0H030PACON0SRAM0H029PACON0SRAM0H028PACON0SRAM0H027PACON0SRAM0H026PACON0SRAM0H025
CO
CO
N0
SR
AM
0H
PA
CO
N0S
RAM
0L0
22
PA
CO
N0S
RAM
0L0
21
PA
CO
N0S
RAM
0L0
20
PAC
ON0S
RAM0
L019
PA
CO
N0S
RAM
0L0
18
PA
CO
N0S
RAM
0L0
17
PA
CO
N0S
RAM
0L0
16
PAC
ON0S
RAM0
L015
PAC
ON0S
RAM0
L014
PA
CO
N0S
RAM
0L0
13
PA
CO
N0S
RAM
0L0
12
PA
CO
N0S
RAM
0L0
11
PAC
ON0S
RAM0
L010
PA
CO
N0
SR
AM
0L
09
PA
CO
N0
SR
AM
0L
08
PA
CO
N0
SR
AM
0L
07
PAC
ON0
SRA
M0L
06
PAC
ON0
SRA
M0L
05
PA
CO
N0
SR
AM
0L
04
PA
CO
N0
SR
AM
0L
03
PA
CO
N0
SR
AM
0L
02
PAC
ON0
SRA
M0L
01
PA
CO
N0S
RAM
0L0
23
PA
CO
N0S
RAM
0L0
24
PAC
ON0S
RAM0
L044
PA
CO
N0S
RAM
0L0
43
PA
CO
N0S
RAM
0L0
42
PA
CO
N0S
RAM
0L0
41
PAC
ON0S
RAM0
L040
PAC
ON0S
RAM0
L039
PA
CO
N0S
RAM
0L0
38
PA
CO
N0S
RAM
0L0
37
PA
CO
N0S
RAM
0L0
36
PAC
ON0S
RAM0
L035
PA
CO
N0S
RAM
0L0
34
PA
CO
N0S
RAM
0L0
33
PA
CO
N0S
RAM
0L0
32
PAC
ON0S
RAM0
L031
PAC
ON0S
RAM0
L030
PA
CO
N0S
RAM
0L0
29
PA
CO
N0S
RAM
0L0
28
PA
CO
N0S
RAM
0L0
27
PAC
ON0S
RAM0
L026
PA
CO
N0S
RAM
0L0
25
CO
CO
N0
SR
AM
0L
PAD701
02
PAD701
01
CO
D7
01
PAD702
02
PAD702
01
CO
D7
02 PAD70302PAD70301CO
D7
03
PAD704
02
PAD704
01
CO
D7
04
PAD705
02
PAD705
01
CO
D7
05
PAD706
02
PAD706
01
CO
D7
06 PAD70702PAD70701CO
D7
07
PAD708
02
PAD708
01
CO
D7
08
PAD709
02
PAD709
01
CO
D7
09
PAD701
002
PAD701
001
CO
D7
01
0
PAD701
102
PAD701
101
CO
D7
01
1
PAD701
202
PAD701
201
CO
D7
01
2
PAD701
302
PAD701
301
CO
D7
01
3
PAD701
402
PAD701
401
CO
D7
01
4
PAD701
502
PAD701
501
CO
D7
01
5
PAD701
602
PAD701
601CO
D7
01
6
PAD
UT0
FLA
SH0
5
PAD
UT0
FLA
SH0
6
PAD
UT0
FLA
SH0
7
PAD
UT0
FLA
SH0
8
PAD
UT0F
LASH
04
PAD
UT0F
LASH
03
PAD
UT0F
LASH
02
PAD
UT0F
LASH
01
CO
DU
T0
FL
AS
H
PADUT0SRAM035PADUT0SRAM036PADUT0SRAM037PADUT0SRAM038PADUT0SRAM039PADUT0SRAM040PADUT0SRAM041PADUT0SRAM042PADUT0SRAM043PADUT0SRAM044PADUT0SRAM045PADUT0SRAM046PADUT0SRAM047PADUT0SRAM048PADUT0SRAM049PADUT0SRAM050PADUT0SRAM051PADUT0SRAM052PADUT0SRAM053PADUT0SRAM054
PADUT0SRAM034PADUT0SRAM03
3
PADUT0SRAM01PADUT0S
RAM02PADUT0SRAM03
PADUT0SRAM04PADUT0SRAM0
5PADUT0SRAM06PADU
T0SRAM07PADUT0SRAM08
PADUT0SRAM09PADUT0SRAM01
0PADUT0SRAM011PADU
T0SRAM012PADUT0SRAM013
PADUT0SRAM014PADUT0SRAM01
5PADUT0SRAM016PADU
T0SRAM017PADUT0SRAM018
PADUT0SRAM019PADUT0SRAM02
0PADUT0SRAM021PADU
T0SRAM022
PADUT0SRAM027PADUT0SRAM026PADUT0SRAM025PADUT0SRAM024PADUT0SRAM023
PADUT0SRAM028PADUT0SRAM029
PADUT0SRAM032PADUT0SRAM03
1PADUT0SRAM030
CODUT0SRAM
PAFPGA1010208PAFPGA1010207PAFPGA1010206P
AFPGA1010205PAFPGA1010204PAFPGA1010203P
AFPGA1010202PAFPGA1010201PAFPGA1010200PA
FPGA1010199PAFPGA1010198PAFPGA1010197PAF
PGA1010196PAFPGA1010195PAFPGA1010194PAFP
GA1010193PAFPGA1010192PAFPGA1010191PAFPG
A1010190PAFPGA1010189PAFPGA1010188PA
FPGA1010187PAFPGA1010186PAFPGA1010185PAF
PGA1010184PAFPGA1010183PAFPGA1010182PAFP
GA1010181PAFPGA1010180PAFPGA1010179PAFPG
A1010178PAFPGA1010177PAFPGA1010176PAFPGA
1010175PAFPGA1010174PAFPGA1010173PAFPGA1
010172PAFPGA1010171PAFPGA1010170PAFPGA10
10169PAFPGA1010168PAFPGA1010167PAFPGA101
0166PAFPGA1010165PAFPGA1010164PAFPGA1
010163PAFPGA1010162PAFPGA1010161PAFPGA10
10160PAFPGA1010159PAFPGA1010158PAFPGA101
0157 PAFP
GA
10
10
15
6
PA
FP
GA
10
10
15
5
PA
FP
GA1
010
154
PA
FP
GA
10
10
15
3
PA
FP
GA
10
10
15
2
PA
FP
GA1
010
151
PA
FP
GA
10
10
15
0
PA
FP
GA1
010
149
PA
FP
GA
10
10
14
8
PA
FP
GA
10
10
14
7
PA
FP
GA1
010
146
PA
FP
GA
10
10
14
5
PA
FP
GA
10
10
14
4
PA
FP
GA1
010
143
PA
FP
GA
10
10
14
2
PA
FP
GA
10
10
14
1
PA
FP
GA1
010
140
PA
FP
GA
10
10
13
9
PA
FP
GA1
010
138
PA
FP
GA
10
10
13
7
PA
FP
GA
10
10
13
6
PA
FP
GA1
010
135
PA
FP
GA
10
10
13
4
PA
FP
GA
10
10
13
3
PA
FP
GA1
010
132
PA
FP
GA
10
10
13
1
PA
FP
GA
10
10
13
0
PA
FP
GA1
010
129
PA
FP
GA
10
10
12
8
PA
FP
GA
10
10
12
7
PA
FP
GA1
010
126
PA
FP
GA
10
10
12
5
PA
FP
GA1
010
124
PA
FP
GA
10
10
12
3
PA
FP
GA
10
10
12
2
PA
FP
GA1
010
121
PA
FP
GA
10
10
12
0
PA
FP
GA
10
10
11
9
PA
FP
GA1
010
118
PA
FP
GA
10
10
11
7
PA
FP
GA
10
10
11
6
PA
FP
GA1
010
115
PA
FP
GA
10
10
11
4
PA
FP
GA1
010
113
PA
FP
GA
10
10
11
2
PA
FP
GA
10
10
11
1
PA
FP
GA1
010
110
PA
FP
GA
10
10
10
9
PA
FP
GA
10
10
10
8
PA
FP
GA1
010
107
PA
FP
GA
10
10
10
6
PA
FP
GA
10
10
10
5
PAFPGA1010104PAFPGA1010103PAFPGA1010102PAFPGA1010101PAFPGA1010100PAFPGA101099PAFPGA101098PAFPGA101097PAFPGA101096PAFPGA101095PAFPGA101094PAFPGA101093PAFPGA101092PAFPGA101091PAFPGA101090PAFPGA101089PAFPGA101088PAFPGA101087PAFPGA101086PAFPGA101085PAFPGA101084PAFPGA101083PAFPGA101082PAFPGA101081PAFPGA101080PAFPGA101079PAFPGA101078PAFPGA101077PAFPGA101076PAFPGA101075PAFPGA101074PAFPGA101073PAFPGA101072PAFPGA101071PAFPGA101070PAFPGA101069PAFPGA101068PAFPGA101067PAFPGA101066PAFPGA101065PAFPGA101064PAFPGA101063PAFPGA101062PAFPGA101061PAFPGA101060PAFPGA101059PAFPGA101058PAFPGA101057PAFPGA101056PAFPGA101055PAFPGA101054PAFPGA101053
PA
FP
GA
10
10
52
PA
FP
GA
10
10
51
PAF
PGA
101
050
PA
FP
GA
10
10
49
PA
FP
GA
10
10
48
PAF
PGA
101
047
PA
FP
GA
10
10
46
PA
FP
GA
10
10
45
PAF
PGA
101
044
PA
FP
GA
10
10
43
PAF
PGA
101
042
PA
FP
GA
10
10
41
PA
FP
GA
10
10
40
PAF
PGA
101
039
PA
FP
GA
10
10
38
PA
FP
GA
10
10
37
PAF
PGA
101
036
PA
FP
GA
10
10
35
PA
FP
GA
10
10
34
PAF
PGA
101
033
PA
FP
GA
10
10
32
PAF
PGA
101
031
PA
FP
GA
10
10
30
PA
FP
GA
10
10
29
PAF
PGA
101
028
PA
FP
GA
10
10
27
PA
FP
GA
10
10
26
PAF
PGA
101
025
PA
FP
GA
10
10
24
PA
FP
GA
10
10
23
PAF
PGA
101
022
PA
FP
GA
10
10
21
PA
FP
GA
10
10
20
PAF
PGA
101
019
PA
FP
GA
10
10
18
PAF
PGA
101
017
PA
FP
GA
10
10
16
PA
FP
GA
10
10
15
PAF
PGA
101
014
PA
FP
GA
10
10
13
PA
FP
GA
10
10
12
PAF
PGA
101
011
PA
FP
GA
10
10
10
PA
FP
GA
10
10
9
PA
FP
GA
101
08
PA
FP
GA
10
10
7
PA
FP
GA
101
06
PA
FP
GA
10
10
5
PA
FP
GA
10
10
4
PA
FP
GA
101
03
PA
FP
GA
10
10
2
PA
FP
GA
10
10
1
CO
FP
GA
10
1
PAFPGA2010208PAFPGA2010207PAFPGA2010206P
AFPGA2010205PAFPGA2010204PAFPGA2010203PA
FPGA2010202PAFPGA2010201PAFPGA20102
00PAFPGA2010199PAFPGA2010198PAFPGA201019
7PAFPGA2010196PAFPGA2010195PAFPGA2010194
PAFPGA2010193PAFPGA2010192PAFPGA2010191P
AFPGA2010190PAFPGA2010189PAFPGA2010188PA
FPGA2010187PAFPGA2010186PAFPGA2010185PAF
PGA2010184PAFPGA2010183PAFPGA2010182PAFP
GA2010181PAFPGA2010180PAFPGA2010179PAF
PGA2010178PAFPGA2010177PAFPGA2010176PAFP
GA2010175PAFPGA2010174PAFPGA2010173PAFPG
A2010172PAFPGA2010171PAFPGA2010170PAFPGA
2010169PAFPGA2010168PAFPGA2010167PAFPGA2
010166PAFPGA2010165PAFPGA2010164PAFPG
A2010163PAFPGA2010162PAFPGA2010161PAFPGA
2010160PAFPGA2010159PAFPGA2010158PAFPGA2
010157 PAF
PG
A2
01
01
56
PA
FP
GA
20
10
15
5
PAF
PGA
201
015
4
PA
FP
GA
20
10
15
3
PAF
PGA
201
015
2
PA
FP
GA
20
10
15
1
PA
FP
GA
20
10
15
0
PAF
PGA
201
014
9
PA
FP
GA
20
10
14
8
PA
FP
GA
20
10
14
7
PAF
PGA
201
014
6
PA
FP
GA
20
10
14
5
PA
FP
GA
20
10
14
4
PAF
PGA
201
014
3
PA
FP
GA
20
10
14
2
PAF
PGA
201
014
1
PA
FP
GA
20
10
14
0
PA
FP
GA
20
10
13
9
PAF
PGA
201
013
8
PA
FP
GA
20
10
13
7
PA
FP
GA
20
10
13
6
PAF
PGA
201
013
5
PA
FP
GA
20
10
13
4
PA
FP
GA
20
10
13
3
PAF
PGA
201
013
2
PA
FP
GA
20
10
13
1
PA
FP
GA
20
10
13
0
PAF
PGA
201
012
9
PA
FP
GA
20
10
12
8
PAF
PGA
201
012
7
PA
FP
GA
20
10
12
6
PA
FP
GA
20
10
12
5
PAF
PGA
201
012
4
PA
FP
GA
20
10
12
3
PA
FP
GA
20
10
12
2
PAF
PGA
201
012
1
PA
FP
GA
20
10
12
0
PA
FP
GA
20
10
11
9
PAF
PGA
201
011
8
PA
FP
GA
20
10
11
7
PAF
PGA
201
011
6
PA
FP
GA
20
10
11
5
PA
FP
GA
20
10
11
4
PAF
PGA
201
011
3
PA
FP
GA
20
10
11
2
PA
FP
GA
20
10
11
1
PAF
PGA
201
011
0
PA
FP
GA
20
10
10
9
PA
FP
GA
20
10
10
8
PAF
PGA
201
010
7
PA
FP
GA
20
10
10
6
PA
FP
GA
20
10
10
5
PAFPGA2010104PAFPGA2010103PAFPGA2010102PAFPGA2010101PAFPGA2010100PAFPGA201099PAFPGA201098PAFPGA201097PAFPGA201096PAFPGA201095PAFPGA201094PAFPGA201093PAFPGA201092PAFPGA201091PAFPGA201090PAFPGA201089PAFPGA201088PAFPGA201087PAFPGA201086PAFPGA201085PAFPGA201084PAFPGA201083PAFPGA201082PAFPGA201081PAFPGA201080PAFPGA201079PAFPGA201078PAFPGA201077PAFPGA201076PAFPGA201075PAFPGA201074PAFPGA201073PAFPGA201072PAFPGA201071PAFPGA201070PAFPGA201069PAFPGA201068PAFPGA201067PAFPGA201066PAFPGA201065PAFPGA201064PAFPGA201063PAFPGA201062PAFPGA201061PAFPGA201060PAFPGA201059PAFPGA201058PAFPGA201057PAFPGA201056PAFPGA201055PAFPGA201054PAFPGA201053
PA
FP
GA
20
10
52
PA
FP
GA
20
10
51
PA
FP
GA
201
050
PA
FP
GA
20
10
49
PA
FP
GA
20
10
48
PA
FP
GA
201
047
PA
FP
GA
20
10
46
PA
FP
GA
20
10
45
PA
FP
GA
201
044
PA
FP
GA
20
10
43
PA
FP
GA
20
10
42
PA
FP
GA
201
041
PA
FP
GA
20
10
40
PA
FP
GA
201
039
PA
FP
GA
20
10
38
PA
FP
GA
20
10
37
PA
FP
GA
201
036
PA
FP
GA
20
10
35
PA
FP
GA
20
10
34
PA
FP
GA
201
033
PA
FP
GA
20
10
32
PA
FP
GA
20
10
31
PA
FP
GA
201
030
PA
FP
GA
20
10
29
PA
FP
GA
201
028
PA
FP
GA
20
10
27
PA
FP
GA
20
10
26
PA
FP
GA
201
025
PA
FP
GA
20
10
24
PA
FP
GA
20
10
23
PA
FP
GA
201
022
PA
FP
GA
20
10
21
PA
FP
GA
20
10
20
PA
FP
GA
201
019
PA
FP
GA
20
10
18
PA
FP
GA
20
10
17
PA
FP
GA
201
016
PA
FP
GA
20
10
15
PA
FP
GA
201
014
PA
FP
GA
20
10
13
PA
FP
GA
20
10
12
PA
FP
GA
201
011
PA
FP
GA
20
10
10
PA
FP
GA
20
10
9
PA
FP
GA
20
10
8
PA
FP
GA
20
10
7
PA
FP
GA
20
10
6
PA
FP
GA
20
10
5
PA
FP
GA
20
10
4
PA
FP
GA
20
10
3
PA
FP
GA
20
10
2
PA
FP
GA
20
10
1
CO
FP
GA
20
1
PAJP10
101
PAJP10
103
PAJP10
105
PAJP10
107
PAJP10
109
PAJP10
102
PAJP10
104
PAJP10
106
PAJP10
108
PAJP101
010
COJP101
PAJP10
201
PAJP10
203
PAJP10
205
PAJP10
207
PAJP10
209
PAJP10
202
PAJP10
204
PAJP10
206
PAJP10
208
PAJP102
010
COJP102
PAJP1
0308
PAJP1
0307
PAJP1
0301
PAJP1
0302
PAJP1
0303
PAJP1
0304
PAJP1
0305
PAJP1
0306
PAJP10
3015
PAJP10
3011
PAJP10
3013
PAJP10
3014
PAJP10
3010
PAJP10
3012
PAJP1
0309
PAJP10
3016COJP103
PAJP20
101
PAJP20
103
PAJP20
105
PAJP20
107
PAJP20
109
PAJP20
102
PAJP20
104
PAJP20
106
PAJP20
108
PAJP201
010
COJP201
PAJP20
201
PAJP20
203
PAJP20
205
PAJP20
207
PAJP20
209
PAJP20
202
PAJP20
204
PAJP20
206
PAJP20
208
PAJP202
010
COJP202
PAJP30102
PAJ
P301
03
PAJP30101 COJP3
01
PAJP50
101
PAJP50
103
PAJP50
105
PAJP50
107
PAJP50
109
PAJP50
102
PAJP50
104
PAJP50
106
PAJP50
108
PAJP501
010
COJP501
PAJP502
01
PAJP502
03
PAJP502
05
PAJP502
07
PAJP502
09
PAJP502
02
PAJP502
04
PAJP502
06
PAJP502
08
PAJP5020
10
COJP502
PAJP50
301
PAJP50
303
PAJP50
302
PAJP50
304
COJP503
PAJP5
0401
PAJP5
0403
PAJP5
0402
PAJP5
0404
COJP504
PAJP60
109
PAJP60
108
PAJP60
106
PAJP60
104
PAJP60
102
PAJP60
107
PAJP60
105
PAJP60
103
PAJP60
101
CO
JP
60
1
PAJP701
01
PAJP701
03
PAJP701
05
PAJP701
07
PAJP701
09
PAJP701
02
PAJP701
04
PAJP701
06
PAJP701
08
PAJP7010
10 COJP701 PAJP702010
PAJP70
208
PAJP70
206
PAJP70
204
PAJP70
202
PAJP70
209
PAJP70
207
PAJP70
205
PAJP70
203
PAJP70
201
CO
JP
70
2
PAJP70
303
PAJP70
302
PAJP70
301
CO
JP
70
3
PAJP7
0403
PAJP7
0402
PAJP7
0401
CO
JP
70
4
PAJP80
106
PAJP80
1014
PAJP80
1013
PAJP80
1012
PAJP80
1011
PAJP80
1010
PAJP80
109
PAJP80
105
PAJP80
104
PAJP80
103
PAJP80
102
PAJP80
101
PAJP80
107
PAJP80
1015
PAJP80
108
CO
JP
80
1
PAL
6010
1
PAL
6010
2
CO
L6
01
PA
OP
401
08
PA
OP
401
09
PAO
P40
101
0
PAO
P40
101
1
PAO
P40
101
2
PAO
P40
101
3
PAO
P40
101
4
PA
OP
40
10
7
PA
OP
40
10
6
PA
OP
40
10
5
PA
OP
40
10
4
PA
OP
40
10
3
PA
OP
40
10
2
PA
OP
40
10
1
CO
OP
40
1
PAP30101
PAP30103
PAP301
02
CO
P3
01
PAP30201
PAP30203 PAP302
02
CO
P3
02
PA
P3
03
01
PAP
303
03
PAP30
302COP303
PAP30401
PAP30403 PAP304
02
CO
P3
04
PAP30505
PAP30504PAP30503P
AP30502
PAP30501
COP305 PAP30605
PAP30604PAP30603
PAP30602P
AP30601
COP306
PAP
B10
102
PAP
B10
101COPB101
PAPB70102
PAPB70101
CO
PB
70
1
PAPB70202
PAPB70201
CO
PB
70
2
PAQ70102PAQ7
0103 PAQ70
101
CO
Q7
01PAQ70202 PAQ70203PAQ70201
CO
Q7
02
PAQ70302PAQ7
0303 PAQ70
301
C
O
Q
7
0
3
PAQ70402 PAQ70403PAQ70401
CO
Q7
04
PAQ70502PAQ7
0503 PAQ70
501
CO
Q7
05
PAQ70602 PAQ70603PAQ70601
CO
Q7
06
PAQ70702PAQ7
0703 PAQ70
701
C
O
Q
7
0
7
PAQ70802 PAQ70803PAQ70801
CO
Q7
08
PAQ70902P
AQ70903 PAQ
70901
CO
Q7
09PAQ7010
02
PAQ701003PAQ701001
CO
Q7
01
0
PAQ701102PA
Q701103 PAQ7
01101
CO
Q7
01
1PAQ701202 PAQ701203PAQ701201
CO
Q7
01
2
PAQ701302PA
Q701303 PAQ7
01301
CO
Q7
01
3PAQ701402 PAQ701403PAQ701401
CO
Q7
01
4
PAQ701502PA
Q701503 PAQ7
01501
CO
Q7
01
5PAQ701602 PAQ701603PAQ701601
CO
Q7
01
6
PAR101
01
PAR101
02
CO
R1
01
PAR102
01
PAR102
02 COR102PAR10301 PAR10302
COR103
PAR104
01
PAR104
02 COR104
PAR105
02
PAR105
01
CO
R1
05
PAR201
01
PAR201
02
CO
R2
01
PAR202
01
PAR202
02
COR202PAR20
301
PAR20
302
CO
R2
03
PAR20
401
PAR20
402
CO
R2
04
PAR205
01
PAR205
02
CO
R2
05
PAR206
01
PAR206
02
CO
R2
06
PAR207
02
PAR207
01
CO
R2
07
PAR208
02
PAR208
01
CO
R2
08
PAR305
01
PAR305
02
CO
R3
05
PAR306
01
PAR306
02
CO
R3
06
PAR4010
2
PAR4010
1
CO
R4
01
PAR40201
PAR40202
CO
R4
02
PAR403
02
PAR403
01
CO
R4
03
PAR405
02
PAR405
01
CO
R4
05
PAR406
02
PAR406
01
CO
R4
06
PAR4070
1
PAR4070
2
CO
R4
07
PAR401
001
PAR401
002
CO
R4
01
0
PAR401
101
PAR401
102
CO
R4
01
1
PAR501
02
PAR501
01
CO
R5
01
PAR502
02
PAR502
01
CO
R5
02
PAR503
02
PAR503
01
CO
R5
03
PAR504
02
PAR504
01
CO
R5
04
PAR505
02
PAR505
01
CO
R5
05
PAR601
01
PAR601
02
CO
R6
01
PAR602
01
PAR602
02
COR602
PAR603
01
PAR603
02
CO
R6
03
PAR604
02
PAR604
01
CO
R6
04
PAR605
01
PAR605
02
CO
R6
05
PAR606
01
PAR606
02
CO
R6
06
PAR607
01
PAR607
02
CO
R6
07
PAR608
01
PAR608
02
CO
R6
08
PAR609
01
PAR609
02
CO
R6
09
PAR601
001
PAR601
002
COR6010
PAR601
101
PAR601
102
COR6011
PAR601
202
PAR601
201COR6012
PAR601
301
PAR601
302
CO
R6
01
3
PAR601
402
PAR601
401
COR6014
PAR601
502
PAR601
501
CO
R6
01
5
PAR601
602
PAR601
601
CO
R6
01
6
PAR601
702
PAR601
701
CO
R6
01
7
PAR601
802
PAR601
801
CO
R6
01
8
PAR601
902
PAR601
901
CO
R6
01
9
PAR602
001
PAR602
002
CO
R6
02
0
PAR701
01
PAR701
02
CO
R7
01
PAR702
01
PAR702
02
CO
R7
02
PAR703
01
PAR703
02
C
O
R
7
0
3
PAR704
01
PAR704
02
C
O
R
7
0
4
PAR705
01
PAR705
02
CO
R7
05
PAR706
01
PAR706
02
CO
R7
06
PAR707
01
PAR707
02
CO
R7
07
PAR708
01
PAR708
02
C
O
R
7
0
8
PAR709
01
PAR709
02
CO
R7
09
PAR701
001
PAR701
002
CO
R7
01
0
PAR701
101
PAR701
102
CO
R7
01
1
PAR701
201
PAR701
202
C
O
R
7
0
1
2
PAR701
301
PAR701
302
CO
R7
01
3
PAR701
401
PAR701
402
CO
R7
01
4
PAR701
501
PAR701
502
CO
R7
01
5
PAR701
601
PAR701
602
C
O
R
7
0
1
6
PAR7017
02
PAR701
701
CO
R7
01
7
PAR701
802
PAR7018
01
CO
R7
01
8
PAR701
902
PAR7019
01
CO
R7
01
9
PAR702
002
PAR702
001
CO
R7
02
0
PAR80
101
PAR801
02
CO
R8
01
PAR901
02
PAR90
101
CO
R9
01
PAR902
02
PAR902
01
CO
R9
02
PATP10
101
CO
TP
10
1
PATP201
01
CO
TP
20
1
PATP20
201
CO
TP
20
2
PATP20
401 COTP204PATP20501 COTP205
PATP206
01 COTP206
PATP30
101
CO
TP
30
1
PATP30
201COTP302
PATP30
301COTP303
PATP30
401COTP304
PATP30
501
CO
TP
30
5
PATP30
601
CO
TP
30
6
PATP401
01CO
TP
40
1
PATP402
01
CO
TP
40
2
PATP40
301
CO
TP
40
3
PATP50
101 COTP501
PATP50
201 COTP502
PATP50
401
COTP504
PATP50
501COTP505
PATP50
601
CO
TP
50
6
PATP50
701
CO
TP
50
7
PATP50
901
COTP509
PATP501
001COTP5010 PATP501101 COTP5011
PA
U4
01
01
6
PA
U4
01
01
5
PA
U4
01
01
4
PA
U4
01
01
3
PA
U4
01
01
2
PA
U4
01
01
1
PA
U4
01
01
0
PA
U4
01
09
PA
U4
01
08
PA
U4
01
07
PA
U4
01
06
PA
U4
01
05
PA
U4
01
04
PA
U4
01
03
PA
U4
01
02
PA
U4
01
01
CO
U4
01
PA
U4
02
01
PAU
402
02
PA
U4
02
03
PA
U40
204
PA
U40
205
CO
U4
02
PAU
403
01
PAU
403
02
PAU
403
03
PAU
403
04
PAU
403
05
CO
U4
03
PA
U40
401
PAU
404
02
PA
U40
403
PA
U40
404
PA
U40
405CO
U4
04
PA
U4
05
01
PA
U4
05
02
PA
U4
05
04
PA
U4
05
03
PA
U4
05
06
PA
U4
05
05
PA
U4
05
07
PA
U4
05
08 C
OU
40
5
PA
U4
07
08
PA
U4
07
07
PA
U4
07
05
PA
U4
07
06
PA
U4
07
03
PA
U4
07
04
PA
U4
07
02
PA
U4
07
01 CO
U4
07
PAU601048PAU601047PAU601
046PAU601045PAU601044
PAU601043PAU601042PAU601
041PAU601040PAU601039PAU
601038PAU601037 PA
U6
01
03
6
PA
U6
01
03
5
PA
U6
01
03
4
PA
U6
01
03
3
PA
U6
01
03
2
PA
U6
01
03
1
PA
U6
01
03
0
PA
U6
01
02
9
PA
U6
01
02
8
PA
U6
01
02
7
PA
U6
01
02
6
PA
U6
01
02
5
PAU601024PAU601023PAU601022PAU601021PAU601020PAU601019PAU601018PAU601017PAU601016PAU601015PAU601014PAU601013
PA
U6
01
01
2
PA
U6
01
01
1
PA
U6
01
01
0
P
A
U6
01
09
PA
U6
01
08
P
A
U6
01
07
P
A
U6
01
06
PA
U6
01
05
P
A
U6
01
04
PA
U6
01
03
P
A
U6
01
02
P
A
U6
01
01
CO
U6
01
PAX10104 PAX10103
PAX10102PAX10101
CO
X1
01
PAX2
0104
PAX2
0103
PAX
2010
2
PAX
2010
1COX201
PAXVR50108P
AXVR50107
PAXVR50105
PAXVR50106 PAXVR50103P
AXVR50104
PAXVR50102
PAXVR50101
CO
XV
R5
01
PAXVR50208P
AXVR50207
PAXVR50205
PAXVR50206 PAXVR50203P
AXVR50204
PAXVR50202
PAXVR50201
COXVR502
PA
FP
GA
10
10
11
2
PATP10
101PAX10103PAC20
1702 PAC201
802
PAC201
902
PAC202
002
PAC202
102
PAC202
202
PAC202
302
PAC202
402
PAC203
002
PAC309
02
PAC
301
002
PA
FP
GA
201
016
PA
FP
GA
20
10
27
PA
FP
GA
201
036
PAFPGA201071
PAFPGA201088
PA
FP
GA
20
10
13
1
PA
FP
GA
20
10
14
2
PAFPGA2010171
PAFPGA2010187
PAP30
302
PATP30
401
PAC3011
02PAC301202
PAP304
02
PAR4010
1
PATP30
501
PA
U4
02
03
PA
OP
40
10
6
PA
OP
40
10
7
PATP401
01
PA
U4
01
03
PAC101
702
PAC101
802
PAC101
902
PAC102
002
PAC102
102
PAC102
202
PAC102
302
PAC102
402
PAC103
002
PA
FP
GA
10
10
16
PA
FP
GA
10
10
27
PAF
PGA
101
036
PAFPGA101071
PAFPGA101088
PA
FP
GA
10
10
13
1
PA
FP
GA
10
10
14
2
PAFPGA1010171
PAFPGA1010187
PAR4010
2
PA
U4
01
01
PA
U40
204
PA
FP
GA
20
10
32
PATP20
401
PAX2
0103
PAC20
102
PAC202
02
PAC203
02
PAC204
02
PAC205
02
PAC206
02
PAC207
02
PAC208
02
PAC209
02
PAC201
002
PAC201
102
PAC201
202
PAC201
302
PAC201
402
PAC201
502
PAC201
602
PAC202
802
PAC202
902
PAC305
02
PAC30602
PAC
601
02
PAC602
02
PAC603
02
PAC604
02
PAC901
02
PAC902
02
PAC903
02
PAC904
02PA
C90502
PAC906
02
PA
CON
0FL
ASH
0H0
37
PACO
N0FL
ASH0
H047
PACON0FLASH0L037
PACON0FLASH0L047
PACON0SRAM0H011 PACON0SRAM0H033
PA
CO
N0S
RAM
0L0
11
PA
CO
N0S
RAM
0L0
33
PA
FP
GA
20
10
3
PA
FP
GA
20
10
18
PA
FP
GA
20
10
40
PA
FP
GA
201
050
PAFPGA201053
PAFPGA201062
PAFPGA201072
PAFPGA201089
PAFPGA2010104PA
FP
GA
20
10
11
1
PA
FP
GA
20
10
12
3
PA
FP
GA
20
10
14
0
PAF
PGA
201
015
4
PAFPGA2010157
PAFPGA2010170
PAFPGA2010186
PAFPGA2010200
PAFPGA2010208
PAJP202
010
PAL
6010
2
PA
OP
40
10
4
PAP301
02
PAR201
01 P
AR204
02
PAR205
01
PAR206
01
PAR207
02
PAR208
02
PAR601
01
PAR902
02
PATP30
201
PA
U4
01
01
2
PA
U40
205
PAU
403
05
PA
U40
405
PA
U4
05
08
PA
U4
07
06
PA
U4
07
08
PA
U6
01
03
2
PAU601048
PAX2
0104
PAC609
02
PAC601
002
PAC601
102
PAC601
202
PAC601
402
PAJP60
104
PAJP60
105
PAL
6010
1
PAR601
501PAR601
601
PAR601
701
PAR601
801
PAU601022
PAC307
02PAC30802
PAP302
02
PAR40201
PATP30
301
PAU
403
03
PA
OP
40
10
1
PA
OP
40
10
2
PATP402
01
PA
U4
01
04
PAC101
02
PAC102
02
PAC103
02
PAC104
02
PAC105
02
PAC106
02
PAC107
02
PAC108
02
PAC109
02
PAC101
002
PAC101
102
PAC101
202
PAC101
302
PAC101
402
PAC101
502
PAC101
602
PAC102
802
PAC102
902
PAC803
02
PAC804
02
PAC805
02
PAC80
602
PAC807
02
PAC808
02
PAC809
02 PADUT0SRAM01
PADUT0SRAM03
PADUT0SRAM09
PADUT0SRAM014
PADUT0SRAM027
PADUT0SRAM043
PADUT0SRAM049
PA
FP
GA
101
03
PA
FP
GA
10
10
18
PA
FP
GA
10
10
40
PAF
PGA
101
050
PAFPGA101053
PAFPGA101062
PAFPGA101072
PAFPGA101089
PAFPGA1010104PA
FP
GA
10
10
11
1
PA
FP
GA
10
10
12
3
PA
FP
GA1
010
140
PA
FP
GA1
010
154
PAFPGA1010157
PAFPGA1010170
PAFPGA1010186
PAFPGA1010200
PAFPGA1010208
PAJP102
010
PAJP80
109
PAR101
01 P
AR1040
2
PAR105
02
PAR40202
PAR505
02
PA
U4
01
02
PAU
403
04
PAX10104
PAC501
02
PAC50
202
PAR505
01
PATP5011
01
PAXVR50103
PAXVR50203
PACO
N0FL
ASH0
H025
PACON0FLASH0L025
PACON0SRAM0H01
PAC
ON0
SRA
M0L
01
PAFPGA2010175
PACO
N0FL
ASH0
H024
PACON0FLASH0L024
PACON0SRAM0H02
PA
CO
N0
SR
AM
0L
02
PAFPGA2010176
PA
CON
0FL
ASH
0H0
23
PACON0FLASH0L023
PACON0SRAM0H03
PA
CO
N0
SR
AM
0L
03
PAFPGA2010177
PA
CON
0FL
ASH
0H0
22
PACON0FLASH0L022
PACON0SRAM0H04
PA
CO
N0
SR
AM
0L
04
PAFPGA2010179
PACO
N0FL
ASH0
H021
PACON0FLASH0L021
PACON0SRAM0H05
PAC
ON0
SRA
M0L
05
PAFPGA2010180
PA
CON
0FL
ASH
0H0
20
PACON0FLASH0L020
PACON0SRAM0H018
PA
CO
N0S
RAM
0L0
18
PAFPGA2010167
PA
CON
0FL
ASH
0H0
19
PACON0FLASH0L019
PACON0SRAM0H019
PAC
ON0S
RAM0
L019
PAFPGA2010168
PACO
N0FL
ASH0
H018
PACON0FLASH0L018
PACON0SRAM0H020
PA
CO
N0S
RAM
0L0
20
PAFPGA2010169
PA
CO
N0F
LAS
H0H
08
PACON0FLASH0L08
PACON0SRAM0H021
PA
CO
N0S
RAM
0L0
21
PAFPGA2010172
PAC
ON0F
LASH
0H07
PACON0FLASH0L07
PACON0SRAM0H022
PA
CO
N0S
RAM
0L0
22
PAFPGA2010173
PA
CO
N0F
LAS
H0H
06
PACON0FLASH0L06
PACON0SRAM0H023
PA
CO
N0S
RAM
0L0
23
PAFPGA2010189
PAC
ON0F
LASH
0H05
PACON0FLASH0L05
PACON0SRAM0H024
PA
CO
N0S
RAM
0L0
24
PAFPGA2010190
PA
CO
N0F
LAS
H0H
04
PACON0FLASH0L04
PACON0SRAM0H025
PA
CO
N0S
RAM
0L0
25
PAFPGA2010191
PA
CO
N0F
LAS
H0H
03
PACON0FLASH0L03
PACON0SRAM0H026
PAC
ON0S
RAM0
L026
PAFPGA2010192
PAC
ON0F
LASH
0H02
PACON0FLASH0L02
PACON0SRAM0H027
PA
CO
N0S
RAM
0L0
27
PAFPGA2010193
PA
CO
N0F
LAS
H0H
01
PACON0FLASH0L01
PACON0SRAM0H042
PA
CO
N0S
RAM
0L0
42
PAFPGA2010194
PA
CON
0FL
ASH
0H0
48
PACON0FLASH0L048
PACON0SRAM0H043
PA
CO
N0S
RAM
0L0
43
PAFPGA2010196
PA
CON
0FL
ASH
0H0
17
PACON0FLASH0L017
PACON0SRAM0H044
PAC
ON0S
RAM0
L044
PAFPGA2010182
PACO
N0FL
ASH0
H016
PACON0FLASH0L016
PAFPGA2010183
PA
CO
N0F
LAS
H0H
09
PACON0FLASH0L09
PAFPGA2010185
PADUT0SRAM020
PAFPGA101086
PADUT0SRAM021
PAFPGA101087
PAFPGA1010191
PA
FP
GA
20
10
21
PAFPGA1010190
PA
FP
GA
201
022
PAFPGA1010189
PA
FP
GA
20
10
23
PAFPGA1010188
PA
FP
GA
20
10
24
PAFPGA1010185
PA
FP
GA
20
10
26
PAFPGA1010184
PA
FP
GA
201
028
PAFPGA1010183
PA
FP
GA
201
030
PAFPGA1010182
PA
FP
GA
20
10
31
PAFPGA1010181
PA
FP
GA
201
033
PAFPGA1010180
PA
FP
GA
20
10
34
PAFPGA1010179
PA
FP
GA
20
10
35
PAFPGA1010177
PA
FP
GA
20
10
37
PAFPGA1010176
PA
FP
GA
20
10
38
PAFPGA1010175
PA
FP
GA
201
039
PAFPGA1010174
PA
FP
GA
20
10
42
PAFPGA1010173
PA
FP
GA
20
10
43
PAFPGA1010172
PA
FP
GA
201
044
PAFPGA1010169
PA
FP
GA
20
10
45
PAFPGA1010168
PA
FP
GA
20
10
46
PAFPGA1010167
PA
FP
GA
201
047
PAFPGA1010166
PA
FP
GA
20
10
48
PAFPGA1010165
PA
FP
GA
20
10
49
PAFPGA1010164
PAFPGA201055
PAFPGA1010163
PAFPGA201056
PAFPGA1010161
PAFPGA201057
PAJP50
302
PAJP5
0403
PATP201
01
PAFPGA1010160
PAFPGA201058
PAJP50
303
PAJP5
0402
PATP20
201
PAFPGA1010159
PAFPGA201059
PA
FP
GA
10
10
15
3
PAFPGA201060
PA
FP
GA
10
10
15
2
PAFPGA201061
PA
FP
GA1
010
151
PAFPGA201063
PA
FP
GA
10
10
15
0
PAFPGA201064
PA
FP
GA1
010
149
PAFPGA201066
PA
FP
GA
10
10
14
8
PAFPGA201067
PA
FP
GA
10
10
14
7
PAFPGA201068
PA
FP
GA1
010
146
PAFPGA201069
PA
FP
GA
10
10
14
5
PAFPGA201070
PA
FP
GA
10
10
14
4
PAFPGA201073
PA
FP
GA1
010
143
PAFPGA201074
PA
FP
GA
10
10
13
9
PAFPGA201075
PA
FP
GA1
010
138
PAFPGA201076
PA
FP
GA
10
10
13
7
PAFPGA201077
PA
FP
GA
10
10
13
6
PAFPGA201078
PA
FP
GA1
010
135
PAFPGA201079
PA
FP
GA
10
10
13
4
PAFPGA201080
PA
FP
GA1
010
132
PAFPGA201082
PA
FP
GA1
010
129
PAFPGA201083
PA
FP
GA
10
10
12
8
PAFPGA201084
PA
FP
GA
10
10
12
7
PAFPGA201085
PA
FP
GA
10
10
12
5
PAFPGA201086
PA
FP
GA1
010
124
PAFPGA201087
PA
FP
GA1
010
121
PAFPGA201090
PAP
B10
102
PAR105
01
PAJP50
104
PAR501
02
PATP50
401
PAXVR50107
PAJP50
103
PAR501
01
PATP50
501
PAXVR50106
PAJP502
04
PAR503
02
PATP50
901
PAXVR50207
PAJP502
03
PAR503
01
PATP501
001
PAXVR50206
PAJP5
0401
PATP50
201PAXVR50104
PAFPGA1010203
PAJP5
0404
PAJP50
301
PATP50
101PAXVR50101 PA
FPGA1010204
PAJP50
304
PAFPGA1010205
PATP50
701PAXVR50204
PAFPGA1010206
PATP50
601PAXVR50201
PADUT0SRAM017
PAFPGA101083
PADUT0SRAM037
PAFPGA101069
PADUT0SRAM038
PAFPGA101068
PADUT0SRAM019
PAFPGA101085
PA
CON
0FL
ASH
0H0
29
PACON0SRAM0H07
PA
FP
GA
20
10
15
PACO
N0FL
ASH0
H031
PACON0SRAM0H08
PA
FP
GA
20
10
13
PACO
N0FL
ASH0
H033
PACON0SRAM0H09
PA
FP
GA
201
011
PA
CON
0FL
ASH
0H0
35
PACON0SRAM0H010
PA
FP
GA
20
10
9
PA
CON
0FL
ASH
0H0
38
PACON0SRAM0H013
PA
FP
GA
20
10
7
PA
CON
0FL
ASH
0H0
40
PACON0SRAM0H014
PA
FP
GA
20
10
5
PACO
N0FL
ASH0
H042
PACON0SRAM0H015
PAFPGA2010206
PACO
N0FL
ASH0
H044
PACON0SRAM0H016
PAFPGA2010204
PA
CON
0FL
ASH
0H0
30
PACON0SRAM0H029
PA
FP
GA
201
014
PA
CON
0FL
ASH
0H0
32
PACON0SRAM0H030
PA
FP
GA
20
10
12
PA
CON
0FL
ASH
0H0
34
PACON0SRAM0H031
PA
FP
GA
20
10
10
PACO
N0FL
ASH0
H036
PACON0SRAM0H032
PA
FP
GA
20
10
8
PACO
N0FL
ASH0
H039
PACON0SRAM0H035
PA
FP
GA
20
10
6
PA
CON
0FL
ASH
0H0
41
PACON0SRAM0H036
PA
FP
GA
20
10
4
PA
CON
0FL
ASH
0H0
43
PACON0SRAM0H037
PAFPGA2010205
PA
CON
0FL
ASH
0H0
45
PACON0SRAM0H038
PAFPGA2010203
PACON0FLASH0L029
PA
CO
N0
SR
AM
0L
07
PAFPGA2010164
PACON0FLASH0L031
PA
CO
N0
SR
AM
0L
08
PAFPGA2010161
PACON0FLASH0L033
PA
CO
N0
SR
AM
0L
09
PAFPGA2010159
PACON0FLASH0L035
PAC
ON0S
RAM0
L010
PAF
PGA
201
015
2
PACON0FLASH0L038
PA
CO
N0S
RAM
0L0
13
PA
FP
GA
20
10
15
0
PACON0FLASH0L040
PAC
ON0S
RAM0
L014
PA
FP
GA
20
10
14
8
PACON0FLASH0L042
PAC
ON0S
RAM0
L015
PAF
PGA
201
014
6
PACON0FLASH0L044
PA
CO
N0S
RAM
0L0
16
PA
FP
GA
20
10
14
4
PACON0FLASH0L030
PA
CO
N0S
RAM
0L0
29
PAFPGA2010163
PACON0FLASH0L032
PAC
ON0S
RAM0
L030
PAFPGA2010160
PACON0FLASH0L034
PAC
ON0S
RAM0
L031
PA
FP
GA
20
10
15
3
PACON0FLASH0L036
PA
CO
N0S
RAM
0L0
32
PA
FP
GA
20
10
15
1
PACON0FLASH0L039
PAC
ON0S
RAM0
L035
PAF
PGA
201
014
9
PACON0FLASH0L041
PA
CO
N0S
RAM
0L0
36
PA
FP
GA
20
10
14
7
PACON0FLASH0L043
PA
CO
N0S
RAM
0L0
37
PA
FP
GA
20
10
14
5
PACON0FLASH0L045
PA
CO
N0S
RAM
0L0
38
PAF
PGA
201
014
3
PADUT0SRAM039
PAFPGA101067
PADUT0SRAM015
PAFPGA101080PADUT0FLA
SH01
PAJP80
102
PAR801
02
PAD
UT0
FLA
SH0
7
PAJP80
105
PAD
UT0F
LASH
03
PAJP80
104
PA
FP
GA
20
10
13
9
PAP30503
PAP30603
PATP30
601
PAD
UT0
FLA
SH0
6
PAJP80
106
PAD
UT0
FLA
SH0
5
PAJP80
107
PAD
UT0F
LASH
02
PAJP80
103
PA
FP
GA
20
10
13
6
PAR601
02
PA
U6
01
03
0
PAF
PGA
201
013
5
PA
U6
01
03
1
PA
FP
GA
20
10
12
8
PAR602
02
PA
FP
GA
20
10
12
5
PAR603
02
PAF
PGA
201
011
8
PAR604
02
PAF
PGA
201
011
6
PA
U6
01
03
PA
FP
GA
20
10
11
5
P
A
U6
01
04
PA
FP
GA
20
10
11
4
PA
U6
01
05
PAF
PGA
201
011
3
P
A
U6
01
06
PA
FP
GA
20
10
11
7
P
A
U6
01
02
PAF
PGA
201
013
2
PAR605
02
PAF
PGA
201
012
4
PAR606
02
PAF
PGA
201
012
1
PAR607
02
PA
FP
GA
20
10
12
0
PAR608
02
PA
FP
GA
20
10
11
9
PAR609
02
PAF
PGA
201
012
7
PAR601
002
PAF
PGA
201
012
9
PAR601
102
PAR601
202
PAF
PGA
201
013
8
PAR601
302
PA
FP
GA
20
10
11
2
PAR601
401
P
A
U6
01
07
PA
FP
GA
20
10
13
7
PAR602
002
PA
U6
01
02
9
PA
FP
GA
20
10
13
4
PA
U6
01
03
4
PAFPGA1010101
PAJP10
101
PAR102
02
PAFPGA1010102
PAJP10
109
PA
FP
GA
10
10
10
8 PAJP10
103
PAFPGA1010103
PAJP10
105
PA
FP
GA
10
10
10
9
PAJP10
108
PAR103
02
PAC1027
02
PA
FP
GA1
010
110
PAJP10
106
PAR101
02
PAC102
502
PAC102
602
PA
FP
GA
10
10
10
6
PAJP10
107
PAR104
01
PAFPGA2010101
PAJP20
101
PAR202
02
PAFPGA2010102
PAJP20
109
PA
FP
GA
20
10
10
8
PAJP20
103
PAFPGA2010103
PAJP20
105
PA
FP
GA
20
10
10
9
PAJP20
108
PAR20
302
PAC202
702
PAF
PGA
201
011
0 PAJP20
106
PAR201
02
PAC202
502
PAC202
602
PA
FP
GA
20
10
10
6
PAJP20
107
PAR20
401
PA
CON
0FL
ASH
0H0
26
PACON0FLASH0L026
PAFPGA2010202
PAR902
01
PAFPGA1010198
PAJP80
1010 PAFPGA1010194PAJP8010
13
PACO
N0FL
ASH0
H028
PACON0FLASH0L028
PAFPGA2010201
PAC801
02
PAC802
02
PAD
UT0
FLA
SH0
8
PAJP80
101
PAR80
101
PA
CON
0FL
ASH
0H0
12
PACON0FLASH0L012
PAFPGA2010184
PAR901
02
PA
CON
0FL
ASH
0H0
11
PACON0FLASH0L011
PAFPGA2010188
PAFPGA1010196PAJ
P80101
2
PAC101
01
PAC102
01
PAC103
01
PAC104
01
PAC105
01
PAC106
01
PAC107
01
PAC108
01
PAC109
01
PAC101
001
PAC101
101
PAC101
201
PAC101
301
PAC101
401
PAC101
501
PAC101
601
PAC101
701
PAC101
801
PAC101
901
PAC102
001
PAC102
101
PAC102
201
PAC102
301
PAC102
401
PAC102
501
PAC102
601
PAC1027
01
PAC102
801
PAC102
901
PAC103
001
PAC201
01
PAC202
01
PAC203
01
PAC204
01
PAC205
01
PAC206
01
PAC207
01
PAC208
01
PAC209
01
PAC201
001
PAC201
101
PAC201
201
PAC201
301
PAC201
401
PAC201
501
PAC201
601
PAC201
701
PAC201
801
PAC201
901
PAC202
001
PAC202
101
PAC202
201
PAC202
301
PAC202
401
PAC202
501
PAC202
601
PAC202
701
PAC202
801
PAC202
901
PAC203
001
PAC301
01PAC30201
PAC303
01
PAC
304
01
PAC305
01
PAC30601
PAC307
01PAC30801
PAC309
01
PAC
3010
01
PAC3011
01PAC301201
PAC501
01
PAC502
01
PAC
601
01
PAC602
01
PAC603
01
PAC604
01
PAC605
01
PAC
606
01
PAC607
01
PAC608
01
PAC609
01
PAC601
001
PAC601
101
PAC601
201
PAC601
301
PAC601
401
PAC80
101
PAC80
201
PAC803
01
PAC804
01
PAC805
01
PAC806
01
PAC807
01
PAC808
01
PAC809
01
PAC901
01
PAC902
01
PAC903
01
PAC904
01
PAC905
01
PAC906
01
PA
CON
0FL
ASH
0H0
27
PA
CON
0FL
ASH
0H0
46
PACON0FLASH0L027
PACON0FLASH0L046
PACON0SRAM0H012
PACON0SRAM0H028
PACON0SRAM0H034
PA
CO
N0S
RAM
0L0
12
PA
CO
N0S
RAM
0L0
28
PA
CO
N0S
RAM
0L0
34
PAD
UT0F
LASH
04
PADUT0SRAM06
PADUT0SRAM012
PADUT0SRAM028
PADUT0SRAM041
PADUT0SRAM046
PADUT0SRAM052
PADUT0SRAM054
PA
FP
GA
10
10
1
PA
FP
GA
10
10
2
PAF
PGA
101
017
PAF
PGA
101
025
PA
FP
GA
10
10
29
PA
FP
GA
10
10
41
PA
FP
GA
10
10
51
PA
FP
GA
10
10
52
PAFPGA101054
PAFPGA101065
PAFPGA101081
PAFPGA101097P
AFPGA1010100
PA
FP
GA
10
10
10
5
PA
FP
GA1
010
107
PA
FP
GA
10
10
12
2
PA
FP
GA
10
10
13
0
PA
FP
GA
10
10
13
3
PA
FP
GA
10
10
14
1
PA
FP
GA
10
10
15
5
PA
FP
GA
10
10
15
6
PAFPGA1010158
PAFPGA1010162
PAFPGA1010178
PAFPGA1010195
PAFPGA1010207
PA
FP
GA
20
10
1
PA
FP
GA
20
10
2
PA
FP
GA
20
10
17
PA
FP
GA
201
025
PA
FP
GA
20
10
29
PA
FP
GA
201
041
PA
FP
GA
20
10
51
PA
FP
GA
20
10
52
PAFPGA201054
PAFPGA201065
PAFPGA201081
PAFPGA201097P
AFPGA2010100
PA
FP
GA
20
10
10
5
PAF
PGA
201
010
7
PA
FP
GA
20
10
12
2
PA
FP
GA
20
10
13
0
PA
FP
GA
20
10
13
3
PAF
PGA
201
014
1
PA
FP
GA
20
10
15
5
PA
FP
GA
20
10
15
6
PAFPGA2010158
PAFPGA2010162
PAFPGA2010178
PAFPGA2010195
PAFPGA2010207
PAJP10
102
PAJP101
010
PAJP10
209
PAJP1
0301
PAJP10
3016
PAJP20
102
PAJP201
010
PAJP20
209
PAJP30102
PAJP50
102
PAJP50
105
PAJP502
02
PAJP502
05
PAJP80
108
PAO
P40
101
1
PAP30101
PAP30201
PA
P3
03
01
PAP30401
PAP30502
PAP30602
PAP
B10
101
PAR102
01
PAR103
01
PAR202
01
PAR20
301
PAR305
01
PAR306
01
PAR403
01
PAR405
01
PAR406
01
PAR401
101
PAR502
02
PAR504
02
PAR601
201
PAR601
402
PAR601
901
PAR602
001
PAR90
101
PA
U4
01
01
1
PAU
402
02
PAU
403
02
PAU
404
02
PA
U4
05
04
PA
U4
05
05
PA
U4
05
06
PA
U4
05
07
PA
U4
07
04
PA
U4
07
05
PA
U4
07
07
PAU601015
PAU601019
PA
U6
01
03
5
PA
U6
01
03
6
PAU601047
PAX10102
PAX
2010
2
PAXVR50102
PAXVR50202
PAJP701
09
PAPB70101
PAQ70102
PAQ70202
PAQ70302
PAQ70402
PAQ70502
PAQ70602
PAQ70702
PAQ70802
PAJP70
209
PAPB70201
PAQ70902
PAQ701002
PAQ701102
PAQ701202
PAQ701302
PAQ701402
PAQ701502
PAQ701602
PA
FP
GA1
010
118
PAJP10
205
PA
FP
GA
10
10
11
7
PAJP10
206
PA
FP
GA
10
10
12
0
PAJP10
207
PA
FP
GA
10
10
11
9
PAJP10
208
PAFPGA201092
PAJP20
205
PAFPGA201098
PAJP20
206
PAFPGA201091
PAJP20
207
PAFPGA201099
PAJP20
208
PAJP701
01
PAJP70
301
PAJP70
302
PAQ70101PAJP701
02
PAQ70201
PAJP701
03 PAQ70301PAJP701
04
PAQ70401
PAJP701
05 PAQ70501PAJP701
06
PAQ70601
PAJP701
07 PAQ70701PAJP701
08
PAQ70801
PAJP70
201
PAJP7
0401
PAJP7
0402
PAQ709
01
PAJP70
202
PAQ701001
PAJP70
203 PAQ701101
PAJP70
204
PAQ701201
PAJP70
205 PAQ701301
PAJP70
206
PAQ701401
PAJP70
207 PAQ701501
PAJP70
208
PAQ701601
PAC605
02
PAC
606
02
PAC607
02
PAC608
02
PAU601018
PAU601023PAU601037
PAC601
302
PAJP60
107
PAJP60
108
PAJP60
109
PAD701
02
PAR701
02
PAD702
02
PAR702
02
PAD703
02
PAR703
02
PAD704
02
PAR704
02
PAD705
02
PAR705
02
PAD706
02
PAR706
02
PAD707
02
PAR707
02
PAD708
02
PAR708
02
PAD709
02
PAR709
02
PAD701
002
PAR701
002
PAD701
102
PAR701
102
PAD701
202
PAR701
202
PAD701
302
PAR701
302
PAD701
402
PAR701
402
PAD701
502
PAR701
502
PAD701
602
PAR701
602
PA
FP
GA
10
10
4
PAJP1
0302
PA
FP
GA
10
10
5
PAJP1
0303
PA
FP
GA
101
06
PAJP1
0304
PA
FP
GA
10
10
7
PAJP1
0305
PA
FP
GA
101
08
PAJP1
0306
PA
FP
GA
10
10
9
PAJP1
0307
PA
FP
GA
10
10
10
PAJP1
0308
PAF
PGA
101
011
PAJP1
0309
PA
FP
GA
10
10
12
PAJP10
3010
PA
FP
GA
10
10
13
PAJP10
3011
PAF
PGA
101
014
PAJP10
3012
PA
FP
GA
10
10
15
PAJP10
3013
PAF
PGA
101
019
PAJP10
3014
PA
FP
GA
10
10
20
PAJP10
3015
PA
OP
40
10
3
PAR405
02
PAU
403
01
PA
OP
40
10
5
PAR403
02
PA
U4
02
01
PAO
P40
101
0
PAR406
02
PA
U40
401
PAP30203
PAP30505
PAP30403PAP30605
PAP30504
PAR305
02
PAP30604PAR306
02
PAQ70103
PAR701
01PAQ70203
PAR702
01
PAQ70303 PAR703
01
PAQ70403PAR704
01
PAQ70503 PAR705
01
PAQ70603PAR706
01
PAQ70703 PAR707
01
PAQ70803PAR708
01
PAQ70903
PAR709
01PAQ701003
PAR701
001
PAQ701103 PAR701
101PAQ701203PAR701
201
PAQ701303 PAR701
301
PAQ701403PAR701
401
PAQ701503 PAR701
501
PAQ701603PAR701
601
PAR502
01
PAXVR50108
PAR504
01
PAXVR50208
PAR602
01
PAU601040
PAR603
01
PAU601042
PAR604
01
P
A
U6
01
01
PAR605
01
PAU601038
PAR606
01
PAU601043
PAR607
01
PAU601044
PAR608
01
PAU601045
PAR609
01
PAU601046
PAR601
001
PAU601041
PAR601
101
PAU601039
PAR601
301
PA
U6
01
02
5
PAR601
902
PAU601024
PAR7017
02
PAR7018
01
PAR701
902
PAR702
001
PAJP70
303PAPB70102 PAR701701 PAJP70403PAPB70202 PAR701901
PAD701
01
PAD702
01
PAD703
01
PAD704
01
PAD705
01
PAD706
01
PAD707
01
PAD708
01
PAJP7010
10
PAR701
802
PAD709
01
PAD701
001
PAD701
101
PAD701
201
PAD701
301
PAD701
401
PAD701
501
PAD701
601
PAJP702
010
PAR702
002
PADUT0SRAM018
PAFPGA101084
PAJP60
103
PAR601
702
PAU601014
PAJP60
106
PAR601
802
PAU601013
PADUT0SRAM023
PAFPGA101091
PADUT0SRAM024
PAFPGA101092
PADUT0SRAM025
PAFPGA101093
PADUT0SRAM026
PAFPGA101094
PADUT0SRAM029
PAFPGA101079
PADUT0SRAM030
PAFPGA101078
PADUT0SRAM031
PAFPGA101077
PADUT0SRAM032
PAFPGA101076
PADUT0SRAM033
PAFPGA101075
PADUT0SRAM034
PAFPGA101074
PADUT0SRAM022
PAFPGA101090
PADUT0SRAM035
PAFPGA101073
PADUT0SRAM036
PAFPGA101070
PA
FP
GA
20
10
20
PAR206
02
PAR208
01
PATP206
01
PA
U4
01
09PA
U4
05
02
PA
U4
07
02
PADUT0SRAM02
PAF
PGA
101
044
PADUT0SRAM04
PA
FP
GA
10
10
45
PADUT0SRAM05
PA
FP
GA
10
10
46
PADUT0SRAM07
PAF
PGA
101
047
PADUT0SRAM08
PA
FP
GA
10
10
48
PADUT0SRAM010
PA
FP
GA
10
10
49
PADUT0SRAM011
PAFPGA101055
PADUT0SRAM013
PAFPGA101056
PADUT0SRAM042PAFPGA101066 PADUT0SRAM044PAFPGA101064 PADUT0SRAM045PAFPGA101063
PADUT0SRAM047PAFPGA101061 PADUT0SRAM048PAFPGA101
060
PADUT0SRAM050
PAFPGA101059
PADUT0SRAM051
PAFPGA101058
PADUT0SRAM053
PAFPGA101057
PA
FP
GA
201
019
PAR205
02
PAR207
01
PATP20
501
PA
U4
01
01
0
PA
U4
05
01
PA
U4
07
01
PAFPGA1010193PAJP8010
14
PAFPGA1010197P
AJP801
011 PAFPGA1010192
PAJP80
1015
PACON0SRAM0H06
PAC
ON0
SRA
M0L
06
PAFPGA2010181
PACON0SRAM0H041
PA
CO
N0S
RAM
0L0
41
PAFPGA2010199
PACON0SRAM0H039
PAFPGA2010197
PACON0SRAM0H040
PAFPGA2010198
PAC
ON0S
RAM0
L039
PAFPGA2010166
PAC
ON0S
RAM0
L040
PAFPGA2010165
PACON0SRAM0H017
PA
CO
N0S
RAM
0L0
17
PAFPGA2010174
PA
OP
401
08
PA
OP
401
09
PATP40
301
PA
U4
01
05
PAJP60
101
PAR601
502
PAU601017
PAJP60
102
PAR601
602
PAU601016
PAFPGA201094
PAJP20
201
PAFPGA201095
PAJP20
202
PAFPGA201093
PAJP20
203
PAFPGA201096
PAJP20
204
PA
FP
GA
10
10
11
4
PAJP10
201
PA
FP
GA1
010
113
PAJP10
202
PA
FP
GA
10
10
11
6
PAJP10
203
PA
FP
GA1
010
115
PAJP10
204
PAJP30101
PAR4070
1
PATP30
101
PA
U40
403
PAR401
001
PAR401
102
PA
U4
01
01
6
PAC301
02PAC30202
PAC303
02
PAC
304
02
PAP30103
PAP
303
03
PAP30501
PAP30601
PAR4070
2
PAR401
002
PA
U40
404
PADUT0SRAM016
PAFPGA101082
Figure B.11 – Top layer of the PCB, excluding ground plane
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 113
P A C 1 0 1 0 1
P A C 1 0 1 0 2
C O C 1 0 1
P A C 1 0 2 0 1
P A C 1 0 2 0 2
C O C 1 0 2
P A C 1 0 3 0 1
P A C 1 0 3 0 2
C O C 1 0 3
P A C 1 0 4 0 1
P A C 1 0 4 0 2
C O C 1 0 4
P A C 1 0 5 0 1
P A C 1 0 5 0 2
C O C 1 0 5
P A C 1 0 6 0 1
P A C 1 0 6 0 2
C O C 1 0 6
P A C 1 0 7 0 1
P A C 1 0 7 0 2
C O C 1 0 7
P A C 1 0 8 0 1
P A C 1 0 8 0 2
C O C 1 0 8
P A C 1 0 9 0 1
P A C 1 0 9 0 2
C O C 1 0 9
P A C 1 0 1 0 0 1
P A C 1 0 1 0 0 2
C O C 1 0 1 0
P A C 1 0 1 1 0 1
P A C 1 0 1 1 0 2
C O C 1 0 1 1
P A C 1 0 1 2 0 1
P A C 1 0 1 2 0 2
C O C 1 0 1 2
P A C 1 0 1 3 0 1
P A C 1 0 1 3 0 2
C O C 1 0 1 3
P A C 1 0 1 4 0 1
P A C 1 0 1 4 0 2
C O C 1 0 1 4
P A C 1 0 1 5 0 1
P A C 1 0 1 5 0 2
C O C 1 0 1 5
P A C 1 0 1 6 0 1
P A C 1 0 1 6 0 2
C O C 1 0 1 6
P A C 1 0 1 7 0 1
P A C 1 0 1 7 0 2
C O C 1 0 1 7
P A C 1 0 1 8 0 1
P A C 1 0 1 8 0 2
C O C 1 0 1 8
P A C 1 0 1 9 0 1
P A C 1 0 1 9 0 2
C O C 1 0 1 9
P A C 1 0 2 0 0 1
P A C 1 0 2 0 0 2
C O C 1 0 2 0
P A C 1 0 2 1 0 1
P A C 1 0 2 1 0 2
C O C 1 0 2 1
P A C 1 0 2 2 0 1
P A C 1 0 2 2 0 2
C O C 1 0 2 2
P A C 1 0 2 3 0 1
P A C 1 0 2 3 0 2
C O C 1 0 2 3
P A C 1 0 2 4 0 1
P A C 1 0 2 4 0 2
C O C 1 0 2 4
P A C 1 0 2 5 0 1
P A C 1 0 2 5 0 2
C O C 1 0 2 5
P A C 1 0 2 6 0 1
P A C 1 0 2 6 0 2 C O C 1 0 2 6
P A C 1 0 2 7 0 1
P A C 1 0 2 7 0 2
C O C 1 0 2 7
P A C 1 0 2 8 0 1
P A C 1 0 2 8 0 2
C O C 1 0 2 8
P A C 1 0 2 9 0 1
P A C 1 0 2 9 0 2C O C 1 0 2 9
P A C 1 0 3 0 0 1
P A C 1 0 3 0 0 2
C O C 1 0 3 0
P A C 2 0 1 0 2
P A C 2 0 1 0 1
C O C 2 0 1
P A C 2 0 2 0 2
P A C 2 0 2 0 1
C O C 2 0 2
P A C 2 0 3 0 2
P A C 2 0 3 0 1
C O C 2 0 3
P A C 2 0 4 0 2
P A C 2 0 4 0 1
C O C 2 0 4
P A C 2 0 5 0 2
P A C 2 0 5 0 1
C O C 2 0 5
P A C 2 0 6 0 2
P A C 2 0 6 0 1
C O C 2 0 6
P A C 2 0 7 0 2
P A C 2 0 7 0 1
C O C 2 0 7
P A C 2 0 8 0 2
P A C 2 0 8 0 1 C O C 2 0 8
P A C 2 0 9 0 2
P A C 2 0 9 0 1
C O C 2 0 9
P A C 2 0 1 0 0 2
P A C 2 0 1 0 0 1
C O C 2 0 1 0
P A C 2 0 1 1 0 2
P A C 2 0 1 1 0 1 C O C 2 0 1 1
P A C 2 0 1 2 0 2
P A C 2 0 1 2 0 1
C O C 2 0 1 2
P A C 2 0 1 3 0 2
P A C 2 0 1 3 0 1
C O C 2 0 1 3
P A C 2 0 1 4 0 2
P A C 2 0 1 4 0 1
C O C 2 0 1 4
P A C 2 0 1 5 0 2
P A C 2 0 1 5 0 1
C O C 2 0 1 5
P A C 2 0 1 6 0 2
P A C 2 0 1 6 0 1
C O C 2 0 1 6
P A C 2 0 1 7 0 2
P A C 2 0 1 7 0 1
C O C 2 0 1 7
P A C 2 0 1 8 0 2
P A C 2 0 1 8 0 1
C O C 2 0 1 8
P A C 2 0 1 9 0 2
P A C 2 0 1 9 0 1
C O C 2 0 1 9
P A C 2 0 2 0 0 2
P A C 2 0 2 0 0 1
C O C 2 0 2 0
P A C 2 0 2 1 0 2
P A C 2 0 2 1 0 1
C O C 2 0 2 1
P A C 2 0 2 2 0 2
P A C 2 0 2 2 0 1 C O C 2 0 2 2
P A C 2 0 2 3 0 2
P A C 2 0 2 3 0 1
C O C 2 0 2 3
P A C 2 0 2 4 0 2
P A C 2 0 2 4 0 1
C O C 2 0 2 4
P A C 2 0 2 5 0 2
P A C 2 0 2 5 0 1C O C 2 0 2 5
P A C 2 0 2 6 0 2
P A C 2 0 2 6 0 1C O C 2 0 2 6
P A C 2 0 2 7 0 2
P A C 2 0 2 7 0 1
C O C 2 0 2 7
P A C 2 0 2 8 0 1 P A C 2 0 2 8 0 2
C O C 2 0 2 8
P A C 2 0 2 9 0 1
P A C 2 0 2 9 0 2
C O C 2 0 2 9
P A C 2 0 3 0 0 1
P A C 2 0 3 0 0 2
C O C 2 0 3 0
P A C 3 0 1 0 1
P A C 3 0 1 0 2
C O C 3 0 1P A C 3 0 2 0 2
P A C 3 0 2 0 1
C O C 3 0 2
P A C 3 0 3 0 1
P A C 3 0 3 0 2
C O C 3 0 3 P A C 3 0 4 0 2
P A C 3 0 4 0 1
C O C 3 0 4
P A C 3 0 5 0 1
P A C 3 0 5 0 2
C O C 3 0 5
P A C 3 0 6 0 2
P A C 3 0 6 0 1C O C 3 0 6
P A C 3 0 7 0 1
P A C 3 0 7 0 2
C O C 3 0 7
P A C 3 0 8 0 2
P A C 3 0 8 0 1
C O C 3 0 8
P A C 3 0 9 0 1
P A C 3 0 9 0 2 C O C 3 0 9
P A C 3 0 1 0 0 2
P A C 3 0 1 0 0 1
C O C 3 0 1 0
P A C 3 0 1 1 0 1
P A C 3 0 1 1 0 2
C O C 3 0 1 1
P A C 3 0 1 2 0 2
P A C 3 0 1 2 0 1
C O C 3 0 1 2
P A C 5 0 1 0 2
P A C 5 0 1 0 1
C O C 5 0 1
P A C 5 0 2 0 2
P A C 5 0 2 0 1
C O C 5 0 2
P A C 6 0 1 0 2
P A C 6 0 1 0 1
C O C 6 0 1
P A C 6 0 2 0 1
P A C 6 0 2 0 2
C O C 6 0 2
P A C 6 0 3 0 1
P A C 6 0 3 0 2
C O C 6 0 3
P A C 6 0 4 0 1
P A C 6 0 4 0 2
C O C 6 0 4
P A C 6 0 5 0 1
P A C 6 0 5 0 2
C O C 6 0 5
P A C 6 0 6 0 2
P A C 6 0 6 0 1
C O C 6 0 6
P A C 6 0 7 0 1
P A C 6 0 7 0 2
C O C 6 0 7
P A C 6 0 8 0 1
P A C 6 0 8 0 2
C O C 6 0 8
P A C 6 0 9 0 1
P A C 6 0 9 0 2
C O C 6 0 9
P A C 6 0 1 0 0 1
P A C 6 0 1 0 0 2
C O C 6 0 1 0
P A C 6 0 1 1 0 1
P A C 6 0 1 1 0 2
C O C 6 0 1 1
P A C 6 0 1 2 0 1
P A C 6 0 1 2 0 2
C O C 6 0 1 2
P A C 6 0 1 3 0 1
P A C 6 0 1 3 0 2
C O C 6 0 1 3
P A C 6 0 1 4 0 1
P A C 6 0 1 4 0 2
C O C 6 0 1 4
P A C 8 0 1 0 1
P A C 8 0 1 0 2
C O C 8 0 1
P A C 8 0 2 0 1
P A C 8 0 2 0 2
C O C 8 0 2
P A C 8 0 3 0 2
P A C 8 0 3 0 1
C O C 8 0 3
P A C 8 0 4 0 2
P A C 8 0 4 0 1
C O C 8 0 4
P A C 8 0 5 0 2
P A C 8 0 5 0 1C O C 8 0 5
P A C 8 0 6 0 2
P A C 8 0 6 0 1
C O C 8 0 6
P A C 8 0 7 0 2
P A C 8 0 7 0 1C O C 8 0 7
P A C 8 0 8 0 2
P A C 8 0 8 0 1C O C 8 0 8
P A C 8 0 9 0 2
P A C 8 0 9 0 1
C O C 8 0 9
P A C 9 0 1 0 1
P A C 9 0 1 0 2
C O C 9 0 1
P A C 9 0 2 0 1
P A C 9 0 2 0 2
C O C 9 0 2
P A C 9 0 3 0 1
P A C 9 0 3 0 2C O C 9 0 3
P A C 9 0 4 0 1
P A C 9 0 4 0 2
C O C 9 0 4
P A C 9 0 5 0 1
P A C 9 0 5 0 2
C O C 9 0 5
P A C 9 0 6 0 1
P A C 9 0 6 0 2
C O C 9 0 6
P A C O N 0 F L A S H 0 H 0 1
P A C O N 0 F L A S H 0 H 0 2
P A C O N 0 F L A S H 0 H 0 3
P A C O N 0 F L A S H 0 H 0 4
P A C O N 0 F L A S H 0 H 0 5
P A C O N 0 F L A S H 0 H 0 6
P A C O N 0 F L A S H 0 H 0 7
P A C O N 0 F L A S H 0 H 0 8
P A C O N 0 F L A S H 0 H 0 9
P A C O N 0 F L A S H 0 H 0 1 0
P A C O N 0 F L A S H 0 H 0 1 1
P A C O N 0 F L A S H 0 H 0 1 2
P A C O N 0 F L A S H 0 H 0 1 3
P A C O N 0 F L A S H 0 H 0 1 4
P A C O N 0 F L A S H 0 H 0 1 5
P A C O N 0 F L A S H 0 H 0 1 6
P A C O N 0 F L A S H 0 H 0 1 7
P A C O N 0 F L A S H 0 H 0 1 8
P A C O N 0 F L A S H 0 H 0 1 9
P A C O N 0 F L A S H 0 H 0 2 0
P A C O N 0 F L A S H 0 H 0 2 1
P A C O N 0 F L A S H 0 H 0 2 2
P A C O N 0 F L A S H 0 H 0 2 3
P A C O N 0 F L A S H 0 H 0 2 4
P A C O N 0 F L A S H 0 H 0 4 8
P A C O N 0 F L A S H 0 H 0 4 7
P A C O N 0 F L A S H 0 H 0 4 6
P A C O N 0 F L A S H 0 H 0 4 5
P A C O N 0 F L A S H 0 H 0 4 4
P A C O N 0 F L A S H 0 H 0 4 3
P A C O N 0 F L A S H 0 H 0 4 2
P A C O N 0 F L A S H 0 H 0 4 1
P A C O N 0 F L A S H 0 H 0 4 0
P A C O N 0 F L A S H 0 H 0 3 9
P A C O N 0 F L A S H 0 H 0 3 8
P A C O N 0 F L A S H 0 H 0 3 7
P A C O N 0 F L A S H 0 H 0 3 6
P A C O N 0 F L A S H 0 H 0 3 5
P A C O N 0 F L A S H 0 H 0 3 4
P A C O N 0 F L A S H 0 H 0 3 3
P A C O N 0 F L A S H 0 H 0 3 2
P A C O N 0 F L A S H 0 H 0 3 1
P A C O N 0 F L A S H 0 H 0 3 0
P A C O N 0 F L A S H 0 H 0 2 9
P A C O N 0 F L A S H 0 H 0 2 8
P A C O N 0 F L A S H 0 H 0 2 7
P A C O N 0 F L A S H 0 H 0 2 6
P A C O N 0 F L A S H 0 H 0 2 5
C O C O N 0 F L A S H 0 H
P A C O N 0 F L A S H 0 L 0 1 P A C O N 0 F L A S H 0 L 0 2
P A C O N 0 F L A S H 0 L 0 3 P A C O N 0 F L A S H 0 L 0 4
P A C O N 0 F L A S H 0 L 0 5 P A C O N 0 F L A S H 0 L 0 6
P A C O N 0 F L A S H 0 L 0 7 P A C O N 0 F L A S H 0 L 0 8
P A C O N 0 F L A S H 0 L 0 9 P A C O N 0 F L A S H 0 L 0 1 0
P A C O N 0 F L A S H 0 L 0 1 1 P A C O N 0 F L A S H 0 L 0 1 2
P A C O N 0 F L A S H 0 L 0 1 3 P A C O N 0 F L A S H 0 L 0 1 4
P A C O N 0 F L A S H 0 L 0 1 5 P A C O N 0 F L A S H 0 L 0 1 6
P A C O N 0 F L A S H 0 L 0 1 7 P A C O N 0 F L A S H 0 L 0 1 8
P A C O N 0 F L A S H 0 L 0 1 9 P A C O N 0 F L A S H 0 L 0 2 0
P A C O N 0 F L A S H 0 L 0 2 1 P A C O N 0 F L A S H 0 L 0 2 2
P A C O N 0 F L A S H 0 L 0 2 3 P A C O N 0 F L A S H 0 L 0 2 4
P A C O N 0 F L A S H 0 L 0 4 8 P A C O N 0 F L A S H 0 L 0 4 7
P A C O N 0 F L A S H 0 L 0 4 6 P A C O N 0 F L A S H 0 L 0 4 5
P A C O N 0 F L A S H 0 L 0 4 4 P A C O N 0 F L A S H 0 L 0 4 3
P A C O N 0 F L A S H 0 L 0 4 2 P A C O N 0 F L A S H 0 L 0 4 1
P A C O N 0 F L A S H 0 L 0 4 0 P A C O N 0 F L A S H 0 L 0 3 9
P A C O N 0 F L A S H 0 L 0 3 8 P A C O N 0 F L A S H 0 L 0 3 7
P A C O N 0 F L A S H 0 L 0 3 6 P A C O N 0 F L A S H 0 L 0 3 5
P A C O N 0 F L A S H 0 L 0 3 4 P A C O N 0 F L A S H 0 L 0 3 3
P A C O N 0 F L A S H 0 L 0 3 2 P A C O N 0 F L A S H 0 L 0 3 1
P A C O N 0 F L A S H 0 L 0 3 0 P A C O N 0 F L A S H 0 L 0 2 9
P A C O N 0 F L A S H 0 L 0 2 8 P A C O N 0 F L A S H 0 L 0 2 7
P A C O N 0 F L A S H 0 L 0 2 6 P A C O N 0 F L A S H 0 L 0 2 5C O C O N 0 F L A S H 0 L
P A C O N 0 S R A M 0 H 0 2 2 P A C O N 0 S R A M 0 H 0 2 1 P A C O N 0 S R A M 0 H 0 2 0 P A C O N 0 S R A M 0 H 0 1 9 P A C O N 0 S R A M 0 H 0 1 8 P A C O N 0 S R A M 0 H 0 1 7 P A C O N 0 S R A M 0 H 0 1 6 P A C O N 0 S R A M 0 H 0 1 5 P A C O N 0 S R A M 0 H 0 1 4 P A C O N 0 S R A M 0 H 0 1 3 P A C O N 0 S R A M 0 H 0 1 2 P A C O N 0 S R A M 0 H 0 1 1 P A C O N 0 S R A M 0 H 0 1 0 P A C O N 0 S R A M 0 H 0 9 P A C O N 0 S R A M 0 H 0 8 P A C O N 0 S R A M 0 H 0 7 P A C O N 0 S R A M 0 H 0 6 P A C O N 0 S R A M 0 H 0 5 P A C O N 0 S R A M 0 H 0 4 P A C O N 0 S R A M 0 H 0 3 P A C O N 0 S R A M 0 H 0 2 P A C O N 0 S R A M 0 H 0 1
P A C O N 0 S R A M 0 H 0 2 3 P A C O N 0 S R A M 0 H 0 2 4
P A C O N 0 S R A M 0 H 0 4 4
P A C O N 0 S R A M 0 H 0 4 3
P A C O N 0 S R A M 0 H 0 4 2
P A C O N 0 S R A M 0 H 0 4 1
P A C O N 0 S R A M 0 H 0 4 0
P A C O N 0 S R A M 0 H 0 3 9
P A C O N 0 S R A M 0 H 0 3 8
P A C O N 0 S R A M 0 H 0 3 7
P A C O N 0 S R A M 0 H 0 3 6
P A C O N 0 S R A M 0 H 0 3 5
P A C O N 0 S R A M 0 H 0 3 4
P A C O N 0 S R A M 0 H 0 3 3
P A C O N 0 S R A M 0 H 0 3 2
P A C O N 0 S R A M 0 H 0 3 1
P A C O N 0 S R A M 0 H 0 3 0
P A C O N 0 S R A M 0 H 0 2 9
P A C O N 0 S R A M 0 H 0 2 8
P A C O N 0 S R A M 0 H 0 2 7
P A C O N 0 S R A M 0 H 0 2 6
P A C O N 0 S R A M 0 H 0 2 5
C O C O N 0 S R A M 0 H
P A C O N 0 S R A M 0 L 0 2 2
P A C O N 0 S R A M 0 L 0 2 1
P A C O N 0 S R A M 0 L 0 2 0
P A C O N 0 S R A M 0 L 0 1 9
P A C O N 0 S R A M 0 L 0 1 8
P A C O N 0 S R A M 0 L 0 1 7
P A C O N 0 S R A M 0 L 0 1 6
P A C O N 0 S R A M 0 L 0 1 5
P A C O N 0 S R A M 0 L 0 1 4
P A C O N 0 S R A M 0 L 0 1 3
P A C O N 0 S R A M 0 L 0 1 2
P A C O N 0 S R A M 0 L 0 1 1
P A C O N 0 S R A M 0 L 0 1 0
P A C O N 0 S R A M 0 L 0 9
P A C O N 0 S R A M 0 L 0 8
P A C O N 0 S R A M 0 L 0 7
P A C O N 0 S R A M 0 L 0 6
P A C O N 0 S R A M 0 L 0 5
P A C O N 0 S R A M 0 L 0 4
P A C O N 0 S R A M 0 L 0 3
P A C O N 0 S R A M 0 L 0 2
P A C O N 0 S R A M 0 L 0 1
P A C O N 0 S R A M 0 L 0 2 3
P A C O N 0 S R A M 0 L 0 2 4
P A C O N 0 S R A M 0 L 0 4 4
P A C O N 0 S R A M 0 L 0 4 3
P A C O N 0 S R A M 0 L 0 4 2
P A C O N 0 S R A M 0 L 0 4 1
P A C O N 0 S R A M 0 L 0 4 0
P A C O N 0 S R A M 0 L 0 3 9
P A C O N 0 S R A M 0 L 0 3 8
P A C O N 0 S R A M 0 L 0 3 7
P A C O N 0 S R A M 0 L 0 3 6
P A C O N 0 S R A M 0 L 0 3 5
P A C O N 0 S R A M 0 L 0 3 4
P A C O N 0 S R A M 0 L 0 3 3
P A C O N 0 S R A M 0 L 0 3 2
P A C O N 0 S R A M 0 L 0 3 1
P A C O N 0 S R A M 0 L 0 3 0
P A C O N 0 S R A M 0 L 0 2 9
P A C O N 0 S R A M 0 L 0 2 8
P A C O N 0 S R A M 0 L 0 2 7
P A C O N 0 S R A M 0 L 0 2 6
P A C O N 0 S R A M 0 L 0 2 5
C O C O N 0 S R A M 0 L
P A D 7 0 1 0 2
P A D 7 0 1 0 1
C O D 7 0 1
P A D 7 0 2 0 2
P A D 7 0 2 0 1
C O D 7 0 2
P A D 7 0 3 0 2
P A D 7 0 3 0 1
C O D 7 0 3
P A D 7 0 4 0 2
P A D 7 0 4 0 1
C O D 7 0 4
P A D 7 0 5 0 2
P A D 7 0 5 0 1
C O D 7 0 5
P A D 7 0 6 0 2
P A D 7 0 6 0 1
C O D 7 0 6
P A D 7 0 7 0 2
P A D 7 0 7 0 1
C O D 7 0 7
P A D 7 0 8 0 2
P A D 7 0 8 0 1
C O D 7 0 8
P A D 7 0 9 0 2
P A D 7 0 9 0 1
C O D 7 0 9
P A D 7 0 1 0 0 2
P A D 7 0 1 0 0 1
C O D 7 0 1 0
P A D 7 0 1 1 0 2
P A D 7 0 1 1 0 1
C O D 7 0 1 1
P A D 7 0 1 2 0 2
P A D 7 0 1 2 0 1
C O D 7 0 1 2
P A D 7 0 1 3 0 2
P A D 7 0 1 3 0 1
C O D 7 0 1 3
P A D 7 0 1 4 0 2
P A D 7 0 1 4 0 1
C O D 7 0 1 4
P A D 7 0 1 5 0 2
P A D 7 0 1 5 0 1
C O D 7 0 1 5
P A D 7 0 1 6 0 2
P A D 7 0 1 6 0 1C O D 7 0 1 6
P A D U T 0 F L A S H 0 5
P A D U T 0 F L A S H 0 6
P A D U T 0 F L A S H 0 7
P A D U T 0 F L A S H 0 8
P A D U T 0 F L A S H 0 4
P A D U T 0 F L A S H 0 3
P A D U T 0 F L A S H 0 2
P A D U T 0 F L A S H 0 1
C O D U T 0 F L A S H
P A D U T 0 S R A M 0 3 5
P A D U T 0 S R A M 0 3 6
P A D U T 0 S R A M 0 3 7
P A D U T 0 S R A M 0 3 8
P A D U T 0 S R A M 0 3 9
P A D U T 0 S R A M 0 4 0
P A D U T 0 S R A M 0 4 1
P A D U T 0 S R A M 0 4 2
P A D U T 0 S R A M 0 4 3
P A D U T 0 S R A M 0 4 4
P A D U T 0 S R A M 0 4 5
P A D U T 0 S R A M 0 4 6
P A D U T 0 S R A M 0 4 7
P A D U T 0 S R A M 0 4 8
P A D U T 0 S R A M 0 4 9
P A D U T 0 S R A M 0 5 0
P A D U T 0 S R A M 0 5 1
P A D U T 0 S R A M 0 5 2
P A D U T 0 S R A M 0 5 3
P A D U T 0 S R A M 0 5 4
P A D U T 0 S R A M 0 3 4 P A D U T 0 S R A M 0 3 3
P A D U T 0 S R A M 0 1 P A D U T 0 S R A M 0 2 P A D U T 0 S R A M 0 3 P A D U T 0 S R A M 0 4 P A D U T 0 S R A M 0 5 P A D U T 0 S R A M 0 6 P A D U T 0 S R A M 0 7 P A D U T 0 S R A M 0 8 P A D U T 0 S R A M 0 9 P A D U T 0 S R A M 0 1 0 P A D U T 0 S R A M 0 1 1 P A D U T 0 S R A M 0 1 2 P A D U T 0 S R A M 0 1 3 P A D U T 0 S R A M 0 1 4 P A D U T 0 S R A M 0 1 5 P A D U T 0 S R A M 0 1 6 P A D U T 0 S R A M 0 1 7 P A D U T 0 S R A M 0 1 8 P A D U T 0 S R A M 0 1 9 P A D U T 0 S R A M 0 2 0 P A D U T 0 S R A M 0 2 1 P A D U T 0 S R A M 0 2 2
P A D U T 0 S R A M 0 2 7
P A D U T 0 S R A M 0 2 6
P A D U T 0 S R A M 0 2 5
P A D U T 0 S R A M 0 2 4
P A D U T 0 S R A M 0 2 3
P A D U T 0 S R A M 0 2 8
P A D U T 0 S R A M 0 2 9
P A D U T 0 S R A M 0 3 2 P A D U T 0 S R A M 0 3 1 P A D U T 0 S R A M 0 3 0
C O D U T 0 S R A M
P A F P G A 1 0 1 0 2 0 8 P A F P G A 1 0 1 0 2 0 7 P A F P G A 1 0 1 0 2 0 6 P A F P G A 1 0 1 0 2 0 5 P A F P G A 1 0 1 0 2 0 4 P A F P G A 1 0 1 0 2 0 3 P A F P G A 1 0 1 0 2 0 2 P A F P G A 1 0 1 0 2 0 1 P A F P G A 1 0 1 0 2 0 0 P A F P G A 1 0 1 0 1 9 9 P A F P G A 1 0 1 0 1 9 8 P A F P G A 1 0 1 0 1 9 7 P A F P G A 1 0 1 0 1 9 6 P A F P G A 1 0 1 0 1 9 5 P A F P G A 1 0 1 0 1 9 4 P A F P G A 1 0 1 0 1 9 3 P A F P G A 1 0 1 0 1 9 2 P A F P G A 1 0 1 0 1 9 1 P A F P G A 1 0 1 0 1 9 0 P A F P G A 1 0 1 0 1 8 9 P A F P G A 1 0 1 0 1 8 8 P A F P G A 1 0 1 0 1 8 7 P A F P G A 1 0 1 0 1 8 6 P A F P G A 1 0 1 0 1 8 5 P A F P G A 1 0 1 0 1 8 4 P A F P G A 1 0 1 0 1 8 3 P A F P G A 1 0 1 0 1 8 2 P A F P G A 1 0 1 0 1 8 1 P A F P G A 1 0 1 0 1 8 0 P A F P G A 1 0 1 0 1 7 9 P A F P G A 1 0 1 0 1 7 8 P A F P G A 1 0 1 0 1 7 7 P A F P G A 1 0 1 0 1 7 6 P A F P G A 1 0 1 0 1 7 5 P A F P G A 1 0 1 0 1 7 4 P A F P G A 1 0 1 0 1 7 3 P A F P G A 1 0 1 0 1 7 2 P A F P G A 1 0 1 0 1 7 1 P A F P G A 1 0 1 0 1 7 0 P A F P G A 1 0 1 0 1 6 9 P A F P G A 1 0 1 0 1 6 8 P A F P G A 1 0 1 0 1 6 7 P A F P G A 1 0 1 0 1 6 6 P A F P G A 1 0 1 0 1 6 5 P A F P G A 1 0 1 0 1 6 4 P A F P G A 1 0 1 0 1 6 3 P A F P G A 1 0 1 0 1 6 2 P A F P G A 1 0 1 0 1 6 1 P A F P G A 1 0 1 0 1 6 0 P A F P G A 1 0 1 0 1 5 9 P A F P G A 1 0 1 0 1 5 8 P A F P G A 1 0 1 0 1 5 7
P A F P G A 1 0 1 0 1 5 6
P A F P G A 1 0 1 0 1 5 5
P A F P G A 1 0 1 0 1 5 4
P A F P G A 1 0 1 0 1 5 3
P A F P G A 1 0 1 0 1 5 2
P A F P G A 1 0 1 0 1 5 1
P A F P G A 1 0 1 0 1 5 0
P A F P G A 1 0 1 0 1 4 9
P A F P G A 1 0 1 0 1 4 8
P A F P G A 1 0 1 0 1 4 7
P A F P G A 1 0 1 0 1 4 6
P A F P G A 1 0 1 0 1 4 5
P A F P G A 1 0 1 0 1 4 4
P A F P G A 1 0 1 0 1 4 3
P A F P G A 1 0 1 0 1 4 2
P A F P G A 1 0 1 0 1 4 1
P A F P G A 1 0 1 0 1 4 0
P A F P G A 1 0 1 0 1 3 9
P A F P G A 1 0 1 0 1 3 8
P A F P G A 1 0 1 0 1 3 7
P A F P G A 1 0 1 0 1 3 6
P A F P G A 1 0 1 0 1 3 5
P A F P G A 1 0 1 0 1 3 4
P A F P G A 1 0 1 0 1 3 3
P A F P G A 1 0 1 0 1 3 2
P A F P G A 1 0 1 0 1 3 1
P A F P G A 1 0 1 0 1 3 0
P A F P G A 1 0 1 0 1 2 9
P A F P G A 1 0 1 0 1 2 8
P A F P G A 1 0 1 0 1 2 7
P A F P G A 1 0 1 0 1 2 6
P A F P G A 1 0 1 0 1 2 5
P A F P G A 1 0 1 0 1 2 4
P A F P G A 1 0 1 0 1 2 3
P A F P G A 1 0 1 0 1 2 2
P A F P G A 1 0 1 0 1 2 1
P A F P G A 1 0 1 0 1 2 0
P A F P G A 1 0 1 0 1 1 9
P A F P G A 1 0 1 0 1 1 8
P A F P G A 1 0 1 0 1 1 7
P A F P G A 1 0 1 0 1 1 6
P A F P G A 1 0 1 0 1 1 5
P A F P G A 1 0 1 0 1 1 4
P A F P G A 1 0 1 0 1 1 3
P A F P G A 1 0 1 0 1 1 2
P A F P G A 1 0 1 0 1 1 1
P A F P G A 1 0 1 0 1 1 0
P A F P G A 1 0 1 0 1 0 9
P A F P G A 1 0 1 0 1 0 8
P A F P G A 1 0 1 0 1 0 7
P A F P G A 1 0 1 0 1 0 6
P A F P G A 1 0 1 0 1 0 5
P A F P G A 1 0 1 0 1 0 4 P A F P G A 1 0 1 0 1 0 3 P A F P G A 1 0 1 0 1 0 2
P A F P G A 1 0 1 0 1 0 1 P A F P G A 1 0 1 0 1 0 0 P A F P G A 1 0 1 0 9 9
P A F P G A 1 0 1 0 9 8 P A F P G A 1 0 1 0 9 7
P A F P G A 1 0 1 0 9 6 P A F P G A 1 0 1 0 9 5 P A F P G A 1 0 1 0 9 4
P A F P G A 1 0 1 0 9 3 P A F P G A 1 0 1 0 9 2 P A F P G A 1 0 1 0 9 1
P A F P G A 1 0 1 0 9 0 P A F P G A 1 0 1 0 8 9 P A F P G A 1 0 1 0 8 8
P A F P G A 1 0 1 0 8 7 P A F P G A 1 0 1 0 8 6 P A F P G A 1 0 1 0 8 5
P A F P G A 1 0 1 0 8 4 P A F P G A 1 0 1 0 8 3
P A F P G A 1 0 1 0 8 2 P A F P G A 1 0 1 0 8 1 P A F P G A 1 0 1 0 8 0
P A F P G A 1 0 1 0 7 9 P A F P G A 1 0 1 0 7 8 P A F P G A 1 0 1 0 7 7
P A F P G A 1 0 1 0 7 6 P A F P G A 1 0 1 0 7 5 P A F P G A 1 0 1 0 7 4
P A F P G A 1 0 1 0 7 3 P A F P G A 1 0 1 0 7 2
P A F P G A 1 0 1 0 7 1 P A F P G A 1 0 1 0 7 0 P A F P G A 1 0 1 0 6 9
P A F P G A 1 0 1 0 6 8 P A F P G A 1 0 1 0 6 7 P A F P G A 1 0 1 0 6 6
P A F P G A 1 0 1 0 6 5 P A F P G A 1 0 1 0 6 4 P A F P G A 1 0 1 0 6 3
P A F P G A 1 0 1 0 6 2 P A F P G A 1 0 1 0 6 1
P A F P G A 1 0 1 0 6 0 P A F P G A 1 0 1 0 5 9 P A F P G A 1 0 1 0 5 8
P A F P G A 1 0 1 0 5 7 P A F P G A 1 0 1 0 5 6 P A F P G A 1 0 1 0 5 5
P A F P G A 1 0 1 0 5 4 P A F P G A 1 0 1 0 5 3
P A F P G A 1 0 1 0 5 2
P A F P G A 1 0 1 0 5 1
P A F P G A 1 0 1 0 5 0
P A F P G A 1 0 1 0 4 9
P A F P G A 1 0 1 0 4 8
P A F P G A 1 0 1 0 4 7
P A F P G A 1 0 1 0 4 6
P A F P G A 1 0 1 0 4 5
P A F P G A 1 0 1 0 4 4
P A F P G A 1 0 1 0 4 3
P A F P G A 1 0 1 0 4 2
P A F P G A 1 0 1 0 4 1
P A F P G A 1 0 1 0 4 0
P A F P G A 1 0 1 0 3 9
P A F P G A 1 0 1 0 3 8
P A F P G A 1 0 1 0 3 7
P A F P G A 1 0 1 0 3 6
P A F P G A 1 0 1 0 3 5
P A F P G A 1 0 1 0 3 4
P A F P G A 1 0 1 0 3 3
P A F P G A 1 0 1 0 3 2
P A F P G A 1 0 1 0 3 1
P A F P G A 1 0 1 0 3 0
P A F P G A 1 0 1 0 2 9
P A F P G A 1 0 1 0 2 8
P A F P G A 1 0 1 0 2 7
P A F P G A 1 0 1 0 2 6
P A F P G A 1 0 1 0 2 5
P A F P G A 1 0 1 0 2 4
P A F P G A 1 0 1 0 2 3
P A F P G A 1 0 1 0 2 2
P A F P G A 1 0 1 0 2 1
P A F P G A 1 0 1 0 2 0
P A F P G A 1 0 1 0 1 9
P A F P G A 1 0 1 0 1 8
P A F P G A 1 0 1 0 1 7
P A F P G A 1 0 1 0 1 6
P A F P G A 1 0 1 0 1 5
P A F P G A 1 0 1 0 1 4
P A F P G A 1 0 1 0 1 3
P A F P G A 1 0 1 0 1 2
P A F P G A 1 0 1 0 1 1
P A F P G A 1 0 1 0 1 0
P A F P G A 1 0 1 0 9
P A F P G A 1 0 1 0 8
P A F P G A 1 0 1 0 7
P A F P G A 1 0 1 0 6
P A F P G A 1 0 1 0 5
P A F P G A 1 0 1 0 4
P A F P G A 1 0 1 0 3
P A F P G A 1 0 1 0 2
P A F P G A 1 0 1 0 1
C O F P G A 1 0 1
P A F P G A 2 0 1 0 2 0 8 P A F P G A 2 0 1 0 2 0 7 P A F P G A 2 0 1 0 2 0 6 P A F P G A 2 0 1 0 2 0 5 P A F P G A 2 0 1 0 2 0 4 P A F P G A 2 0 1 0 2 0 3 P A F P G A 2 0 1 0 2 0 2 P A F P G A 2 0 1 0 2 0 1 P A F P G A 2 0 1 0 2 0 0 P A F P G A 2 0 1 0 1 9 9 P A F P G A 2 0 1 0 1 9 8 P A F P G A 2 0 1 0 1 9 7 P A F P G A 2 0 1 0 1 9 6 P A F P G A 2 0 1 0 1 9 5 P A F P G A 2 0 1 0 1 9 4 P A F P G A 2 0 1 0 1 9 3 P A F P G A 2 0 1 0 1 9 2 P A F P G A 2 0 1 0 1 9 1 P A F P G A 2 0 1 0 1 9 0 P A F P G A 2 0 1 0 1 8 9 P A F P G A 2 0 1 0 1 8 8 P A F P G A 2 0 1 0 1 8 7 P A F P G A 2 0 1 0 1 8 6 P A F P G A 2 0 1 0 1 8 5 P A F P G A 2 0 1 0 1 8 4 P A F P G A 2 0 1 0 1 8 3 P A F P G A 2 0 1 0 1 8 2 P A F P G A 2 0 1 0 1 8 1 P A F P G A 2 0 1 0 1 8 0 P A F P G A 2 0 1 0 1 7 9 P A F P G A 2 0 1 0 1 7 8 P A F P G A 2 0 1 0 1 7 7 P A F P G A 2 0 1 0 1 7 6 P A F P G A 2 0 1 0 1 7 5 P A F P G A 2 0 1 0 1 7 4 P A F P G A 2 0 1 0 1 7 3 P A F P G A 2 0 1 0 1 7 2 P A F P G A 2 0 1 0 1 7 1 P A F P G A 2 0 1 0 1 7 0 P A F P G A 2 0 1 0 1 6 9 P A F P G A 2 0 1 0 1 6 8 P A F P G A 2 0 1 0 1 6 7 P A F P G A 2 0 1 0 1 6 6 P A F P G A 2 0 1 0 1 6 5 P A F P G A 2 0 1 0 1 6 4 P A F P G A 2 0 1 0 1 6 3 P A F P G A 2 0 1 0 1 6 2 P A F P G A 2 0 1 0 1 6 1 P A F P G A 2 0 1 0 1 6 0 P A F P G A 2 0 1 0 1 5 9 P A F P G A 2 0 1 0 1 5 8 P A F P G A 2 0 1 0 1 5 7
P A F P G A 2 0 1 0 1 5 6
P A F P G A 2 0 1 0 1 5 5
P A F P G A 2 0 1 0 1 5 4
P A F P G A 2 0 1 0 1 5 3
P A F P G A 2 0 1 0 1 5 2
P A F P G A 2 0 1 0 1 5 1
P A F P G A 2 0 1 0 1 5 0
P A F P G A 2 0 1 0 1 4 9
P A F P G A 2 0 1 0 1 4 8
P A F P G A 2 0 1 0 1 4 7
P A F P G A 2 0 1 0 1 4 6
P A F P G A 2 0 1 0 1 4 5
P A F P G A 2 0 1 0 1 4 4
P A F P G A 2 0 1 0 1 4 3
P A F P G A 2 0 1 0 1 4 2
P A F P G A 2 0 1 0 1 4 1
P A F P G A 2 0 1 0 1 4 0
P A F P G A 2 0 1 0 1 3 9
P A F P G A 2 0 1 0 1 3 8
P A F P G A 2 0 1 0 1 3 7
P A F P G A 2 0 1 0 1 3 6
P A F P G A 2 0 1 0 1 3 5
P A F P G A 2 0 1 0 1 3 4
P A F P G A 2 0 1 0 1 3 3
P A F P G A 2 0 1 0 1 3 2
P A F P G A 2 0 1 0 1 3 1
P A F P G A 2 0 1 0 1 3 0
P A F P G A 2 0 1 0 1 2 9
P A F P G A 2 0 1 0 1 2 8
P A F P G A 2 0 1 0 1 2 7
P A F P G A 2 0 1 0 1 2 6
P A F P G A 2 0 1 0 1 2 5
P A F P G A 2 0 1 0 1 2 4
P A F P G A 2 0 1 0 1 2 3
P A F P G A 2 0 1 0 1 2 2
P A F P G A 2 0 1 0 1 2 1
P A F P G A 2 0 1 0 1 2 0
P A F P G A 2 0 1 0 1 1 9
P A F P G A 2 0 1 0 1 1 8
P A F P G A 2 0 1 0 1 1 7
P A F P G A 2 0 1 0 1 1 6
P A F P G A 2 0 1 0 1 1 5
P A F P G A 2 0 1 0 1 1 4
P A F P G A 2 0 1 0 1 1 3
P A F P G A 2 0 1 0 1 1 2
P A F P G A 2 0 1 0 1 1 1
P A F P G A 2 0 1 0 1 1 0
P A F P G A 2 0 1 0 1 0 9
P A F P G A 2 0 1 0 1 0 8
P A F P G A 2 0 1 0 1 0 7
P A F P G A 2 0 1 0 1 0 6
P A F P G A 2 0 1 0 1 0 5
P A F P G A 2 0 1 0 1 0 4 P A F P G A 2 0 1 0 1 0 3 P A F P G A 2 0 1 0 1 0 2
P A F P G A 2 0 1 0 1 0 1 P A F P G A 2 0 1 0 1 0 0 P A F P G A 2 0 1 0 9 9
P A F P G A 2 0 1 0 9 8 P A F P G A 2 0 1 0 9 7 P A F P G A 2 0 1 0 9 6
P A F P G A 2 0 1 0 9 5 P A F P G A 2 0 1 0 9 4 P A F P G A 2 0 1 0 9 3
P A F P G A 2 0 1 0 9 2 P A F P G A 2 0 1 0 9 1 P A F P G A 2 0 1 0 9 0
P A F P G A 2 0 1 0 8 9 P A F P G A 2 0 1 0 8 8 P A F P G A 2 0 1 0 8 7
P A F P G A 2 0 1 0 8 6 P A F P G A 2 0 1 0 8 5 P A F P G A 2 0 1 0 8 4
P A F P G A 2 0 1 0 8 3 P A F P G A 2 0 1 0 8 2
P A F P G A 2 0 1 0 8 1 P A F P G A 2 0 1 0 8 0 P A F P G A 2 0 1 0 7 9
P A F P G A 2 0 1 0 7 8 P A F P G A 2 0 1 0 7 7 P A F P G A 2 0 1 0 7 6
P A F P G A 2 0 1 0 7 5 P A F P G A 2 0 1 0 7 4
P A F P G A 2 0 1 0 7 3 P A F P G A 2 0 1 0 7 2 P A F P G A 2 0 1 0 7 1
P A F P G A 2 0 1 0 7 0 P A F P G A 2 0 1 0 6 9 P A F P G A 2 0 1 0 6 8
P A F P G A 2 0 1 0 6 7 P A F P G A 2 0 1 0 6 6 P A F P G A 2 0 1 0 6 5
P A F P G A 2 0 1 0 6 4 P A F P G A 2 0 1 0 6 3 P A F P G A 2 0 1 0 6 2
P A F P G A 2 0 1 0 6 1 P A F P G A 2 0 1 0 6 0
P A F P G A 2 0 1 0 5 9 P A F P G A 2 0 1 0 5 8 P A F P G A 2 0 1 0 5 7
P A F P G A 2 0 1 0 5 6 P A F P G A 2 0 1 0 5 5 P A F P G A 2 0 1 0 5 4
P A F P G A 2 0 1 0 5 3
P A F P G A 2 0 1 0 5 2
P A F P G A 2 0 1 0 5 1
P A F P G A 2 0 1 0 5 0
P A F P G A 2 0 1 0 4 9
P A F P G A 2 0 1 0 4 8
P A F P G A 2 0 1 0 4 7
P A F P G A 2 0 1 0 4 6
P A F P G A 2 0 1 0 4 5
P A F P G A 2 0 1 0 4 4
P A F P G A 2 0 1 0 4 3
P A F P G A 2 0 1 0 4 2
P A F P G A 2 0 1 0 4 1
P A F P G A 2 0 1 0 4 0
P A F P G A 2 0 1 0 3 9
P A F P G A 2 0 1 0 3 8
P A F P G A 2 0 1 0 3 7
P A F P G A 2 0 1 0 3 6
P A F P G A 2 0 1 0 3 5
P A F P G A 2 0 1 0 3 4
P A F P G A 2 0 1 0 3 3
P A F P G A 2 0 1 0 3 2
P A F P G A 2 0 1 0 3 1
P A F P G A 2 0 1 0 3 0
P A F P G A 2 0 1 0 2 9
P A F P G A 2 0 1 0 2 8
P A F P G A 2 0 1 0 2 7
P A F P G A 2 0 1 0 2 6
P A F P G A 2 0 1 0 2 5
P A F P G A 2 0 1 0 2 4
P A F P G A 2 0 1 0 2 3
P A F P G A 2 0 1 0 2 2
P A F P G A 2 0 1 0 2 1
P A F P G A 2 0 1 0 2 0
P A F P G A 2 0 1 0 1 9
P A F P G A 2 0 1 0 1 8
P A F P G A 2 0 1 0 1 7
P A F P G A 2 0 1 0 1 6
P A F P G A 2 0 1 0 1 5
P A F P G A 2 0 1 0 1 4
P A F P G A 2 0 1 0 1 3
P A F P G A 2 0 1 0 1 2
P A F P G A 2 0 1 0 1 1
P A F P G A 2 0 1 0 1 0
P A F P G A 2 0 1 0 9
P A F P G A 2 0 1 0 8
P A F P G A 2 0 1 0 7
P A F P G A 2 0 1 0 6
P A F P G A 2 0 1 0 5
P A F P G A 2 0 1 0 4
P A F P G A 2 0 1 0 3
P A F P G A 2 0 1 0 2
P A F P G A 2 0 1 0 1 C O F P G A 2 0 1
P A J P 1 0 1 0 1 P A J P 1 0 1 0 3 P A J P 1 0 1 0 5 P A J P 1 0 1 0 7 P A J P 1 0 1 0 9
P A J P 1 0 1 0 2 P A J P 1 0 1 0 4 P A J P 1 0 1 0 6 P A J P 1 0 1 0 8 P A J P 1 0 1 0 1 0
C O J P 1 0 1
P A J P 1 0 2 0 1
P A J P 1 0 2 0 3
P A J P 1 0 2 0 5
P A J P 1 0 2 0 7
P A J P 1 0 2 0 9
P A J P 1 0 2 0 2
P A J P 1 0 2 0 4
P A J P 1 0 2 0 6
P A J P 1 0 2 0 8
P A J P 1 0 2 0 1 0
C O J P 1 0 2
P A J P 1 0 3 0 8
P A J P 1 0 3 0 7
P A J P 1 0 3 0 1
P A J P 1 0 3 0 2
P A J P 1 0 3 0 3
P A J P 1 0 3 0 4
P A J P 1 0 3 0 5
P A J P 1 0 3 0 6
P A J P 1 0 3 0 1 5
P A J P 1 0 3 0 1 1
P A J P 1 0 3 0 1 3
P A J P 1 0 3 0 1 4
P A J P 1 0 3 0 1 0
P A J P 1 0 3 0 1 2
P A J P 1 0 3 0 9
P A J P 1 0 3 0 1 6
C O J P 1 0 3
P A J P 2 0 1 0 1 P A J P 2 0 1 0 3 P A J P 2 0 1 0 5 P A J P 2 0 1 0 7 P A J P 2 0 1 0 9
P A J P 2 0 1 0 2 P A J P 2 0 1 0 4 P A J P 2 0 1 0 6 P A J P 2 0 1 0 8 P A J P 2 0 1 0 1 0
C O J P 2 0 1
P A J P 2 0 2 0 1
P A J P 2 0 2 0 3
P A J P 2 0 2 0 5
P A J P 2 0 2 0 7
P A J P 2 0 2 0 9P A J P 2 0 2 0 2
P A J P 2 0 2 0 4
P A J P 2 0 2 0 6
P A J P 2 0 2 0 8
P A J P 2 0 2 0 1 0
C O J P 2 0 2
P A J P 3 0 1 0 2
P A J P 3 0 1 0 3
P A J P 3 0 1 0 1 C O J P 3 0 1
P A J P 5 0 1 0 1
P A J P 5 0 1 0 3
P A J P 5 0 1 0 5
P A J P 5 0 1 0 7
P A J P 5 0 1 0 9
P A J P 5 0 1 0 2
P A J P 5 0 1 0 4
P A J P 5 0 1 0 6
P A J P 5 0 1 0 8
P A J P 5 0 1 0 1 0
C O J P 5 0 1
P A J P 5 0 2 0 1
P A J P 5 0 2 0 3
P A J P 5 0 2 0 5
P A J P 5 0 2 0 7
P A J P 5 0 2 0 9
P A J P 5 0 2 0 2
P A J P 5 0 2 0 4
P A J P 5 0 2 0 6
P A J P 5 0 2 0 8
P A J P 5 0 2 0 1 0
C O J P 5 0 2
P A J P 5 0 3 0 1
P A J P 5 0 3 0 3
P A J P 5 0 3 0 2
P A J P 5 0 3 0 4
C O J P 5 0 3
P A J P 5 0 4 0 1 P A J P 5 0 4 0 3
P A J P 5 0 4 0 2
P A J P 5 0 4 0 4C O J P 5 0 4
P A J P 6 0 1 0 9
P A J P 6 0 1 0 8
P A J P 6 0 1 0 6
P A J P 6 0 1 0 4
P A J P 6 0 1 0 2
P A J P 6 0 1 0 7
P A J P 6 0 1 0 5
P A J P 6 0 1 0 3
P A J P 6 0 1 0 1
C O J P 6 0 1
P A J P 7 0 1 0 1 P A J P 7 0 1 0 3 P A J P 7 0 1 0 5 P A J P 7 0 1 0 7 P A J P 7 0 1 0 9
P A J P 7 0 1 0 2 P A J P 7 0 1 0 4 P A J P 7 0 1 0 6 P A J P 7 0 1 0 8 P A J P 7 0 1 0 1 0 C O J P 7 0 1 P A J P 7 0 2 0 1 0
P A J P 7 0 2 0 8
P A J P 7 0 2 0 6
P A J P 7 0 2 0 4
P A J P 7 0 2 0 2
P A J P 7 0 2 0 9
P A J P 7 0 2 0 7
P A J P 7 0 2 0 5
P A J P 7 0 2 0 3
P A J P 7 0 2 0 1
C O J P 7 0 2
P A J P 7 0 3 0 3
P A J P 7 0 3 0 2
P A J P 7 0 3 0 1
C O J P 7 0 3
P A J P 7 0 4 0 3
P A J P 7 0 4 0 2
P A J P 7 0 4 0 1
C O J P 7 0 4
P A J P 8 0 1 0 6
P A J P 8 0 1 0 1 4
P A J P 8 0 1 0 1 3
P A J P 8 0 1 0 1 2
P A J P 8 0 1 0 1 1
P A J P 8 0 1 0 1 0
P A J P 8 0 1 0 9 P A J P 8 0 1 0 5
P A J P 8 0 1 0 4
P A J P 8 0 1 0 3
P A J P 8 0 1 0 2
P A J P 8 0 1 0 1
P A J P 8 0 1 0 7
P A J P 8 0 1 0 1 5 P A J P 8 0 1 0 8
C O J P 8 0 1
P A L 6 0 1 0 1
P A L 6 0 1 0 2
C O L 6 0 1
P A O P 4 0 1 0 8
P A O P 4 0 1 0 9
P A O P 4 0 1 0 1 0
P A O P 4 0 1 0 1 1
P A O P 4 0 1 0 1 2
P A O P 4 0 1 0 1 3
P A O P 4 0 1 0 1 4
P A O P 4 0 1 0 7
P A O P 4 0 1 0 6
P A O P 4 0 1 0 5
P A O P 4 0 1 0 4
P A O P 4 0 1 0 3
P A O P 4 0 1 0 2
P A O P 4 0 1 0 1
C O O P 4 0 1
P A P 3 0 1 0 1
P A P 3 0 1 0 3
P A P 3 0 1 0 2C O P 3 0 1
P A P 3 0 2 0 1
P A P 3 0 2 0 3 P A P 3 0 2 0 2
C O P 3 0 2
P A P 3 0 3 0 1
P A P 3 0 3 0 3P A P 3 0 3 0 2C O P 3 0 3
P A P 3 0 4 0 1
P A P 3 0 4 0 3 P A P 3 0 4 0 2
C O P 3 0 4
P A P 3 0 5 0 5
P A P 3 0 5 0 4P A P 3 0 5 0 3 P A P 3 0 5 0 2 P A P 3 0 5 0 1
C O P 3 0 5 P A P 3 0 6 0 5 P A P 3 0 6 0 4P A P 3 0 6 0 3 P A P 3 0 6 0 2 P A P 3 0 6 0 1C O P 3 0 6
P A P B 1 0 1 0 2
P A P B 1 0 1 0 1
C O P B 1 0 1
P A P B 7 0 1 0 2
P A P B 7 0 1 0 1
C O P B 7 0 1
P A P B 7 0 2 0 2
P A P B 7 0 2 0 1
C O P B 7 0 2
P A Q 7 0 1 0 2P A Q 7 0 1 0 3 P A Q 7 0 1 0 1
C O Q 7 0 1P A Q 7 0 2 0 2 P A Q 7 0 2 0 3P A Q 7 0 2 0 1
C O Q 7 0 2
P A Q 7 0 3 0 2P A Q 7 0 3 0 3 P A Q 7 0 3 0 1
C
O
Q
7
0
3
P A Q 7 0 4 0 2
P A Q 7 0 4 0 3
P A Q 7 0 4 0 1
C O Q 7 0 4
P A Q 7 0 5 0 2P A Q 7 0 5 0 3 P A Q 7 0 5 0 1
C
O
Q7
05P A Q 7 0 6 0 2
P A Q 7 0 6 0 3
P A Q 7 0 6 0 1
C O Q 7 0 6
P A Q 7 0 7 0 2P A Q 7 0 7 0 3 P A Q 7 0 7 0 1
C
O
Q
7
0
7
P A Q 7 0 8 0 2
P A Q 7 0 8 0 3
P A Q 7 0 8 0 1
C O Q 7 0 8
P A Q 7 0 9 0 2P A Q 7 0 9 0 3 P A Q 7 0 9 0 1
C O Q 7 0 9P A Q 7 0 1 0 0 2 P A Q 7 0 1 0 0 3P A Q 7 0 1 0 0 1
C O Q 7 0 1 0
P A Q 7 0 1 1 0 2P A Q 7 0 1 1 0 3 P A Q 7 0 1 1 0 1
C O Q 7 0 1 1P A Q 7 0 1 2 0 2 P A Q 7 0 1 2 0 3P A Q 7 0 1 2 0 1
C O Q 7 0 1 2
P A Q 7 0 1 3 0 2P A Q 7 0 1 3 0 3 P A Q 7 0 1 3 0 1
C O Q 7 0 1 3P A Q 7 0 1 4 0 2 P A Q 7 0 1 4 0 3P A Q 7 0 1 4 0 1
C O Q 7 0 1 4
P A Q 7 0 1 5 0 2P A Q 7 0 1 5 0 3 P A Q 7 0 1 5 0 1
C O Q 7 0 1 5P A Q 7 0 1 6 0 2 P A Q 7 0 1 6 0 3P A Q 7 0 1 6 0 1
C O Q 7 0 1 6
P A R 1 0 1 0 1
P A R 1 0 1 0 2
C O R 1 0 1
P A R 1 0 2 0 1
P A R 1 0 2 0 2
C O R 1 0 2P A R 1 0 3 0 1 P A R 1 0 3 0 2
C O R 1 0 3
P A R 1 0 4 0 1
P A R 1 0 4 0 2 C O R 1 0 4
P A R 1 0 5 0 2
P A R 1 0 5 0 1
C O R 1 0 5
P A R 2 0 1 0 1
P A R 2 0 1 0 2
C O R 2 0 1
P A R 2 0 2 0 1
P A R 2 0 2 0 2
C O R 2 0 2P A R 2 0 3 0 1 P A R 2 0 3 0 2
C O R 2 0 3
P A R 2 0 4 0 1
P A R 2 0 4 0 2
C O R 2 0 4
P A R 2 0 5 0 1
P A R 2 0 5 0 2
C O R 2 0 5
P A R 2 0 6 0 1
P A R 2 0 6 0 2
C O R 2 0 6
P A R 2 0 7 0 2
P A R 2 0 7 0 1
C O R 2 0 7
P A R 2 0 8 0 2
P A R 2 0 8 0 1
C O R 2 0 8
P A R 3 0 5 0 1
P A R 3 0 5 0 2
C O R 3 0 5
P A R 3 0 6 0 1
P A R 3 0 6 0 2
C O R 3 0 6
P A R 4 0 1 0 2
P A R 4 0 1 0 1
C O R 4 0 1
P A R 4 0 2 0 1
P A R 4 0 2 0 2
C O R 4 0 2
P A R 4 0 3 0 2
P A R 4 0 3 0 1
C O R 4 0 3
P A R 4 0 5 0 2
P A R 4 0 5 0 1
C O R 4 0 5
P A R 4 0 6 0 2
P A R 4 0 6 0 1
C O R 4 0 6
P A R 4 0 7 0 1
P A R 4 0 7 0 2
C O R 4 0 7
P A R 4 0 1 0 0 1
P A R 4 0 1 0 0 2
C O R 4 0 1 0
P A R 4 0 1 1 0 1
P A R 4 0 1 1 0 2
C O R 4 0 1 1
P A R 5 0 1 0 2
P A R 5 0 1 0 1
C O R 5 0 1
P A R 5 0 2 0 2
P A R 5 0 2 0 1
C O R 5 0 2
P A R 5 0 3 0 2
P A R 5 0 3 0 1
C O R 5 0 3
P A R 5 0 4 0 2
P A R 5 0 4 0 1
C O R 5 0 4
P A R 5 0 5 0 2
P A R 5 0 5 0 1
C O R 5 0 5
P A R 6 0 1 0 1
P A R 6 0 1 0 2
C O R 6 0 1
P A R 6 0 2 0 1
P A R 6 0 2 0 2
C O R 6 0 2
P A R 6 0 3 0 1
P A R 6 0 3 0 2
C O R 6 0 3
P A R 6 0 4 0 2
P A R 6 0 4 0 1
C O R 6 0 4
P A R 6 0 5 0 1
P A R 6 0 5 0 2
C O R 6 0 5
P A R 6 0 6 0 1
P A R 6 0 6 0 2
C O R 6 0 6
P A R 6 0 7 0 1
P A R 6 0 7 0 2
C O R 6 0 7
P A R 6 0 8 0 1
P A R 6 0 8 0 2
C O R 6 0 8
P A R 6 0 9 0 1
P A R 6 0 9 0 2
C O R 6 0 9
P A R 6 0 1 0 0 1
P A R 6 0 1 0 0 2
C O R 6 0 1 0
P A R 6 0 1 1 0 1
P A R 6 0 1 1 0 2
C O R 6 0 1 1
P A R 6 0 1 2 0 2
P A R 6 0 1 2 0 1
C O R 6 0 1 2
P A R 6 0 1 3 0 1
P A R 6 0 1 3 0 2
C O R 6 0 1 3
P A R 6 0 1 4 0 2
P A R 6 0 1 4 0 1
C O R 6 0 1 4
P A R 6 0 1 5 0 2
P A R 6 0 1 5 0 1
C O R 6 0 1 5
P A R 6 0 1 6 0 2
P A R 6 0 1 6 0 1
C O R 6 0 1 6
P A R 6 0 1 7 0 2
P A R 6 0 1 7 0 1
C O R 6 0 1 7
P A R 6 0 1 8 0 2
P A R 6 0 1 8 0 1
C O R 6 0 1 8
P A R 6 0 1 9 0 2
P A R 6 0 1 9 0 1
C O R 6 0 1 9
P A R 6 0 2 0 0 1
P A R 6 0 2 0 0 2
C O R 6 0 2 0
P A R 7 0 1 0 1
P A R 7 0 1 0 2
C
O
R
70
1
P A R 7 0 2 0 1
P A R 7 0 2 0 2
C O R 7 0 2
P A R 7 0 3 0 1
P A R 7 0 3 0 2
C
O
R
7
0
3
P A R 7 0 4 0 1
P A R 7 0 4 0 2
C
O
R
7
0
4
P A R 7 0 5 0 1
P A R 7 0 5 0 2
C
O
R
70
5P A R 7 0 6 0 1P A R 7 0 6 0 2
C
O
R
70
6
P A R 7 0 7 0 1
P A R 7 0 7 0 2
C O R 7 0 7
P A R 7 0 8 0 1
P A R 7 0 8 0 2
C
O
R
7
0
8
P A R 7 0 9 0 1
P A R 7 0 9 0 2
C
O
R
70
9
P A R 7 0 1 0 0 1
P A R 7 0 1 0 0 2
C
O
R
70
10
P A R 7 0 1 1 0 1
P A R 7 0 1 1 0 2
C O R 7 0 1 1
P A R 7 0 1 2 0 1
P A R 7 0 1 2 0 2
C
O
R
7
0
1
2
P A R 7 0 1 3 0 1
P A R 7 0 1 3 0 2
C
O
R
70
13
P A R 7 0 1 4 0 1
P A R 7 0 1 4 0 2
C
O
R
70
14
P A R 7 0 1 5 0 1
P A R 7 0 1 5 0 2
C O R 7 0 1 5P A R 7 0 1 6 0 1P A R 7 0 1 6 0 2
C
O
R
7
0
1
6
P A R 7 0 1 7 0 2
P A R 7 0 1 7 0 1
C O R 7 0 1 7P A R 7 0 1 8 0 2 P A R 7 0 1 8 0 1
C O R 7 0 1 8 P A R 7 0 1 9 0 2 P A R 7 0 1 9 0 1
C O R 7 0 1 9P A R 7 0 2 0 0 2 P A R 7 0 2 0 0 1
C O R 7 0 2 0
P A R 8 0 1 0 1
P A R 8 0 1 0 2
C O R 8 0 1
P A R 9 0 1 0 2 P A R 9 0 1 0 1
C O R 9 0 1
P A R 9 0 2 0 2
P A R 9 0 2 0 1
C O R 9 0 2
P A T P 1 0 1 0 1
C O T P 1 0 1
P A T P 2 0 1 0 1
C O T P 2 0 1
P A T P 2 0 2 0 1
C O T P 2 0 2
P A T P 2 0 4 0 1
C O T P 2 0 4P A T P 2 0 5 0 1 C O T P 2 0 5P A T P 2 0 6 0 1 C O T P 2 0 6
P A T P 3 0 1 0 1
C O T P 3 0 1
P A T P 3 0 2 0 1
C O T P 3 0 2
P A T P 3 0 3 0 1
C O T P 3 0 3
P A T P 3 0 4 0 1
C O T P 3 0 4
P A T P 3 0 5 0 1
C O T P 3 0 5
P A T P 3 0 6 0 1
C O T P 3 0 6
P A T P 4 0 1 0 1C O T P 4 0 1
P A T P 4 0 2 0 1
C O T P 4 0 2
P A T P 4 0 3 0 1
C O T P 4 0 3
P A T P 5 0 1 0 1
C O T P 5 0 1
P A T P 5 0 2 0 1
C O T P 5 0 2
P A T P 5 0 4 0 1
C O T P 5 0 4
P A T P 5 0 5 0 1C O T P 5 0 5
P A T P 5 0 6 0 1
C O T P 5 0 6
P A T P 5 0 7 0 1
C O T P 5 0 7
P A T P 5 0 9 0 1
C O T P 5 0 9
P A T P 5 0 1 0 0 1C O T P 5 0 1 0 P A T P 5 0 1 1 0 1 C O T P 5 0 1 1
P A U 4 0 1 0 1 6
P A U 4 0 1 0 1 5
P A U 4 0 1 0 1 4
P A U 4 0 1 0 1 3
P A U 4 0 1 0 1 2
P A U 4 0 1 0 1 1
P A U 4 0 1 0 1 0
P A U 4 0 1 0 9
P A U 4 0 1 0 8
P A U 4 0 1 0 7
P A U 4 0 1 0 6
P A U 4 0 1 0 5
P A U 4 0 1 0 4
P A U 4 0 1 0 3
P A U 4 0 1 0 2
P A U 4 0 1 0 1C O U 4 0 1
P A U 4 0 2 0 1
P A U 4 0 2 0 2
P A U 4 0 2 0 3
P A U 4 0 2 0 4
P A U 4 0 2 0 5
C O U 4 0 2
P A U 4 0 3 0 1
P A U 4 0 3 0 2
P A U 4 0 3 0 3
P A U 4 0 3 0 4
P A U 4 0 3 0 5
C O U 4 0 3
P A U 4 0 4 0 1
P A U 4 0 4 0 2
P A U 4 0 4 0 3
P A U 4 0 4 0 4
P A U 4 0 4 0 5
C O U 4 0 4
P A U 4 0 5 0 1
P A U 4 0 5 0 2
P A U 4 0 5 0 4
P A U 4 0 5 0 3
P A U 4 0 5 0 6
P A U 4 0 5 0 5
P A U 4 0 5 0 7
P A U 4 0 5 0 8 C O U 4 0 5
P A U 4 0 7 0 8
P A U 4 0 7 0 7
P A U 4 0 7 0 5
P A U 4 0 7 0 6
P A U 4 0 7 0 3
P A U 4 0 7 0 4
P A U 4 0 7 0 2
P A U 4 0 7 0 1 C O U 4 0 7
P A U 6 0 1 0 4 8 P A U 6 0 1 0 4 7 P A U 6 0 1 0 4 6 P A U 6 0 1 0 4 5 P A U 6 0 1 0 4 4 P A U 6 0 1 0 4 3 P A U 6 0 1 0 4 2 P A U 6 0 1 0 4 1 P A U 6 0 1 0 4 0 P A U 6 0 1 0 3 9 P A U 6 0 1 0 3 8 P A U 6 0 1 0 3 7 P A U 6 0 1 0 3 6
P A U 6 0 1 0 3 5
P A U 6 0 1 0 3 4
P A U 6 0 1 0 3 3
P A U 6 0 1 0 3 2
P A U 6 0 1 0 3 1
P A U 6 0 1 0 3 0
P A U 6 0 1 0 2 9
P A U 6 0 1 0 2 8
P A U 6 0 1 0 2 7
P A U 6 0 1 0 2 6
P A U 6 0 1 0 2 5
P A U 6 0 1 0 2 4 P A U 6 0 1 0 2 3
P A U 6 0 1 0 2 2 P A U 6 0 1 0 2 1
P A U 6 0 1 0 2 0 P A U 6 0 1 0 1 9
P A U 6 0 1 0 1 8 P A U 6 0 1 0 1 7
P A U 6 0 1 0 1 6 P A U 6 0 1 0 1 5
P A U 6 0 1 0 1 4 P A U 6 0 1 0 1 3
P A U 6 0 1 0 1 2
P A U 6 0 1 0 1 1
P A U 6 0 1 0 1 0
P
A U 6 0 1 0 9
P A U 6 0 1 0 8
P
A U 6 0 1 0 7
P
A U 6 0 1 0 6
P A U 6 0 1 0 5
P
A U 6 0 1 0 4
P A U 6 0 1 0 3
P
A U 6 0 1 0 2
P
A U 6 0 1 0 1
C O U 6 0 1
P A X 1 0 1 0 4 P A X 1 0 1 0 3
P A X 1 0 1 0 2P A X 1 0 1 0 1
C O X 1 0 1
P A X 2 0 1 0 4
P A X 2 0 1 0 3
P A X 2 0 1 0 2
P A X 2 0 1 0 1C O X 2 0 1
P A X V R 5 0 1 0 8 P A X V R 5 0 1 0 7
P A X V R 5 0 1 0 5
P A X V R 5 0 1 0 6 P A X V R 5 0 1 0 3 P A X V R 5 0 1 0 4
P A X V R 5 0 1 0 2
P A X V R 5 0 1 0 1
C O X V R 5 0 1
P A X V R 5 0 2 0 8 P A X V R 5 0 2 0 7
P A X V R 5 0 2 0 5
P A X V R 5 0 2 0 6 P A X V R 5 0 2 0 3 P A X V R 5 0 2 0 4
P A X V R 5 0 2 0 2
P A X V R 5 0 2 0 1
C O X V R 5 0 2
P A F P G A 1 0 1 0 1 1 2
P A T P 1 0 1 0 1
P A X 1 0 1 0 3P A C 2 0 1 7 0 2 P A C 2 0 1 8 0 2 P A C 2 0 1 9 0 2
P A C 2 0 2 0 0 2
P A C 2 0 2 1 0 2
P A C 2 0 2 2 0 2
P A C 2 0 2 3 0 2
P A C 2 0 2 4 0 2
P A C 2 0 3 0 0 2
P A C 3 0 9 0 2
P A C 3 0 1 0 0 2
P A F P G A 2 0 1 0 1 6
P A F P G A 2 0 1 0 2 7
P A F P G A 2 0 1 0 3 6
P A F P G A 2 0 1 0 7 1
P A F P G A 2 0 1 0 8 8
P A F P G A 2 0 1 0 1 3 1
P A F P G A 2 0 1 0 1 4 2
P A F P G A 2 0 1 0 1 7 1
P A F P G A 2 0 1 0 1 8 7
P A P 3 0 3 0 2
P A T P 3 0 4 0 1
P A C 3 0 1 1 0 2
P A C 3 0 1 2 0 2
P A P 3 0 4 0 2
P A R 4 0 1 0 1
P A T P 3 0 5 0 1
P A U 4 0 2 0 3
P A O P 4 0 1 0 6
P A O P 4 0 1 0 7
P A T P 4 0 1 0 1
P A U 4 0 1 0 3
P A C 1 0 1 7 0 2
P A C 1 0 1 8 0 2
P A C 1 0 1 9 0 2
P A C 1 0 2 0 0 2
P A C 1 0 2 1 0 2
P A C 1 0 2 2 0 2
P A C 1 0 2 3 0 2
P A C 1 0 2 4 0 2
P A C 1 0 3 0 0 2
P A F P G A 1 0 1 0 1 6
P A F P G A 1 0 1 0 2 7
P A F P G A 1 0 1 0 3 6
P A F P G A 1 0 1 0 7 1
P A F P G A 1 0 1 0 8 8
P A F P G A 1 0 1 0 1 3 1
P A F P G A 1 0 1 0 1 4 2
P A F P G A 1 0 1 0 1 7 1
P A F P G A 1 0 1 0 1 8 7
P A R 4 0 1 0 2
P A U 4 0 1 0 1
P A U 4 0 2 0 4
P A F P G A 2 0 1 0 3 2
P A T P 2 0 4 0 1
P A X 2 0 1 0 3
P A C 2 0 1 0 2
P A C 2 0 2 0 2
P A C 2 0 3 0 2 P A C 2 0 4 0 2
P A C 2 0 5 0 2
P A C 2 0 6 0 2
P A C 2 0 7 0 2
P A C 2 0 8 0 2P A C 2 0 9 0 2
P A C 2 0 1 0 0 2
P A C 2 0 1 1 0 2
P A C 2 0 1 2 0 2
P A C 2 0 1 3 0 2
P A C 2 0 1 4 0 2
P A C 2 0 1 5 0 2
P A C 2 0 1 6 0 2
P A C 2 0 2 8 0 2
P A C 2 0 2 9 0 2
P A C 3 0 5 0 2
P A C 3 0 6 0 2
P A C 6 0 1 0 2
P A C 6 0 2 0 2
P A C 6 0 3 0 2
P A C 6 0 4 0 2
P A C 9 0 1 0 2
P A C 9 0 2 0 2
P A C 9 0 3 0 2
P A C 9 0 4 0 2P A C 9 0 5 0 2
P A C 9 0 6 0 2
P A C O N 0 F L A S H 0 H 0 3 7
P A C O N 0 F L A S H 0 H 0 4 7
P A C O N 0 F L A S H 0 L 0 3 7
P A C O N 0 F L A S H 0 L 0 4 7
P A C O N 0 S R A M 0 H 0 1 1
P A C O N 0 S R A M 0 H 0 3 3
P A C O N 0 S R A M 0 L 0 1 1
P A C O N 0 S R A M 0 L 0 3 3
P A F P G A 2 0 1 0 3
P A F P G A 2 0 1 0 1 8
P A F P G A 2 0 1 0 4 0
P A F P G A 2 0 1 0 5 0 P A F P G A 2 0 1 0 5 3
P A F P G A 2 0 1 0 6 2
P A F P G A 2 0 1 0 7 2
P A F P G A 2 0 1 0 8 9
P A F P G A 2 0 1 0 1 0 4
P A F P G A 2 0 1 0 1 1 1
P A F P G A 2 0 1 0 1 2 3
P A F P G A 2 0 1 0 1 4 0
P A F P G A 2 0 1 0 1 5 4
P A F P G A 2 0 1 0 1 5 7
P A F P G A 2 0 1 0 1 7 0
P A F P G A 2 0 1 0 1 8 6
P A F P G A 2 0 1 0 2 0 0
P A F P G A 2 0 1 0 2 0 8
P A J P 2 0 2 0 1 0
P A L 6 0 1 0 2
P A O P 4 0 1 0 4
P A P 3 0 1 0 2
P A R 2 0 1 0 1 P A R 2 0 4 0 2
P A R 2 0 5 0 1
P A R 2 0 6 0 1
P A R 2 0 7 0 2
P A R 2 0 8 0 2
P A R 6 0 1 0 1
P A R 9 0 2 0 2
P A T P 3 0 2 0 1
P A U 4 0 1 0 1 2
P A U 4 0 2 0 5
P A U 4 0 3 0 5
P A U 4 0 4 0 5
P A U 4 0 5 0 8
P A U 4 0 7 0 6
P A U 4 0 7 0 8
P A U 6 0 1 0 3 2
P A U 6 0 1 0 4 8
P A X 2 0 1 0 4
P A C 6 0 9 0 2
P A C 6 0 1 0 0 2
P A C 6 0 1 1 0 2
P A C 6 0 1 2 0 2
P A C 6 0 1 4 0 2
P A J P 6 0 1 0 4
P A J P 6 0 1 0 5
P A L 6 0 1 0 1
P A R 6 0 1 5 0 1
P A R 6 0 1 6 0 1
P A R 6 0 1 7 0 1
P A R 6 0 1 8 0 1
P A U 6 0 1 0 2 2
P A C 3 0 7 0 2
P A C 3 0 8 0 2 P A P 3 0 2 0 2
P A R 4 0 2 0 1 P A T P 3 0 3 0 1
P A U 4 0 3 0 3
P A O P 4 0 1 0 1
P A O P 4 0 1 0 2
P A T P 4 0 2 0 1
P A U 4 0 1 0 4
P A C 1 0 1 0 2
P A C 1 0 2 0 2
P A C 1 0 3 0 2 P A C 1 0 4 0 2
P A C 1 0 5 0 2
P A C 1 0 6 0 2
P A C 1 0 7 0 2
P A C 1 0 8 0 2P A C 1 0 9 0 2
P A C 1 0 1 0 0 2
P A C 1 0 1 1 0 2
P A C 1 0 1 2 0 2
P A C 1 0 1 3 0 2
P A C 1 0 1 4 0 2
P A C 1 0 1 5 0 2
P A C 1 0 1 6 0 2
P A C 1 0 2 8 0 2
P A C 1 0 2 9 0 2
P A C 8 0 3 0 2
P A C 8 0 4 0 2
P A C 8 0 5 0 2
P A C 8 0 6 0 2
P A C 8 0 7 0 2
P A C 8 0 8 0 2
P A C 8 0 9 0 2 P A D U T 0 S R A M 0 1
P A D U T 0 S R A M 0 3
P A D U T 0 S R A M 0 9
P A D U T 0 S R A M 0 1 4
P A D U T 0 S R A M 0 2 7
P A D U T 0 S R A M 0 4 3
P A D U T 0 S R A M 0 4 9
P A F P G A 1 0 1 0 3
P A F P G A 1 0 1 0 1 8
P A F P G A 1 0 1 0 4 0
P A F P G A 1 0 1 0 5 0 P A F P G A 1 0 1 0 5 3
P A F P G A 1 0 1 0 6 2
P A F P G A 1 0 1 0 7 2
P A F P G A 1 0 1 0 8 9
P A F P G A 1 0 1 0 1 0 4
P A F P G A 1 0 1 0 1 1 1
P A F P G A 1 0 1 0 1 2 3
P A F P G A 1 0 1 0 1 4 0
P A F P G A 1 0 1 0 1 5 4
P A F P G A 1 0 1 0 1 5 7
P A F P G A 1 0 1 0 1 7 0
P A F P G A 1 0 1 0 1 8 6
P A F P G A 1 0 1 0 2 0 0
P A F P G A 1 0 1 0 2 0 8
P A J P 1 0 2 0 1 0
P A J P 8 0 1 0 9
P A R 1 0 1 0 1 P A R 1 0 4 0 2
P A R 1 0 5 0 2
P A R 4 0 2 0 2
P A R 5 0 5 0 2
P A U 4 0 1 0 2
P A U 4 0 3 0 4
P A X 1 0 1 0 4
P A C 5 0 1 0 2
P A C 5 0 2 0 2
P A R 5 0 5 0 1
P A T P 5 0 1 1 0 1
P A X V R 5 0 1 0 3
P A X V R 5 0 2 0 3
P A C O N 0 F L A S H 0 H 0 2 5
P A C O N 0 F L A S H 0 L 0 2 5
P A C O N 0 S R A M 0 H 0 1
P A C O N 0 S R A M 0 L 0 1
P A F P G A 2 0 1 0 1 7 5
P A C O N 0 F L A S H 0 H 0 2 4
P A C O N 0 F L A S H 0 L 0 2 4
P A C O N 0 S R A M 0 H 0 2
P A C O N 0 S R A M 0 L 0 2
P A F P G A 2 0 1 0 1 7 6
P A C O N 0 F L A S H 0 H 0 2 3
P A C O N 0 F L A S H 0 L 0 2 3
P A C O N 0 S R A M 0 H 0 3
P A C O N 0 S R A M 0 L 0 3
P A F P G A 2 0 1 0 1 7 7
P A C O N 0 F L A S H 0 H 0 2 2
P A C O N 0 F L A S H 0 L 0 2 2
P A C O N 0 S R A M 0 H 0 4
P A C O N 0 S R A M 0 L 0 4
P A F P G A 2 0 1 0 1 7 9
P A C O N 0 F L A S H 0 H 0 2 1
P A C O N 0 F L A S H 0 L 0 2 1
P A C O N 0 S R A M 0 H 0 5
P A C O N 0 S R A M 0 L 0 5
P A F P G A 2 0 1 0 1 8 0
P A C O N 0 F L A S H 0 H 0 2 0
P A C O N 0 F L A S H 0 L 0 2 0
P A C O N 0 S R A M 0 H 0 1 8
P A C O N 0 S R A M 0 L 0 1 8
P A F P G A 2 0 1 0 1 6 7
P A C O N 0 F L A S H 0 H 0 1 9
P A C O N 0 F L A S H 0 L 0 1 9
P A C O N 0 S R A M 0 H 0 1 9
P A C O N 0 S R A M 0 L 0 1 9
P A F P G A 2 0 1 0 1 6 8
P A C O N 0 F L A S H 0 H 0 1 8
P A C O N 0 F L A S H 0 L 0 1 8
P A C O N 0 S R A M 0 H 0 2 0
P A C O N 0 S R A M 0 L 0 2 0
P A F P G A 2 0 1 0 1 6 9
P A C O N 0 F L A S H 0 H 0 8
P A C O N 0 F L A S H 0 L 0 8
P A C O N 0 S R A M 0 H 0 2 1
P A C O N 0 S R A M 0 L 0 2 1
P A F P G A 2 0 1 0 1 7 2
P A C O N 0 F L A S H 0 H 0 7
P A C O N 0 F L A S H 0 L 0 7
P A C O N 0 S R A M 0 H 0 2 2
P A C O N 0 S R A M 0 L 0 2 2
P A F P G A 2 0 1 0 1 7 3
P A C O N 0 F L A S H 0 H 0 6
P A C O N 0 F L A S H 0 L 0 6
P A C O N 0 S R A M 0 H 0 2 3
P A C O N 0 S R A M 0 L 0 2 3
P A F P G A 2 0 1 0 1 8 9
P A C O N 0 F L A S H 0 H 0 5
P A C O N 0 F L A S H 0 L 0 5
P A C O N 0 S R A M 0 H 0 2 4
P A C O N 0 S R A M 0 L 0 2 4
P A F P G A 2 0 1 0 1 9 0
P A C O N 0 F L A S H 0 H 0 4
P A C O N 0 F L A S H 0 L 0 4
P A C O N 0 S R A M 0 H 0 2 5
P A C O N 0 S R A M 0 L 0 2 5
P A F P G A 2 0 1 0 1 9 1
P A C O N 0 F L A S H 0 H 0 3
P A C O N 0 F L A S H 0 L 0 3
P A C O N 0 S R A M 0 H 0 2 6
P A C O N 0 S R A M 0 L 0 2 6
P A F P G A 2 0 1 0 1 9 2
P A C O N 0 F L A S H 0 H 0 2
P A C O N 0 F L A S H 0 L 0 2
P A C O N 0 S R A M 0 H 0 2 7
P A C O N 0 S R A M 0 L 0 2 7
P A F P G A 2 0 1 0 1 9 3
P A C O N 0 F L A S H 0 H 0 1
P A C O N 0 F L A S H 0 L 0 1
P A C O N 0 S R A M 0 H 0 4 2
P A C O N 0 S R A M 0 L 0 4 2
P A F P G A 2 0 1 0 1 9 4
P A C O N 0 F L A S H 0 H 0 4 8
P A C O N 0 F L A S H 0 L 0 4 8
P A C O N 0 S R A M 0 H 0 4 3
P A C O N 0 S R A M 0 L 0 4 3
P A F P G A 2 0 1 0 1 9 6
P A C O N 0 F L A S H 0 H 0 1 7
P A C O N 0 F L A S H 0 L 0 1 7
P A C O N 0 S R A M 0 H 0 4 4
P A C O N 0 S R A M 0 L 0 4 4
P A F P G A 2 0 1 0 1 8 2
P A C O N 0 F L A S H 0 H 0 1 6
P A C O N 0 F L A S H 0 L 0 1 6
P A F P G A 2 0 1 0 1 8 3
P A C O N 0 F L A S H 0 H 0 9
P A C O N 0 F L A S H 0 L 0 9
P A F P G A 2 0 1 0 1 8 5
P A D U T 0 S R A M 0 2 0
P A F P G A 1 0 1 0 8 6
P A D U T 0 S R A M 0 2 1
P A F P G A 1 0 1 0 8 7
P A F P G A 1 0 1 0 1 9 1
P A F P G A 2 0 1 0 2 1
P A F P G A 1 0 1 0 1 9 0
P A F P G A 2 0 1 0 2 2
P A F P G A 1 0 1 0 1 8 9
P A F P G A 2 0 1 0 2 3
P A F P G A 1 0 1 0 1 8 8
P A F P G A 2 0 1 0 2 4
P A F P G A 1 0 1 0 1 8 5
P A F P G A 2 0 1 0 2 6
P A F P G A 1 0 1 0 1 8 4
P A F P G A 2 0 1 0 2 8
P A F P G A 1 0 1 0 1 8 3
P A F P G A 2 0 1 0 3 0
P A F P G A 1 0 1 0 1 8 2
P A F P G A 2 0 1 0 3 1
P A F P G A 1 0 1 0 1 8 1
P A F P G A 2 0 1 0 3 3
P A F P G A 1 0 1 0 1 8 0
P A F P G A 2 0 1 0 3 4
P A F P G A 1 0 1 0 1 7 9
P A F P G A 2 0 1 0 3 5
P A F P G A 1 0 1 0 1 7 7
P A F P G A 2 0 1 0 3 7
P A F P G A 1 0 1 0 1 7 6
P A F P G A 2 0 1 0 3 8
P A F P G A 1 0 1 0 1 7 5
P A F P G A 2 0 1 0 3 9
P A F P G A 1 0 1 0 1 7 4
P A F P G A 2 0 1 0 4 2
P A F P G A 1 0 1 0 1 7 3
P A F P G A 2 0 1 0 4 3
P A F P G A 1 0 1 0 1 7 2
P A F P G A 2 0 1 0 4 4
P A F P G A 1 0 1 0 1 6 9
P A F P G A 2 0 1 0 4 5
P A F P G A 1 0 1 0 1 6 8
P A F P G A 2 0 1 0 4 6
P A F P G A 1 0 1 0 1 6 7
P A F P G A 2 0 1 0 4 7
P A F P G A 1 0 1 0 1 6 6
P A F P G A 2 0 1 0 4 8
P A F P G A 1 0 1 0 1 6 5
P A F P G A 2 0 1 0 4 9
P A F P G A 1 0 1 0 1 6 4
P A F P G A 2 0 1 0 5 5
P A F P G A 1 0 1 0 1 6 3
P A F P G A 2 0 1 0 5 6
P A F P G A 1 0 1 0 1 6 1
P A F P G A 2 0 1 0 5 7
P A J P 5 0 3 0 2
P A J P 5 0 4 0 3
P A T P 2 0 1 0 1
P A F P G A 1 0 1 0 1 6 0
P A F P G A 2 0 1 0 5 8
P A J P 5 0 3 0 3
P A J P 5 0 4 0 2
P A T P 2 0 2 0 1
P A F P G A 1 0 1 0 1 5 9
P A F P G A 2 0 1 0 5 9
P A F P G A 1 0 1 0 1 5 3
P A F P G A 2 0 1 0 6 0
P A F P G A 1 0 1 0 1 5 2
P A F P G A 2 0 1 0 6 1
P A F P G A 1 0 1 0 1 5 1
P A F P G A 2 0 1 0 6 3
P A F P G A 1 0 1 0 1 5 0
P A F P G A 2 0 1 0 6 4
P A F P G A 1 0 1 0 1 4 9
P A F P G A 2 0 1 0 6 6
P A F P G A 1 0 1 0 1 4 8
P A F P G A 2 0 1 0 6 7
P A F P G A 1 0 1 0 1 4 7
P A F P G A 2 0 1 0 6 8
P A F P G A 1 0 1 0 1 4 6
P A F P G A 2 0 1 0 6 9
P A F P G A 1 0 1 0 1 4 5
P A F P G A 2 0 1 0 7 0
P A F P G A 1 0 1 0 1 4 4
P A F P G A 2 0 1 0 7 3
P A F P G A 1 0 1 0 1 4 3
P A F P G A 2 0 1 0 7 4
P A F P G A 1 0 1 0 1 3 9
P A F P G A 2 0 1 0 7 5
P A F P G A 1 0 1 0 1 3 8
P A F P G A 2 0 1 0 7 6
P A F P G A 1 0 1 0 1 3 7
P A F P G A 2 0 1 0 7 7
P A F P G A 1 0 1 0 1 3 6
P A F P G A 2 0 1 0 7 8
P A F P G A 1 0 1 0 1 3 5
P A F P G A 2 0 1 0 7 9
P A F P G A 1 0 1 0 1 3 4
P A F P G A 2 0 1 0 8 0
P A F P G A 1 0 1 0 1 3 2
P A F P G A 2 0 1 0 8 2
P A F P G A 1 0 1 0 1 2 9
P A F P G A 2 0 1 0 8 3
P A F P G A 1 0 1 0 1 2 8
P A F P G A 2 0 1 0 8 4
P A F P G A 1 0 1 0 1 2 7
P A F P G A 2 0 1 0 8 5
P A F P G A 1 0 1 0 1 2 5
P A F P G A 2 0 1 0 8 6
P A F P G A 1 0 1 0 1 2 4
P A F P G A 2 0 1 0 8 7
P A F P G A 1 0 1 0 1 2 1
P A F P G A 2 0 1 0 9 0
P A P B 1 0 1 0 2
P A R 1 0 5 0 1
P A J P 5 0 1 0 4
P A R 5 0 1 0 2
P A T P 5 0 4 0 1
P A X V R 5 0 1 0 7P A J P 5 0 1 0 3
P A R 5 0 1 0 1 P A T P 5 0 5 0 1
P A X V R 5 0 1 0 6
P A J P 5 0 2 0 4
P A R 5 0 3 0 2
P A T P 5 0 9 0 1
P A X V R 5 0 2 0 7P A J P 5 0 2 0 3
P A R 5 0 3 0 1 P A T P 5 0 1 0 0 1
P A X V R 5 0 2 0 6
P A J P 5 0 4 0 1
P A T P 5 0 2 0 1P A X V R 5 0 1 0 4
P A F P G A 1 0 1 0 2 0 3
P A J P 5 0 4 0 4
P A J P 5 0 3 0 1
P A T P 5 0 1 0 1P A X V R 5 0 1 0 1 P A F P G A 1 0 1 0 2 0 4
P A J P 5 0 3 0 4
P A F P G A 1 0 1 0 2 0 5
P A T P 5 0 7 0 1P A X V R 5 0 2 0 4
P A F P G A 1 0 1 0 2 0 6
P A T P 5 0 6 0 1P A X V R 5 0 2 0 1
P A D U T 0 S R A M 0 1 7
P A F P G A 1 0 1 0 8 3
P A D U T 0 S R A M 0 3 7
P A F P G A 1 0 1 0 6 9
P A D U T 0 S R A M 0 3 8
P A F P G A 1 0 1 0 6 8
P A D U T 0 S R A M 0 1 9
P A F P G A 1 0 1 0 8 5
P A C O N 0 F L A S H 0 H 0 2 9
P A C O N 0 S R A M 0 H 0 7
P A F P G A 2 0 1 0 1 5
P A C O N 0 F L A S H 0 H 0 3 1
P A C O N 0 S R A M 0 H 0 8
P A F P G A 2 0 1 0 1 3
P A C O N 0 F L A S H 0 H 0 3 3
P A C O N 0 S R A M 0 H 0 9
P A F P G A 2 0 1 0 1 1
P A C O N 0 F L A S H 0 H 0 3 5
P A C O N 0 S R A M 0 H 0 1 0
P A F P G A 2 0 1 0 9
P A C O N 0 F L A S H 0 H 0 3 8
P A C O N 0 S R A M 0 H 0 1 3
P A F P G A 2 0 1 0 7
P A C O N 0 F L A S H 0 H 0 4 0
P A C O N 0 S R A M 0 H 0 1 4
P A F P G A 2 0 1 0 5
P A C O N 0 F L A S H 0 H 0 4 2
P A C O N 0 S R A M 0 H 0 1 5
P A F P G A 2 0 1 0 2 0 6
P A C O N 0 F L A S H 0 H 0 4 4
P A C O N 0 S R A M 0 H 0 1 6
P A F P G A 2 0 1 0 2 0 4
P A C O N 0 F L A S H 0 H 0 3 0
P A C O N 0 S R A M 0 H 0 2 9
P A F P G A 2 0 1 0 1 4
P A C O N 0 F L A S H 0 H 0 3 2
P A C O N 0 S R A M 0 H 0 3 0
P A F P G A 2 0 1 0 1 2
P A C O N 0 F L A S H 0 H 0 3 4
P A C O N 0 S R A M 0 H 0 3 1
P A F P G A 2 0 1 0 1 0
P A C O N 0 F L A S H 0 H 0 3 6
P A C O N 0 S R A M 0 H 0 3 2
P A F P G A 2 0 1 0 8
P A C O N 0 F L A S H 0 H 0 3 9
P A C O N 0 S R A M 0 H 0 3 5
P A F P G A 2 0 1 0 6
P A C O N 0 F L A S H 0 H 0 4 1
P A C O N 0 S R A M 0 H 0 3 6
P A F P G A 2 0 1 0 4
P A C O N 0 F L A S H 0 H 0 4 3
P A C O N 0 S R A M 0 H 0 3 7
P A F P G A 2 0 1 0 2 0 5
P A C O N 0 F L A S H 0 H 0 4 5
P A C O N 0 S R A M 0 H 0 3 8
P A F P G A 2 0 1 0 2 0 3
P A C O N 0 F L A S H 0 L 0 2 9
P A C O N 0 S R A M 0 L 0 7
P A F P G A 2 0 1 0 1 6 4
P A C O N 0 F L A S H 0 L 0 3 1
P A C O N 0 S R A M 0 L 0 8
P A F P G A 2 0 1 0 1 6 1
P A C O N 0 F L A S H 0 L 0 3 3
P A C O N 0 S R A M 0 L 0 9
P A F P G A 2 0 1 0 1 5 9
P A C O N 0 F L A S H 0 L 0 3 5
P A C O N 0 S R A M 0 L 0 1 0
P A F P G A 2 0 1 0 1 5 2
P A C O N 0 F L A S H 0 L 0 3 8
P A C O N 0 S R A M 0 L 0 1 3
P A F P G A 2 0 1 0 1 5 0
P A C O N 0 F L A S H 0 L 0 4 0
P A C O N 0 S R A M 0 L 0 1 4
P A F P G A 2 0 1 0 1 4 8
P A C O N 0 F L A S H 0 L 0 4 2
P A C O N 0 S R A M 0 L 0 1 5
P A F P G A 2 0 1 0 1 4 6
P A C O N 0 F L A S H 0 L 0 4 4
P A C O N 0 S R A M 0 L 0 1 6
P A F P G A 2 0 1 0 1 4 4
P A C O N 0 F L A S H 0 L 0 3 0
P A C O N 0 S R A M 0 L 0 2 9
P A F P G A 2 0 1 0 1 6 3
P A C O N 0 F L A S H 0 L 0 3 2
P A C O N 0 S R A M 0 L 0 3 0
P A F P G A 2 0 1 0 1 6 0
P A C O N 0 F L A S H 0 L 0 3 4
P A C O N 0 S R A M 0 L 0 3 1
P A F P G A 2 0 1 0 1 5 3
P A C O N 0 F L A S H 0 L 0 3 6
P A C O N 0 S R A M 0 L 0 3 2
P A F P G A 2 0 1 0 1 5 1
P A C O N 0 F L A S H 0 L 0 3 9
P A C O N 0 S R A M 0 L 0 3 5
P A F P G A 2 0 1 0 1 4 9
P A C O N 0 F L A S H 0 L 0 4 1
P A C O N 0 S R A M 0 L 0 3 6
P A F P G A 2 0 1 0 1 4 7
P A C O N 0 F L A S H 0 L 0 4 3
P A C O N 0 S R A M 0 L 0 3 7
P A F P G A 2 0 1 0 1 4 5
P A C O N 0 F L A S H 0 L 0 4 5
P A C O N 0 S R A M 0 L 0 3 8
P A F P G A 2 0 1 0 1 4 3
P A D U T 0 S R A M 0 3 9
P A F P G A 1 0 1 0 6 7
P A D U T 0 S R A M 0 1 5
P A F P G A 1 0 1 0 8 0P A D U T 0 F L A S H 0 1
P A J P 8 0 1 0 2
P A R 8 0 1 0 2
P A D U T 0 F L A S H 0 7
P A J P 8 0 1 0 5
P A D U T 0 F L A S H 0 3
P A J P 8 0 1 0 4
P A F P G A 2 0 1 0 1 3 9
P A P 3 0 5 0 3
P A P 3 0 6 0 3
P A T P 3 0 6 0 1
P A D U T 0 F L A S H 0 6
P A J P 8 0 1 0 6
P A D U T 0 F L A S H 0 5
P A J P 8 0 1 0 7
P A D U T 0 F L A S H 0 2
P A J P 8 0 1 0 3
P A F P G A 2 0 1 0 1 3 6
P A R 6 0 1 0 2
P A U 6 0 1 0 3 0
P A F P G A 2 0 1 0 1 3 5
P A U 6 0 1 0 3 1
P A F P G A 2 0 1 0 1 2 8
P A R 6 0 2 0 2
P A F P G A 2 0 1 0 1 2 5
P A R 6 0 3 0 2
P A F P G A 2 0 1 0 1 1 8
P A R 6 0 4 0 2
P A F P G A 2 0 1 0 1 1 6
P A U 6 0 1 0 3
P A F P G A 2 0 1 0 1 1 5
P
A U 6 0 1 0 4
P A F P G A 2 0 1 0 1 1 4
P A U 6 0 1 0 5
P A F P G A 2 0 1 0 1 1 3
P
A U 6 0 1 0 6
P A F P G A 2 0 1 0 1 1 7
P
A U 6 0 1 0 2
P A F P G A 2 0 1 0 1 3 2
P A R 6 0 5 0 2
P A F P G A 2 0 1 0 1 2 4
P A R 6 0 6 0 2
P A F P G A 2 0 1 0 1 2 1
P A R 6 0 7 0 2
P A F P G A 2 0 1 0 1 2 0
P A R 6 0 8 0 2
P A F P G A 2 0 1 0 1 1 9
P A R 6 0 9 0 2
P A F P G A 2 0 1 0 1 2 7
P A R 6 0 1 0 0 2
P A F P G A 2 0 1 0 1 2 9
P A R 6 0 1 1 0 2
P A R 6 0 1 2 0 2
P A F P G A 2 0 1 0 1 3 8
P A R 6 0 1 3 0 2
P A F P G A 2 0 1 0 1 1 2
P A R 6 0 1 4 0 1
P
A U 6 0 1 0 7
P A F P G A 2 0 1 0 1 3 7
P A R 6 0 2 0 0 2
P A U 6 0 1 0 2 9
P A F P G A 2 0 1 0 1 3 4
P A U 6 0 1 0 3 4
P A F P G A 1 0 1 0 1 0 1
P A J P 1 0 1 0 1
P A R 1 0 2 0 2 P A F P G A 1 0 1 0 1 0 2
P A J P 1 0 1 0 9
P A F P G A 1 0 1 0 1 0 8 P A J P 1 0 1 0 3
P A F P G A 1 0 1 0 1 0 3
P A J P 1 0 1 0 5
P A F P G A 1 0 1 0 1 0 9
P A J P 1 0 1 0 8
P A R 1 0 3 0 2
P A C 1 0 2 7 0 2
P A F P G A 1 0 1 0 1 1 0
P A J P 1 0 1 0 6
P A R 1 0 1 0 2
P A C 1 0 2 5 0 2
P A C 1 0 2 6 0 2
P A F P G A 1 0 1 0 1 0 6
P A J P 1 0 1 0 7
P A R 1 0 4 0 1
P A F P G A 2 0 1 0 1 0 1
P A J P 2 0 1 0 1
P A R 2 0 2 0 2 P A F P G A 2 0 1 0 1 0 2
P A J P 2 0 1 0 9
P A F P G A 2 0 1 0 1 0 8
P A J P 2 0 1 0 3
P A F P G A 2 0 1 0 1 0 3
P A J P 2 0 1 0 5
P A F P G A 2 0 1 0 1 0 9
P A J P 2 0 1 0 8
P A R 2 0 3 0 2
P A C 2 0 2 7 0 2
P A F P G A 2 0 1 0 1 1 0
P A J P 2 0 1 0 6
P A R 2 0 1 0 2
P A C 2 0 2 5 0 2
P A C 2 0 2 6 0 2
P A F P G A 2 0 1 0 1 0 6
P A J P 2 0 1 0 7
P A R 2 0 4 0 1
P A C O N 0 F L A S H 0 H 0 2 6
P A C O N 0 F L A S H 0 L 0 2 6
P A F P G A 2 0 1 0 2 0 2
P A R 9 0 2 0 1
P A F P G A 1 0 1 0 1 9 8
P A J P 8 0 1 0 1 0
P A F P G A 1 0 1 0 1 9 4P A J P 8 0 1 0 1 3
P A C O N 0 F L A S H 0 H 0 2 8
P A C O N 0 F L A S H 0 L 0 2 8
P A F P G A 2 0 1 0 2 0 1
P A C 8 0 1 0 2
P A C 8 0 2 0 2
P A D U T 0 F L A S H 0 8
P A J P 8 0 1 0 1
P A R 8 0 1 0 1
P A C O N 0 F L A S H 0 H 0 1 2
P A C O N 0 F L A S H 0 L 0 1 2
P A F P G A 2 0 1 0 1 8 4
P A R 9 0 1 0 2
P A C O N 0 F L A S H 0 H 0 1 1
P A C O N 0 F L A S H 0 L 0 1 1
P A F P G A 2 0 1 0 1 8 8
P A F P G A 1 0 1 0 1 9 6P A J P 8 0 1 0 1 2
P A C 1 0 1 0 1
P A C 1 0 2 0 1
P A C 1 0 3 0 1
P A C 1 0 4 0 1
P A C 1 0 5 0 1
P A C 1 0 6 0 1
P A C 1 0 7 0 1
P A C 1 0 8 0 1
P A C 1 0 9 0 1
P A C 1 0 1 0 0 1
P A C 1 0 1 1 0 1
P A C 1 0 1 2 0 1
P A C 1 0 1 3 0 1
P A C 1 0 1 4 0 1
P A C 1 0 1 5 0 1
P A C 1 0 1 6 0 1
P A C 1 0 1 7 0 1
P A C 1 0 1 8 0 1
P A C 1 0 1 9 0 1
P A C 1 0 2 0 0 1
P A C 1 0 2 1 0 1
P A C 1 0 2 2 0 1
P A C 1 0 2 3 0 1
P A C 1 0 2 4 0 1
P A C 1 0 2 5 0 1
P A C 1 0 2 6 0 1
P A C 1 0 2 7 0 1
P A C 1 0 2 8 0 1
P A C 1 0 2 9 0 1
P A C 1 0 3 0 0 1
P A C 2 0 1 0 1
P A C 2 0 2 0 1
P A C 2 0 3 0 1
P A C 2 0 4 0 1
P A C 2 0 5 0 1
P A C 2 0 6 0 1
P A C 2 0 7 0 1
P A C 2 0 8 0 1
P A C 2 0 9 0 1
P A C 2 0 1 0 0 1
P A C 2 0 1 1 0 1
P A C 2 0 1 2 0 1
P A C 2 0 1 3 0 1
P A C 2 0 1 4 0 1
P A C 2 0 1 5 0 1
P A C 2 0 1 6 0 1
P A C 2 0 1 7 0 1
P A C 2 0 1 8 0 1
P A C 2 0 1 9 0 1
P A C 2 0 2 0 0 1
P A C 2 0 2 1 0 1
P A C 2 0 2 2 0 1
P A C 2 0 2 3 0 1
P A C 2 0 2 4 0 1
P A C 2 0 2 5 0 1
P A C 2 0 2 6 0 1
P A C 2 0 2 7 0 1
P A C 2 0 2 8 0 1
P A C 2 0 2 9 0 1
P A C 2 0 3 0 0 1
P A C 3 0 1 0 1P A C 3 0 2 0 1
P A C 3 0 3 0 1
P A C 3 0 4 0 1
P A C 3 0 5 0 1
P A C 3 0 6 0 1
P A C 3 0 7 0 1
P A C 3 0 8 0 1
P A C 3 0 9 0 1
P A C 3 0 1 0 0 1
P A C 3 0 1 1 0 1
P A C 3 0 1 2 0 1
P A C 5 0 1 0 1
P A C 5 0 2 0 1
P A C 6 0 1 0 1
P A C 6 0 2 0 1
P A C 6 0 3 0 1
P A C 6 0 4 0 1
P A C 6 0 5 0 1
P A C 6 0 6 0 1
P A C 6 0 7 0 1
P A C 6 0 8 0 1
P A C 6 0 9 0 1
P A C 6 0 1 0 0 1
P A C 6 0 1 1 0 1
P A C 6 0 1 2 0 1
P A C 6 0 1 3 0 1
P A C 6 0 1 4 0 1
P A C 8 0 1 0 1
P A C 8 0 2 0 1
P A C 8 0 3 0 1
P A C 8 0 4 0 1
P A C 8 0 5 0 1
P A C 8 0 6 0 1
P A C 8 0 7 0 1
P A C 8 0 8 0 1
P A C 8 0 9 0 1
P A C 9 0 1 0 1
P A C 9 0 2 0 1
P A C 9 0 3 0 1
P A C 9 0 4 0 1
P A C 9 0 5 0 1
P A C 9 0 6 0 1
P A C O N 0 F L A S H 0 H 0 2 7
P A C O N 0 F L A S H 0 H 0 4 6
P A C O N 0 F L A S H 0 L 0 2 7
P A C O N 0 F L A S H 0 L 0 4 6
P A C O N 0 S R A M 0 H 0 1 2
P A C O N 0 S R A M 0 H 0 2 8
P A C O N 0 S R A M 0 H 0 3 4
P A C O N 0 S R A M 0 L 0 1 2
P A C O N 0 S R A M 0 L 0 2 8
P A C O N 0 S R A M 0 L 0 3 4
P A D U T 0 F L A S H 0 4
P A D U T 0 S R A M 0 6
P A D U T 0 S R A M 0 1 2
P A D U T 0 S R A M 0 2 8
P A D U T 0 S R A M 0 4 1
P A D U T 0 S R A M 0 4 6
P A D U T 0 S R A M 0 5 2
P A D U T 0 S R A M 0 5 4P A F P G A 1 0 1 0 1
P A F P G A 1 0 1 0 2
P A F P G A 1 0 1 0 1 7
P A F P G A 1 0 1 0 2 5
P A F P G A 1 0 1 0 2 9
P A F P G A 1 0 1 0 4 1
P A F P G A 1 0 1 0 5 1
P A F P G A 1 0 1 0 5 2
P A F P G A 1 0 1 0 5 4
P A F P G A 1 0 1 0 6 5
P A F P G A 1 0 1 0 8 1
P A F P G A 1 0 1 0 9 7 P A F P G A 1 0 1 0 1 0 0
P A F P G A 1 0 1 0 1 0 5
P A F P G A 1 0 1 0 1 0 7
P A F P G A 1 0 1 0 1 2 2
P A F P G A 1 0 1 0 1 3 0
P A F P G A 1 0 1 0 1 3 3
P A F P G A 1 0 1 0 1 4 1
P A F P G A 1 0 1 0 1 5 5
P A F P G A 1 0 1 0 1 5 6
P A F P G A 1 0 1 0 1 5 8
P A F P G A 1 0 1 0 1 6 2
P A F P G A 1 0 1 0 1 7 8
P A F P G A 1 0 1 0 1 9 5
P A F P G A 1 0 1 0 2 0 7
P A F P G A 2 0 1 0 1
P A F P G A 2 0 1 0 2
P A F P G A 2 0 1 0 1 7
P A F P G A 2 0 1 0 2 5
P A F P G A 2 0 1 0 2 9
P A F P G A 2 0 1 0 4 1
P A F P G A 2 0 1 0 5 1
P A F P G A 2 0 1 0 5 2
P A F P G A 2 0 1 0 5 4
P A F P G A 2 0 1 0 6 5
P A F P G A 2 0 1 0 8 1
P A F P G A 2 0 1 0 9 7 P A F P G A 2 0 1 0 1 0 0
P A F P G A 2 0 1 0 1 0 5
P A F P G A 2 0 1 0 1 0 7
P A F P G A 2 0 1 0 1 2 2
P A F P G A 2 0 1 0 1 3 0
P A F P G A 2 0 1 0 1 3 3
P A F P G A 2 0 1 0 1 4 1
P A F P G A 2 0 1 0 1 5 5
P A F P G A 2 0 1 0 1 5 6
P A F P G A 2 0 1 0 1 5 8
P A F P G A 2 0 1 0 1 6 2
P A F P G A 2 0 1 0 1 7 8
P A F P G A 2 0 1 0 1 9 5
P A F P G A 2 0 1 0 2 0 7
P A J P 1 0 1 0 2
P A J P 1 0 1 0 1 0
P A J P 1 0 2 0 9
P A J P 1 0 3 0 1
P A J P 1 0 3 0 1 6
P A J P 2 0 1 0 2
P A J P 2 0 1 0 1 0
P A J P 2 0 2 0 9
P A J P 3 0 1 0 2
P A J P 5 0 1 0 2P A J P 5 0 1 0 5
P A J P 5 0 2 0 2P A J P 5 0 2 0 5
P A J P 8 0 1 0 8
P A O P 4 0 1 0 1 1
P A P 3 0 1 0 1
P A P 3 0 2 0 1
P A P 3 0 3 0 1
P A P 3 0 4 0 1
P A P 3 0 5 0 2
P A P 3 0 6 0 2
P A P B 1 0 1 0 1
P A R 1 0 2 0 1
P A R 1 0 3 0 1
P A R 2 0 2 0 1
P A R 2 0 3 0 1
P A R 3 0 5 0 1
P A R 3 0 6 0 1
P A R 4 0 3 0 1
P A R 4 0 5 0 1
P A R 4 0 6 0 1
P A R 4 0 1 1 0 1
P A R 5 0 2 0 2
P A R 5 0 4 0 2
P A R 6 0 1 2 0 1
P A R 6 0 1 4 0 2
P A R 6 0 1 9 0 1
P A R 6 0 2 0 0 1
P A R 9 0 1 0 1
P A U 4 0 1 0 1 1
P A U 4 0 2 0 2
P A U 4 0 3 0 2
P A U 4 0 4 0 2
P A U 4 0 5 0 4
P A U 4 0 5 0 5
P A U 4 0 5 0 6
P A U 4 0 5 0 7
P A U 4 0 7 0 4
P A U 4 0 7 0 5
P A U 4 0 7 0 7
P A U 6 0 1 0 1 5
P A U 6 0 1 0 1 9
P A U 6 0 1 0 3 5
P A U 6 0 1 0 3 6
P A U 6 0 1 0 4 7
P A X 1 0 1 0 2
P A X 2 0 1 0 2
P A X V R 5 0 1 0 2
P A X V R 5 0 2 0 2
P A J P 7 0 1 0 9
P A P B 7 0 1 0 1
P A Q 7 0 1 0 2
P A Q 7 0 2 0 2
P A Q 7 0 3 0 2
P A Q 7 0 4 0 2
P A Q 7 0 5 0 2
P A Q 7 0 6 0 2
P A Q 7 0 7 0 2
P A Q 7 0 8 0 2 P A J P 7 0 2 0 9
P A P B 7 0 2 0 1
P A Q 7 0 9 0 2
P A Q 7 0 1 0 0 2
P A Q 7 0 1 1 0 2P A Q 7 0 1 2 0 2
P A Q 7 0 1 3 0 2P A Q 7 0 1 4 0 2
P A Q 7 0 1 5 0 2P A Q 7 0 1 6 0 2
P A F P G A 1 0 1 0 1 1 8
P A J P 1 0 2 0 5
P A F P G A 1 0 1 0 1 1 7
P A J P 1 0 2 0 6
P A F P G A 1 0 1 0 1 2 0
P A J P 1 0 2 0 7
P A F P G A 1 0 1 0 1 1 9
P A J P 1 0 2 0 8
P A F P G A 2 0 1 0 9 2
P A J P 2 0 2 0 5
P A F P G A 2 0 1 0 9 8
P A J P 2 0 2 0 6
P A F P G A 2 0 1 0 9 1
P A J P 2 0 2 0 7
P A F P G A 2 0 1 0 9 9
P A J P 2 0 2 0 8
P A J P 7 0 1 0 1
P A J P 7 0 3 0 1 P A J P 7 0 3 0 2
P A Q 7 0 1 0 1
P A J P 7 0 1 0 2
P A Q 7 0 2 0 1
P A J P 7 0 1 0 3 P A Q 7 0 3 0 1
P A J P 7 0 1 0 4
P A Q 7 0 4 0 1
P A J P 7 0 1 0 5 P A Q 7 0 5 0 1
P A J P 7 0 1 0 6
P A Q 7 0 6 0 1
P A J P 7 0 1 0 7 P A Q 7 0 7 0 1
P A J P 7 0 1 0 8
P A Q 7 0 8 0 1
P A J P 7 0 2 0 1
P A J P 7 0 4 0 1 P A J P 7 0 4 0 2
P A Q 7 0 9 0 1
P A J P 7 0 2 0 2
P A Q 7 0 1 0 0 1
P A J P 7 0 2 0 3 P A Q 7 0 1 1 0 1
P A J P 7 0 2 0 4
P A Q 7 0 1 2 0 1
P A J P 7 0 2 0 5 P A Q 7 0 1 3 0 1
P A J P 7 0 2 0 6
P A Q 7 0 1 4 0 1
P A J P 7 0 2 0 7 P A Q 7 0 1 5 0 1
P A J P 7 0 2 0 8
P A Q 7 0 1 6 0 1
P A C 6 0 5 0 2
P A C 6 0 6 0 2
P A C 6 0 7 0 2
P A C 6 0 8 0 2
P A U 6 0 1 0 1 8
P A U 6 0 1 0 2 3P A U 6 0 1 0 3 7
P A C 6 0 1 3 0 2
P A J P 6 0 1 0 7
P A J P 6 0 1 0 8
P A J P 6 0 1 0 9
P A D 7 0 1 0 2
P A R 7 0 1 0 2
P A D 7 0 2 0 2
P A R 7 0 2 0 2
P A D 7 0 3 0 2
P A R 7 0 3 0 2
P A D 7 0 4 0 2
P A R 7 0 4 0 2
P A D 7 0 5 0 2
P A R 7 0 5 0 2
P A D 7 0 6 0 2
P A R 7 0 6 0 2
P A D 7 0 7 0 2
P A R 7 0 7 0 2
P A D 7 0 8 0 2
P A R 7 0 8 0 2
P A D 7 0 9 0 2
P A R 7 0 9 0 2
P A D 7 0 1 0 0 2
P A R 7 0 1 0 0 2
P A D 7 0 1 1 0 2
P A R 7 0 1 1 0 2
P A D 7 0 1 2 0 2
P A R 7 0 1 2 0 2
P A D 7 0 1 3 0 2
P A R 7 0 1 3 0 2
P A D 7 0 1 4 0 2
P A R 7 0 1 4 0 2
P A D 7 0 1 5 0 2
P A R 7 0 1 5 0 2
P A D 7 0 1 6 0 2
P A R 7 0 1 6 0 2
P A F P G A 1 0 1 0 4
P A J P 1 0 3 0 2
P A F P G A 1 0 1 0 5
P A J P 1 0 3 0 3
P A F P G A 1 0 1 0 6
P A J P 1 0 3 0 4
P A F P G A 1 0 1 0 7
P A J P 1 0 3 0 5
P A F P G A 1 0 1 0 8
P A J P 1 0 3 0 6
P A F P G A 1 0 1 0 9
P A J P 1 0 3 0 7
P A F P G A 1 0 1 0 1 0
P A J P 1 0 3 0 8
P A F P G A 1 0 1 0 1 1
P A J P 1 0 3 0 9
P A F P G A 1 0 1 0 1 2
P A J P 1 0 3 0 1 0
P A F P G A 1 0 1 0 1 3
P A J P 1 0 3 0 1 1
P A F P G A 1 0 1 0 1 4
P A J P 1 0 3 0 1 2
P A F P G A 1 0 1 0 1 5
P A J P 1 0 3 0 1 3
P A F P G A 1 0 1 0 1 9
P A J P 1 0 3 0 1 4
P A F P G A 1 0 1 0 2 0
P A J P 1 0 3 0 1 5
P A O P 4 0 1 0 3
P A R 4 0 5 0 2
P A U 4 0 3 0 1
P A O P 4 0 1 0 5
P A R 4 0 3 0 2
P A U 4 0 2 0 1
P A O P 4 0 1 0 1 0
P A R 4 0 6 0 2
P A U 4 0 4 0 1
P A P 3 0 2 0 3
P A P 3 0 5 0 5
P A P 3 0 4 0 3P A P 3 0 6 0 5
P A P 3 0 5 0 4
P A R 3 0 5 0 2
P A P 3 0 6 0 4
P A R 3 0 6 0 2
P A Q 7 0 1 0 3
P A R 7 0 1 0 1P A Q 7 0 2 0 3
P A R 7 0 2 0 1
P A Q 7 0 3 0 3
P A R 7 0 3 0 1P A Q 7 0 4 0 3
P A R 7 0 4 0 1
P A Q 7 0 5 0 3
P A R 7 0 5 0 1P A Q 7 0 6 0 3
P A R 7 0 6 0 1
P A Q 7 0 7 0 3 P A R 7 0 7 0 1
P A Q 7 0 8 0 3P A R 7 0 8 0 1
P A Q 7 0 9 0 3
P A R 7 0 9 0 1P A Q 7 0 1 0 0 3
P A R 7 0 1 0 0 1
P A Q 7 0 1 1 0 3
P A R 7 0 1 1 0 1P A Q 7 0 1 2 0 3
P A R 7 0 1 2 0 1
P A Q 7 0 1 3 0 3
P A R 7 0 1 3 0 1P A Q 7 0 1 4 0 3
P A R 7 0 1 4 0 1
P A Q 7 0 1 5 0 3 P A R 7 0 1 5 0 1
P A Q 7 0 1 6 0 3P A R 7 0 1 6 0 1
P A R 5 0 2 0 1
P A X V R 5 0 1 0 8
P A R 5 0 4 0 1
P A X V R 5 0 2 0 8
P A R 6 0 2 0 1
P A U 6 0 1 0 4 0
P A R 6 0 3 0 1
P A U 6 0 1 0 4 2
P A R 6 0 4 0 1
P
A U 6 0 1 0 1
P A R 6 0 5 0 1
P A U 6 0 1 0 3 8
P A R 6 0 6 0 1
P A U 6 0 1 0 4 3
P A R 6 0 7 0 1
P A U 6 0 1 0 4 4
P A R 6 0 8 0 1
P A U 6 0 1 0 4 5
P A R 6 0 9 0 1
P A U 6 0 1 0 4 6
P A R 6 0 1 0 0 1
P A U 6 0 1 0 4 1
P A R 6 0 1 1 0 1
P A U 6 0 1 0 3 9
P A R 6 0 1 3 0 1
P A U 6 0 1 0 2 5
P A R 6 0 1 9 0 2
P A U 6 0 1 0 2 4
P A R 7 0 1 7 0 2
P A R 7 0 1 8 0 1
P A R 7 0 1 9 0 2
P A R 7 0 2 0 0 1
P A J P 7 0 3 0 3
P A P B 7 0 1 0 2 P A R 7 0 1 7 0 1 P A J P 7 0 4 0 3P A P B 7 0 2 0 2 P A R 7 0 1 9 0 1
P A D 7 0 1 0 1
P A D 7 0 2 0 1
P A D 7 0 3 0 1
P A D 7 0 4 0 1
P A D 7 0 5 0 1
P A D 7 0 6 0 1
P A D 7 0 7 0 1
P A D 7 0 8 0 1 P A J P 7 0 1 0 1 0
P A R 7 0 1 8 0 2
P A D 7 0 9 0 1
P A D 7 0 1 0 0 1
P A D 7 0 1 1 0 1
P A D 7 0 1 2 0 1
P A D 7 0 1 3 0 1
P A D 7 0 1 4 0 1
P A D 7 0 1 5 0 1
P A D 7 0 1 6 0 1 P A J P 7 0 2 0 1 0
P A R 7 0 2 0 0 2
P A D U T 0 S R A M 0 1 8
P A F P G A 1 0 1 0 8 4
P A J P 6 0 1 0 3P A R 6 0 1 7 0 2
P A U 6 0 1 0 1 4
P A J P 6 0 1 0 6
P A R 6 0 1 8 0 2
P A U 6 0 1 0 1 3
P A D U T 0 S R A M 0 2 3
P A F P G A 1 0 1 0 9 1
P A D U T 0 S R A M 0 2 4
P A F P G A 1 0 1 0 9 2
P A D U T 0 S R A M 0 2 5
P A F P G A 1 0 1 0 9 3
P A D U T 0 S R A M 0 2 6
P A F P G A 1 0 1 0 9 4
P A D U T 0 S R A M 0 2 9
P A F P G A 1 0 1 0 7 9
P A D U T 0 S R A M 0 3 0
P A F P G A 1 0 1 0 7 8
P A D U T 0 S R A M 0 3 1
P A F P G A 1 0 1 0 7 7
P A D U T 0 S R A M 0 3 2
P A F P G A 1 0 1 0 7 6
P A D U T 0 S R A M 0 3 3
P A F P G A 1 0 1 0 7 5
P A D U T 0 S R A M 0 3 4
P A F P G A 1 0 1 0 7 4
P A D U T 0 S R A M 0 2 2
P A F P G A 1 0 1 0 9 0
P A D U T 0 S R A M 0 3 5
P A F P G A 1 0 1 0 7 3
P A D U T 0 S R A M 0 3 6
P A F P G A 1 0 1 0 7 0
P A F P G A 2 0 1 0 2 0
P A R 2 0 6 0 2
P A R 2 0 8 0 1
P A T P 2 0 6 0 1
P A U 4 0 1 0 9P A U 4 0 5 0 2
P A U 4 0 7 0 2
P A D U T 0 S R A M 0 2
P A F P G A 1 0 1 0 4 4 P A D U T 0 S R A M 0 4
P A F P G A 1 0 1 0 4 5
P A D U T 0 S R A M 0 5
P A F P G A 1 0 1 0 4 6
P A D U T 0 S R A M 0 7
P A F P G A 1 0 1 0 4 7
P A D U T 0 S R A M 0 8
P A F P G A 1 0 1 0 4 8
P A D U T 0 S R A M 0 1 0
P A F P G A 1 0 1 0 4 9
P A D U T 0 S R A M 0 1 1
P A F P G A 1 0 1 0 5 5
P A D U T 0 S R A M 0 1 3
P A F P G A 1 0 1 0 5 6
P A D U T 0 S R A M 0 4 2P A F P G A 1 0 1 0 6 6
P A D U T 0 S R A M 0 4 4P A F P G A 1 0 1 0 6 4 P A D U T 0 S R A M 0 4 5P A F P G A 1 0 1 0 6 3
P A D U T 0 S R A M 0 4 7P A F P G A 1 0 1 0 6 1
P A D U T 0 S R A M 0 4 8P A F P G A 1 0 1 0 6 0
P A D U T 0 S R A M 0 5 0
P A F P G A 1 0 1 0 5 9
P A D U T 0 S R A M 0 5 1
P A F P G A 1 0 1 0 5 8
P A D U T 0 S R A M 0 5 3
P A F P G A 1 0 1 0 5 7
P A F P G A 2 0 1 0 1 9
P A R 2 0 5 0 2
P A R 2 0 7 0 1
P A T P 2 0 5 0 1
P A U 4 0 1 0 1 0P A U 4 0 5 0 1
P A U 4 0 7 0 1
P A F P G A 1 0 1 0 1 9 3P A J P 8 0 1 0 1 4
P A F P G A 1 0 1 0 1 9 7
P A J P 8 0 1 0 1 1 P A F P G A 1 0 1 0 1 9 2
P A J P 8 0 1 0 1 5
P A C O N 0 S R A M 0 H 0 6
P A C O N 0 S R A M 0 L 0 6
P A F P G A 2 0 1 0 1 8 1
P A C O N 0 S R A M 0 H 0 4 1
P A C O N 0 S R A M 0 L 0 4 1
P A F P G A 2 0 1 0 1 9 9
P A C O N 0 S R A M 0 H 0 3 9
P A F P G A 2 0 1 0 1 9 7
P A C O N 0 S R A M 0 H 0 4 0
P A F P G A 2 0 1 0 1 9 8
P A C O N 0 S R A M 0 L 0 3 9
P A F P G A 2 0 1 0 1 6 6
P A C O N 0 S R A M 0 L 0 4 0
P A F P G A 2 0 1 0 1 6 5
P A C O N 0 S R A M 0 H 0 1 7
P A C O N 0 S R A M 0 L 0 1 7
P A F P G A 2 0 1 0 1 7 4 P A O P 4 0 1 0 8
P A O P 4 0 1 0 9
P A T P 4 0 3 0 1
P A U 4 0 1 0 5
P A J P 6 0 1 0 1
P A R 6 0 1 5 0 2
P A U 6 0 1 0 1 7
P A J P 6 0 1 0 2
P A R 6 0 1 6 0 2
P A U 6 0 1 0 1 6
P A F P G A 2 0 1 0 9 4
P A J P 2 0 2 0 1
P A F P G A 2 0 1 0 9 5
P A J P 2 0 2 0 2
P A F P G A 2 0 1 0 9 3
P A J P 2 0 2 0 3
P A F P G A 2 0 1 0 9 6
P A J P 2 0 2 0 4
P A F P G A 1 0 1 0 1 1 4
P A J P 1 0 2 0 1
P A F P G A 1 0 1 0 1 1 3
P A J P 1 0 2 0 2
P A F P G A 1 0 1 0 1 1 6
P A J P 1 0 2 0 3
P A F P G A 1 0 1 0 1 1 5
P A J P 1 0 2 0 4
P A J P 3 0 1 0 1
P A R 4 0 7 0 1 P A T P 3 0 1 0 1
P A U 4 0 4 0 3
P A R 4 0 1 0 0 1
P A R 4 0 1 1 0 2
P A U 4 0 1 0 1 6
P A C 3 0 1 0 2
P A C 3 0 2 0 2
P A C 3 0 3 0 2
P A C 3 0 4 0 2
P A P 3 0 1 0 3
P A P 3 0 3 0 3
P A P 3 0 5 0 1
P A P 3 0 6 0 1 P A R 4 0 7 0 2
P A R 4 0 1 0 0 2
P A U 4 0 4 0 4
P A D U T 0 S R A M 0 1 6
P A F P G A 1 0 1 0 8 2
Figure B.12 – Bottom layer of the PCB, excluding ground plane
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX B. PCB SCHEMATICS 114
11
22
33
44
D
D
C
C
B
B
A
A
Ti
tle
N
um
be
r
R
ev
is
io
n
Si
ze A
4
D
at
e:
20
13
/0
7/
11
Sh
ee
t  
  o
f
Fi
le
:
C
:\D
ro
pb
ox
\..
\U
ar
tA
dd
In
.S
ch
D
oc
D
ra
w
n 
B
y:
V
in
3
V
ou
t
2
GND
1
3V
3
G
N
D
C
S
1
SC
L
2
D
3
Q
4
GND
5
O
R
G
6
N
C
7
VCC
8
93
C
46
G
N
D
3V
3
3V
3
V
U
SB
G
N
D
EE
C
S
EE
C
LK
EE
D
A
TA
O
12
K
R
3
12
K
R
4
12
K
R
53
V
3
2.
2K
R
6
EE
D
A
TA
I
EE
C
S
3V
3
EE
D
A
TA
O
EE
D
A
TA
I
EE
C
LK
10
0n
F
C
17
G
N
D
3V
3
3V
3
V
PL
L
V
PH
Y
1V
8
3V
3
1V
8
4.
7u
F
C
3
4.
7u
F
C
4
4.
7u
F
C
5
30
0 
O
hm
L1 30
0 
O
hm
L2
3V
3
3V
3
10
0n
F
C
6
10
0n
F
C
7
G
N
D
G
N
DV
PH
Y
V
PL
L
10
0n
F
C
1
10
0n
F
C
2
G
N
D
10
0n
F
C
8
10
0n
F
C
9
10
0n
F
C
10
10
0n
F
C
11
10
0n
F
C
12
10
0n
F
C
13
10
0n
F
C
14
G
N
D
G
N
D
1V
8
3V
3
2.
2K
R
1
G
N
D
12
K
R
2
0R
0
1
2
X
TA
L
10
0n
F
C
15
10
0n
F
C
16
G
N
D
G
N
D
V
U
SB
G
N
D
V
U
SB
1
D
M
2
D
P
3
ID
4
G
N
D
5
U
SB
GND
1
O
SC
I
2
O
SC
O
3
VPHY
4
GND
5
R
EF
6
D
M
7
D
P
8
VPLL
9
AGND
10
GND
11
VCORE
12
TE
ST
13
R
ES
ET
14
GND
15
TX
16
R
X
17
R
TS
18
C
TS
19
VCCIO
20
D
TR
21
D
SR
22
D
C
D
23
R
I/T
X
D
EN
24
GND
25
TX
26
R
X
27
R
TS
28
C
TS
29
D
TR
30
VCCIO
31
D
SR
32
D
C
D
33
R
I/T
X
D
EN
34
GND
35
SU
SP
EN
D
36
VCORE
37
TX
38
R
X
39
R
TS
40
C
TS
41
VCCIO
42
D
TR
43
D
SR
44
D
C
D
45
R
I/T
X
D
EN
46
GND
47
TX
48
V
R
EG
O
U
T
49
V
R
EG
IN
50
GND
51
R
X
52
R
TS
53
C
TS
54
D
TR
55
VCCIO
56
D
SR
57
D
C
D
58
R
I/T
X
D
EN
59
PW
R
EN
60
EE
D
A
TA
61
EE
C
LK
62
EE
C
S
63
VCORE
64
FT
42
32
H
G
N
D
G
N
D
R
X
1
R
X
3
5
5
7
7
G
N
D
9
TX
2
TX
4
6
6
8
8
3V
3
10
R
X
11
R
X
13
15
15
17
17
G
N
D
19
TX
12
TX
14
16
16
18
18
3V
3_
D
U
T
20
JP
1
2x
 2
x5
 H
ea
de
r
TX
1
R
X
1
TX
2
R
X
2
TX
3
R
X
3
TX
4
R
X
4
TX
1
TX
2
R
X
2
R
X
1
TX
3
TX
4
R
X
4
R
X
3
PI3V301
P
I
3
V
3
0
2
P
I
3
V
3
0
3
CO
3V3
P
I
93
C4
60
1
P
I
93
C4
60
2
P
I
93
C4
60
3
P
I
93
C4
60
4
PI93C4605
P
I
93
C4
60
6
P
I
93
C4
60
7
PI93C4608 CO9
3C
46
PIC101PIC102
COC
1
PIC201PIC202
COC
2
PI
C3
01
PI
C3
02
COC
3
PIC401PIC402
COC
4
PIC501PIC502
COC
5
PIC601PIC602
COC
6
PIC701PIC702
COC
7
PIC801PIC802
COC
8
PIC901PIC902
COC
9
PIC1001PIC1002
CO
C10
PIC1101PIC1102
CO
C11
PIC1201PIC1202
CO
C12
PIC1301PIC1302
CO
C13
PIC1401PIC1402
CO
C14
PIC1501PIC1502
CO
C15
PIC1601PIC1602
CO
C16
PIC1701PIC1702
CO
C17
PIFT4232H01
PI
FT
42
32
H0
2
PI
FT
42
32
H0
3
PIFT4232H04
PIFT4232H05
PI
FT
42
32
H0
6
PI
FT
42
32
H0
7
PI
FT
42
32
H0
8
PIFT4232H09 PIFT4232H010
PIFT4232H011PIFT4232H012
PI
FT
42
32
H0
13
PI
FT
42
32
H0
14
PIFT4232H015
PI
FT
42
32
H0
16
PI
FT
42
32
H0
17
PI
FT
42
32
H0
18
PI
FT
42
32
H0
19
PIFT4232H020
PI
FT
42
32
H0
21
PI
FT
42
32
H0
22
PI
FT
42
32
H0
23
PI
FT
42
32
H0
24
PIFT4232H025
PI
FT
42
32
H0
26
PI
FT
42
32
H0
27
PI
FT
42
32
H0
28
PI
FT
42
32
H0
29
PI
FT
42
32
H0
30
PIFT4232H031
PI
FT
42
32
H0
32
PI
FT
42
32
H0
33
PI
FT
42
32
H0
34
PIFT4232H035
PI
FT
42
32
H0
36
PIFT4232H037
PI
FT
42
32
H0
38
PI
FT
42
32
H0
39
PI
FT
42
32
H0
40
PI
FT
42
32
H0
41
PIFT4232H042
PI
FT
42
32
H0
43
PI
FT
42
32
H0
44
PI
FT
42
32
H0
45
PI
FT
42
32
H0
46
PIFT4232H047
PI
FT
42
32
H0
48
PI
FT
42
32
H0
49
PI
FT
42
32
H0
50
PIFT4232H051
PI
FT
42
32
H0
52
PI
FT
42
32
H0
53
PI
FT
42
32
H0
54
PI
FT
42
32
H0
55
PIFT4232H056
PI
FT
42
32
H0
57
PI
FT
42
32
H0
58
PI
FT
42
32
H0
59
PI
FT
42
32
H0
60
PI
FT
42
32
H0
61
PI
FT
42
32
H0
62
PI
FT
42
32
H0
63
PIFT4232H064
CO
FT
42
32
H
P
I
J
P
1
0
1
P
I
J
P
1
0
2
P
I
J
P
1
0
3
P
I
J
P
1
0
4
P
I
J
P
1
0
5
P
I
J
P
1
0
6
P
I
J
P
1
0
7
P
I
J
P
1
0
8
P
I
J
P
1
0
9
P
I
J
P
1
0
1
0
P
I
J
P
1
0
1
1
P
I
J
P
1
01
2
P
I
J
P
1
0
1
3
P
I
J
P
1
01
4
P
I
J
P
1
0
1
5
P
I
J
P
1
01
6
P
I
J
P
1
0
1
7
P
I
J
P
1
01
8
P
I
J
P
1
0
1
9
P
I
J
P
1
02
0CO
JP1
PI
L1
01
PI
L1
02
COL
1
PI
L2
01
PI
L2
02
COL
2
PI
R0
01
PI
R0
02
COR
0
PI
R1
01
PI
R1
02
COR
1
PI
R2
01
PI
R2
02
COR
2
PIR301 PIR302C
OR3
PIR401 PIR402C
OR4
PIR501 PIR502C
OR5
PI
R6
01
PI
R6
02
COR
6
P
I
U
S
B
0
1
P
I
U
S
B
0
2
P
I
U
S
B
0
3
P
I
U
S
B
0
4
P
I
U
S
B
0
5
PIUSB06PIUSB07PI
USB08PIUSB09COU
SB
PI
XT
AL
01
PI
XT
AL
02 C
OX
TA
L
PI
C3
02
PIC802
PIC902
PIC1002
PIFT4232H012PIFT4232H037
PI
FT
42
32
H0
49
PIFT4232H064
P
I
3
V
3
0
2
P
I
93
C4
60
6
PI93C4608
PIC202
PIC1102
PIC1202
PIC1302
PIC1402
PIC1702
PIFT4232H020PIFT4232H031PIFT4
232H042
PI
FT
42
32
H0
50
PIFT4232H056
PI
L1
01
PI
L2
01
PI
R1
02
PIR301
PIR401
PIR501
P
I
93
C4
60
2
PI
FT
42
32
H0
62
PIR402
NL
EE
CL
K
P
I
93
C4
60
1
PI
FT
42
32
H0
63
PIR302
NL
EE
CS
P
I
93
C4
60
4
PIR502 PIR6
01
NL
EE
DA
TA
I
P
I
93
C4
60
3
PI
FT
42
32
H0
61
PI
R6
02
NL
EE
DA
TA
O
PI3V301
PI93C4605PIC101
PIC201
PI
C3
01
PIC401 PIC501
PIC601PIC701
PIC801
PIC901
PIC1001
PIC1101
PIC1201
PIC1301
PIC1401
PIC1501
PIC1601
PIC1701
PIFT4232H01PIFT4232H05
PIFT4232H010
PIFT4232H011
PI
FT
42
32
H0
13
PIFT4232H015PIFT4232H025PIF
T4232H035PIFT4232H047PIFT42
32H051
P
I
J
P
1
0
9
P
I
J
P
1
0
1
9
PI
R0
02
PI
R2
01
P
I
U
S
B
0
5
P
I
93
C4
60
7
PIC1502
PI
FT
42
32
H0
2
PI
XT
AL
02
PIC1602
PI
FT
42
32
H0
3
PI
XT
AL
01
PI
FT
42
32
H0
6
PI
R2
02PI
FT
42
32
H0
7
P
I
U
S
B
0
2
PI
FT
42
32
H0
8
P
I
U
S
B
0
3
PI
FT
42
32
H0
14
PI
R1
01
PI
FT
42
32
H0
18
PI
FT
42
32
H0
19
PI
FT
42
32
H0
21
PI
FT
42
32
H0
22
PI
FT
42
32
H0
23
PI
FT
42
32
H0
24
PI
FT
42
32
H0
28
PI
FT
42
32
H0
29
PI
FT
42
32
H0
30
PI
FT
42
32
H0
32
PI
FT
42
32
H0
33
PI
FT
42
32
H0
34
PI
FT
42
32
H0
36
PI
FT
42
32
H0
40
PI
FT
42
32
H0
41
PI
FT
42
32
H0
43
PI
FT
42
32
H0
44
PI
FT
42
32
H0
45
PI
FT
42
32
H0
46
PI
FT
42
32
H0
53
PI
FT
42
32
H0
54
PI
FT
42
32
H0
55
PI
FT
42
32
H0
57
PI
FT
42
32
H0
58
PI
FT
42
32
H0
59
PI
FT
42
32
H0
60
P
I
J
P
1
0
5
P
I
J
P
1
0
6
P
I
J
P
1
0
7
P
I
J
P
1
0
8
P
I
J
P
1
0
1
0
P
I
J
P
1
0
1
5
P
I
J
P
1
01
6
P
I
J
P
1
0
1
7
P
I
J
P
1
01
8
P
I
J
P
1
02
0
PI
R0
01
PIUSB06PIUSB07PI
USB08PIUSB09
P
I
U
S
B
0
4
PI
FT
42
32
H0
17
P
I
J
P
1
0
2NL
RX
1
PI
FT
42
32
H0
27
P
I
J
P
1
0
4NL
RX
2
PI
FT
42
32
H0
39
P
I
J
P
1
01
4
NL
RX
3
PI
FT
42
32
H0
52
P
I
J
P
1
01
2
NL
RX
4
PI
FT
42
32
H0
16
P
I
J
P
1
0
1
NL
TX
1
PI
FT
42
32
H0
26
P
I
J
P
1
0
3
NL
TX
2
PI
FT
42
32
H0
38
P
I
J
P
1
0
1
3NL
TX
3
PI
FT
42
32
H0
48
P
I
J
P
1
0
1
1NL
TX
4
PIC402
PIC702
PIFT4232H04
PI
L1
02 PIC502
PIC602
PIFT4232H09
PI
L2
02
P
I
3
V
3
0
3
PIC102
P
I
U
S
B
0
1
Figure B.13 – Schematic Showing the Connection of the UART Daughter-Board
Stellenbosch University  http://scholar.sun.ac.za
Appendix C
Source of XML Sprite
 
1 <?xml version="1.0"?>
<!DOCTYPE flash -device SYSTEM "flash -device.dtd">
<!--//////////////////////////////////////////
5 // Company: Stellenbosch University: Electronic Systems
Laboratory
//
// File: st -m29w160eb -2x8.xml
// File history:
// v0.9: 22 -07 -2013: First Model. Working , but not
complete
10 //
// Description:
//
// This file is a template used by the 8051 Debug Tools’s
Sprite which programs
// the external flash. Each template is unique to the flash
chip used. This
15 // one is writen for ST Microelectronics ’s M29W160EB Flash Chip
.
//
// To use this file , copy it to
// <Softconsole Directory >\Sourcery -G++\ share\sprite\flash\
// and add the following line to the Memory Map Generator
Command
20 // -M ..\st -m29w160eb -2x8 -code -memory.txt
// and place the st -m29w160eb -2x8 -code -memory.txt file inside
your project
//
// Author: Emile Jacobus Thesnaar
115
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX C. SOURCE OF XML SPRITE 116
// Email: 15416909 @sun.ac.za (ejt@live.co.za)
25 //
////////////////////////////////////////////////// -->
<flash -device identifier="st -m29w160eb -2x8">
<flash -device -version >1.1</flash -device -version >
30 <short -name>ST M29W160EB (2x8)</short -name>
<description >
The ST M29W160EB flash memory device.
This flash device description was written to support
35 a single flash part connected in 8-bit mode.
</description >
<manufacturer -id id="0x0020" />
<device -id id="0x2249" />
40
<!-- Commands go in as single 8-bit words. -->
<define -const name="TARGET_WIDTH"
value="1"/>
<!-- Single side in 8-bit mode -->
45 <!-- The M29W160EB can be up to 32x64k erase blocks ,
but the 8051
is only able to access 64k of it...i.e., about
half of one full
erase block on the device. By defining ERASE -
ALL -BLOCKS for a
single initial command , we can speed things up
dramatically by
making much smaller individual block sizes
used to compare the
50 existing memory contents. -->
<define -const name="NB_OF_BLOCKS"
value="32" />
<define -const name="BLOCK_BYTE_SIZE"
value="0x100" />
<!-- We do 8-bit writes in this version. -->
55 <memory -size blocks -symbol="NB_OF_BLOCKS"
size -symbol="BLOCK_BYTE_SIZE"
cell -size="0x8"/>
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX C. SOURCE OF XML SPRITE 117
<define -const name="READY_DELAY"
value="1"/>
60
<!-- Commands -->
<!-- Reset Command -->
<define -const name="RESET"
value="0xF0
"/>
65 <!-- Program Command -->
<define -const name="PROGRAM_FIRST_ADDRESS"
value="0x800555"/>
<define -const name="PROGRAM_FIRST_DATA"
value="0xAA"/>
<define -const name="PROGRAM_SECOND_ADDRESS"
value="0x8002AA"/>
<define -const name="PROGRAM_SECOND_DATA"
value="0x55"/>
70 <define -const name="PROGRAM_THIRD_ADDRESS"
value="0x800555"/>
<define -const name="PROGRAM_THIRD_DATA"
value="0xA0"/>
<!-- Erase Command -->
<define -const name="ERASE_FIRST_ADDRESS"
value="0x800555"/>
75 <define -const name="ERASE_FIRST_DATA"
value="0xAA"/>
<define -const name="ERASE_SECOND_ADDRESS"
value="0x8002AA"/>
<define -const name="ERASE_SECOND_DATA"
value="0x55"/>
<define -const name="ERASE_THIRD_ADDRESS"
value="0x800555"/>
<define -const name="ERASE_THIRD_DATA"
value="0x80"/>
80 <define -const name="ERASE_FOURTH_ADDRESS"
value="0x800555"/>
<define -const name="ERASE_FOURTH_DATA"
value="0xAA"/>
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX C. SOURCE OF XML SPRITE 118
<define -const name="ERASE_FIFTH_ADDRESS"
value="0x8002AA"/>
<define -const name="ERASE_FIFTH_DATA"
value="0x55"/>
<define -const name="ERASE_SIXTH_ADDRESS"
value="0x800555"/>
85 <define -const name="ERASE_SIXTH_DATA"
value="0x10"/>
<define -const name="ERASE_ADDRESS"
value="0x800000"/>
<define -const name="ERASE_SUCCESS"
value="0xFF"/>
<define -const name="ERASE_DELAY"
value="48000"/>
90
<!-- <program -init/> -->
<program >
<!-- Look to be given three arguments. -->
95 <keep -arg name="ADDRESS"/>
<keep -arg name="DATA"/>
<keep -arg name="SIZE"/>
<local -var name="NB_BYTES"/>
100 <until counter -name="NB_BYTES" limit -symbol="
SIZE">
<!-- Write Program command and data -->
<write -value width -symbol="TARGET_WIDTH
" address -symbol="
PROGRAM_FIRST_ADDRESS" value -symbol
="PROGRAM_FIRST_DATA"/>
<write -value width -symbol="TARGET_WIDTH
" address -symbol="
PROGRAM_SECOND_ADDRESS" value -
symbol="PROGRAM_SECOND_DATA"/>
105 <write -value width -symbol="TARGET_WIDTH
" address -symbol="
PROGRAM_THIRD_ADDRESS" value -symbol
="PROGRAM_THIRD_DATA"/>
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX C. SOURCE OF XML SPRITE 119
<write -data address -symbol="ADDRESS"
data -addr -symbol="DATA" width="1"/>
<!-- Do some checking here -->
110 <!-- We do a single byte at a time. -->
<incr name="ADDRESS" value="1"/>
<incr name="DATA" value="1"/>
<incr name="NB_BYTES" value="1"/>
</until>
115
</program >
<!-- <program -fini/> -->
120 <!-- <block -erase/> -->
<erase -all -blocks >
<!-- Write chip erase command -->
<write -value width -symbol="TARGET_WIDTH"
address -symbol="ERASE_FIRST_ADDRESS" value -
symbol="ERASE_FIRST_DATA"/>
125
<write -value width -symbol="TARGET_WIDTH"
address -symbol="ERASE_SECOND_ADDRESS" value
-symbol="ERASE_SECOND_DATA"/>
<write -value width -symbol="TARGET_WIDTH"
address -symbol="ERASE_THIRD_ADDRESS" value -
symbol="ERASE_THIRD_DATA"/>
130 <write -value width -symbol="TARGET_WIDTH"
address -symbol="ERASE_FOURTH_ADDRESS" value
-symbol="ERASE_FOURTH_DATA"/>
<write -value width -symbol="TARGET_WIDTH"
address -symbol="ERASE_FIFTH_ADDRESS" value -
symbol="ERASE_FIFTH_DATA"/>
<write -value width -symbol="TARGET_WIDTH"
address -symbol="ERASE_SIXTH_ADDRESS" value -
symbol="ERASE_SIXTH_DATA"/>
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX C. SOURCE OF XML SPRITE 120
135
<check -status >
<!-- Wait till Finish -->
<local -var name="CHECK" init="0x00"/>
<wait -for address -symbol="ERASE_ADDRESS
" timeout -symbol="ERASE_DELAY">
140 <expect -bit value="
ERASE_SUCCESS" width -symbol
="TARGET_WIDTH"/>
</wait -for>
</check -status >
</erase -all -blocks >
145
<!-- <reset/> -->
<!-- <unlock -block/> -->
150 </flash -device > 
Listing C.1 – Sprite for SoftConsole to program memory
Stellenbosch University  http://scholar.sun.ac.za
Appendix D
Libero Design
Figure D.1 – Final Libero Design for the Device Under Test
121
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX D. LIBERO DESIGN 122
Figure D.2 – Final Libero Design for the Controller
Stellenbosch University  http://scholar.sun.ac.za
Appendix E
Simulation Waveforms
This page has been left blank intentionally.
123
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX E. SIMULATION WAVEFORMS 124
ed
b
ed
f
Oc
9
Od
9
5P
M
5O
M
7c
b
78
b
95
b
95
a
be
a
be
8
df
O
d7
O
fD
8
fD
a
D7
f
M7
e
ee
f
ea
ea
O8
O8
56
56
78
78
9a
bc
de
fD
Df
Mf
ed
Me DD
Mg
DD
M5
DD
M6
DD
M7
DD
M8
DD
M9
DD
Ma
DD
Mb
DD
Mc
DD
Md
DD
ed
ea
O8
56
78
9a
bc
de
fD
Df
Mf
ed
MD
6O
8D
Dr
ns
MD
6P
OD
Dr
ns
MD
6P
6D
Dr
ns
MD
6g
DD
Dr
ns
:c
an
_t
es
tb
en
ch
:T
w
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:fi
fo
ed
b
ed
f
Oc
9
Od
9
5P
M
5O
M
7c
b
78
b
95
b
95
a
be
a
be
8
df
O
d7
O
fD
8
fD
a
D7
f
M7
e
ee
f
yyy
st
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:d
at
a_
ou
t_
fif
o
ea
ea
O8
O8
56
56
78
78
9a
bc
de
fD
Df
Mf
ed
yyy
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:b
it_
D_
po
s_
m
at
ch
yyy
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:b
it_
M_
po
s_
m
at
ch
yyy
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:b
it_
O_
po
s_
m
at
ch
yyy
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:b
it_
P_
po
s_
m
at
ch
yyy
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:b
it_
g_
po
s_
m
at
ch
yyy
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:b
it_
5_
po
s_
m
at
ch
yyy
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:b
it_
6_
po
s_
m
at
ch
yyy
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:b
it_
7_
po
s_
m
at
ch
:c
an
_t
es
tb
en
ch
:S
Y
S
C
LK
:c
an
_t
es
tb
en
ch
:N
S
Y
S
R
E
S
E
T
:c
an
_t
es
tb
en
ch
:a
m
ba
M_
da
t_
i
Me
:c
an
_t
es
tb
en
ch
:a
m
ba
M_
ad
r_
i
DD
Mg
DD
M5
DD
M6
DD
M7
DD
M8
DD
M9
DD
Ma
DD
Mb
DD
Mc
DD
Md
DD
:c
an
_t
es
tb
en
ch
:a
m
ba
M_
en
a_
i
:c
an
_t
es
tb
en
ch
:a
m
ba
M_
se
l_
i
:c
an
_t
es
tb
en
ch
:a
m
ba
M_
w
e_
i
:c
an
_t
es
tb
en
ch
:a
m
ba
M_
da
t_
o
ed
ea
O8
56
78
9a
bc
de
fD
Df
Mf
ed
yyy
te
st
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:\p
os
iti
on
[P
]
yyy
te
st
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:\p
os
iti
on
[O
]
yyy
te
st
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:\p
os
iti
on
[M
]
yyy
te
st
be
nc
h:
Tw
oC
A
N
to
p_
D:
i_
ca
n_
to
p:
i_
ca
n_
fif
o:
da
ta
_d
ec
od
er
:\p
os
iti
on
[D
]
E
nt
ity
:c
an
_t
es
tb
en
ch
rA
rc
hi
te
ct
ur
e:
rD
at
e:
rM
on
rO
ct
rM
gr
D7
:5
g:
Dg
rA
M
rS
ou
th
rA
fri
ca
rS
ta
nd
ar
dr
Ti
m
er
OD
MP
r
R
ow
:rM
rP
ag
e:
rM
Figure E.1 – Timing Diagram of the Mitigated CAN Controller’s FIFO Module With Injected
Errors Showing Mitigation and Hamming Code Recovery
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX E. SIMULATION WAVEFORMS 125
LL
LK
LL
LL
LL
LL
LL
KK
LL
LL
KL
LK
LL
LL
KK
LL
LL
LL
LL
LL
LL
LK
KL
LL
LL
LL
LL
LL
LL
LK
KL
LL
LL
LL
LL
LL
LL
LK
KL
LL
LL
LL
LL
LL
LL
LK
KL
LL
LL
LL
LL
LL
LL
LL
LL
LK
LL
LL
KK
LK
LL
LL
KL
:4
LL
LL
LI
ps
:5
LL
LL
LI
ps
:f
LL
LL
LI
ps
:P
LL
LL
LI
ps
DL
LL
LL
LI
ps
DK
LL
LL
LI
ps
jjj
st
be
nc
hY
Tw
oC
A
N
to
p_
LY
i_
ca
n_
to
pY
i_
B
U
S
_T
IM
IN
G
_L
_R
E
G
Yd
at
a_
in
_m
x_
L_
w
jjj
hY
Tw
oC
A
N
to
p_
LY
i_
ca
n_
to
pY
i_
B
U
S
_T
IM
IN
G
_L
_R
E
G
Yd
at
a_
ou
t_
ba
nk
_K
_L
_w
jjj
hY
Tw
oC
A
N
to
p_
LY
i_
ca
n_
to
pY
i_
B
U
S
_T
IM
IN
G
_L
_R
E
G
Yd
at
a_
ou
t_
ba
nk
_:
_L
_w
jjj
hY
Tw
oC
A
N
to
p_
LY
i_
ca
n_
to
pY
i_
B
U
S
_T
IM
IN
G
_L
_R
E
G
Yd
at
a_
ou
t_
ba
nk
_D
_L
_w
jjj
st
be
nc
hY
Tw
oC
A
N
to
p_
LY
i_
ca
n_
to
pY
i_
B
U
S
_T
IM
IN
G
_L
_R
E
G
Ye
rr
or
_b
an
k_
L_
w
jjj
es
tb
en
ch
YT
w
oC
A
N
to
p_
LY
i_
ca
n_
to
pY
i_
B
U
S
_T
IM
IN
G
_L
_R
E
G
Ye
rr
or
_c
om
bi
ne
d
Yc
an
_t
es
tb
en
ch
YT
w
oC
A
N
to
p_
LY
i_
ca
n_
to
pY
i_
B
U
S
_T
IM
IN
G
_L
_R
E
G
Yre
g_
en
ab
le
jjj
ch
YT
w
oC
A
N
to
p_
LY
i_
ca
n_
to
pY
i_
B
U
S
_T
IM
IN
G
_L
_R
E
G
Yre
g_
w
e_
bu
s_
tim
in
g_
L
jjj
tb
en
ch
YT
w
oC
A
N
to
p_
LY
i_
ca
n_
to
pY
i_
B
U
S
_T
IM
IN
G
_L
_R
E
G
Ys
yn
c_
ju
m
p_
w
id
th
LL
LK
Yc
an
_t
es
tb
en
ch
YT
w
oC
A
N
to
p_
LY
i_
ca
n_
to
pY
i_
B
U
S
_T
IM
IN
G
_L
_R
E
G
Yb
au
d_
r_
pr
es
c
LL
LL
LL
LL
LL
KK
LL
LL
KL
Yc
an
_t
es
tb
en
ch
YS
Y
S
C
LK
Yc
an
_t
es
tb
en
ch
YN
S
Y
S
R
E
S
E
T
Yc
an
_t
es
tb
en
ch
Ya
m
ba
K_
da
t_
i
LK
LL
LL
KK
LL
LL
LL
LL
Yc
an
_t
es
tb
en
ch
Ya
m
ba
K_
ad
r_
i
LL
LL
LK
KL
LL
LL
LL
LL
LL
LL
LK
KL
LL
LL
LL
LL
LL
LL
LK
KL
LL
LL
LL
LL
LL
LL
LK
KL
LL
LL
LL
LL
Yc
an
_t
es
tb
en
ch
Ya
m
ba
K_
en
a_
i
Yc
an
_t
es
tb
en
ch
Ya
m
ba
K_
se
l_
i
Yc
an
_t
es
tb
en
ch
Ya
m
ba
K_
w
e_
i
Yc
an
_t
es
tb
en
ch
Ya
m
ba
K_
da
t_
o
LL
LL
LL
LL
LK
LL
LL
KK
LK
LL
LL
KL
E
nt
ity
:c
an
_t
es
tb
en
ch
IA
rc
hi
te
ct
ur
e:
ID
at
e:
IF
riI
O
ct
IK
fI
KL
:F
::
O4
IA
M
IS
ou
th
IA
fri
ca
IS
ta
nd
ar
dI
Ti
m
eI
:L
KD
I
R
ow
:IK
IP
ag
e:
IK
Figure E.2 – Timing Diagram of the Mitigated CAN Controller’s Bus Timing 0 Register
With Injected Errors Showing Mitigation and TMR Recovery
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX E. SIMULATION WAVEFORMS 126
00
...
00
...
00
...
00
00
00
00
00
00
00
00
0.
..
0.
..
00
00
00
00
00
00
00
00
0.
..
0.
..
0.
..
00
11
11
10
11
11
11
11
00
...
00
...
0.
..
00
00
00
00
00
00
00
00
0.
..
00
...
0.
..
00
00
00
00
00
00
00
00
0.
..
00
...
0.
..
11
11
11
11
00
11
11
10
00
...
0.
..
0.
..
11
10
11
01
11
10
11
01
0u
ps
10
00
00
00
00
up
s
/c
an
_t
es
tb
en
ch
/N
S
Y
S
R
E
S
E
T
/c
an
_t
es
tb
en
ch
/s
ta
rt_
tb
/c
an
_t
es
tb
en
ch
/a
m
ba
1_
da
t_
i
00
...
00
...
00
...
00
00
00
00
00
00
00
00
/c
an
_t
es
tb
en
ch
/a
m
ba
1_
ad
r_
i
0.
..
0.
..
00
00
00
00
00
00
00
00
/c
an
_t
es
tb
en
ch
/a
m
ba
1_
en
a_
i
/c
an
_t
es
tb
en
ch
/a
m
ba
1_
se
l_
i
/c
an
_t
es
tb
en
ch
/a
m
ba
1_
w
e_
i
/c
an
_t
es
tb
en
ch
/a
m
ba
1_
da
t_
o
0.
..
0.
..
0.
..
00
11
11
10
11
11
11
11
/c
an
_t
es
tb
en
ch
/a
m
ba
2_
da
t_
i
00
...
00
...
0.
..
00
00
00
00
00
00
00
00
/c
an
_t
es
tb
en
ch
/a
m
ba
2_
ad
r_
i
0.
..
00
...
0.
..
00
00
00
00
00
00
00
00
/c
an
_t
es
tb
en
ch
/a
m
ba
2_
en
a_
i
/c
an
_t
es
tb
en
ch
/a
m
ba
2_
se
l_
i
/c
an
_t
es
tb
en
ch
/a
m
ba
2_
w
e_
i
/c
an
_t
es
tb
en
ch
/a
m
ba
2_
da
t_
o
0.
..
00
...
0.
..
11
11
11
11
00
11
11
10
/c
an
_t
es
tb
en
ch
/c
an
1_
tx
_o
/c
an
_t
es
tb
en
ch
/c
an
2_
tx
_o
/c
an
_t
es
tb
en
ch
/c
an
1_
irq
_o
n
/c
an
_t
es
tb
en
ch
/c
an
2_
irq
_o
n
/c
an
_t
es
tb
en
ch
/c
an
1_
bu
s_
of
f_
on
/c
an
_t
es
tb
en
ch
/c
an
2_
bu
s_
of
f_
on
/c
an
_t
es
tb
en
ch
/rx
/c
an
_t
es
tb
en
ch
/rx
_a
nd
_t
x
/c
an
_t
es
tb
en
ch
/d
el
ay
ed
_t
x
/c
an
_t
es
tb
en
ch
/tx
/c
an
_t
es
tb
en
ch
/c
an
1_
tx
_t
m
p
/c
an
_t
es
tb
en
ch
/c
an
2_
tx
_t
m
p
/c
an
_t
es
tb
en
ch
/tm
p_
da
ta
00
...
0.
..
0.
..
11
10
11
01
11
10
11
01
/c
an
_t
es
tb
en
ch
/e
xt
en
de
d_
m
od
e
/c
an
_t
es
tb
en
ch
/re
se
t_
m
od
e
E
nt
ity
:c
an
_t
es
tb
en
ch
uA
rc
hi
te
ct
ur
e:
uD
at
e:
uT
ue
uN
ov
u1
9u
01
:1
0:
23
uP
M
uS
ou
th
uA
fri
ca
uS
ta
nd
ar
du
Ti
m
eu
20
13
u
R
ow
:u1
uP
ag
e:
u1
Figure E.3 – Simulation showing message transmission and reception between the mitigated
and unmitigated CAN controller
Stellenbosch University  http://scholar.sun.ac.za
Appendix F
iThemba Test Log
Time Message
30/10/13 15:00:00 Beam defocussing started, Beam at 1nA
30/10/13 15:00:02 Beam on
Prelimanary Test 1
30/10/13 16:31:20 Test Started, Beam at 1nA, Board at 90o
30/10/13 16:33:20 Test Stopped
Prelimanary Test 2
30/10/13 16:35:02 Test Started, Beam at 1nA, Board at 90o
30/10/13 16:37:02 Test Stopped
31/10/13 16:37:02 1.5V supply to DUT at 11mA
31/10/13 16:37:02 3.3V supply to DUT at 27mA
31/10/13 16:37:02 5.25V supply to Board at 190mA
31/10/13 16:37:02 PCB temp between FPGAs at 29.75 oC
31/10/13 16:37:02 PCB temp at PSUs at 35.06 oC
30/10/13 16:41:02 Beam off
30/10/13 16:41:02 Beam defocussing complete
30/10/13 16:41:02 Power Cycle
30/10/13 16:47:00 Moving DUT to 0o
Test 1
30/10/13 16:48:02 Test Started, Beam turned on at 0.1nA, Board at 0o
30/10/13 16:48:52 Test Aborted due to no particles being measured. This was due
to particle current being to small to measure. DUT was in Beam
for 27 seconds.
30/10/13 16:48:52 Test Stopped, Beam off
31/10/13 16:48:52 Core current to DUT at 12mA, rest normal
Test 2
30/10/13 16:52:34 Test Started, Beam turned on at 0.1nA, Board at 0o
30/10/13 16:54:34 Test Stopped, Beam off
31/10/13 16:54:34 Core current to DUT at 11mA, rest normal
Table F.1 – iThemba Test Logs Part 1
127
Stellenbosch University  http://scholar.sun.ac.za
APPENDIX F. ITHEMBA TEST LOG 128
Test 3
30/10/13 16:56:00 Test Started, Beam turned on at 0.1nA, Board at 0o
30/10/13 17:03:00 Several errors on all CAN controllers noted.
30/10/13 16:58:00 Test Stopped, Beam off
30/10/13 16:59:00 Power Cycle
31/10/13 17:59:00 Core current to DUT at 12mA, rest normal
Test 4
30/10/13 17:00:59 Test Started, Beam turned on at 0.1nA, Board at 0o
30/10/13 17:03:00 Several errors on all CAN controllers noted.
30/10/13 17:03:00 Test Stopped, Beam off
31/10/13 17:03:00 Core current to DUT at 22mA, rest normal
Test 5
30/10/13 17:06:30 Test Started, Beam turned on at 0.1nA, Board at 0o
30/10/13 17:08:30 Test Stopped, Beam off
31/10/13 17:08:30 Core current to DUT at 22mA, rest normal
Test 6
30/10/13 17:11:30 Test Started, Beam turned on at 0.2nA, Board at 0o
30/10/13 17:13:30 Failure in CAN Controller 1 config
30/10/13 17:13:30 Test Stopped, Beam off
31/10/13 17:13:02 1.5V supply to DUT at 26mA
31/10/13 17:13:02 3.3V supply to DUT at 27mA
31/10/13 17:13:02 5.23V supply to Board at 245mA
31/10/13 17:13:02 PCB temp between FPGAs at 29.63 oC
31/10/13 17:13:02 PCB temp at PSUs at 36.81 oC
End of testing. Francois turn
30/10/13 17:16:00 Reprogramming for Francois
30/10/13 17:16:30 Erase Failed, Suspect Cabling or FPGA Damage
Annealing 30/10/13 17:16:30 - 31/10/13 09:31:00
31/10/13 09:31:30 Further attempts at reprogramming failed, even after opening of
Tank.
31/10/13 09:31:30 Damage to Charge Pumps suspected.
31/10/13 09:31:30 Core current to DUT at 22mA, rest normal
Post Failure Tests 1
31/10/13 09:36:40 Test Started, no vaccum and tank open
31/10/13 09:36:50 Failure in all CAN 2 config registers.
31/10/13 09:36:50 Partial erase prior to charge pump failure expected.
31/10/13 09:38:40 Test Stopped
31/10/13 09:38:30 Core current to DUT at 22mA, rest normal
Post Failure Tests 2
31/10/13 09:39:30 Test Started, no vaccum and tank open
31/10/13 09:39:40 Failure in all CAN 2 config registers.
31/10/13 09:41:30 Test Stopped
31/10/13 09:41:45 Power Cycle
31/10/13 09:41:30 Core current to DUT at 22mA, rest normal
Post Failure Tests 3
31/10/13 09:43:30 Test Started, no vaccum and tank open
31/10/13 09:43:40 Failure in all CAN 2 config registers.
31/10/13 09:45:30 Test Stopped
31/10/13 09:45:30 Core current to DUT at 22mA, rest normal
Table F.2 – iThemba Test Logs Part 2
Stellenbosch University  http://scholar.sun.ac.za
