Frame capturing and sending in FPGA by Zahno, Silvan & Corthay, François






















Frame capturing and 






Dozent François Corthay 
 
Experte Prof. Jorgen Nordberg 




Systems Engineering: Infotronic 
 Diploma Work 
 
- Frame Capturing and Sending in FPGA - 
 
Author Zahno Silvan 
Under guidance of Patrik Arlos, Corthay Francois 
Version v 1.0 
Karlskrona, 25.03.08 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 2/49 - 
Table of content 
1 Acknowledgments .................................................................................................................................... 5 
2 Preface ...................................................................................................................................................... 5 
2.1 Introduction ....................................................................................................................................... 5 
2.2 Appendix ............................................................................................................................................ 5 
3 Overview ................................................................................................................................................... 6 
4 Hardware .................................................................................................................................................. 7 
4.1 Interface ............................................................................................................................................ 7 
4.2 Converter ........................................................................................................................................... 9 
4.2.1 Pin assignment on the Controller ............................................................................................ 10 
4.3 Controller ......................................................................................................................................... 11 
4.3.1 Memory ................................................................................................................................... 11 
4.3.2 Arm7 ........................................................................................................................................ 13 
5 Passive Measurement Infrastructure ..................................................................................................... 14 
5.1 MArC ................................................................................................................................................ 15 
5.2 Consumer......................................................................................................................................... 15 
5.3 MP .................................................................................................................................................... 16 
6 Software .................................................................................................................................................. 17 
6.1 CPLD on Interface-board ................................................................................................................. 17 
6.1.1 High-impedance Buffer ............................................................................................................ 18 
6.1.2 RS422 interface ........................................................................................................................ 18 
6.1.3 Serial management interface .................................................................................................. 18 
6.1.4 Phy clock .................................................................................................................................. 19 
6.1.5 Reset gen ................................................................................................................................. 19 
6.1.6 Mac data interface................................................................................................................... 19 
6.1.6.1 Reduce frequency ................................................................................................................ 19 
6.1.6.2 Reduce cross talking ............................................................................................................ 21 
6.2 FPGA on Dev-board ......................................................................................................................... 22 
6.2.1 RAM Structure ......................................................................................................................... 22 
6.2.1.1 Measurement frame ............................................................................................................ 22 
6.2.1.2 Control and Status frames ................................................................................................... 24 
6.2.1.3 Intermediate frame ............................................................................................................. 25 
6.2.1.4 Filter data base structure (FDB) ........................................................................................... 26 
6.2.1.5 Dataflow .............................................................................................................................. 26 
6.2.2 Top-level .................................................................................................................................. 27 
6.2.3 ResetGen ................................................................................................................................. 28 
6.2.4 Capture interface ..................................................................................................................... 28 
6.2.4.1 Synchronization ................................................................................................................... 28 
6.2.4.2 Receiver ............................................................................................................................... 29 
6.2.4.3 Filter ..................................................................................................................................... 30 
6.2.5 Conversion filterrules .............................................................................................................. 32 
6.2.6 Arbiter ...................................................................................................................................... 32 
6.2.7 CI-demux .................................................................................................................................. 34 
6.2.8 Output-choice .......................................................................................................................... 36 
6.2.9 Sender ...................................................................................................................................... 37 
6.2.9.1 Transmitter .......................................................................................................................... 39 
6.2.10 UART ........................................................................................................................................ 41 
6.2.11 TSC ........................................................................................................................................... 43 
7 Tests ........................................................................................................................................................ 45 
8 Actual state ............................................................................................................................................. 45 
9 Further work ........................................................................................................................................... 46 
10 Conclusion and remarks ......................................................................................................................... 47 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 3/49 - 
11 Glossary ................................................................................................................................................... 48 
12 References .............................................................................................................................................. 49 
13 Appendix ................................................................................................................................................. 49 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 4/49 - 
Table of figures 
Fig. 3.1   Bloc diagram of the hardware ............................................................................................................. 6 
Fig. 4.1   Bloc diagram of the Interface .............................................................................................................. 8 
Fig. 4.2   Interfaceboard..................................................................................................................................... 8 
Fig. 4.3   Blocdiagramm of Converter-board ..................................................................................................... 9 
Fig. 4.4   Converterboard ................................................................................................................................... 9 
Fig. 4.5   Table pin assignment ........................................................................................................................ 10 
Fig. 4.6   Table memory overview .................................................................................................................... 11 
Fig. 4.7   RAM block schema ............................................................................................................................ 12 
Fig. 4.8   Table utilization and performance from Arm7 soft core .................................................................. 13 
Fig. 4.9   Actel CoreMP7 Developement Kit .................................................................................................... 13 
Fig. 5.1   Measurement Area ........................................................................................................................... 14 
Fig. 5.2   MArC Interface .................................................................................................................................. 15 
Fig. 5.3   MP schematic overview .................................................................................................................... 16 
Fig. 6.1   Top-level of the CPLD design ............................................................................................................. 17 
Fig. 6.2   Table MII Management Serial Protocol ............................................................................................ 18 
Fig. 6.3   Serial management interface ............................................................................................................ 18 
Fig. 6.4   FSM of serial management interface ................................................................................................ 19 
Fig. 6.5   Mac data interface ............................................................................................................................ 20 
Fig. 6.6   Mac data interface ............................................................................................................................ 21 
Fig. 6.7   Bloc diagram of the dataflow inside the FPGA.................................................................................. 26 
Fig. 6.8   Bloc diagram of the capture interface, the demux and the filters.................................................... 27 
Fig. 6.9   Table I/O signals resetgen ................................................................................................................. 28 
Fig. 6.10 Table Input signals synchronisation .................................................................................................. 28 
Fig. 6.11 Table I/O signals receiver .................................................................................................................. 29 
Fig. 6.12 Table I/O signals receiver .................................................................................................................. 29 
Fig. 6.13 Table I/O signals receiver .................................................................................................................. 30 
Fig. 6.14 Block schema of filter ........................................................................................................................ 31 
Fig. 6.15 Statemachine filter_heart ................................................................................................................. 32 
Fig. 6.16 Table I/O signals arbiter .................................................................................................................... 33 
Fig. 6.17 Statemachine arbiter ........................................................................................................................ 33 
Fig. 6.18 Table I/O signals ci-demux ................................................................................................................ 34 
Fig. 6.19 Block schema of CI-demux ................................................................................................................ 35 
Fig. 6.20 Statemachine CI-demux_heart ......................................................................................................... 36 
Fig. 6.21 Table I/O signals output-choice ........................................................................................................ 37 
Fig. 6.22 Table I/O signals sender .................................................................................................................... 37 
Fig. 6.23 Block schema of sender .................................................................................................................... 38 
Fig. 6.24 Statemachine transmitter_controller ............................................................................................... 39 
Fig. 6.25 Table I/O signals transmitter............................................................................................................. 40 
Fig. 6.26 Block schema of transmitter ............................................................................................................. 40 
Fig. 6.27 Received filterbuffer ......................................................................................................................... 40 
Fig. 6.28 Table I/O signals UART ...................................................................................................................... 41 
Fig. 6.29 Block schema of UART ...................................................................................................................... 41 
Fig. 6.30 Received filterbuffer ......................................................................................................................... 42 
Fig. 6.31 Statemachine UART_heart ................................................................................................................ 42 
Fig. 6.32 Table UART configuration ................................................................................................................. 43 
Fig. 6.33 Time synchronisation network ......................................................................................................... 43 
Fig. 6.34 Table I/O signals TSC ......................................................................................................................... 44 
Fig. 6.35 Block schema of TSC ......................................................................................................................... 44 
Fig. 6.36 Statemachine delay_calc .................................................................................................................. 44 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 5/49 - 
1 Acknowledgments 
First, I would like to thanks all of the people who helped me and gave me the opportunity to come here to 
BTH, Sweden to do my diploma work. 
A special thanks goes to the supervisor and mentor of the project, Patrik Arlos. He assisted me in many 
ways and gave me useful tips during the whole project. 
A big thanks belongs to Francois Corthay and Olivier Gubler, who sent me some required electronic parts 
and helped me a lot with the VHDL programming. 
Everyone of my student colleagues and friends with whom I stayed in contact during my work. They have 
supported me from Ireland, China, Japan and also Switzerland. 




This diploma work is the second part of a project, which began in Switzerland and was continued in 
Karlskrona, Sweden. 
The subject of the Diploma Work is “Frame capturing and sending in FPGA”. In this part of the project, all 
components are brought together and developed into an MP. The hardware, or a part of it, I already made 
during my semester project in Switzerland. It is the sequel of the work in Switzerland. A first prototype of 
an MP was made by Olivier Gubler. He also did his work in Sweden with Patrik Arlos. 
 
The goal is to explore and to develop the functionalities of a MP and then to implement and test these 
functions. For the work I have several hardware available: 
- CoreMP7 Development Kit made by Actel 
- The Interface I created during my semester project 
- Converter which allows to attach the Interface with the Dev-Board 
 
I will also give a small overview on the programs I used during this project. 
- Libero v8.0 
- CoreConsole v1.3 
- SoftConsole (Eclipse) v1.1 
- Xilinx Webpack v9.2 
- HDLDesigner v2002.b 
- Synplify 
 
Before you read this report, it would be useful, if you have already read the semester project report. There 
you have a good overview about the hardware I used. 
 
2.2 Appendix 
Some articles and parts of the work are given in the appendixes. They can be found at the end of the 
report. A few appendixes are just given on the enclosed CD. In chapter 13 you can see a list of all 
appendixes. 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 6/49 - 
3 Overview 
The goal is to build a type of Hardware, called Measurement Point (MP). Such a device does packet 
capturing. Then the captured data will be filtered, and a time stamp added onto each packet. The new 
packet will be stored into a buffer. After all, this packet will be sending in data packets in a measurement 
frame with defined sizes. 
You also have the possibility to send some requests from a GUI called DPMI which was made in BTH by 
Patrik Arlos. This DPMI will analyze the captured packets and make some graphical approaches. 
I will realize this MP with an FPGA, which can implement a microprocessor as an IP soft-core. Therefore, the 
used programming languages are C/C++ and VHDL. 
 
The Ethernet input connections are: 
- 10/100 Copper Ethernet RJ45 
- Fiber Ethernet 100Base-FX (optional) 
 
Because an MP is a passive device to the Ethernet input, it must be invisible to the Measurement Area 
Network (MArN). To do a serious time stamp, an exact time synchronization is needed. Therefore an RS422 
Interface is added, to synchronize with a master’s clock. 
The captured data will also be sent with a 10/100 Copper Ethernet RJ45. The programming interface of the 
board will be done via JTAG interface for the FPGA and also the Soft ARM7-Core. 
 
It should also be possible to exchange the Interface with a different one, so that the input sources can be 
enlarged again; for example, to implement Giga Ethernet or other transmission mediums. For this project, it 
is sufficient to have a 10/100Base –TX or a FX support. However with a new Interface, it is possible to 














 Fig. 3.1   Bloc diagram of the hardware 
 
As discussed with Mr. Arlos, this MP should contain the following functionalities: 
- Auto configure at boot 
- Capture frames 
- Filter frames 
- Build and send measurement frames 
- Send status messages 
- Accept and act according to control messages 
o Add filter 
o Change filter 
o Remove filter 
o Flush buffers 
- Use UDP/IP for messaging 






































Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 7/49 - 
4 Hardware 
 
The Hardware is divided into three main parts: 
- Interface to the MArN 
- Converter between Interface and Controller 
- Controller to generate the captured packets 
 
I will give here just a little overview about the hardware I used during this project. More detailed 
information can be found on the semester project-report. 
 
 Appendix 1 Report Semester project 
 
4.1 Interface 
This part of the hardware submits the captured packages of the MArN-Network to the Controller, without 
changes in the content. The network entrance can be carried out via a 100Base-TX twisted pair, a 10Base-T 
twisted pair or a 100Base-FX fiber (optional). 
This Interface can be used for the following tasks: 
- Active tap :  Both input-lines go directly to the physical Interface (Phy) 
without any influence. 
- Passive tap:  Both Rx-Channels are connected through the high-impedance 
    tap to the Phy. Since we are just listening, we do not need  
    the Tx-Channels 
 
In this project, only the passive tap is in use, because a normal MP is always invisible to the MArN-Network. 
The active tap is to implement functions in the future. 
For example, it would be possible to attach either the twisted pair (TP) or the fiber. There are the following 
possibilities: 
- TPTP:   Both twisted pair inputs are used 
- TPfiber:  One twisted pair and one fiber are used (TP – FX conversion) 
- fiberfiber:  Both fiber inputs are used 
 
In the passive case, it is only possible to attach the twisted pair. It is not possible to listen completely 
passively to the fiber-network. The fiber plug, already do a conversion between the light pulses and the 
electrical Signals. 
- TPTP:   Both twisted pair inputs are used 
 
With Jumpers it is possible to switch the input-line between the RJ45 and the optical fiber input, as well as 
for the switch from the active to the passive tap. This is illustrated in the following picture. 
The schematic is given in the appendix. 
 
 Appendix 2 Schematic Interface 
 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 8/49 - 
Plug RJ45 Plug RJ45Plug Fiber  Plug Fiber

















Tx Rx              Tx Rx
Jumper
Tx Rx              Tx Rx



























































Jumper for switch 
from TP to Fiber
Jumper for passive (P)
 or active (A) tap
JumperJumper
RxP        RxATxP        TxARxA        RxPTxA        TxP
To
CPLD
               Disable
To
CPLD












 Fig. 4.1   Bloc diagram of the Interface 
 
As you can see in the picture above, the board also provides a CPLD to implement some conversions 
between the interface board and the controller board. These conversions must be done to avoid 







 Fig. 4.2   Interfaceboard 
3*32Pin connector 
Ethernet input 
Connect to MArN 





JTAG interface Jumpers Reset 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 9/49 - 
4.2 Converter 
We need a Converter board so that our Interface board is able to connect to the Controller board. A new 
Controller which can be done in future works, could attached directly to the Interface without using the 
Converter board. However, in my case, I use a prefabricated Dev board as Controller and therefore, I have 
to use the Converter board. 
This converter has on one side a 96-Pin connector for the connection with the Interface and on the other 
side, three 40Pin connectors to attach the Controller. The connectors on the Controller board also offer 
several powerlines, like 5V, 3.3V and GND. Therefore, we do not need the external 5V connector in the 










































To Interface board 
To Controller board 
Power test pins 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 10/49 - 
4.2.1 Pin assignment on the Controller 
With the help of the Converter board, the signals of the Interface, which belongs together, can be 
consolidated on one or several I/O Banks of the Controller. 
The pin assignment of the different signals are shown in the following table. 
 
Pin from Interface 
Signal description Number of pins Pin of the Header I/O Bank of the Controller 
Header J11 (control) 
RES 1-5 5 [4..8] Bank 0 [3..5]   & Bank 1 [0..1] 
RS422 Interface 4 [11..14] Bank 1 [4..5]   & Bank 2 [0..1] 
Control signals of port B 10 [17..24] Bank 2 [4..6]   & Bank 3 [0..4] 
Control signals of port A 10 [27..34] Bank 3 [7..11] & Bank 4 [0..2] 
MDIO Interface 2 [37..38] Bank 4 [5..6] 
High impedance buffer disable 2 [39..40] Bank 4 [7..8] 
Header J12 (data port B) 
 
Data signals of port B 
 
32 / 4 
 
[1..32] 
Bank 4 [9..23] & 
Bank 5 [0..5]   & 
Bank 6 [0..10] 
Header J13 (data port A & power signals) 
Data signals of port A 32 / 4 [5..36] Bank 7 [0..31] 
5V 1 [38] - 
3.3V 1 [37] - 
GND 1 [39..40] - 
Total Nbr of Pins 129   
 Fig. 4.5   Table pin assignment 
 
For further information, look at the schematic given in the appendixes 
 
 Appendix 3 Schematic Converter 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 11/49 - 
4.3 Controller 
The Controller part will receive all the Rx packets. These packets will be filtered and a time stamp will be 
added. After this, the packets will be reorganized and saved in RAM-Modules. To send the filtered packets 
to a computer, an Ethernet connection is used. On the computer, we have a DPMI-Interface, which is 
developed by Arlos Patrik, this interface will analyze the captured packets which were sent by the 
Controller. 
 
The board consists of the following: 
- Wall-mount power supply connector with switch and LED indicator 
- Switches to select from 1.5 V, 2.5 V, and 3.3 V (I/O Bank) voltages on banks 3–4 
- 10-pin, 0.1"-pitch programming connector compatible with Altera connections 
- 50 MHz oscillator and 32kHz oscillator for real-time clock (RTC) calculations 
- Eight LEDs driven by outputs from the device 
- Jumpers allowing disconnection of all external circuitry from the FPGA 
- One monostable pulse generator switch 
- Eight switches providing input to the device 
- Two RS-232 serial interfaces 
- Two 10/100 Ethernet interfaces 
- One Controller Area Network (CAN) 2.0B serial interface 
- One USB 1.1 serial interface 
 
 Appendix 4 CoreMP7 development kit users guide 
 
Remark: A reason why I chose this Dev-Board is, that the FPGA works with a 50MHz oscillator(clock). The 
packets leave the Phy with a speed of 25Mhz, so we have a certain surplus and can work without problems 
on the data in the FPGA. Otherwise, we could have an anti-aliasing effect. 
 
4.3.1 Memory 
One of the major tasks is to store all the data from the captured interface in a memory; to filter, modify and 
send them forward to the DPMI interface. 
On the Dev-Board, SRAM and Flash memory are provided. We have two external memories and two 
internal memories. The external memories are slower than the internal, also the width and the depth are 
more or less fixed. The advantage of the external memories is that they are much bigger. 
 
On the following table you can see an overview about all provided memory from the Dev-Board 
 
Internal Memory 
Type Description Number Total size Address bits Data bits 
SRAM Built-in SRAM 32 block à 4608bit 18kbytes 0 … 16 0 … 576 
Flash Built-in Flash 1 128bytes 6 7 
External memory 
Type Chip description Number Total size Configuration 
SRAM STMicroelectronics 
M29W800DT 
2 2Mbytes 1M x 16 or 512k x 32 
 
Flash GSI Technology 
GS8001BT 
2 2Mbytes 1M x 16 or 512k x 32 
 
 Fig. 4.6   Table memory overview 
 
In this project, the internal SRAM is used as filter storage and buffers for the Capture blocks. The external 
SRAM has to be used as program storage for the Arm. 
One of the advantages of the internal SRAM is, that it is a true Dual-Port Ram and each block can have his 
separate address- and data-lines, therefore, it is possible to work parallel on the different buffers. 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  




The evaluation board includes two STMicroelectronics M29W800DT Flash memory chips, totaling 2 MB, 
which can be arranged in either a 1M × 16 or a 512K × 32 configuration. The Flash memory is intended for 
use as executable program storage for the embedded ARM microprocessor. However, it can also be used as 
nonvolatile memory for the storage of system constants and parameters. 
SRAM 
There are also two GSI Technology GS8001BT Synchronous SRAM provided on the board, totaling 2 MB, 
which can be arranged in either a 1M × 16 or a 512K × 32 configuration like the external flash memory. The 
SRAM memory is used for the embedded ARM microprocessor stacks (both hardware and software) and for 
dynamic system data. 
 
Internal SRAM 
In the FPGA we have chosen for this project, it is 144kbits(18kbyte) of RAM in 4,608bit (576bytes) blocks 
provided. Inside the FPGA, these blocks are arranged along the top and bottom of the device to allow a 
better access from the core and the I/O. All these blocks are true dual-port and can be configured in many 
different aspect ratios. The true dual-port functionality allows to read and write independently on two 
ports. Both ports can also have different clock speeds, because these RAMs are used as buffers. It is 
possible to read faster than write, which is a big advantage in this case. With the same RAMs, it is also 
possible to make a two-port RAM which has also two independent working ports. The difference to the 
dual-port is that on one port you can just write and on the other just read. 
 
The maximum space taken in the RAM to store one whole Ethernet packet is 759 lines. The maximum 
length of an Ethernet frame is 1’518 bytes (12’144 bits) and the RAM width is 16 bits, in order to have an 
sufficient gap to write the capture header. 
So it is necessary to have 10 bits to write the length of a frame and 10 bits it is also the minimum number of 
RAM address. With 10 bits, there are 1024 lines in RAM. 
 
In this case, the data length is 16 bits and the address length is 10 bits. This means that each buffer has an 
available space of 2kbytes. 
Because there are 18kbytes of RAM available and 4kbytes are already used from the ARM7 Core, is possible 
to have 7 buffers of 2kbytes space. 
In the following picture, you can see both possible RAM blocks with the input and output signals. 
 
 
   
 Fig. 4.7   RAM block schema 
Two-port Dual-port 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 13/49 - 
4.3.2 Arm7 
The CoreMP7 soft IP core is an ARM7 family processor optimized for use in Actel ARM-ready FPGAs and is 
compatible with the ARM7TDMI-S.  
CoreMP7 is supplied with an Advanced Microcontroller Bus Architecture (AMBA) Advanced High-
Performance Bus (AHB) compliant wrapper for inclusion in an AMBA-based processor system. 
The microprocessor has the following features: 
- FPGA Optimized ARM7™ Family Processor 
- 32/16-Bit RISC Architecture (ARMv4T) 
- 16-Bit Thumb Instruction Set 
- 32-Bit Unified Bus Interface 
- 3-Stage Pipeline 
- 32-Bit ALU 
- 32-Bit Memory Addressing Range 
 
Utilization and Performance: 
Core variant Performance (MHz) Tiles RAM Block Utilization (%) 
Core only 28.12 6083 4 (4kbytes) 24.8% 
Core with debug 21.7 7931 4 (4kbytes) 32.3% 
 Fig. 4.8   Table utilization and performance from Arm7 soft core 
 
Unfortunately, there is no Interface between the FPGA logic and the ARM processor (AMBA Bus). The time 
was too small to develop this interface, also a cheap Ethernet interface was required, but the Actel 10/100 
Ethernet core costs 2000$ per project, because of these reasons, the Arm Core was not used as intended. 
The core was implemented and tested, but it is not used for the MP system. The tested subcores are listed 
below. 
- Core MP7 & Core MP7 Bridge 
- GPIO-Interface 
- UART-Interface 
- Interrupt core 
- AHB2APB core 
- AHB SRAM 
 










USB 1.0 Interface 
Actel FPGA 
Connect to Interface-Board 
Power supply / On/Off Switch 
JTag Interface 
Top side: Flash memory 
Bottom side: SRAM memory 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 14/49 - 
5 Passive Measurement Infrastructure 
In this section you will find an overview about the passive measurement infrastructure. For a good quality 
analysis of networks, it is necessary to have exact and accurate packet capturing. A passive measurement 
infrastructure allows to capture and filter data from a computer network. After that, it can be analyzed and 
displayed for the user. 
A passive measurement infrastructure consists of 4 components which are connected together: 
- Measurement Area Controller (MArC), this device controls the MP 
- Measurement Point (MP), device which physically listens to channels, captures the wanted 
packets and distributed it. 
- Time Synchronization Device (TSD), which gives the exact time to the MP 
- Consumer receive the sent data by the MP and analyze it and finally displays to the user 
 
The passive measurement infrastructure is further explained in the documentation of Patrik Arlos. 
 
 Appendix 6 Passive measurement infrastructure 
 
All these devices are connected together through several networks. A RS 482 connection is between the 
TSD and the MP. The consumers, the MArC and the MP’s are connected over the MArN network. 


















 Fig. 5.1   Measurement Area 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 15/49 - 
5.1 MArC 
The MArC is the central component of the Infrastructure, and provides the user an Interface to the MP. 
In the MArC, the filter can be set and changed, as well as the status of the MP checked. An example of an 




 Fig. 5.2   MArC Interface 
5.2 Consumer 
In the DPMI Interface, there is also a consumer integrated which displays the results of the analysis for the 
user. These are the possible diagrams in the actual DPMI: 
- Packet inter arrival time 
- Link utilization 
- Link utilization over 24h 
- Hosts > 5 pkts/min 
- Hosts < 5 pkts/min 
- Protocol distribution VLAN 
- Protocol distribution network 
- Protocol distribution Transport 
- Protocol distribution application 
- Protocol distribution ICMP 
- Beacon test 
- Paket inter arrival (comparison) 
- Kilroy classical 
- Kilroy Nueco 
- Kilroy 
- OWTT 
- BPS comparison classical 
- Timestamp comparison 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 16/49 - 
5.3 MP 
The MP is the device which has to be developed. In this project, it listens to one or several links under test. 
It can be a logical or a physical device, in this case the MP will be a physically device, made in custom 
hardware. 
To the captured data there will be several additional pieces of information’s added. These are listed in 
chapter 6.2 ( see 6.2 RAM-structure). 
In the following picture, you can see a schematic overview of an MP with two capture interfaces. 
- Capture interface:  Each MP has at least one capture interface. It listens to a channel, captures  
    and filters the arriving packets. If a frame arrives which should be stored, it  
    adds also a capture header to each frame. 
- Time synchronization client: This block receives the actual time and forwards it to the CI. It is  
                necessary for the timestamp in the capture header. 
- Sender:   The sender interacts with the MArN and if a full Ethernet packet is filled  
    with captured frames, he adds an measurement header and send the  
    packet through the MArN to the consumer. 
- Controller:  The communication between the CI and the sender is managed by the  
    controller. 
 





Sender MArN Link under 
test 
Controller 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 17/49 - 
6 Software 
In this project, there are 2 tasks to implement and test: 
- Implementation of the Interface functionalities in the CPLD. The hardware will be described in 
VHDL 
- Implementation of the Controller functionalities in the FPGA. The hardware will be described in 
VHDL 
 
The following features are integrated in the MP to be developed: 
- 2 Capture Interfaces (CI), which represent the connection to the MArN 
- Time synchronization client (TSC) 
- Filtering possibility for 2 filters 
- Adaptable filter- and capture-length 
- An Ethernet Interface to connect to the MArC 
- Sending of status message every second 
 
6.1 CPLD on Interface-board 
On the Interface is a Xilinx XC95288XL CPLD mounted. There we have enough space to implement the 
Interface functions, which are: 
- Activate the high impedance buffers 
- Pass on the RS422 interface to the Controller 
- Pass the control signals from Phy to the Controller 
- Manage the bidirectional MII interface 
- Generate the 25Mhz clock for the Phy 
 
These functions were implemented with HDL-Designer. In the following section, I will give you a more 
detailed view. In the next picture, you can see the top-level of the CPLD design. I split it up into 7 sub bloc’s 
to separate the different problems. On the picture you can see on the left side of the blocs, the signals 





 Fig. 6.1   Top-level of the CPLD design 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 18/49 - 
6.1.1 High-impedance Buffer 
In the high impedance buffer, it is possible to control the input from the Ethernet plugs to the Phy. You can 
either turn it on and let pass on all the packets to the Phy or bloc all signals to the Phy. In this case we do 
not need this functionality. Each buffer is enabled all of the time. 
 
6.1.2 RS422 interface 
Since the Dev-board does not have a RS422 interface for the time synchronization, it was added in the 
interface-board. The CPLD gives the signals directly to the FPGA without any changes made to the signals. 
The interface for the RS422 is done in the FPGA. 
 
6.1.3 Serial management interface 
In the Phy, some control and status register are available. To reach these registers a MII serial management 
interface is used.  
This interface consists of two pins: Management Data Clock (MDC) and Management Data Input/Output 
(MDIO). MDC has a maximum clock rate of 25MHz and no minimum clock rate. In this case I used a clock 
rate of 25MHz. The MDIO line is bi-directional and can be shared with other devices. The MDIO frame 
format for read and write access is shown in the Figure below. 
 
MII Management Serial Protocol 
Operation \ Protocol <idle><start><op code><device addr><reg addr><turnaround><data><idle> 
Read operation <idle><01><10><AAAAA><RRRRR><Z0><xxxx xxxx xxxx xxxx><idle> 
Write operation <idle><01><01><AAAAA><RRRRR><10><xxxx xxxx xxxx xxxx><idle> 
 Fig. 6.2   Table MII Management Serial Protocol 
 
The communication with the Phy will be done in the Dev-Board. In the CPLD the signals will be connected 
together. Since the MDIO signal is bi-directional, it is necessary to build a logic who can detect a read or a 
write access and enables the right buffer. This problem was solved by two tri-state buffers and a finite state 




 Fig. 6.3   Serial management interface 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  














 Fig. 6.4   FSM of serial management interface 
 
6.1.4 Phy clock 
To work in the CPLD with the phy-signals, it is indispensable to have a clock with a higher frequency than 
the clock in the phy. He needs a 25MHz clk. On the board is a 50MHz +/-10VPP mounted. The CPLD use this 
clock to create the 25MHz for the phy. 
 
Clock25MHz = Clock50MHz / 2 
 
6.1.5 Reset gen 
This block is necessary to synchronize and invert the nreset signal with the used clock in the CPLD. As 
output we finally get a well synchronized reset signal. 
 
6.1.6 Mac data interface 
One of the problems of the ancient Diploma work was that the sending of the packets from the Interface to 
the Controller Board caused some errors in the CRC-Check. Because of this, some frames were lost. 
To prevent the lost of a package, I tried 2 possibility the first was to reduce the frequency of the data 
between the Interface and the Controller and the second was to reduce the cross talking during 
transmitting over the ribbon cable. 
 
6.1.6.1 Reduce frequency 
The phy has a data-output of 4 signals, which means he gives the data nibble per nibble to the Controller. 




We have chosen to use 32 lines/channel, this gives a maximal frequency of: 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 20/49 - 
 
 
For the assignment about a ribbon cable or hard plug, 31.25MHz does not represent a problem. Some of 
the CRC-checks were right after that modification but the problem was not completely solved, there were 
still some problems during transmitting which affected the CRC-check. In the next section you can see my 
implementation to change the number of data signals from 4 to 32. 
 
Three sub-blocks were used to implement this function in the CPLD. 
- Synchronization: All the used signals from the Phy will synchronized by a D-FlipFlop with the  
    rx_clk from the phy. 
- Shift register: In this shift register we take the synchronized nibbles and put it in our 32- 
    bits output signals. If all the signals are filled, we generate an additional  
    word valid signal (en) to indicate that the 32-bits are ready to read. Since   
    a frame doesn’t have to be a multiple of 32bit, there is another signal  
    (byte_valid_nb) to say, which bytes are valid from the sent 32bit data. 
    Finally the signal rx_dv will also be generated to avoid synchronization  
    problems between the two boards, so that we have the guarantee that the  
    rising and falling edge is at exactly the right time. 
- Frame detector: For the Shift register we have to know, when the data should be shifted.  
    This is the case when the start of a frame delimiter is detected (after the  
    preamble and SOF). This bloc generates this impulse if a SOF is detected in  
    the rx-data signals. This signal will also be sent to the Controller, so that  
    we do not have to test it again. 
 
The following figure shows the three blocks with the in- and output signals. 
All error control signals are just going through, so that the Controller can see directly, when an error 
occurred. 
Because there are 2 Capture Interfaces (CI) on the Interface board, the mac data interface bloc is 
implemented twice in the CPLD-Design, once for the RX lines and once for the TX lines. 
 
 
 Fig. 6.5   Mac data interface 
 
Synchronisation 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 21/49 - 
6.1.6.2 Reduce cross talking 
In the finally version of the MP, this implementation was used. In a ribbon cable the signals were parallel 
and very close to each other, this affected the signal during transmitting. Therefore there were some 
glitches of the signals. To prevent this, I putted between each signal a ground line, that the signals are 
shielded from each other. Therefore, the number of signals could not be adapted, some signals are used as 
ground between the these lines. 
 
To have a more stable and better synchronized signals, a D-FF and a buffer was inserted on each signal. This 
means on all control and data signals from the Phy. This solution was better and eliminated the wrong CRC-
Checks. All packets arrive properly with a right CRC calculation. In the next figure you can see the 
implemented buffer and D-FF’s. 
 
 
 Fig. 6.6   Mac data interface 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 22/49 - 
6.2 FPGA on Dev-board 
MP functions will be implemented in the FPGA. The Interface is connected on the user I/O pins to receive 
the packets and also the timestamp. The implemented MP functions are: 
- RS422 Receiver for time stamping 
- MII Interface to get the status from the Phy 
- Capture Interface to receive and filter the incoming packets 
- Sending the captured frames over Ethernet 
- Sending and receive control/status messages over UDP/IP 
 
First I would like to give you an overview about the different data packets formats which exist in the MP. 
We can separate the packets in measurement frames, control/status frames and intermediate frames. The 
last frame format will be generated by the Mac receiver and transmitter, he will store all the packets into a 
intermediate buffer, then it is possible to take the data any time, in any order and many times. 
 
6.2.1 RAM Structure 
6.2.1.1 Measurement frame 
The measurement frame contains the captured frames (CF) and to each frames an additional capture 
header (CH) is added, to specify some information’s about the MP and a time will also be added as the 
length of the captured frame. In the measurement header (MH) are some additional informations about 
the Measurement frame. The entire packet has finally also an Eth header (EthH). The maximum size of a 
measurement frame is the same as an Ethernet frame and it can contain 0-1500 bytes of data (captured 
header(s), captured frame(s) and measurement header). 
In the following section you can see a measurement frame with all his content and a small description. 
 
EthH MH CH i CF i CH i + 1 CF i + 1 ... CH j CF j 
14 bytes 20 bytes 36 bytes 0-1444 bytes 36 bytes -  36 bytes - 
 
We have not drawn the SFD (Start of Frame Delimiter) and the Preamble, since this is really Ethernet-
specific and of course all processing of this is done by the hard coded Ethernet MAC. We will now focusing 
on the different sections in the packet/frame and explain the details of them. 
 
Ethernet header 
EthH MH CH i CF i CH i + 1 CF i + 1 ... CH j CF j 
 
 
Eth DST Eth SRC Eth type 
6 bytes 6 bytes 2 bytes 
 
Eth DST  Ethernet Destination address of the computer, were the DPMI run. 
Eth SRC  Ethernet Source address from this hardware. 
Eth type The Ethernet type depends on which kind of packet we want to sent. For 
measurement frames which are only Ethernet based, it is 0x0810 (defined by the 
DPMI). For the status frames which are IP based it is 0x0800. 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 23/49 - 
Measurement header 
EthH MH CH i CF i CH i + 1 CF i + 1 ... CH j CF j 
 
 
Seqnr Pktnr Flush Version 
8 bytes 8 bytes 12 bytes 4 bytes 
 
 Seqnr  Sequence number, which increments each time a full packet is sent. 
 Pktnr  Packet number, says how many captured packets are in the frame. 
 Flush  Indicates the last packet. 
 Version  Here it is possible to indicate the version number for the file format which is used. 
 
Capture header 
EthH MH CH i CF i CH i + 1 CF i + 1 ... CH j CF j 
 
 
CI-id MAMP-id Time Lenght Caplenght 
8 bytes 8 bytes 12 bytes 4 bytes 4 bytes 
 
 CI-id  Captured interface id, it identifies the CI where the frame was caught. 
 MAMP-id This field identifies the MP, were the frame was caught. 
 Time  The Time field is divided into a 4 bytes value which indicated the time in  
   seconds and an 8 byte value, which indicates the time in picoseconds. 
 Lenght  Indicates the length of the whole frame. 
 Caplenght Indicates which length of the frame is being captured. 
 
It has to be mentioned, that the CI-id and the MAMP-id in this headers are human readable, therefore are 
the different fields quite large. 
 
Capture frame 
EthH MH CH i CF i CH i + 1 CF i + 1 ... CH j CF j 
 
 
Eth DST Eth SCR Eth type Data 
6 bytes 6 bytes 2 bytes 0 - 1430 bytes 
 
In this part is a captured packet stored. The preamble, the SOF and also the CRC will be removed. If we do 
not want a full frame catch, we store just the number of bytes indicated in the caplen of the filter. 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 24/49 - 
6.2.1.2 Control and Status frames 
All control and status frames were sending to the DPMI interface over IP/UDP. The status messages will be 
sent from the MP to the DPMI to indicate the current state of the MP. 
The control messages will initialize the MP on the DPMI. It provides several status information’s. There exist 
other control messages, but because the receiving part of the MArN interface is not yet finished, this 
messages are not implemented. In the other control messages can be found several information’s, like flush 
buffers, add- , remove- or change filters. 
In the following pictures all field are explained in detail, the EthH rests the same as in the measurement 
frame. 
 
EthH IP header UDP header Data 
14 bytes 20 bytes 8 bytes 0-1472 bytes 
 
IP header 
The IP header has the IPv4 format. 
 
EthH IP header UDP header Data 
 
 
Version IHL TOS length ID Flags Offset TTL Protokol Checksum IP source IP dest 
4 bit 4 bit 1 byte 2 bytes 2 bytes 3 bit 13 bit 1byte 1 byte 2 bytes 4 bytes 4 bytes 
 
- Version: IP header version, always version 4. 
- IHL: IP header length, length of the header. 
- TOS: Type of service, not used here. 
- Length: Total length of the entire packet. 
- ID: Identification, for reassembling of IP-packets. It is not used here 
- Flags: Flags for the reassembling, not used. 
- TTL: Time to live, always 128. 
- Protocol: Identify the next protocol, in this case udp, value 17. 
- Checksum: Header checksum, it is the once complement of the one’s complement sum of the IP  
  header. It is defined in the RFC 791 standard. 
- IP-source: IP source address, little endian. 
- IP-dest: IP destination address, little endian. 
 
UDP header 
Inside the IP data is a UDP header 
 
EthH IP header UDP header Data 
 
 
Source port Destination Port length Checksum 
2 bytes 2 bytes 2 bytes 2 bytes 
 
- Source port: Source port number, always 0. 
- Destination port: Destination port number, always 1600. 
- Length: Size of the UPD-header and data in octet. 
- Checksum: The checksum is the ones complement of the ones complements sum of the UDP- 
  pseudo header, the UDP header and the data. It is defined in RFC 768 standard. 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 25/49 - 
 
Fields of the UDP checksum 
IP source address 
IP destination address 
IP Protocol UDP length 
UDP source port UDP destination port 
UDP length Data 
Data... 
2 bytes 2 bytes 
Status messages 
Like mentioned above, these messages are send by the MP to the DPMI every second, it indicate the status 
of the MP. The information’s are given in the data section of the frame described above. 
 
Msg_type MAMPid No_filters Matched No_CI CI_msg 
4 bytes 16 bytes 4 bytes 4 bytes 4 bytes 30 bytes 
 
- Msg type: Identification of the message type, for status messages always 2. 
- MAMPid: MP id, always “FPGAMP0”. 
- No filter: Number of active filters in this case max 2. 
- Matched: Number of packets who pass a filter. 
- No CI: Number of active CI, max 2. 
- CI msg: An optional message for the DPMI. In this case, it is always “STATUSMESSAGE”. 
6.2.1.3 Intermediate frame 
Inside the MAC-receiver and -transmitter are dual port buffers integrated, they store the intermediate 
frames. All the received packets from MAC-receiver are stored inside the rx-buffer, also the frames ready to 
sent will be stored with the same frame structure inside the tx-buffer.  
It also adds a frame header (FH) if the packet was received or stored properly or an error header (ErrH) will 
be added, if there was an error during packet receiving. There are two different structures, one if the frame 
is valid and the other if an error is occurred. At the end of a packet structure or an error structure there is 
always an empty header (EH) which represent the frame header or error header of the next packet 
structure. 
 
Valid frame structure 
FH Frame data EH 
The valid frame structure contains a frame header, the frame data and an empty header which represent 
the space for the frame header of the next frame structure. 
 
Error frame structure 
ErrH EH 
In this version of the MP the empty header is not intended to use. But in further version it can be used to 




Header valid 0 0 0 0 0 Frame length 
Bit 15 Bit 14 Bit 13 Bit 12 Bit 11 Bit 10 Bit9 - 0 
 Header valid The header valid bit indicate, when the valid frame is ready to read. 
 Frame length The length of the frame data is stored in these nine bits. It shows the offset to the  
   next header. 
UDP pseudo header 
UDP header + data 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 26/49 - 
Filter 
Error header 
Header valid Error name 0 0 Error number 
Bit 15 Bit 14 – 12 Bit 11 Bit 10 Bit9 - 0 
Header valid The header valid bit indicate when the frame is being processed, but an error is  
occurred. 
Error name It exist 4 different types of error, which can be 
“000” : nothing / “001” : CRC error / “010” : Rx error / “100” : buffer is full 
 
Empty header 
0      0      0      0      0      0      0      0      0      0      0      0      0      0     0 
Bit 15 – 0 
The empty header is always at the end of a structre and represent the space for the next frame header. 
Therefore, it is filled with Zeros. 
 
6.2.1.4 Filter data base structure (FDB) 
In this buffer the filterrules are stored. The received filterrules will be converted into this structre, which 
contains 4 entries per Ram line. Each filter has a value and a mask with a size of 16bits so that it is possible 
to read the two buffers at the same time, the buffer must have a databus of 64bits. Each filter has a size of 
84 bytes (42 bytes mask and 42 bytes value), therefore both filter occupied 21 RAM lines. 
The system is build for an easy enlargement. Because the minimal size of an internal RAM is 2kbyte and we 
just use 21 Ram lines in the actual filter, it remains 235 lines in the RAM. Theoretically, if there are two 
filters implemented, the first 512bytes of a PDU could be filtered. 
Ram line structure 
Value filter1 Mask filter1 Value filter2 Mask filter2 
2 bytes 2 bytes 2 bytes 2 bytes 
Value This 2 bytes value shows the desired packet content 
Mask In the mask is defined, which bits should be checked 
 
6.2.1.5 Dataflow 
The data goes through the different blocks, each block adds an additional header to the measurement 
frame. 
The Rx- and Tx-buffers contains the intermediate frames with the FH or ErrH. The Filter bloc adds the CH 
and the CI-demux bloc adds the MH to the frames and store it into the Filterbuffer. 
The control and status messages are generated directly in the sender and will put into the Tx_buffer at the 
right time. 
 
In the next picture you can see an overview, when which header will be added. 
 




























Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 27/49 - 
6.2.2 Top-level 
The top-level of the FPGA design contains the entire logical blocks from the MP. Each bloc will be described 
in detail in the following section. 
The next picture shows an overview about the entire top-level design in the FPGA. It has to be mentioned 
that there were 3 different designs implemented. One with the 32 bit input and the other with a 4 bit input 
in the CI. The explained design is with the 4bit version. 
 
 Fig. 6.8   Bloc diagram of the capture interface, the demux and the filters 
 
The system is build for an easier enlargement of the number of CI and filters in another hardware. In the 
used FPGA, the number of CI is fix defined, because of the Interface board which provides two CI. Also the 
number of filter cannot be greater than two in the actual FPGA, because the numbers of available internal 
RAM’s were limited. To increase the number of CI it is necessary to adapt the Arbiter, the CI-demux and just 






Add CH & MH 
 
































25MHz  50MHz 
25MHz  50MHz 







Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 28/49 - 
6.2.3 ResetGen 
Because in the FPGA are four main clocks signals, the reset signal has to be synchronized with each clock, 
and connected to the belonging blocs. It contains some D-FF with different clock inputs. 
In the following table you can see all the signals of this bloc. 
 
Signal Type (direction, type) Description 
Reset input 
Reset In, std_logic Reset signal, connected to the reset button 
Reset for systemclock 
Clock In, std_logic 50Mhz systemclock input 
Clk_reset Out, std_ulogic Clock synchronized reset signal 
Reset for CI1 interface 
Rx_clk_a In, std_logic 25MHz CI1 clock signal 
Rx_clk_a_reset Out, std_ulogic CI1 clock synchronized reset signal 
Reset for CI2 interface 
Rx_clk_b In, std_logic 25MHz CI2 clock signal 
Rx_clk_b_reset Out, std_ulogic CI2 clock synchronized reset signal 
Reset for transmitter 
Tx_clk In, std_logic 25MHz transmitter clock signal 
Tx_clk_reset Out, std_ulogic Transmitter clock synchronized reset signal 
 Fig. 6.9   Table I/O signals resetgen 
 
6.2.4 Capture interface 
The capture interface (CI) receives all packets from MArN, perform a CRC-check and store it into an 
intermediate buffer. After that, the packets will be filtered and the CH will be added with the exact 
timestamp, if the filterbuffer’s are not used by the other CI, he send the packets to the CI-Demux. A capture 
interface can just listen to one channel. 
This block contains a synchronization, a Mac-receiver and a filter. The receiver has a two-port buffer which 
works like an endless queue. When a packet arrives, the Mac receivers store it into the buffer and perform 
the CRC-check.  
As soon as the whole packet is stored, a flag in the frame header will be set, that the filter know, the frame 
is ready and valid. If the filter buffers are also ready to store a new packet, the filter takes the packet, 
performs the filtering and sends it forward to the CI-Demux. 
In the following sections, each block will be described carefully. 
 
6.2.4.1 Synchronization 
The synchronization-block is to avoid synchronization problems with the data, which are coming from 
Interface-board. Like in the CPLD, the signals will synchronized with the receiver clock coming from the 
Interface board. All of the following signals will be synchronized. 
 
Signal Type (direction, type) Description 
Data signals 
Rx_data In, std_logic_vector(3 DOWNTO 0) 4bit data signals  
Control signals 
Rx_dv In, std_logic Data valid signal 
Rx_er In, std_logic Error signal 
 Fig. 6.10 Table Input signals synchronisation 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 29/49 - 
6.2.4.2 Receiver 
For the Eth receiver it was possible to take a core that was already made by the school in Switzerland. I 
made some changes to adapt it to my design and hardware, but the system remains the same. The receiver 
takes data from the Interface-board and saves them in a RAM, if the CRC-check was correct. A RAM 
structure is created to recognize what is saved.  See chapter 6.2.1.3 Intermediate frames 
To read the correct data from the RAM, it is necessary to set the signals: base address and address. It gives 
also a start of frame signal to the TSC that he knows, when exactly the frames arrived. 
For additional information’s about the receiver, have a look at appendix 7. 
 
 Appendix 7 SimAP Design report 
 
The changes include the following blocs: 
- The reset synchronization bloc was moved into the resetgen bloc, in the Toplevel, to combine 
all the reset synchronization’s in one bloc 
- Replaced the Xilinx buffer by an Actel dualport buffer 
- Some small changes in the nibble_to_byte (4bit => 8bit) and byte_to_word (8bit => 16bit) bloc 
to avoid synchronization problems 
- Add the save_time signal for an exact timestamping 
 
In the next table shows you the I/O signal of this bloc 
Signal Type (direction, type) Description 
From synchronization 
Rx_data In, std_ulogic_vector(3 DOWNTO 0) 4bit data signals  
Rx_dv In, std_ulogic Data valid signal 
Rx_er In, std_ulogic Error signal 
To/from filter 
Address In, std_ulogic_vector(9 DOWNTO 0) Actual read address of the filter 
Baseaddr In, std_ulogic_vector(9 DOWNTO 0) Boarder address for the write access of the buffer. 
The receiver can write till this address 
Data_out Out, std_ulogic_vector(15 DOWNTO 0) Read data output of the buffer 
Save_time Out, std_ulogic Signal to indicate that a frame is completely stored 
in buffer, and the time can be saved. 
Start_of_frame Out, std_ulogic To know when the a frames is arrived, It will be set 
during the start of frame delimiter (5D) 
 Fig. 6.11 Table I/O signals receiver 
 
A schematic overview about the bloc inside the receiver is given below. 
 












4bit RX data 
RX control 
byte 







start of frame, save time 
25MHz  50MHz 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 30/49 - 
6.2.4.3 Filter 
All received packets from the receiver are stored inside the DP-buffer. As soon as a frame is finished, it will 
update the frameheader. When the filterbuffers are not used by the other CI, the filterbloc will read the 
ready frame and give it to the CI-Demux to store it into the filterbuffer. At the same time it will also 
perform the filtering as well as the CH will be added if the frame is properly stored. 
At the beginning we do not know to which filterbuffer(s) the packet belongs, therefore it will be written 
first in both filterbuffers, if the filtering says that is just for one or none filterbuffer, we jump to the 
beginaddress in this buffer and the already written frame-part is erased. 
In the following pictures you can see the table of I/O signals, the schematic and also the statemachine of 
the bloc filter_heart. 
 
In the next table shows you the I/O signal of this bloc 
Signal Type (direction, type) Description 
To/from Receiver 
Baseaddr Out, std_ulogic_vector(9 DOWNTO 0) The receiver can write data till he reach this addr  
Address Out, std_ulogic_vector(9 DOWNTO 0) Actual read addr of the filter 
Data In, std_ulogic_vector(15 DOWNTO 0) Read data-bus from the buffer inside the receiver 
Read_en In, std_ulogic Read enable from the buffer inside the receiver 
Start_of_frame In, std_ulogic SOF signal to know exactly when a packet is arrived 
Save_time In, std_ulogic Signal that say that a packet is safely stored in the 
buffer, the SOF time can be saved 
To/from Arbiter 
Ci_id In, std_ulogic To identify which CI it is 
Req_filter Out, std_ulogic Signal to request a filter and the filterbuffers 
Av_filter In, std_ulogic To accept the filter request 
End_filter In, std_ulogic Indicate the end of the filtering 
Mask1 In, std_ulogic_vector(15 DOWNTO 0) Mask of filter 0 
Value1 In, std_ulogic_vector(15 DOWNTO 0) Value of filter 0 
Mask2 In, std_ulogic_vector(15 DOWNTO 0) Mask of filter 1 
Value2 In, std_ulogic_vector(15 DOWNTO 0) Value of filter 1 
Caplen_filter0 In, std_ulogic_vector(9 DOWNTO 0) Capture length of filter 0 
Caplen_filter1 In, std_ulogic_vector(9 DOWNTO 0) Capture length of filter 1 
To/from CI-Demux 
Data_ready Out, std_ulogic Say when data_out can be read 
Data_out Out, std_ulogic_vector(15 DOWNTO 0) Data output 
Filtermatch Out, std_ulogic_vector(1 DOWNTO 0) Signal to indicate to which filter the packet match 
filtermatch(0) => filter 0 
filtermatch(1) => filter 1 
WriteCH  Out, std_ulogic Indicate the writing of the CH 
End_writeCH Out, std_ulogic Indicate the end of writing the CH 
Not_free_Ram In, std_ulogic Indicate that the filterbuffer is full 
Packet_error Out, std_ulogic Indicate an error. This signal goes also to the 
Arbiter. That he knows that the buffers are not 
used anymore. 
To/from TSC 
Timestamp In, std_ulogic_vector(95 DOWNTO 0) Timestamp 
 Fig. 6.13 Table I/O signals receiver 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 31/49 - 
 
 Fig. 6.14 Block schema of filter 
 
- Header ctrl:  Reads the data and control, if the frame- or error-header is valid. If it is a  
    frameheader, it also reads the length of the packet and gives it to the  
    filter-address reg and heart. 
- Compare filter: This block performs the filtering, he takes the data, put the mask on it and  
    compares with the value. There are two blocks, one for each filter. 
- CH header gen: Generates the values for the CH frame gen bloc. For the timestamping is an  
    array of 31 std_ulogic_vector(64 DOWNTO 0) implemented, who works like  
    an endless queue. If the SOF signal arrive he store the actual time in the  
    temporary signal, after that if the save_time signal arrive I will be finally  
    stored into the array to use in the appropriate CH. The array has 31  
    entrances because there can be max. 31 frames in the receiver buffer. 
- CH frame gen: If the heart indicate to write the CH, he write the whole CH with the values  
    from the CH header gen. 
- Filter addr reg: Because we do not have registers inside the statemachine, for all the  
    addresses the filter addr reg was created. He manages the actual addr and  
    the baseaddr for the read access on the buffer inside the receiver. The  
    heart can perform some actions on the addresses, like increment,  
    decrement, jumpCH, save_begin, save_end, load_begin, load_end. 
- Filter error reg: This registers stores all errors, if the filterbuffer is full, the ram_full_error  
    signal will indicate it. If we have no filtermatch, the no_match signal will be  
    set. In each case, if an error occurred, the packet_error signal will indicate  
    it to the other blocs. 
- Mux data to ram: The filter-heart can select, if the data or the CH_data should go to the ram. 
- Filter heart: In the filter heart is a statemachine, which controls all the other blocs  
    inside the filter. He waits for a valid frame, takes it, perform the filtering  
    and send it to the CI-demux, at the end a CH will be added. Before he writes  
    something into the filterbuffer(s) he asks for permission to the Arbiter. In  


































req_filter, av_filter, end_filter, caplenfilter0 & 1 
writeCH, end_writeCH 
length 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  







Enable read and 
filtering
Update baseaddr






























 Fig. 6.15 Statemachine filter_heart 
 
6.2.5 Conversion filterrules 
This bloc converts the given filterrules into a mask and a value, which will be stored in the FDB. To see the 
ram structure of this buffer, go to chapter 6.2.1.4 Filterdatabase. 
Because the first 42bytes of a packet will be filtered, each filter contains a mask and a value of 42 bytes. 
The mask say which bits should be compared with the value. At the moment all the filters are static and 
cannot be changed during the runtime of the MP. To change a filter, the FPGA has to be reprogrammed. 
 
6.2.6 Arbiter 
In the FPGA are 2 CI implemented which are using the same filters and filterbuffer’s. Therefore it is 
necessary to have a system that choose which CI can be active and have the permission, to write into the 
filterbuffer’s. In this case in the arbiter-bloc is a round-robin algorithm implemented. When just one CI 
request for a filter, the arbiter gives him the permission, but if both CI wants to use the filterbuffer’s he 
choose the active CI with the round robin algorithm. We have an internal register, where is stored which CI 
got the permission before. 
If a CI is active the arbiter reads the filterrules from the FDB and gives the masks and the values of both 
filters to that CI. To see the FDB buffer structure look at chapter 6.2.1.4 Filterdatabase. 
On the figures below you can see the I/O signal table and the statemachine of the arbiter.  
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 33/49 - 
 
Signal Type (direction, type) Description 
To/from Filterrule-buffer 
RD In, std_ulogic_vector(15 DOWNTO 0) Databus of the filter database 
REN Out, std_ulogic Read enable signals of the filter database 
RADDR Out, std_ulogic_vector(9 DOWNTO 0) Read addrbus of the filter database 
From Conversion_filter 
Caplen_filter1 In, std_ulogic_vector(9 DOWNTO 0) Capture length input of filter1 
Caplen_filter2 In, std_ulogic_vector(9 DOWNTO 0) Capture length input of filter2 
To/from Capture interface 0 & 1 
Req_filter_ci0 In, std_ulogic With this signal the CI0 can request the filterbuffers 
Av_filter_ci0 Out, std_ulogic To give the write permission for the filterbuffers to CI0 
End_filter_ci0 Out, std_ulogic To indicate the end of the filtering for CI0 
Req_filter_ci1 In, std_ulogic With this signal the CI1 can request the filterbuffers 
Av_filter_ci1 Out, std_ulogic To give the write permission for the filterbuffers to CI1 
End_filter_ci1 Out, std_ulogic To indicate the end of the filtering for CI1 
Mask1 Out, std_ulogic_vector(15 DOWNTO 0) Mask of fiter1 
Mask2 Out, std_ulogic_vector(15 DOWNTO 0) Mask of fiter2 
Value1 Out, std_ulogic_vector(15 DOWNTO 0) Value of fiter1 
Value2 Out, std_ulogic_vector(15 DOWNTO 0) Value of fiter2 
Caplength_filter1 Out, std_ulogic_vector(9 DOWNTO 0) Capture length of filter1 
Caplength_filter2 Out, std_ulogic_vector(9 DOWNTO 0) Capture length of filter2 
Packet_error_ci0 In, std_ulogic Indicate an error during filtering in CI0 
Packet_error_ci1 In, std_ulogic Indicate an error during filtering in CI1 
To/from CI-Demux 
Buffer_ready In, std_ulogic This signal indicate that the filterbuffers are not used 
by any CI. 
Seldata Out, std_ulogic_vector(1 DOWNTO 0) These 2 bit indicate the active CI 




















 Fig. 6.17 Statemachine arbiter 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 34/49 - 
6.2.7 CI-demux 
If a CI is active, the data and the CH will be sent to the CI-demux. Which forward it to the appropriate 
filterbuffer(s). After a successful copy in the filterbuffer, he checks, if there is still enough space for another 
frame of a caplength size with the belonging CH. If one or both filterbuffer’s are full, he adds the MH at the 
beginning and sends the flush_buffer signal to the sender. He will take the data and sends a flush_ok back. 
After that the buffer is ready for new packets from the CI. In the next pictures, you can see the I/O table 
and an overview about the sub bloc’s in the CI demux, they will be explained in detail below. 
Because two filterbuffer’s are implemented in the system, the CI-demux has for each filterbuffer a separate 
address register and an error register to store the different addresses and errors 
 
Signal Type (direction, type) Description 
To/from Arbiter 
Buffer_ready Out, std_ulogic This signal will be set if the filterbuffer are not used 
Seldata_arbiter In, std_ulogic_vector(1 DOWNTO 0) Indicate which CI is active bit0 for CI0 and bit 1 for CI1 
Caplen_filter0 In, std_ulogic_vector(9 DOWNTO 0) Capture length of filter0 
Caplen_filter1 In, std_ulogic_vector(9 DOWNTO 0) Capture length of filter1 
From Capture interface 0 
Logger_data_ci0 In, std_ulogic_vector(15 DOWNTO 0) Data from CI0 
Data_ready_ci0 In, std_ulogic Say when the data is ready to read 
writeCH_ci0 In, std_ulogic To write the CH 
endCH_ci0 In, std_ulogic End of writing CH 
Filtermatch_ci0 In, std_ulogic_vector(1 DOWNTO 0) That that CI-demux knows in which buffer the data has 
to be forwarded 
Packet_error_ci0 In, std_ulogic If an error occurred this signal will be set 
From Capture interface 1 
Logger_data_ci1 In, std_ulogic_vector(15 DOWNTO 0) Data from CI1 
Data_ready_ci1 In, std_ulogic Say when the data is ready to read 
writeCH_ci1 In, std_ulogic To write the CH 
endCH_ci1 In, std_ulogic End of writing CH 
Filtermatch_ci1 In, std_ulogic_vector(1 DOWNTO 0) That that CI-demux knows in which buffer the data has 
to be forwarded 
Packet_error_ci1 In, std_ulogic If an error occurred this signal will be set 
To Filterbuffer 0 
WEN_filter0 Out, std_ulogic Write enable of filterbuffer0 
WADDR_filter0 Out, std_ulogic_vector(9 DOWNTO 0) Actual write address of filterbuffer0 
WD_filter0 Out, std_ulogic_vector(15 DOWNTO 0) Data lines of filterbuffer0 
To Filterbuffer 1 
WEN_filter1 Out, std_ulogic Write enable of filterbuffer1 
WADDR_filter1 Out, std_ulogic_vector(9 DOWNTO 0) Actual write address of filterbuffer1 
WD_filter1 Out, std_ulogic_vector(15 DOWNTO 0) Data lines of filterbuffer1 
To/from Output Choice (forward to sender) 
Flush_buffer Out, std_ulogic_vector(1 DOWNTO 0) Indicate which buffers has to be flushed by the sender 
Flush_ok In, std_ulogic_vector(1 DOWNTO 0) Confirmation of buffer-flush 
Not_free_ram Out, std_ulogic Error signal if buffer in sender is full 
End_addr_filter0 Out, std_ulogic_vector(9 DOWNTO 0) End of the data in filterbuffer0 
End_addr_filter1 Out, std_ulogic_vector(9 DOWNTO 0) End of the data in filterbuffer1 
 Fig. 6.18 Table I/O signals ci-demux 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 35/49 - 
 
 Fig. 6.19 Block schema of CI-demux 
 
- Mux CI:  Because there are 2 CI implemented, the Arbiter choose, which one should  
    be active, he set also the seldata_arbiter to forward the right data lines to  
    the buffer. 
- Demux filter: The heart choose with help of the filtermatch signal, in which buffers the  
    data should go, it can be just one or both filterbuffer’s at the same time.  
    With this bloc we choose also which input we want to store. It can be the  
    data from the CI or one of the MH-data. 
- MH headergen filter0 & 1: In this bloc all the values of the MH will be generated. If a new  
     Measurement frame will be created the MH_frame_gen bloc  
     indicate with a signal to increment the sequence-number, and the  
     CI-demux_heart set a signal to indicate to increment the number of  
     packets. 
- MH framegen filter0 & 1: If a filterbuffer is full, the heart set the writeMH signal. This bloc  
     take all the values from the MH headergen bloc and write it in the  
     filterbuffers, after finishing, the end_writeMH signal will be set, so  
     that the heart can go on and flush the buffer. 
- Addr registers filter 0 & 1: Due to not have registers inside the statemachine, for all the  
     addresses, the addr registers were created. It will save the begin-,  
     end- and actual addresses, it is also responsible to check if there is  
     enough space in the filterbuffer for another packet of the caplength  
     size. For each filterbuffer we have one address registers. The heart  
     can perform some actions on the addresses, like increment,  
     decrement, jumpCH, jumpMH, save_begin, save_end, load_begin,  
     load_end, load_MH and en_check_space. 
- Error registers filter 0 & 1: If the filterbuffer is full, it receives the ram_full_error signal from  
     the address register and if the error is enabled by the heart, it will  



























control signals ci0 













flush_buffer, flush_ok, not_free_ram 
CI-demux 
heart 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 36/49 - 
- CI-demux heart: The heart contains a statemachine, which controls all the other bloc’s in the  
    CI-demux, he will fill the filterbuffer’s, add the MH if it is full and send the  
    flush signal to the sender. In the following picture you can see the  


















































 Fig. 6.20 Statemachine CI-demux_heart 
6.2.8 Output-choice 
To have an easier debug possibility in the MP, the Output-choice bloc was created. By pushing the button0 
on the board, the output format can be changed from Ethernetframes to UART. It has to be mentioned, 
that the UART is not that fast as the Ethernet output, therefore the MP will not work on fullspeed, the 
performance will be much lower and some frames can be lost, due to the UART transmission which takes 
more than 800 times longer than the 100Mbps Ethernet. The output-choice button should just pressed in 
case of a restart of the system, it may gives some errors, if the button is pressed during the MP is running. 
In the table below you can see the I/O signal table of this bloc. 
 
 
Signal Type (direction, type) Description 
From Button 
switch In, std_logic To change between UART- and Ethernet-output 
1 => Ethernet (default) 
0 => UART 
To /from CI-demux 
Flush_buffer In, std_ulogic_vector(1 DOWNTO 0) Indicate which buffers should be flushed 
Flush_ok Out, std_ulogic_vector(1 DOWNTO 0) If the flush is done, flush_ok <= flush_buffer 
To Filterbuffer0 
RADDR_filter0 Out, std_ulogic_vector(9 DOWNTO 0) Read address of filterbuffer0 
REN_filter0 Out, std_ulogic Read enable signal of filterbuffer0 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 37/49 - 
To Filterbuffer1 
RADDR_filter0 Out, std_ulogic_vector(9 DOWNTO 0) Read address of filterbuffer1 
REN_filter0 Out, std_ulogic Read enable signal of filterbuffer1 
To/from UART transmitter 
Flush_buffer_UART Out, std_ulogic_vector(1 DOWNTO 0) Indicate which buffers should be flushed 
Flush_ok_UART In, std_ulogic_vector(1 DOWNTO 0) If the flush is done, flush_ok <= flush_buffer 
RADDR_filter0_UART In, std_ulogic_vector(9 DOWNTO 0) Read addr of filterbuffer0 from UART transmitter 
REN_filter0_UART In, std_ulogic Read enable of filterbuffer0 from UART transmitter 
RADDR_filter1_UART In, std_ulogic_vector(9 DOWNTO 0) Read addr of filterbuffer1 from UART transmitter 
REN_filter1_UART In, std_ulogic Read enable of filterbuffer1 from UART transmitter 
To/from Sender 
Flush_buffer_sender Out, std_ulogic_vector(1 DOWNTO 0) Indicate which buffers should be flushed 
Flush_ok_sender In, std_ulogic_vector(1 DOWNTO 0) If the flush is done, flush_ok <= flush_buffer 
RADDR_filter0_sender In, std_ulogic_vector(9 DOWNTO 0) Read addr of filterbuffer0 from sender 
REN_filter0_sender In, std_ulogic Read enable of filterbuffer0 from sender 
RADDR_filter1_sender In, std_ulogic_vector(9 DOWNTO 0) Read addr of filterbuffer1 from sender 
REN_filter1_sender In, std_ulogic Read enable of filterbuffer1 from sender 
 Fig. 6.21 Table I/O signals output-choice 
 
6.2.9 Sender 
The sender flushes the filterbuffer’s if the signal flush_buffer is set, all the data from the filterbuffer will be 
copied in the transmitter-buffer as well as the Ethernetheader (EthH) will be added. The EthH is statically 
and cannot be changed during runtime of the MP. After that, the flush_ok signal will be set, to indicate to 
the CI-Demux, that the filterbuffer’s are empty and can used for new packets. In the figures below, you can 
see the I/O signal table and a schematic overview about the different subblocs in the sender. 
The sender has for each accessed filter an address register, for the transmitterbuffer is also an errorregister 
added to store the ramfull error. 
 
Signal Type (direction, type) Description 
From CI-demux 
End_addr_filter0 In, std_ulogic_vector(9 DOWNTO 0) Last used address in the filterbuffer0 
End_addr_filter1 In, std_ulogic_vector(9 DOWNTO 0) Last used address in the filterbuffer1 
Incr_matched In, std_ulogic Increment number of frames who passed a filter 
To/from Phy (Toplevel) 
Tx_error In, std_logic If an error occurred during transmitting the phy will set 
this signal 
Tx_clk In, std_logic 25MHz transmitting clock from the phy 
Tx_reset In, std_logic Reset signal who is synchronized with the tx_clk 
Tx_enable Out, std_logic To enable the phy for transmitting a packet 
Tx_data Out, std_logic_vector(3 DOWNTO 0) Data lines for the phy 
To/from Output choice 
RADDR_filter0 Out, std_ulogic_vector(9 DOWNTO 0) Read address of filterbuffer0 
REN_filter0 Out, std_ulogic Read enable signal of filterbuffer0 
RADDR_filter1 Out, std_ulogic_vector(9 DOWNTO 0) Read address of filterbuffer1 
REN_filter1 Out, std_ulogic Read enable signal of filterbuffer1 
Flush_buffer In, std_ulogic_vector(1 DOWNTO 0) Indicate which buffers should be flushed 
Flush_ok Out, std_ulogic_vector(1 DOWNTO 0) If the flush is done, flush_ok <= flush_buffer 
From Filterbuffer0 
RD_filter0 Out, std_ulogic_vector(15 DOWNTO 0) Data lines of filterbuffer0 
From Filterbuffer1 
RD_filter1 Out, std_ulogic_vector(15 DOWNTO 0) Data lines of filterbuffer1 
 Fig. 6.22 Table I/O signals sender 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 38/49 - 
 
 Fig. 6.23 Block schema of sender 
 
- Addr registers filter0 & 1:  For each filterbuffer an address register, for the read access was  
     created. The transmitter controller can perform the increment or  
     reset of the address registers. 
- Addr registers transmitter: For the Tx-buffer in the transmitter, an address register was created  
     to store the actual-, begin- and end-address of a frame. The  
     transmitter controller can perform some actions on the addresses,  
     like increment, decrement, save_begin, save_end, load_begin,  
     load_end. 
- Error register transmitter: If the Tx-buffer is full, it receives the ram_full_error signal from  
     the address register and if the error is enabled by the controller, it  
     will be stored and sent to the controller. 
- Eth-header gen:  This bloc generate the Ethernet header. The Ethernet destination  
     and source addresses are fixed. The value of the Ethernet type  
     depends on which frame will be sent. For a measurement frame  
     0x0810 and for a status frame 0x0800. 
- Status-message gen: This block generates the UDP/IP headers fields and the data for the  
     statusmessage, each second it will indicate to the controller that he  
     will write the message into the Tx-buffer. The IP and UDP checksum  
     will dynamically calculated, if something changes in the message. 
- Mux data to ram:  The transmitter controller can choose which data should go to the  
     Tx-buffer. It can be the Ethernet data, the filter 1 data, the  
     filter 2 data or the status message data. 
- Transmitter:   Further information see Chapter 6.2.9.1 below. 
- Transmitter controller: Inside the transmitter controller a statemachine is implemented,  
     which controls all the blocks inside the sender. First, the Ethernet  
     header will be written into the Tx-buffer then he will wait for a  
     message to send. This can be either a measurement frame or a  
     status message. In the following picture you can see the  





































Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
















































 Fig. 6.24 Statemachine transmitter_controller 
 
6.2.9.1 Transmitter 
The transmitterblock is made by the school in Switzerland, like in the receiver, I made just some 
adaptations for my design. For additional information’s about the transmitter, have a look at appendix 7. 
Inside the transmitter is a dualport buffer, which stores all the Ethernet frames to send. To see the 
structure of this buffer, have a look at Chapter 6.2.1 Intermediate frames. 
 
 Appendix 7 SimAP Design report 
 
The changes include the following blocs: 
- The reset synchronization bloc was moved into the resetgen bloc in the top-level to combine all 
the reset synchronization’s in one bloc. 
- Replaced the Xilinx buffer by an Actel dual port buffer. 
 
In the next table shows you the I/O signal of this bloc 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 40/49 - 
 
Signal Type (direction, type) Description 
To/from Phy (Toplevel) 
Tx_error In, std_logic If an error occurred during transmitting the phy will set 
this signal 
Tx_clk In, std_logic 25MHz transmitting clock from the phy 
Tx_reset In, std_logic Reset signal from the phy 
Tx_enable Out, std_logic To enable the phy for transmitting a packet 
Tx_data Out, std_logic_vector(3 DOWNTO 0) Data lines for the phy 
To/from transmitter controller 
End_of_frame Out, std_ulogic Indicate the end of transmitting of a frame 
Not_set_ram Out, std_ulogic If the data should not taken from the buffer but from 
the datalines directly 
Write_ram In, std_ulogic Enable write signal for the transmitter-buffer 
To/from address registers 
Address In, std_ulogic_vector(9 DOWNTO 0) Actual write address of the transmitter-buffer 
Base_addr Out, std_ulogic_vector(9 DOWNTO 0) Address till the transmitter controller can write new 
packets to send 
To/from muxram to data 
Data In, std_ulogic_vector(15 DOWNTO 0) Write data-lines for the transmitter-buffer 
 Fig. 6.25 Table I/O signals transmitter 
 
A schematic overview about the bloc inside the receiver is given below. 
 
 Fig. 6.26 Block schema of transmitter 
 
The sent packets from the transmitter was captured by a PC with the program Wireshark 
 














byte CRC 32 
























   
 
  
   
 
  
   
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 41/49 - 
6.2.10 UART 
By pushing the button0 on the Controller-board during restart, the output format will be changed from 
Ethernet to UART. In the UART case, all the data from the filterbuffer, who has to be flushed, will be send 
through the RS232 Interface, no additional data will be added. In the following pictures, you can see a 
schematic overview, about the sub bloc’s inside the UART, the I/O signal table and a flushed filterbuffer 
with a MH, a CH and 1 packets received by a PC, with a serial port terminal. 
 
It has to be mentioned that the UART output is just used as debug output, because the speed is limited to 
115Kbps, during the flush of the filterbuffer’s, some packets will be lost if the traffic on the CI’s is too high.  
 
Signal Type (direction, type) Description 
From CI-demux 
End_addr_filter0 In, std_logic_vector(9 DOWNTO 0) Last used address in the filterbuffer0 
End_addr_filter1 In, std_logic_vector(9 DOWNTO 0) Last used address in the filterbuffer1 
To/from Phy (Toplevel) 
TX1 In, std_logic If an error occurred during transmitting the phy will set 
this signal 
To/from Output choice 
RADDR_filter0 Out, std_ulogic_vector(9 DOWNTO 0) Read address of filterbuffer0 
REN_filter0 Out, std_ulogic Read enable signal of filterbuffer0 
RADDR_filter1 Out, std_ulogic_vector(9 DOWNTO 0) Read address of filterbuffer1 
REN_filter1 Out, std_ulogic Read enable signal of filterbuffer1 
Flush_buffer In, std_ulogic_vector(1 DOWNTO 0) Indicate which buffers should be flushed 
Flush_ok Out, std_ulogic_vector(1 DOWNTO 0) If the flush is done, flush_ok <= flush_buffer 
From Filterbuffer0 
RD_filter0 Out, std_ulogic_vector(15 DOWNTO 0) Data lines of filterbuffer0 
From Filterbuffer1 
RD_filter1 Out, std_ulogic_vector(15 DOWNTO 0) Data lines of filterbuffer1 
 Fig. 6.28 Table I/O signals UART 
 
 
































To all bloc‘s 
TX1 
REN_filter0 & 1, flush_ok 
flush_buffer 
50MHz  114.83Khz 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  




 Fig. 6.30 Received filterbuffer 
 
- Data synch: Because the UART-sender works with a different clock, all signals  
  which change during transmitting, has to be synchronized with the  
  UART-clock. In this case, there are the address- and data-lines of the  
  filterbuffer’s. 
- UART addr registers: The UART bloc accesses both filterbuffer’s, the addresses are stored  
  in the addr registers. 
- UART clock gen: The UART interface is a serial transmission through RS232, the speed is  
  much lower than the Ethernet. To achieve a baud rate of 115200bps the  
  tx_clock has to be 115.2kHz. The nearest approach to this, with a 50MHz  
  systemclock, is 114.83Khz. The clock is created in this bloc. 
- Mux data to send: Depending which filterbuffer’s has to be flushed, the heart can choose  
  which data lines should be connected to the UART core. 
- UART: This core was taken from a website which provides free IP cores. It is  
  called  www.opencores.org. Because just the transmitting part was  
  needed, the core was adapted, and the receiving part has been deleted. 
- UART heart: The heart controls all the other sub blocks in the UART-sender. If a  
  filterbuffer has to be flushed, the data will be taken and forwarded to  
  the UART core, which sends it over the RS232 interface to a PC to  
  display it. The statemachine of the UART-heart is given in the following  






               Flush 




















 Fig. 6.31 Statemachine UART_heart 
MH CH Data 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 43/49 - 
 
The configuration of the UART is given in the table below. 
UART configuration 
Baud rate 115200bps 
Data bits 8 
Parity type None 
Stop bits 1 
Flow control Off 
 Fig. 6.32 Table UART configuration 
 
6.2.11 TSC 
The Time Synchronization Client provides us the possibility to have a more accurate timestamping. In the 
actual version of the MP, the timestamp is a relative value, by pressing the reset button, the time starts 
from 0 in picoseconds with an accuracy of 20ns. 
A previous diploma work was already made in this topic, it is called Time and frequency synchronization, 
see appendix 8. Unfortunately the hardware that was already made for the timesynchronization was not 
ready to use. Therefore there is no absolute timestamping and not all of the features could be tested. 
In following section you have an explanation how the time synchronization works. 
 
 Appendix 8 Time and frequency synchronization 
 
The device structure for the time synchronization network, is a Master – Slave – Client architecture. The MP 
made in this project, is used as client for the RS422 Network, this is obvious in the following picture. 
 
 
 Fig. 6.33 Time synchronisation network 
 
To have an exact time, 3 Points have to be considered. 
- Prevent the internal clock from drifting 
- Calculate the delay of the time transmission 
- Take the actual time from the GPS antenna (not implemented) 









FPGA FPGA FPGA 
FPGA 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 44/49 - 
Signal Type (direction, type) Description 
To CI 1&2 
timestamp  Out, std_logic_vector(96 DOWNTO 0) Relative time in picoseconds 
To/from Output choice 
PPS In, std_logic The PPS signal is a 1Hz clock from the GPS antenna, 
with this clock you prevent the internal clock from 
drifting 
Delay_in In, std_logic With the delay in and out signal it is possible to 
calculate the delay between Client-Salve or Client-
Master 
Delay_out Out, std_logic See above 
Time In, std_logic This signal should give the MP the actual time but 
unfortunately this could not implemented 
 Fig. 6.34 Table I/O signals TSC 
 
In the following figure you can see a schematic overview about the sub blocks in the TSC. 
 
 
 Fig. 6.35 Block schema of TSC 
 
- Clock drift correction: If a rising edge of the PPS-signal arrives, a counter is started till the  
     next rising edge, to know the number of systemclock pulses for  
     1 sec. 
- Pico counter:  He has a 96bit counter to count the time in picoseconds for the CH.  
     The threshold from the clock_drift_correction-block gives the  
     number of counts, till 1sec is passed. 
- Delay calc:   To calculate the delay, a small statemachine is used. He sends a 1  
     on delay_out and starts a counter, till the 1 appears on the signal  
     delay_in. The counter has than the time of the delay. It has to be  
     divided by 2, to know the one way delay. The statemachine is given  
     below. 
 
Init
Send signal on 
delay_out

















Delay in ps 
Threshold for 1sec 
Update threshold 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 45/49 - 
7 Tests 
In this part, the hardware tests I made, are explained in detail. Before the FPGA could be programmed, the 
design has to be verified in the simulations. But because the two boards was from different manufactures, 
one with a CPLD from Xilinx the other with a FPGA from Actel, it was not possible to simulate the behavior 
between the two boards, therefore, I could test just partially in the simulation. There were a lot of 
problems with the synchronization of both boards. After that was solved, the hardware tests could be 
made. 
 
The implementation was tested with a Frame generator program where it is possible to define the content 
of a packet and the time between 2 packets. A constant frame rate could be generated. In the last week we 
also made together with Arlos Patrik, a test run where the custom MP could be compared with a real MP. 
 
The following issues were tested: 
- Receiving: The packets received properly on both CI. At the end also the CRC-check  
  went fine and worked as expected. The receiving works with a 100Mbps  
  and also with the 10Mbps connection. 
- Filtering: The filtering was successful tested. In the actual version it is possible to  
  filter the first 42 bytes of a packet. 
- CH / MH: The capture- and measurement-header will be added with the right  
  values. There is a problem with the bit ordering of some fields, in the CH.  
  It should be easy to solve. 
- Timestamping: The time of the frame is taken when the start of frame signal is detected,  
  that is what we expected. Also here the bit order was not compatible with  
  version 0.6 of the DPMI interface. 
- Statusmessage: The status messages are sending every second with the right content. 
- Switch UART-Eth output: As long as the button is pressed before restart, the switch between the  
  two outputs worked well. But if it is pressed during the MP is running, it  
  may be able to lose some packets. In each case the UART output has not a  
  good performance, some packets will be lost if the traffic is too high. 
8 Actual state 
The MP was developed, but the system is not ready for the market, there are some implementation left, 
like the Control messages, to and from the DPMI interface. But since the last version of Gubler Olivier, 
some improvements could be made. 
 
Interface 
The Interface was programmed and tested in the 32bit and 4bit version. In the last week in Sweden the 
Interface board was damaged (VCC and GND are connected), and could not further used. I implemented a 
demonstration MP with the 2 Ethernetplugs of the Dev-Board. One acts as CI and the other as connection 
to the MArN. 
 
Controller 
Not all of the goals were reached. We made some simplifications, that I could finish the project. One 
problem was, that the Arm Core could not use as indented. The actual version has two CI with two working 
filters. The capture length is adaptable from none to fullframe catch and also the filterlength can be 
changed from 42bytes to 512bytes per filter. The communication with the DPMI Interface worked, but not 
all the control messages could be implemented. The receiving part of these messages like add/remove 
filter, flush buffer are missing. 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 46/49 - 
9 Further work 
I would like to make suggestions for the further development of the project: 
- Finish further development of the Interface-board 
o Mount the optical receivers on the Interface 
o Test the Interface 
- Build of a Interface with other Input Sources, like 1000Base-TX 
- Build a proper RS422 transmitter for a real timestamping 
- Build of the Controller Board with an Actel Core MP7 FPGA 
o In this project was a prefabricated board used as Controller, the next step would be to 
make the own board with just the necessary functions. 
- Better use of the ARM Core 
o Interface between ARM and FPGA logic 
o In this Project the ARM Core was not used as intended, in the further development it 
could be used more intensive as now, this could be done by an interface between the 
Arm-core and the FPGA logic. 
- Implement new functions in the Controller 
o Optical capture interface 
o MP with more than 2 capture interfaces 
o Optical  Twisted pair converter 
o Implement Control frames (flush buffer, add/remove filter) 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 47/49 - 
10 Conclusion and remarks 
During the semester project and the diploma work, I could see how a prototype is growing from the 
beginning. At first, the conception of the board, choose the right components and testing. After that, I 
could start with the programming of the FPGA and the CPLD. Because the chips on the boards were from 
different manufacturer, Actel and Xilinx, I had to work with the corresponding programs it was really 
interesting to see the advantages and disadvantages of each program. 
 
In the project I improved my acknowledge about VHDL, hardware conception and project management. It 
was a challenging project, a lot of problems occurred during the development of each step. Now at the end, 
I would handle some things in a different way, so I look forward to my next project. 
 
I had to work together with many people, without those, it would not have been possible, to progress so far 
in this project. Thanks to everyone, who was helping me. Your support, ideas and comments were very 
helpful. 
 
Unfortunately, I did not reach all goals of the project, because of the lack of time. In further projects, it 
should be possible to have closer look at those points. 
 
These 5 months opened my horizon and gave me the chance to get in contact with new people, a new 
culture and an interesting country. The BTH school is very international, there work peoples from 
everywhere of the world. I hope that it will always be possible to do such exchanges for students, to show 
them new fields in science and to open their mind for other countries and cultures. To make new 








 Zahno Silvan: 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 48/49 - 
11 Glossary 
MP Measurement Point 
FPGA  Field Programmable Gate Array, is a semiconductor device containing programmable 
logic components and programmable interconnects. 
CPLD Complex Programmable Logic Device is a programmable logic device. The building 
block of a CPLD is the macro cell, which contains logic implementing disjunctive 
normal form expressions and more specialized logic operations. 
Dev-Board Development Board from Actel, this is a Board which allows to develop different kind 
of application. In this paper it is also called Controller-board. 
Phy Physical, this IC representing the first layer of the OSI-model. 
MArN Measurement Area Network, network which analyzes and tread the sent 
 Measurement frames. 
MArC Measurement Area Controller, this device controls the MP. 
Eth Ethernet 
CI Captured Interface, a MP can have different CI, each can capture one line, in this 
project there exist 2 CI 
MH  Measurement Header, on each sended packet are a MH added to give the DPMI 
some additional informations 
CH Capture Header, on each captured frame is a CH added, which provide some 
information about the captured frame 
SOF Start Of Frame, a Ethernet packet starts with the preamble (0x5) and after that the 
sof delimiter (0x5D), it indicates the begin of a Ethernet packet. 
TP Twisted Pair, is a form of wiring, this cables are used to connect the MP to the MArN 
VHDL  Very High Speed Integrated Circuit Hardware Description Language, is a 
programming language to describe hardware 
JTAG  Joint Test Action Group, is the usual name used for the IEEE 1149.1 standard entitled 
Standard Test Access Port and Boundary-Scan Architecture for test access ports used 
for testing printed circuit boards using boundary scan 
10BaseT 10Base-T is a form of medium speed Ethernet, providing 10Mbit/s 
100BaseTX 100Base-TX is the predominant form of Fast Ethernet, providing 100 Mbit/s Ethernet. 
It introduces an additional, medium dependent sublayer, which employs MLT-3 as a 
final encoding of the data stream before transmission 
100Base-FX 100Base-FX is a version of Fast Ethernet over optical fiber. It uses two strands of 
multi-mode optical fiber for receive and transmit 
RJ45 Registered Jack (RJ) is a standardized physical interface for connecting 
telecommunications equipment or computer networking equipment. The standard 
designs for these connectors and their wiring are named RJ11, RJ14, RJ45, etc. 
PCB Printed Circuit Boards are used to mechanically support and electrically connect 
electronic components using conductive pathways, or traces, etched from copper 
sheets laminated onto a non-conductive substrate.  
CRC Cyclic Redundancy Check (CRC) is a type of function that takes as input a data stream 
of unlimited length and produces as output a value of a certain fixed size. The term 
CRC is often used to denote either the function or the function's output. A CRC can 
be used in the same way as a checksum to detect accidental alteration of data during 
transmission or storage. 
RTC Real-Time Clock is a computer clock that keeps track of the current time. Although 
the term often refers to the devices in personal computers, servers and embedded 
systems, RTCs are present in most any electronic device which needs to keep 
accurate time. 
UART Universal Asynchronous Receiver/Transmitter, is usually an individual (or part of an) 
integrated circuit used for serial communications over a computer or peripheral 
device serial port. UARTs are now commonly included in microcontrollers. 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
  
25.03.2008  - 49/49 - 
12 References 
Books: 
“On The Quality Of Computer Network Measurements” 
Patrik Arlos 
Bleckinge Institute of Technology 
Doctoral Dissertation Series No. 2005:05 
 
“VHDL-Synthese. Entwurf digitaler Schaltungen und Systeme“ 
























and much other sites… 
 
13 Appendix 
Appendix 1: Report Semester project 
Appendix 2: Schematic Interface 
Appendix 3: Schematic Converter 
Appendix 4: CoreMP7 development kit users guide 
Appendix 5: Datasheet CoreMP7 
Appendix 6: Passive measurement infrastructure 
Appendix 7: SimAP Design report 
Appendix 8: Time and frequency synchronization 



















Systems Engineering: Infotronic 
 Semester project 
  Part I of the Diploma Work 
- Frame Capturing and Sending in FPGA - 
 
Author Zahno Silvan 
Under guidance of Corthay Francois and Gubler Olivier 
Version v 1.0 
Sion, 13.01.08 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 2/27 - 
Table of contents 
 
1 Author ................................................................................................................................................. 4 
2 Preface ................................................................................................................................................ 4 
2.1 Introduction ................................................................................................................................. 4 
2.2 Appendix ...................................................................................................................................... 4 
2.3 Structure of this project ................................................................................................................ 4 
2.3.1 Planification .......................................................................................................................... 4 
3 Overview ............................................................................................................................................. 5 
4 Hardware ............................................................................................................................................ 6 
4.1 Problem analysis and solution approaches .................................................................................... 6 
4.2 Interface ....................................................................................................................................... 6 
4.2.1 Active Ethernet tap ............................................................................................................... 8 
4.2.2 Passive Ethernet tap.............................................................................................................. 8 
4.2.3 Sending the Data from the plug to the Phy .......................................................................... 11 
4.2.4 Physical Interface ................................................................................................................ 13 
4.2.4.1 Strap options ............................................................................................................... 13 
4.2.5 Sending of the packets to the Controller ............................................................................. 15 
4.2.5.1 Choice of the CPLD ...................................................................................................... 15 
4.2.6 RS422 interface ................................................................................................................... 16 
4.2.7 Connector ........................................................................................................................... 17 
4.3 Controller ................................................................................................................................... 18 
4.3.1 Choice of the FPGA ............................................................................................................. 18 
4.3.2 Design flow ......................................................................................................................... 20 
4.4 Converter-board ......................................................................................................................... 21 
4.4.1 Pin assignment on the Controller ........................................................................................ 21 
5 Construction of the hardware ............................................................................................................ 22 
5.1 Interface PCB .............................................................................................................................. 22 
5.2 Converter PCB ............................................................................................................................ 22 
5.3 List of order for Project Frame Capturing and sending in FPGA ................................................... 22 
6 Actual state ....................................................................................................................................... 24 
7 Further work...................................................................................................................................... 24 
8 Conclusion and remarks ..................................................................................................................... 25 
9 Glossary ............................................................................................................................................. 26 
10 Bibliography ...................................................................................................................................... 27 
11 Appendix ........................................................................................................................................... 27 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 3/27 - 
Table of figures 
 
Fig. 2.1   Time table diagram of the Project .................................................................................................. 4 
Fig. 4.1   Bloc diagram of the Interface ......................................................................................................... 7 
Fig. 4.2   Active tap bloc diagram of the Interface ......................................................................................... 8 
Fig. 4.3   High-impedance-bloc ..................................................................................................................... 9 
Fig. 4.4   Offset circuit .................................................................................................................................. 9 
Fig. 4.5   Passive tap bloc diagram of the Interface ..................................................................................... 10 
Fig. 4.6   Worse passive tap of the fiber-network ........................................................................................ 10 
Fig. 4.7   Termination circuit for RJ45 and construction of the RJ45-plug .................................................... 11 
Fig. 4.8   Termination circuit for fiber-plug.................................................................................................. 11 
Fig. 4.9   ZTool to calculate the line impedance .......................................................................................... 12 
Fig. 4.10 Application of the Phy .................................................................................................................. 13 
Fig. 4.11 Table of mode options ................................................................................................................. 14 
Fig. 4.12 Table of MAC interface options .................................................................................................... 14 
Fig. 4.13 Table of Led mode select.............................................................................................................. 14 
Fig. 4.14 CPLD-Pin table ............................................................................................................................. 15 
Fig. 4.15 RS422 network overview .............................................................................................................. 16 
Fig. 4.16 Bloc diagram of the RS422 Interface ............................................................................................. 17 
Fig. 4.17 CPLD-Pin table ............................................................................................................................. 17 
Fig. 4.18 FPGA choice table ........................................................................................................................ 18 
Fig. 4.19 MP7 FPGA-Core ........................................................................................................................... 18 
Fig. 4.20 Actel CoreMP7 Developement Kit ................................................................................................ 19 
Fig. 4.21 Schema of the design flow ........................................................................................................... 20 
Fig. 4.22 Blocdiagramm of Converter-board ............................................................................................... 21 
Fig. 4.23 Pin assignment table .................................................................................................................... 21 
Fig. 5.1   List of order .................................................................................................................................. 23 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 





This Semester project should be the first part of my diploma work, which I will continue in Sweden, 
Blekinge. 
The subject of the Diploma Work will be “Frame capturing and sending in FPGA”. In this part of the project, 
I will develop the Hardware, or a part of it, for the work in Sweden. It is the sequel of the Diploma work of 
Oliver Gubler, who also made his work in Sweden. 
 
In fact, in this part, I will develop a more powerful Hardware than I usually need. For my specific diploma 
work, I don’t need Hardware with so many I/O Interfaces, but to extend the project for future students, it’s 
good to have some expansion capabilities in the Hardware. 
In consideration of this reason, my board should contains the following I/O Interfaces: 
- 10/100Base-TX Copper Ethernet RJ45 
- Fiber Ethernet 100Base-FX 
- RS 422 for time synchronization 
- LCD display 
- USB 2.0 Interface 
- SD-Card-Reader 
- JTag Inferface 
- Led’s 
2.2 Appendix 
Some articles and parts of the work are given in appendix. They can be found at the end of the report. The 
appendixes 2-10 are just given on the enclosed CD. 




C Fig. 2.1   Time table diagram of the Project 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 5/27 - 
3 Overview 
The goal is to build a hardware, called Measurement Point (MP). Such a device does packet capturing, then 
the captured data will be filtered and a time stamp will be added on each packet. The new packet will be 
buffered. After all, this packet will be sending in data packets in a measurement frame with defined sizes. 
I will realize this MP with a FPGA, which can implement a microprocessor as an IP soft-core or a hard-wired-
core. 
 
The Ethernet input connections are: 
- 10/100 Copper Ethernet RJ45 
- fiber Ethernet 100Base-FX 
 
Because a MP is a passive device to the Ethernet input, it must be invisible to the Measurement Area 
Network (MArN). To do a serious time stamp, an exact time synchronization is needed. Therefore a RS422 
Interface is added to synchronize with a master’s clock.  
The captured data will also be sent with a 10/100 Copper Ethernet RJ45. The programming interface of the 
board will be done via JTAG interface and it is possible to store the program in the FPGA as well as in a 
Smardcard-reader (SD), which is also integrated in the board. Other additional I/O’s for further work are: 
- USB Interface 
- LCD Display 
- Led’s 
- Optional optical input 
 
It should also be possible to exchange the Interface with a different one, so that the input sources can be 
enlarged again, for example, to implement Giga Ethernet, or other Transmission mediums. For this project, 
it is sufficient to have a 10/100Base –TX or a FX support. 
 
The functional specifications were discussed with Mr F.Corthay and O.Gubler. The meeting documents are 
given in the appendix. 
 













































Eth TP 2 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 6/27 - 
4 Hardware 
 
The Hardware is divided into three main parts: 
- Interface to the MArN 
- Converter between Interface and Controller 
- Controller to generate the captured packets 
4.1 Problem analysis and solution approaches 
The tasks of the MP to be developed can, be summarized in the following central problems. 
 
Interface: 
- Passive Ethernet tap 
- Active Ethernet tap 
- Sending the Data from plug to the Physical Layer (Phy) 
- Physical Interface for 100Base-TX, 10Base-T and 100BaseFX 








- RAM module 
- Power over Ethernet 
- Synchronization with a masters-clock 
- JTag Interface to store in SD-Card or directly in the FPGA 
- Additional I/O Interfaces 
 
 
These points must be analyzed, so that they can be converted in practicable solutions. 
4.2 Interface 
This part of the hardware submits the captured packages of the MArN-Network to the Controller, without 
changements of the content. The network entrance can be carried out via a 100Base-TX twisted pair, a 
10Base-T twisted pair or a 100Base-FX fiber. 
This Interface can be used for the following tasks: 
- Active tap :  Both input-lines go directly to the physical Interface (Phy) 
without any influence. 
- Passive tap:  Both Rx-Channels are connected through the high-impedance 
    tap to the Phy, because we are just listening, we don’t need  
    the Tx-Channels 
 
In the active case it’s possible to attach either the twisted pair (TP) or the fiber. There are the following 
possibilities: 
- TPßàTP:   Both twisted pair inputs are used 
- TPßàfiber:  One twisted pair and one fiber are used (TP – FX conversion) 
- fiberßàfiber:  Both fiber inputs are used 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 7/27 - 
In the passive case it’s only possible to attach the twisted pair. It is not possible to listen complete passively 
to the fiber-network. 
- TPßàTP:   Both twisted pair inputs are used 
 
With Jumpers it is possible to switch the input-line between the RJ45 and the optical fiber input, as well as 
for the switch from the active to the passive tap. 
 
The routage of the conducting paths was realized by a specialist of the school. The construction of the 
printed circuit board (PCB) couldn’t be realized at school because the board owns 4 different layers. 
Therefore, the production of the PCB was passed on to an external manufacturer by a quantity of 1. 
Unfortunately, at the end of the semesterproject, the board wasn’t completed, therefore it was impossible 
to mount the components on the board and to test it. 
 
 
Plug RJ45 Plug RJ45Plug Fiber Plug Fiber

















Tx Rx              Tx Rx
Jumper
Tx Rx              Tx Rx
Tx                        Rx   Led’s Tx Rx    Led’s
High impedance buffer
Jumper























































Jumper for switch 
from TP to Fiber
Jumper for passive (P)
or active (A) tap
JumperJumper


















C Fig. 4.1   Bloc diagram of the Interface 
 
 
Remark: We have moved the RS422 Interface for the synchronization with the master’s clock of the 
Controller board to the Interface, so that we have the possibility to attach a controller without a RS422-
Interface. Because the time for the completion of the Controller is not sufficient, an Actel Development-
Board without a RS422 Interface is used as Controller (C see 4.3 Controller). 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 8/27 - 
4.2.1 Active Ethernet tap 
The active Ethernet tap gives us the possibility to use the MP also as converter between the TP and the 
optical fiber. This is also very useful to “turn off" the MP and to connect the 2 MArN lines with each other. 
Through this, no cables have to be changed. The Rx and Tx lines go directly to the Phy without going 
through the high-impedance buffer. Of course, we can also put TPßàTP or fiberßàfiber together. 
For this feature, we have to send the packets to the CPLD by the Phy and mix up RxßàTx there. After, the 





C Fig. 4.2   Active tap bloc diagram of the Interface 
 
4.2.2 Passive Ethernet tap 
To capture the data traffic on an Ethernet connection, the signals must be tapped off by the lines. Not to 
influence the line and the connection to the next device, the tap has to be carried out with high-
impedance. So the impedance of the line is not changed fundamentally. A high-impedance buffer is added 
between the RJ45 plug and the Phy (C see Fig. 4.3 High impedance Buffer). 
This problem was already solved in an earlier diploma work and will serve us as a template. (C Decoding of 
100Base-TX signals). 
They have used a Voltage follower, so that the seen impedance from the MArN-Network is very high and 
therefore, we won’t disturb it. In reality, we still have some capacitive disturbances from the lines and from 
the operation amplifier (OP)-input (≈2pF), in addition, the OP has an input resistor of 100kΩ and a resistor 
to set an operating point. 
The lines to the OP have no DC-offset of 1.65V ( ), the decoupling will be done by a capacitor, therefore, a 
resistor of 10kΩ adds a DC-offset of 2.05V to the line. These resistors should, however, influence the line 
only insignificantly opposite the capacities. 
The OP, which is used for the DC-offset, is internally already connected with resistors, with which 
reinforcements of 1, 2, -1 can be caused. We only use them as buffer with reinforcements of 1. Since the 
amplifiers as RGB drivers are conceived, they can deliver sufficient current and reject a frequency range of 
over 200MHz. Moreover, they can be activated or deactivated with an additional line(TXEN) (C see Fig. 4.4 
Offset circuit). 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 9/27 - 
 
 
C Fig. 4.3   High-impedance-bloc 
 
C Appendix 2 Datasheet OPA3692ID (only on CD) 
 
 
C Fig. 4.4   Offset circuit 
 
Because the MP only listens to the Ethernet, it knows no difference between the Rx and the Tx line. To be 
able to select the line to be measured, the physical interface must be able to capture both lines at the same 
time or change between the two lines. 
If we judge both solutions, it is obvious, that a 2-port Phy is the best choice. Because the MP has 2 
independent passive Ethernet taps disposes, both lines can be captured when required. Fortunately, there 
already exist some good Phys on the market, like the National Semiconductor DP83849ID Transceiver, 







Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 




C Fig. 4.5   Passive tap bloc diagram of the Interface 
 
Because the fiber-plugs do already transform the light pulses into electrical signals, we cannot listen 
passively to the fiber-network. The lines between the connector and the Phy have their own impedance 
network: The signals first go through an entrance impedance, match the network near the plug and after, 
through an output impedance and match the network near the Phy. The transmission lines between the 2 
networks have an impedance of 50Ω. 
The passive tap of the fiber-network doesn’t work, because the 2 fiber-plugs are connected through 2 





































Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 11/27 - 
4.2.3 Sending the Data from the plug to the Phy 
Between the RJ45 and the fiber-plugs, the packets are still available in an analogous form. It can cause 
some disturbances or reflections on the line, therefore, we have to add a termination circuit, which 
includes an entrance- and output-resistances-circuit and in addition, the lines can have a line impedance of 




In the following figure, you can see the required resistors. We also need two RJ45 plugs with a 1:1 
transformer to achieve a DC-decoupling. RJ45 plugs, with integrated magnetic, are available at school and 
fit perfectly to this application. 
In addition, it still has to be mentioned that these RJ45 plugs have some short-circuited pin’s (4, 5, 7, 8) and 
are directly connected to the mass. 
 
              
C Fig. 4.7   Termination circuit for RJ45 and construction of the RJ45-plug 
 
C Appendix 3 Datasheet MagJack 0801-1X1T-03 (only on CD) 
 
Ethernet fiber-plug 
For the fiber connection we must have a termination circuit. That means, entrance-, output-resistors and a 








C Fig. 4.8   Termination circuit for fiber-plug 
 
Because the fiber plug is designed for future diploma works, we will neither order nor put together these 
plugs at the board. 
 
C Appendix 4 Datasheet Agilent AFBR-5903Z (only on CD) 
 
Calculation of the 50Ω line-impedance: 
The Calculation of the impedance of the line can be done via the program ZTool (C see CD). 
















Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 12/27 - 
 
 
C Fig. 4.9   ZTool to calculate the line impedance 
 
National Semiconductor offers a scheme of a Development board that exactly is adapted to the Phy. On this 
scheme, neither the fiber-network nor the TP-network has a line impedance of 50Ω. Because this board is 
done by specialists, we decided to take it as a template and we didn’t adapt the line with 50Ω. However, we 
had to place the Phy as close as possible to the plugs, to minimize the reflections on the lines between the 
plug and the Phy. 
 
C Appendix 5 DP83849 Dual Phyter Demo II Stump Jumper scheme (only on CD) 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 13/27 - 
4.2.4 Physical Interface 
The decoding of the physical layer of the 100Base-TX and also of the 100Base-FX signals are very complex. 
With a 100Base-TX hardware the raw bits go through a 4B5B binary encoding to generate a series of 0 and 
1 bits, clocked at 125 MHz; the 4B5B encoding provides DC equalization and spectrum shaping. Just as in 
the 100Base-FX case, the bits are then transferred to the physical medium attachment layer, using NRZ 
encoding. However, the 100Base-TX introduces an additional, medium dependent sublayer, which employs 
MLT-3 as a final encoding of the data stream before transmission. 
 
But as already mentioned above, there exist IC’s, which offer these functionalities. The chosen 2-Port Phy is 
the National Semiconductor DP84839ID. It offers a Dual Port 10/100Mbit/s Ethernet Layer Transceiver with 
FX support. One of the reasons why I chose this Phy, is, that mostly the packing unit is up to 400 pieces per 
order. But by National Semiconductor, there is the possibility to order samples in a quantity of 1-5 pieces. I 
would like to thank to National Semiconductor for giving me 4 examples of this Phy for free to use in this 
project. 
This is more than sufficient for this work. 
 
 
C Fig. 4.10 Application of the Phy 
 
C Appendix 6 Datasheet National Semiconductor DP83849ID (only on CD) 
4.2.4.1 Strap options 
The Phy uses many of the functional pins as strap options. The values of these pins are sampled during 
reset and used to strap the device into specific modes of operation. 
A 2.2kΩ resistor should be used to pull-down or pull-up to change the default strap option. 
All strap options can also be set through a register access. 
In the following part I will give you an overview of the possible options: 
- Mode options: With the 4 pins (FX_EN, AN_EN, AN1 and AN0) we choose the mode of our 
Phy for port 1 and 2. 
 - FX_EN à fiber enable 
 - AN_EN à Auto-Negotiation enable 
 - AN1/AN0 à Control the forced or advertised operating mode 
The default is 0111 since FX_EN pin has an internal pull-down and the Auto-Negotiation 
pins have internal pull-ups. 
To choose the different options, jumpers are added to these pins to force 0 or 1. 
So we have 3 configuration possibilities (see in following table). 
CPLD 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 14/27 - 
 
 
C Fig. 4.11 Table of mode options 
 
 
- MAC Interface mode: With the 2 pins (MII_MODE and SNI_MODE) we determines the  
  operating mode of the MAC Data Interface 
  - MII_MODE à disable MMI mode 
  - SNI_MODE à enable SNI mode 




C Fig. 4.12 Table of MAC Interface options 
 
 
- LED configuration: With the 2 pins (CRS_DV and CRS) several functions can be multiplexed  
  onto the three LED’s using three different modes of operation. In our case  
  we don’t need the LED_SPEED 
The default mode is “mode1” the LED_CFG[1] register is only controllable through the register 
access and cannot be set by a strap pin. 
 
 
C Fig. 4.13 Table of Led mode select 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 15/27 - 
4.2.5 Sending of the packets to the Controller 
One of the problems of the ancient Diploma work was, that the sending of the packets from the Interface 
to the Controller Board caused some errors in the CRC-Check. Because of this, some frames were lost. 
To prevent the lost of a package, we have to reduce the speed of the data between the Interface and the 
Controller. 








For the assignment about a ribbon cable or hard plug, 31.25MHz does not represent a problem. 
 
Therefore, we add a complex programmable logic device (CPLD), which has the following tasks: 
- Enlarges the number of data lines 
- Adapts the control signals 
- Realizes the transformation TPßàfiber 
- Disables the high-impedance buffer 
- Transmits the RS422 master’s clock to the Controller 
4.2.5.1 Choice of the CPLD 
The choice of the CPLD is carried out with the required pin. In the following table, all needed I/O are listed 
with the number of pin required: 
 
Pin from Interface 
Description Number of pins Direction 
Rx-Data lines 
(Port A and B) 
8 Input 
Tx-Data lines 
(Port A and B) 
8 Input 
Control-signals 18 I/O 
RS422 Interface 4 I/O 
High-impedance buffer disable 2 Output 
Pin to Controller 
Description Number of pins Direction 
Rx-Data lines 64 Output 
Control-signals 18 I/O 
RS422 Interface 4 I/O 
High-impedance buffer disable 2 Input 
Reserve 5 I/O 
Total Nbr of Pins 129  
C Fig. 4.14 CPLD-Pin table 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 16/27 - 
With this table it is obvious that we need a CPLD with 129 pin supported. We considered to use the Xilinx 
XC9500XL family. This CPLD was already used often and it is a low energy device with up to 5V I/O 
capabilities. The numbers of the available user I/O can be selected between 34 – 196 Pin’s. In this case we 
took the CPLD with 168 User pin in a PQ208 package. 
 
C Appendix 7 Datasheet Xilinx XC95288XL (only on CD) 
4.2.6 RS422 Interface 
The RS422 Interface is needed for exact time synchronization with a master’s clock and for the time stamp, 
which we add in each captured packet. This problem has already been solved in an earlier diploma work (C 
Time and frequency synchronization). The MP made in this project, is used as client for the RS422 Network, 
this is obvious in the following picture. 
 
The slave calculates the delay from master to slave (tMS) and add this to the time, which was sent by the 
master. The client will now calculate the delay from slave to itself (tSC) and adds this to the time, that was 
sent by the slave too. After this process, the result has the exact time and can be used further for the time 



















































Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 17/27 - 
 
 
C Fig. 4.16 Bloc diagram of the RS422 Interface 
 
4.2.7 Connector 
The decision, which connector we take, depends on the number of required pins. In our case, it is better to 
install a hard Plug and not to work with a ribbon cable. One of the advantages is, that the disturbances will 
be minimized. At the completion of all parts (Interface and Controller), the components should be 
connected fix through the connector without using a Converter-board. 
We decided to take a 96 pin (3*32) male-female connector. 
 
Which signals are connected to the Connector is obvious in the following table 
 
Pin from Interface 
Description Number of pins Direction 
Rx-Data lines 
(Port A and B) 
64 Input 
Control-signals 18 I/O 
RS422 Interface 4 I/O 
High-impedance buffer disable 2 Output 
Power signals 3 Input 
Reserved 5 - 
Total Nbr of Pins 96  
C Fig. 4.17 CPLD-Pin table 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 18/27 - 
4.3 Controller 
The Controller part will receive all the Rx packets. These packets will be filtered and a time stamp will be 
added. After this, the packets will be reorganized and saved in RAM-Modules. To send the filtered packets 
to a Computer, a Ethernet connection is used. On the Computer we have a DPMI-Interface which is 
developed by Arloos Patrik, this interface will analyse the captured packets who was sended by the 
Controller. This board contains the additional I/O interfaces for the further diploma works. 
 
Unfortunately, the Controller can’t be realized in this semester project, because time is restricted and not 
sufficient. 
It is inevitable, to take an already prefabricated development board, which is used as Controller. 
 
The development board should contain the following features: 
- Connector to the Interface 
- RJ45-Ethernet plug 
- Power supply (also for the interface) 
- RAM-modules 
- FPGA which can implement a IP soft-core or hard-wired-core 
- Other additional Interfaces 
4.3.1 Choice of the FPGA 
First of all, it is necessary to choose the FPGA to use in the Controller. The features that can be 
implemented are a microprocessor, such as an IP soft-core or a hard-wired-core. It should also support 
enough I/O’s for all the interface signals. In addition, the same FPGA should also be available as low power 
FPGA and as one time programmable (OTP). The following table shows the chosen possibilities: 
 
Items Integrated Prozessor FPGA Licence Code / Example Avail. DevBoard DevTools 






 - 32-bit MicroBlaze™  
   soft processor 
   It use 800-2600 LUTs 
 No 
 - Spartan 3  
  XC3S1000-4FG456C $60 
 - Spartan 3E  
  XC3S100E-4CP132C $30 SoftCore needs EDK 
 - There exist  
    some example 
 - Microblaze  
   codes are    
   availabe 
Yes 
 - Spartan-3A Starter Kit 
   (HW-SPAR3A-SK-UNI-G) $199 
 - Spartan-3E 1600E MicroBlaze  
    Development Kit (DO-SP3E1600E-DK- 
    UNI-G) $599 
 - ISE™ Foundation  
   DS-ISE-FND  
   $2500 
 - The Embedded  
   Dev Kit (EDK)  
 - Real View Dev  
    Kit $2000 Xilinx Virtex 
Embedded PowerPC 
405 (PPC405) core 
Virtex-4 FX 
FX not available 
HardCore Free 
SoftCore needs EDK No 
PowerPC & Microblaze Starter Kit 
DO-ML403-EDK-ISE-USB-EC $895 
The Virtex™-II Proy 
HardCore Free 




 - MP7 soft core, impl. 
   ARM7TDMI-S.  
   Available for all M7  
   devices for free No 
 - M7 ProASIC3  
   $30<$150 
 - M7 Fusion  
 - M7 IGLOO Free for M7 devices 
 - 1 example 
    # Core MP7 - WebServer 
 - SoftCore codes are  
   available for free Yes 
The CoreMP7-1000 are available on May 
COREMP7-1000-DEV-KIT-FP3 $600 
with Programmer FP3 ($100). 
# Fusion Starter Kit 
# ProASIC3 Starter Kit 
# ProASIC3E Starter Kit 
 
 - Design Software 
    Libero® DIE Free 
 - CoreConsole for    
    configuration 
 - SoftConsole free 
C Fig. 4.18 FPGA choice table 
 
In this Project, I decided to take the Actel MP7 FPGA. In this FPGA we have the possibility to implement one 
(or more) ARM7TDMI-S microprocessor as IP soft-core. The ARM7 Core is the most widely used 
architecture in 32-Bit microprocessors. We chose the Actel Development board with a MP7A3P1000 FPGA 
chip. With this chip, we have sufficient user I/O’s for our Interface board. 
 
 
C Fig. 4.19 MP7 FPGA-Core 
 
C Appendix 8 Datasheet ProASIC3E Flash Family (only on CD) 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 19/27 - 
The board consists of the following: 
- Wall-mount power supply connector with switch and LED indicator 
- Switches to select from 1.5 V, 2.5 V, and 3.3 V (I/O Bank) voltages on banks 3–4 
- 10-pin, 0.1"-pitch programming connector compatible with Altera connections 
- 48 MHz oscillator and 32kHz oscillator for real-time clock (RTC) calculations 
- Eight LEDs driven by outputs from the device 
- Jumpers allowing disconnection of all external circuitry from the FPGA 
- One monostable pulse generator switch 
- Eight switches providing input to the device 
- Two RS-232 serial interfaces 
- Two 10/100 ethernet interfaces 
- One Controller Area Network (CAN) 2.0B serial interface 
- One USB 1.1 serial interface 
 
C Appendix 9 CoreMP7 development kit users guide (only on CD) 
 
CoreMP7 is a soft IP-core implementation of the popular ARM7TDMI-S microprocessor. The CoreMP7 
microprocessor has the following features: 
- 32-bit ARM instruction set for maximum performance and flexibility 
- 16-bit Thumb instruction set for increase code density 
- Inified bus interface 
- 3-stage pipeline 
- 32-bit ALU 
- Fully static operation 
 
C Appendix 10 Datasheet CoreMP7 (only on CD) 
 
Remark: A reason why I chose this Dev-Board is, that the FPGA works with a 50MHz oszillator. The packets 
leave the Phy with a speed of 25Mhz, so we have a certain surplus and can work without problems on the 














USB 1.0 Interface 
Actel FPGA 
Connect to Interface-Board 
Power supply / On/Off Switch 
JTag Interface 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 20/27 - 
4.3.2 Design flow 
In the following picture you can see the Design flow of a program, the individual evolutionary steps can be 
subdivided into 3 groups: 
- Design creation/verification 
In this step, the VHDL code will be generated (HDL-Editor) and simulated (ModelSim). The 
VHDL code of the MP7-Core will also be generated out of the SmartGen Core Generator. 
After this, the synthesis will be made with PALACE. 
- Design implementation 
In this step, the code will be compiled and to conclude, the program files will be generated. 
- Programming software 




C Fig. 4.21 Schema of the design flow 
 
In the last week of the project, I began to program the dev-board with a tutorial project, which was given 
with the development kit. I tried to implement the ARM7TDMI-S IP soft-core in the FPGA. During the step 
“place & route”, I had a compile error which I couldn’t eliminate until the end of the semesterproject. 
 
Error: CMP073 power found on external GND pin NET: ‘GND’ 
 
I have contacted Actel, to inform about this error in the tutorial project. Unfortunately, my request was not 
solved till now. 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 21/27 - 
4.4 Converter-board 
We need a Converter-board so that our Interface-board is able to connect to the Controller-board.  
This converter has on one side a 96Pin connector for the connection with the Interface and on the other 
side three 40Pin connectors to attach the Controller. The connectors on the Controller-board also offer 
several powerlines, like 5V, 3.3V and GND, therefore, we don’t need the external 5V connector in the 













C Fig. 4.22 Blocdiagramm of Converter-board 
 
4.4.1 Pin assignment on the Controller 
With the help of the Converter-board, the signals of the Interface, which belong together, can be 
summarized on one or several I/O Banks of the Controller. Later, the different signals can simply be 
accessed and mistakes are avoided. 
 
The pin assignment of the different signals are shown in the following table 
 
Pin from Interface 
Signal description Number of pins Pin of the Header I/O Bank of the Controller 
Header J11 (control) 
RES 1-5 5 [4..8] Bank 0 [3..5]   & Bank 1 [0..1] 
RS422 Interface 4 [11..14] Bank 1 [4..5]   & Bank 2 [0..1] 
Control signals of port B 8 [17..24] Bank 2 [4..6]   & Bank 3 [0..4] 
Control signals of port A 8 [27..34] Bank 3 [7..11] & Bank 4 [0..2] 
MDIO Interface 2 [37..38] Bank 4 [5..6] 
High impedance buffer disable 2 [39..40] Bank 4 [7..8] 
Header J12 (data port B) 
Data signals of port B 32 
 
[1..32] 
Bank 4 [9..23] & 
Bank 5 [0..5]   & 
Bank 6 [0..10] 
Header J13 (data port A & power signals) 
Data signals of port A 32 [5..36] Bank 7 [0..31] 
5V 1 [38] - 
3.3V 1 [37] - 
GND 1 [39..40] - 
Total Nbr of Pins 129   





















Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 22/27 - 
5 Construction of the hardware 
5.1 Interface PCB 
The construction of the Interface PCB cannot be realized at school, because the board owns 4 different 
layers. Therefore, the production of the PCB was passed on to an extern manufacturer. 
Because the routage of the schema will be very complicated, it will be done by Steve Gallay of the 
electronic section. The final electrical scheme and PCB layout are given in the Appendix 10. I also want to 
thank Steve, for his time spent on this project. 
 
C Appendix 11 Electrical and PCB layout of the Interface board 
5.2 Converter PCB 
The Converter board contains 2 layers. The routage was done by me, because the different lines were, with 
some exceptions, directly connected to the Controller. Therefore it was relatively simple to realize the PCB 
layout. The final electrical scheme and PCB layout are given in the Appendix 11. 
 
C Appendix 12 Electrical and PCB layout of the Converter board 
5.3 List of order for Project Frame Capturing and sending in FPGA 
In the following table, you can see a complete list of all components I ordered. It includes all components 
for the Interface-board, the Converter-board and the Development-board. The total costs of my project 
were 1150SFr. One of the reason, why this amount is so high, is, that we had not the time to build the 










         No Distrelec         
2 644127 VX3MH-5000 Oszillator 50Mhz 50PPM SFr. 7.00 SFr. 14.00 
Distrelec 
www.distrelec.ch 
1 640916 XC 95288-20PQ208C  Xilinx CPLD XC9500XL SFr. 84.00 SFr. 84.00 
1 121776 154963  3 x 32  Female 3X32Pin Connector SFr. 7.10 SFr. 7.10 
6 110831 NFE31PT222Z1E9L Filter SFr. 1.72 SFr. 10.32 
2 513096 3801-40 Ribbon cabel 40-Pol SFr. 10.11 SFr. 20.22 
10 121674 0918 540 6813  Female Plug 2*20Pol SFr. 4.52 SFr. 45.20 
       
  
Total Distrelec SFr. 180.84 
          SFr. 180.84   
         No Farnell         







2 1106047 TPS54316PWP Texas Instument Buck-Boost SFr. 10.10 SFr. 20.20 
2 1188060 MAX811LEUS+T Maxim Dallas  Manual Reset SFr. 4.60 SFr. 9.20 
2 9487956 DS26LS32ACN 
National Semiconductor  
RS422 quad Receiver SFr. 2.50 SFr. 5.00 
2 9724516 MAX483ECPA+ 
Maxim Dallas  
RS422 single transmitter SFr. 6.70 SFr. 13.40 
       
  
Total Farnell SFr. 71.65 
          SFr. 252.49   
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 23/27 - 
 





         MSC         
1  -  CORE-MP7_1000-DEV-KIT 
Developement Kit Actel 
+ Flashpro3 Programmer $600.00 $600.00 
MSC Suisse SA 




1  -  M7A3P1000-FG484 Actel FPGA 1M gates $85.00 $85.00 
       
  
Total MSC $685.00 
          SFr. 1'013   
         National Semiconductors         
1  -  DP83849CVS 
Dual-Port Ethernet 
Transceiver SFr. 0.00 SFr. 0.00 
www.national.com 
Sample order 
       
  
Total National Semiconductor SFr. 0.00 
          SFr. 1'013   










     
 
Various inductances 
   16 
 
Jumpers  
   1 
 
JTAG Connector 
   1 
 
3*32Pin Male Connector 
   1 
 
RJ45 Connector    without magnetics 
  2 
 
MagJack 0810-1X1T-03 RJ45 with magnetics 
  3 
 
SMD-LED 
   1 
 
5V-Power Plug 
   3 
 
2X20Pin Connector 
   1 
 
Reset-Button 
          Total school SFr. 0.00   
   
Total price SFr. 1'013.24 
 C Fig. 5.1   List of order 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 24/27 - 
6 Actual state 
Interface 
The Interface electrical scheme and also the routage is done. Within the last weeks of school, the PCB 
scheme was submitted to the external manufacturer. Until the end of the project, the board couldn’t be 




The Converter was completed on time and the components were put together. Because the Interface 
couldn’t be finished completely, we could test this board only conditionally. 
 
Controller 
The Development board was ordered. The enclosed programmes were installed properly. The 
development-kit include a tutorial project, I have tried to implement this project on the dev-board. But we 
had an error while place & route. I would have needed a bit more time to eliminate this error. 
Nevertheless, I could still read some documentation and get an overview of how the board works. 
 
7 Further work 
I would like to make suggestions for the further development of the project: 
- Finish and test the Interface-board 
o Mount the components on the Interface 
o Test the Interface 
- Build of a Interface with other Input Sources, like 1000Base-TX 
- Build of the Controller Board with an Actel Core MP7 FPGA 
o See points I listed on 4.1 Problem analysis and solution approches 
- Implement the CPLD-functions 
o Split the 4 Data-signals per port to 32 Data-signals per port 
o Adapt the control signals 
o Create the 25Mhz for the Phy 
o Transmit the RS422 Signals 
o Transmit or control the high-impedance buffer disable 
- Understanding how the Development board works 
o Implement the tutorial 
- Programming of the Development board 
o Implement the controller functions 
o Implement the time synchronization for the time stamp 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 25/27 - 
8 Conclusion and remarks 
One interest of this project was to realize a work, which should be a simplified diploma work, a kind of a 
small introduction. Because this project took also place in cooperation with Patrik Arloos, it should be 
possible for him to read this report. This was also one of the reasons, why I wrote this report in English.  
 
I also improved my knowledge in project management and project planning. In advance, I wrote a time 
schedule, which I tried to follow, as much as possible. It was also necessary to correct it. I had to work 
together with many people, without those, it would not have been possible to progress so far in this 
project. 
I would like to thank everyone, who tried to help me in this project. Your support, ideas and comments 
were very helpful. Special thanks go to: 
- Corthay Francois, supervisor of this project 
- Gubler Olivier, for giving me his Diploma work as a help 
- Steve Gallay, for designing the PCB of the Interface and all the library components I needed 
- Sartoretti Pascal, for helping me with the Pcad and to order all the needed components 
- Pignat Marc, for helping me to drawn the electrical scheme 
- Biner Hans-Peter, for giving me useful tips for the high impedance buffer and high frequency 
transmissions 
- All of my student colleagues 
 
This project was very challenging for me. I learned a lot in electrical engineering and how to build a PCB. An 
important point is also to choose the right components. The first weeks were just gathering of the required 
information and looking what I had to do, after that, I could really start working seriously on the project. 
During this semester I could work in many different topics: Hardware, Software 
 
Unfortunately, I didn’t succeed in finishing the whole project, because of the lack of time. I still must 








 Zahno Silvan: 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 
13.01.2008  - 26/27 - 
9 Glossary 
MP Measurement Point 
FPGA  Field Programmable Gate Array, is a semiconductor device containing programmable 
logic components and programmable interconnects. 
Phy Physical, this IC representing the first layer of the OSI-model 
MArN Measurement Area Network 
Eth Ethernet 
TP Twisted Pair, is a form of wiring, this cables are used to connect the MP to the MArN 
VHDL  Very High Speed Integrated Circuit Hardware Description Language, is a 
programming language to describe hardware 
JTAG  Joint Test Action Group, is the usual name used for the IEEE 1149.1 standard entitled 
Standard Test Access Port and Boundary-Scan Architecture for test access ports used 
for testing printed circuit boards using boundary scan 
SD Memory Card  Secure Digital Memory Card, is a digital storage medium, which is based on the 
princip of the flash technologie 
10BaseT 10Base-T is a form of medium speed Ethernet, providing 10Mbit/s 
100BaseTX 100Base-TX is the predominant form of Fast Ethernet, providing 100 Mbit/s Ethernet. 
It introduces an additional, medium dependent sublayer, which employs MLT-3 as a 
final encoding of the data stream before transmission 
100Base-FX 100Base-FX is a version of Fast Ethernet over optical fiber. It uses two strands of 
multi-mode optical fiber for receive and transmit 
4B5B 4B5B is a form of data communications line code. It works by mapping groups of four 
bits onto groups of 5 bits 
MLT3 MLT-3 encoding is a line code (a signaling method used in a telecommunication 
system for transmission purposes) that uses three voltage levels. An MLT-3 interface 
emits less electromagnetic interference and requires less bandwidth than most other 
binary or ternary interfaces that operate at the same data rate 
OTP One Time Programmable are devices which have a memory which can be 
programmed just ones. 
OP An Operational amplifier, usually referred to as an op for brevity, is a DC-coupled 
high-gain electronic voltage amplifier with differential inputs and, usually, a single 
output. 
RJ45 Registered Jack (RJ) is a standardized physical interface for connecting 
telecommunications equipment or computer networking equipment. The standard 
designs for these connectors and their wiring are named RJ11, RJ14, RJ45, etc. 
PCB Printed Circuit Boards are used to mechanically support and electrically connect 
electronic components using conductive pathways, or traces, etched from copper 
sheets laminated onto a non-conductive substrate.  
NRZ-encoding Non-Return-to-Zero (NRZ) line code is a binary code in which can represent just two 
conditions, “0” and “1” 
CPLD Complex Programmable Logic Device is a programmable logic device. The building 
block of a CPLD is the macro cell, which contains logic implementing disjunctive 
normal form expressions and more specialized logic operations. 
CRC Cyclic Redundancy Check (CRC) is a type of function that takes as input a data stream 
of unlimited length and produces as output a value of a certain fixed size. The term 
CRC is often used to denote either the function or the function's output. A CRC can 
be used in the same way as a checksum to detect accidental alteration of data during 
transmission or storage. 
RTC Real-Time Clock is a computer clock that keeps track of the current time. Although 
the term often refers to the devices in personal computers, servers and embedded 
systems, RTCs are present in most any electronic device which needs to keep 
accurate time. 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 




















and much other sites… 
 
11 Appendix 
Appendix 1: Meeting Document 
Appendix 2: Datasheet OPA3692ID 
Appendix 3: Datasheet MagJack 0801-1X1T-03 
Appendix 4: Datasheet Agilent AFBR-5903Z 
Appendix 5: DP83849 Dual Phyter Demo II Stump Jumper scheme 
Appendix 6: Datasheet National Semiconductor DP83849ID 
Appendix 7: Datasheet Xilinx XC95288XL 
Appendix 8: Datasheet ProASIC3E Flash Family 
Appendix 9: CoreMP7 Development Kit Users Guide 
Appendix 10: Datasheet CoreMP7 
Appendix 11: Electrical and PCB scheme of the Interface board 
Appendix 12: Electrical and PCB scheme of the Converter board 
 
Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 















Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 



















Frame Capturing and Sending in FPGA  Zahno Silvan 
 
 


















































































	   !"#$"#%&"'(  #&)*+#+#,-(.#&'-&'*/'&-0%+"12#&%.%#3425#677777777(78 %+694 :3"$%#"1*&+-"42'2%:5"$&-"##$#"-4-&'%':1"#2"#5:%':2%'+;&*"4$#&"#;#&'"'+'"1 ( 2%<+'";%##%'&+;&*#+$"*&+-"42'%&"'%'--&+ %&2+%':&2$ &-;%##%'&+"12#*%'%5& &:"#1&'++1"#%$%#&4 %#$4#$"+(='1"#2%&"'&'*&+-"42'&++45>"*%');&*"4'"&( %++42+'"#+$"'+&5& &:1"#%':##"#+*%2%:%$$%#&'*&+-"42'(?*&+-"42'"'%&'+"'1&-'&% $#"$#&%#:&'1"#2%&"'*%&+'""5-&+ "+-"%':4'%4*"#&@-$#+"';&*"4$#&"#;#&'"'+'"1 !"#$"#%&"'(?#%-2%#<+ %'-*  ")"%##)&+#-#%-2%#<+"1 !"#$"#%&"'(-"5%'-#"5%8%-#%##)&+#-#%-2%#<+"1-"50:+2+A='(  "*#$#"-4+"#5#%'-'%2+2'&"'-%##%-2%#<+"##)&+#-#%-2%#<+"1*&##+$&,*" -#+(
  	
  




 	  

  !"#$%&'()$*"+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+",-./012&3&4"5)&6 "+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+"",-.7 &8 9:"#$%&'()$*"+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+"",-.7 #);<4"2=& *""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+",>?@ 9 !A$("#A00 (+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+",B,7A*('& "#& 3)$&""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+"",B,C$(&4"7A*('& "/&$%<)$4"#A00 ("7&<(& "+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+"",B,C$(&4"/&$%<)$4"#A00 (+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+"",B,D &E*)(&""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+"",B,7<($()<;"(%&"7A*('& "/&$%<)$4"#A00 ("7&<(& "+""+""+""+""+""+""+""+""+""+""+""+""+""+"",B-F<!&G ""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+""+",B?
  	
  












  !"#$%&'#()!"* +,#-./0 /1)2#3)/!4#5)6%7"."0#8"9
  	
  
   	 





  !"#$%%&' ()*+,*-./01*23--45*62*-1.76808*/69:*9:0*;0704.-<0=9*>69*?@6A310*BCBDE*F:010*G10*<G=5*-./01*23--45*H.<-.=0=92*.=*9:0*I7G43G96.=*J.G18*9.*6443291G90*9:0*<G=5*/G52*9:G9*86KK016=A*7.49GA0*LG=M2*<G5*L0*3208*/69:*N O)PQ*G=8*N O)PQI*90H:=.4.A5E*F:020*7.49GA0*LG=M2*G10*=.9*G44*10R36108*K.1*A0=01G4*320*.K*9:0*N O)PQ*2646H.=E*F:05*G10*-1.76808*K.1*6443291G9670*-31-.202*.=45E











   	 



















 !"##$%&'"#()*+,-./)01.234.567745-48.-6.-,4.849*54.9*2.:;<=431>.?@.-,4.:;<=431.234.*7.=A254B.-,4.849*54.?CD.527.83*94.-,4./)01>.E,4./)01.5,27+4.F2148.67.-,4.6;-=;-.21.@6AA6G1HI J.KLK.67.-,4.6;-=;-.6@.-,4.849*54.A*+,-1.-,4./)0>I J.KMK.67.-,4.6;-=;-.6@.-,4.849*54.1G*-5,41.6@@.-,4./)0>I J7.;7=36+32<<48.63.-3*1-2-48.6;-=;-.<2N.1,6G.2.@2*7-AN.A*-./)0>O6-4H ?@.-,4.?CD.96A-2+4.6@.P27Q.R.S67.JTU)B.14-.FN.VWX.63.P27Q.Y.SJTUB.14-.FN.VWX.*1.76-.2-.A421-.Y>RZB.-,4./)01.G*AA.76-.*AA;<*72-4>.J.14--*7+.6@.L>[Z.67.-,4.96A-2+4.F27Q.G*AA.52;14.4\-34<4AN.@2*7-.*AA;<*72-*67>E2FA4.Y]L.A*1-1.-,4.:;<=43.278.849*54.567745-*67.21165*2-48.G*-,.425,./)0>
E6.;14.-,4.849*54.?CD.@63.6-,43.=;3=6141B.34<694.-,4.:;<=431>























 !"#$%&$%%'()*#"+#)',- ./#- #+)0)1!+23456786779:;9<=9>?@54=5?9A 5B:<9CDD5;;923=?43EE549FA C2G9?@<?9D3==5D?;9H3D<E9C45<9I5?J34K;9FHCI;G9<?9B<?<94<?5;93L96793496779A MN;9F;559O:PQ459RSTGU9V?9@<;9<9A 5B:<9V=B5N5=B5=?9V=?54L<D59FA VVG9L349N@W;:D<E9D3==5D?:3=9<=B9:XNE5X5=?;92<44:549Y5=;59A QE?:NE59CDD5;;9J:?@923EE:;:3=9Z5?5D?:3=9F2YA C82ZG9<EP34:?@X;[9N549V>>>9\7RUTU9>?@54=5?9:;9<9D3XX3=9;?<=B<4B9Q;5B9:=9D3XNQ?54[9D3XXQ=:D<?:3=;[9:=BQ;?4:<E[9<=B93?@549<NNE:D<?:3=;U
]^_`abcdefgchibai^bjcklcmcnop q^mrcskabtuvtuucwoxybzZ5?<:E5B923456786779:=L34X<?:3=9:;9<{<:E<ME59:=9?@59|}~} }9B<?<;@55?9<?9@??N88JJJU<D?5EUD3X8:NB3D;8234567677ZYUNBLU@59A VV9:=?54L<D59?3923456786779J34K;9J:?@9X3;?9>?@54=5?9 9D@:N;U9Z Q59?39?@59<=<E3P945Q:45X5=?;93L9<=9>?@54=5?9 [9;QD@9D<==3?9M59:XNE5X5=?5B9:=9<=9CD?5E9OCU@592345A 9>{<EQ<?:3=93<4B9;QNN34?;9BQ<E9>?@54=5?9D3==5D?:3=;U9C=9CA 2\V9L43X9CB{<=D5B9A :D439Z5{:D5;9FCA ZG9:;9Q;5B9L3495<D@9 9F69<=B9R7GU9Y559<ME59RS93=9N<P59R79L349B5?<:E;93=9?@59D3==5D?:3=;9M5?J55=9?@59OC9<=B95<D@9 9{:<9R9<=B9R[9J@:D@9<459D3==5D?:3=8B:;D3==5D?:3=9N3:=?;9L349 79<=B9 6[945;N5D?:{5EWUI3?5 @59BQ<E923456786779>?@54=5?9:=?54L<D5;9<4593=EW9N3NQE<?5B93=9M3<4B;9M<;5B93=9?@59A CT67779B5{:D5U
w mab¡¢£¤ nam¥xz y^¢£¤





  !"#$%&"' ()#*+,-.,/0%1#2%,&3#014-.3"5#,#6,0&4!0-3#7"804%13.4/%&#972: ::;' #972#/&,154"0+"&<# !"#972#5/,13,&3#5="40>0"5#5.==%&/#>%&#8.-/0=-"#3"+04"#4%11"4/0%15?#,--%@01A#.=#/%#:B)#.10C."#3"+04"5<#6.&/!"&?#/!"#6,0&4!0-3#/&,154"0+"&#5.==%&/5#/!"#/&,1580//01A#,13#&"4"0+01A#%>#5"&0,-#3,/,#,/#D%/!#>.--E5=""3#F:B' D=5G#,13#-%@E5=""3#F:<H' D=5G#3,/,#&,/"5<#I8=-"8"1/,/0%1#%>#/!"#7"&0,-#I1/"&>,4"#*1A01"#F7I*G#05#&"C.0&"3#/%#.5"#/!"#972#01/"&>,4"#=&"5"1/#%1#/!"#*+,-.,/0%1#2%,&3<#I1>%&8,/0%1#%1#/!"#7I*#4,1#D"#>%.13#%1#/!"#972#I8=-"8"1/"&5#6%&.8#,/#!//=JKK@@@<.5D<%&A<









 !" #$%&!% !'() *+),-./)0" #1(" (%2$2&!%34567896:;<6=<6>6?@AA;B=?>C=@B6<C>BD>ED6F=C46A;GC=HA><C5E6?>I>:=G=CJK65EE@E6D5C5?C=@B6>BD6?@EE5?C=@BK6>BD6:E@>D6=BD;<CEJ6>??5IC>B?5L634567896:;<6F><6D5<=MB5D6N@E6C456>;C@A@:=G56=BD;<CEJK6:;C678964><6E5?5BCGJ6:55B6>II5>E=BM6=B6B@BHCE>D=C=@B>G6>IIG=?>C=@B<L634567896:;<6?@AIE=<5<6CF@6<=MB>G<6C@6F4=?46>GG6B5CF@EO5D6D5P=?5<6>E56?@BB5?C5DK6C4;<6>GG@F=BM6?@AA;B=?>C=@B6:5CF55B6A;GC=IG56D5P=?5<L63456E5G=>:=G=CJ6>BD65EE@E6D5C5?C=@B6=<64>BDG5D6:J6>6<5E=5<6@N6>E:=CE>C=@B<K6QB@CR6>?OB@FG5DM5<K6>BD67S76?45?O<L3>:G56THU6D5C>=G<6C456?@BB5?C=@B<6:5CF55B6C456V W8XYZ[6\Y]86>BD6C456@B:@>ED67896CE>B<?5=P5E6Q^ _` RL634567@E5V YW6[P>G;>C=@B6a@>ED6=<6>G<@65b;=II5D6F=C46c[d<6Qd _` 6>BD6d_eR6?@BB5?C5D6C@6C4563fd6>BD6Sfd6G=B5<6@N6C4567896:;<L6345E5N@E5K6F45B6D>C>6=<6:5=BM6CE>B<A=CC5D6@E6E5?5=P5DK6C456E5<I5?C=P56c[d6F=GG6:G=BOLgN6B5CF@EO6C5EA=B>C=@B6=<6B55D5D6QCJI=?>GGJ6N@E67896:>;D6E>C5<6ME5>C5E6C4>B6_hhO:I<RK6<4@EC=BM6iYX` 6Q789j3[SV R6=B<5EC<6>6_Thk6E5<=<C@E6:5CF55B6789Hl 6>BD6789HcL
 1!mn) &'mo&2p34567@E5V YW6[P>G;>C=@B6a@>ED64><6CF@6?G@?O6?=E?;=C<q6>6r` V l s6@<?=GG>C@E6>BD6>6XTOl s6@<?=GG>C@ELtu)v wx)ypm&11$2!'3456r` V l s6@<?=GG>C@E6@B6C456:@>ED6=<6>6XhIIAz<C>:=G=CJ6?EJ<C>G6A@D;G56C4>C6IE@P=D5<6A@E56C4>B6>D5b;>C56I5EN@EA>B?56>BD6?>B6:56?@BB5?C5D6C@6>6M5B5E>G6I;EI@<56gZ{6QI=B6| _TR6@E6>6?4=IHF=D56MG@:>G6QI=B6| _WR6;<=BM6>6};AI5EL~,)nwx)ypm&11$2!'3456XTOl s6@<?=GG>C@E6@B6C456:@>ED6=<6>6XhIIAz<C>:=G=CJ6?EJ<C>G6A@D;G56C4>C6F=GG6IE@P=D565B@;M46>??;E>?J6C@6I5EN@EA6S376?>G?;G>C=@B<6>BD6=<64>EDF=E5D6C@6>6?4=IHF=D56MG@:>G6QI=B6_RL


























 !"#$ %&' ()* +,-.&
/0 1234567 89:; <4=>1?/@:3A B?=A 89CD3; =>:C/EF>?G9GF>D3H:HI:J?=?:3H
K?1L?=; /M:43N3F3?=>:1F
I=G1<>O1; P:43 Q=CRSTFF1>=>39; =?>K1A 3?
9; =?>U:; 3V/U:; 3?
W3>4:H>@:3A 3?XYZ/T>>?:J<>3E2:>1?
K:FE2:>1?0 <4>:@:3A /W=[:L=>1?OD:PK4=FF3?




OD=:FQ<:423?`(,&. ,a (&bM4=HDK?1`(,&. ,a (&b9:4:C1F/9C<4P>1?c`'-d&e(,&. ,a (&b
K?1L?=; ; :FL/91 >^A =?3 0 :C?1P?1C3HH1?/B3H:LF/O?3=>:1FY@3?:^:C=>:1F
9GFP4:^G8/9GF>D3H:H
fa ' ga (,-)''h-)',( ga (,-)'
iej c&&'a '-&
g(h- iej g-,'k,k&())l(,'''
%&' gm'-.&& ,'kjl-a n,-)'+d)a ,'h jl-a n,-)'
g-,-h fa ' c',(m&& ,'ko)'&-,'-& pk-)+)* c',(m&&q,hr"c'')-,-k fa 'd) ga (,-)'%&' gh.a ,-h s*
g-a (& t',-)'
jl-a n,-)' ,'k %8o
fa '"%u' +(,h",'k"8)-






  		  










   











 !"#$%&'"%&()&#"$*+*,-./012134.5607438.9:/0/1:7;<=;/1:70.>/142?1.3>/03>0-3@0130?4:51:050A34:A3>/36:0743B:?105>90C:>:451:050A34:A3>/36:09:/.C>D0,-:012134.560?3>/./1/03E01-4::0/1:7/F0GH1:70I0J0A4:51.>C01-:0K5/.?0A34:A3>/36:0L43B:?1MN0GH1:70O0J0K2.69.>C01-:0H2</=/1:P0@.1-.>0A34:A3>/36:M03>075C:0QRN05>90GH1:70R0J0S:8.:@.>C05>90T:>:451.>C01-:0A34:A3>/36:0U:/.C>M03>075C:0QVDW31:F K:E34:0=320<:C.>01-./012134.56N0P5X:0/24:01-:0A34:A3>/36:0/3E1@54:0./0.>/1566:9DYZ[\]^ ]_]` a[bZcde]Zf[]gbhci]` ja[`jdhjk[]lajm[iZn>0H1:70IN0=3206:54>01-:0<5/.?0E:5124:/03E0A34:A3>/36:0<=0?4:51.>C050<5/.?0A34:A3>/36:0743B:?1D0o320@.6602/:01-:0p?1:60A34:A3>/36:0nL0U:763=P:>10L651E34P0133601309:8:637050/X:6:13>0A34:q Lr0/=/1:PD0,-./0/=/1:P0?5>0<:0/.P2651:905>90/=>1-:/.s:9t0-3@:8:4N0.10./01330<5/.?0E340745?1.?5602/:05>90@.660<:0:u1:>9:90.>0GH1:70O0J0K2.69.>C01-:0H2</=/1:P0@.1-.>0A34:A3>/36:MDvwxyz{|}{x}~{xwz{ww{xzw{y}ID U32<6:;?6.?X01-:00.?3>03>0=32409:/X1370130/154101-:0743C45PN0340/:6:?10000000DOD 43P01-:00P:>2N0/:6:?10D0,-:0W:@0U:/.C>0@.>93@09./765=/N05/0/-3@>0.>0.C24:0;ID





  !"#$%&&$'()##$"*+,*!#!'-$(%.#$/##!$%00#0$'*$'(#$0#-12!3$1'$-(*4&0$)#-#+/&#$5124)#$6789*'#: ;*+#$*<$'(#$"*+,*!#!'-$%)#$*.#)&%,,1!2$=*$%))%!2#$'(#$"*+,*!#!'-$!#%'&>3$-#&#"'$?@ABCDEFB@A$<)*+$'(#$?GAHBIJ$+#!4







 !" ##$"%!" & ' #$#%(!) *%+*#!, -.!/ .$/ #( 0$!'. 1$"%234 56789:;<9=>?@ABC98<DEF9G<H<I:9=J?AKL?@?>M49N;OG9POGQHRSG9:;<9TE:79U:O:I;ODV9WODP7WF9RG9G;7WD9OD95OVE6<9XYZ4





  !"#$%&'#(&)&!*) +#),#!'-./"&"0#1'%2#3",)+ #,*'%/3#2","-4/"#5)+%2"#678













  !"#$ %&'"()*#+,-./01+2/3.423562007+89+,9096391+5:+3-9+;"!<+=5901+>=+53+5,+:.3+,9096391?+,90963+53+=@.4+3-9+1@.AB1.C:+49:/+D-9:+,90963+EFGH IGHJ+=@.4+3-9+;"!<K%(LMNO+1@.AB1.C:+49:/?+2,+,-.C:+5:+P5Q/@9+RBS







 !"#$%&' ( &)*+,&-$./012#$&-.*+"3&,/-/04"/&2./&*5/&#5&6#7+,/&89: 





  !"#$%&#'!()*+, *(+#'!((&-$*!(#.*/0!+#1!23#4&0&-$#56789:;<= 8>?9@A:789B;C8#*(#$%&#D9?>EFG:HIJ#. !KL.!M(#"&(,3#/4#4%!M(#*(#*+, &#NLO







 ! "#$%&'( )!'*+,-'.%/0123$%'./+,#4'-0.015#0'3/0'+60'$6'7$8,-0'9:;!


















  !"#$%&'()*('+,(!'-($(.)$"/'$0'.!"#$/,%12'(!'!31%*(1'!"' !%14567'*"2' !%181&*39'()1"'.:$.;'()1'<=>=?@'A,((!" !%1 !"0!:1'B$::'()1"'.!""1.('()1'C  DE'*"2'"8F-FG'3$"0'(!'()1'.!&3!"1"(0'H!,'*2212I 7".1'.!&3:1(129'H!,%' !%1 !"0!:1'0.)1&*($.'0)!,:2':!!;'0$&$:*%'J$/,%1'IKLM












  !" #$%&#! $'()* #%+,** #$-./01/23124565/730642385291:/;52;1<5265;5997/=2>1/2?;35@2A0B5/12CDEF2=1:2G:932G1<0>=23852;16>04:/73016295330649HIH .19030162=1:/2G1:952;:/91/21J5/23852KLMNO PQ2;1GR16563276<2;@0;S23852KLTUVWXMN2B:33162Y385295;16<2B:33162>/1G23852@5>3F2Z03823852B067/=2<04039[H\852]16>04:/0642]1/5^ ._2<07@142B1` 2<09R@7=9F2792981Z62062a04:/52bcIdH







 !"# $ %&'&()$*"# *"(+", -$./&'$0('&,$1"'2$3#")# ++$1/#+$2/4 $# /52 6$7889$:;&)0# $<=7>?@$A2&+$3#"5 ++$5/($'/B $03$'"$><$+ 5"(6+-$6 3 (6&()$"($+C+' D$5"D3, %&'C$/(6$E*$# +"0#5 +@






"#$%&'()*%+,'-./'01234567898:8;<6=568=8>6? 8@<AB6C5DEFGHGIJKHLGJGHIEJHMFNJOPHQRSHT RMHSUFIPOHIPHJVIJOHWVHXYIJZH[POJ\ ] H^_JOFZP` HUJGF`Vabcdefghigdijgdklmgfcdnopdqgflrcsdtfcugeivwa RPLNZJxYZFYyHIEJHz{|}~HFYPVHPVHPLOHUJGyIPKHIPHGIWOIHIEJHKOP` OWaa OPHIEJH{}HJVLHGJZJYIH}~}aHDEFGHUFGKZWGHIEJHJH]OPJYIH FWOUHGEPVHFVHF`LOJHxwa







 !"#"$%&'()*&+*(,"$%&-./0123&4053&678&9.:;.<5 &=(*&%>?@&%)%(*?6#3&@"#"$%&9ABCDEFGH3&%>"&I JCG9HKLL&8?"3&678&MNMO-PQC&R(*&%>"&+6$S6T"&U=?T)*"&VWXY 














 !"#$%&'()&*++&,-''./&'.&011&0&1#22)3)/'&45/'()6#67&4#8-"0'#./7&.3&4'#8-"-6&'.." &92&5.-&:#6(&'.&011&0&'.."7&;#,)3.&9<=&.>)/6&'()&*++?@ABCDEF&1#0".G&,.H&IJ#G-3)&KLMNO 




















   
!"# $%&'%()*+,-).-+/%01)'23+-451'+2#)67'08)9:;:<=)1+)07+>%)1?%)@ 'A5-B)52B)0-%51%)*+,-)2%().-+/%01)CD'E,-%)FGH!I#)67'08)JKLM)1+)-%1,-2)1+)52*)>1%.)+3)1?%)@ 'A5-B)52B)0+--%01)'23+-451'+2)'2)*+,-).-+/%01#






















 !"#$#%#&!'()'* #&'!+,- .!/0/#0* 123 0)-4567869:7;:6<7=;7;=>?@A:=8B7:567C4D7E6;FG=<:=H87HI7:567E6;=B8J7K=G;:L7MH?7>?;:7FG6A:67A7:H<N@6O6@7:6;:P68F57:H7<GHO=E67A7;:=>?@?;7IHG7:567E6;=B8J7Q66<7=87>=8E7MH?7R=@@78H:7P67AP@67:H7;=>?@A:67SHG6T UV7P?:7R=@@7G6@M7H87:567W?;7K?8F:=H8A@7T HE6@7XWKT YL7R5=F57=;7A7FMF@6NAFF?GA:67>HE6@7HI7:5676>P6EE6E7ZCT V4[T \N]7<GHF6;;HGJ7_^ a`bcdec e`fc e`_ghicjci`eckelcmafnoJ KGH>7:567pqrs7>68?L7;6@6F:7pqrs7A8E7:5687tsuJ745=;7H<68;7:567v6R7E=A@HB7PH9L7;5HR87=87K=B?G67wNxyJ



























 !"#$%&'"#&( )*&+,&'"#&-+.#&/#-01#&203&$0,'+,3# &4,5#1&'"#&6+.#&7 8,89#1&'8/&:6+931#&;<=>?@&1+9"'<$.+$%&ABCDEFGHADIJCKLM&8,5&N#.#$'&OPQRSTU VW &X"+N&$"#$%N&'"#&N2,'8Y&0-&ABCDEFGHADIJCKLML&Z#-01#&[0\+,9&'0&'"#&,#Y'&N#$'+0,@&[05+-2&'"#&$05#&+-&203&-+,5&8,2&#1101N 
































 !" #$ %&'(!)*+,%-.#/!#0 1)!-1$!2#+0*% )!. !)#,/2 !3*% )4!-)!)#51!*1!6*7,/ !89:;<






!"#$%&'$%#()*+,-&+("%#()*,$&$./%&'$%.+)0,-&(1%.+)0,-&$.%2(1%&'$%3$2-0,&%&+)$%*$1+(3%(2%4555%"./%-"3%-%6-7$%6+"3(6/%.'(6"%+"%8+901$%4:;;/%(*$".%&(%3+.*,-<%&'$%.+)0,-&+("%1$.0,&.=%>'$%3$2-0,&%6-7$%6+"3(6%#011$"&,<%#("&-+".%(",<%&'$%?@?ABC%-"3%D?@?EF?F>%.+9"-,.=%@(0%6+,,%$G*-"3%&'+.%.'(1&,<=%>'$%1$.0,&.%(2%&'$%3$2-0,&%H8I %.#1+*&.%#-"%-,.(%J$%7+$6$3%+"%&'$%I (3$,KLM%,(9%6+"3(6%N-.%.'(6"%+"%8+901$%4:;O%("%*-9$%PPQ=%>'$%.0##$..20,%1$-3.%-"3%61+&$.%#("2+1)%&'-&%A(1$I RS%+.%#(""$#&$3%*1(*$1,<%21()%&'$%&(*%,$7$,%3(6"%&(%&'$%7-1+(0.%J0..$.=







 !"#$%%#&'(#)"*(+ ,#-./0$1-#&"#&'(#+ "%(1234#5 $6(#7.0%"78#0$6./$&(#&"#&'(#9:;<= >?@ABBC#.0-&$0D(#.0#&'(#+ "%(1234#7"*E-F$D(8#7'.D'#D$0#G(#H"I0%#I0%(*#&'(#H"11"7.0/#'.(*$*D'J#K-'"70#.0#L./I*(#MNOPQR!I&"*.$1!"FST#U#!I&"*.$1!"F#U#)"*(+ ,VWTTX#X*$/#&'(#)"*(+ ,VWTTX#.0-&$0&.$&."0#&"#&'(#+ "%(1234#7$6(#7.0%"7 #!'(#.0-&$0&.$&."0Y-#-./0$1-#7.11#$FF($* 






"# $%&'()&* +,)-./0&123%45267'&89+:;&<6%,+<=&'>7)&?@ABC?B#&1(64&<6--&D26%:&E7&'()&F)4'32'&,63-+:&D+G&84(+<%&6%&H6:E2)&IJKI;#&L-65M&'()&N@ABC?B&DE''+%#&1(64&<6--&2)4)'&'()&46OE-3'6+%&'+&'()&D):6%%6%:&4+&'(3'&-+::6%:&+P&'()&L+2)* QR&46:%3-4&+55E24#
STUVWXYZ[\Z]Y^ _`Xab YcXdefWeYgTfa_UYh_ij# k 6'(6%&'()&* +,)-./0&123%45267'&<6%,+<=&'>7)&?lmnCoo#&1(64&<6--&2)J2E%&'()&,)P3E-'&')4'D)%5(&3%,&pH* &45267'4#&1()&2)4E-'4&4(+E-,&D)&'()&43O)&34&'()&72)q6+E4&2E%#&r+'65)&'()&* +,)-./0&k 3q)&<6%,+<s '()&L+2)* QR&46:%3-4&%+<&(3q)&<3q)P+2O4&344+563'),&<6'(&'()O#tu# v%,+5M&'()&* +,)-./0&k 3q)&<6%,+<&3%,&O3G6O6w)&6'=&'()%&4)-)5'&xyyz{|loo&P2+O&'()&}~@ xyyz&O)%E#&G3O6%6%:&'()&F=&F1=&k 1=&k F$1=&$=&L9=&%F1=&3%,&rF1&46:%3-4&3--+<4&'()&2)J52)3'6+%&+P&'()&pH* &45267'4&3%,&q3-6,3')4&'()&2)4E-'4#&1()&5+22)47+%,6%:&46:%3-4&(3q)&D))%&:2+E7),&'+:)'()2&3%,&32)&4(+<%&6%&H6:E2)&IJK#














 ! "#$%&'()&*+,-./0&%)123&4)5)6'&789:.8.;0<0=,;>? 90=,;@!&A(B4&CB4D5EF4&'()&$D'B$14&G$#&'()&H%D5)%)1'E'B$1&CBE5$I&J$K3&E4&4($L1&B1&"BI2#)&MNOP&G$#&'()&Q RSOTUVWW!





















 !" #$% !& ' %($)*!+ $,-./!)0 *1!23$45. !6789:;














  !"#$%!"$&'()$(*+,-%$.+%/,#0$1/23,4$5,6$2++"2-07$20$/#$)/48-"$9:;<7$=3/=>$? @$A!/0$B/33$-":/*+,-%$%!"$0,8-="$C/3"0$D233$%!-""$,C$%!"*E$/#%,$'"0/4#"-







 !"#$%!&'()*+#,!"'-.!'/!"#$%'0%/'".)1"'-.!'2-#,#30-#)%')4'-.!'"!,!(-!/'/!5#(!6'7,")8'%)-!'-.0-'-.!'9)*+#,!'#()%'#%' !"#$%!&'-2&%"'$&!!%')%(!'-.!'()*+#,!'.0"'"2((!""42,,:'()*+,!-!/6;6 <%(!'-.!'/!"#$%'()*+#,!"'"2((!""42,,:8'2"!'-.!'=><'7--&#?2-!'@/#-)&'-)),'-)'5!&#4:'-.!'+#%'0""#$%*!%-"'#*+)&-!/'4&)*'-.!'+#%'()%"-&0#%-"'4#,!6'7,-!&%0-#5!,:8'-.!'=><'7--&#?2-!'@/#-)&'(0%'?!'2"!/'-)'(&!0-!'+#%'0""#$%*!%-"6'9,#(A'-.!'BCD EFGGHIJKGLEMNIGOH'-)')+!%'-.!'-)),6'=-')+!%"'#%'-.!'P 2,-#Q#!1'R05#$0-)&'2"!&'#%-!&40(!8'0"'".)1%'#%'S#$2&!'TUVV6







 !"# $%#%&$ '!"#()*+,#*!-#.' ,/)*+,0# $%#1+#-+#2-!(/3 $$+,#)# !4$#')%13+5#23!"6#-+# ((,)(,! +#!")$#)# ""+#-++#))357),#'),+#!$8),' !)$#)$#-++#81$"!)$0#,+8+,#)#-+#9+!4$+,#),#:!;+,)#<9=#)$3!$+#-+3(5>>5 <$#9+!4$+,0#"3!"6#?@ABCD5#E-!#)(+$#-+#: &)1#F(!)$#%! 3)4#;)G0#-)*$#!$#7!41,+#HIJH5












































<=>?@ABCDCEFBGHIJKBLMNO=>?@PQ=MNBR =NSMTU; V !.!"0 !"9.(,./WW+),"*+X!"W/Y"Z!"[ /),!2"ZY"[X+[\+),"0 !"] _^` ab"Z-00()"/)2")/c+,/0+),"0("0 !")!1"9.(,./WW+),"*+X!;"d/.+(-:"efgh_ia"W/Y"Z!"9!.*(.W!2"-:+),"0 !"2.(962(1)":!X![0+():;"4(."0 +:"0-0(.+/Xj"X!/c!"+0":!0"0("klm nleo "32!*/-X08;"4(."W(.!"+)*(.W/0+()"()"0 !:!"*-)[0+():j".!*!."0("0 !"4X/: %.("()X+)!" !X9;(".!0-.)"0("0 !"%.(,./WW!."&+:0"1+)2(1"34+,-.!"565p8j"[X+[\"0 !"qhb` rk _^s^ tuu b^a"Z-00();


















  		  









NOPQRSTUVUUWTXSYZ[OS\T]SZS _^T]` QR^ STNOZSaTb` RTcR` dS _^TeOYZ` Pf g"-#!"*,&*0&*+,&hijhklmn opjqrskltuvjwkrlxm&J#2,'*02y&"$J&D2,GG&z{|}&~& ;*0&G,(,'*&"((&*+,&3#(,G&#*+#$&*+,&J#2,'*02y z(#')& 9
  	
	 		
  		  !
"# $%&'()* +)&,)-./)$0/1-/)2-1,3103)4056/'-)3&1%57)859#):./)4056/'-)405;/0-&/<)=&,35=),5=)1;;/10<)>?&7@0/)ABACD#







 !"#$%&'("')*%$+*,-./012-345/6*+7%89*"7*%$+*:; <=>?@A,B>; <*CD7+*D7E*F+(+'%*G1HI6A1J*K8LM*%$+*'L7%+N%*M+7OP*DF*F$LQ7*"7*R"#O8+*S&ST 
UVWXYZ[\]\^_[` ZabcVZd[eYfgZhi[eYfjZYiVZk[lfmnVWXYaiVfm[ojiVfmkp$+*qL7K"#O8D%"L7*F+%%"7#F*+7Dr(+*9LO*%L*rO"(E*9LO8*DCC("'D%"L7*C8L#8DM*"7*E"KK+8+7%*QD9F *p$+9*E+K"7+*%$+*%D8#+%*'L7K"#O8D%"L7F*OF+E*"7*%$+*rO"(E*MLE+( *p$+*MLF%*'LMML7*%D8#+%*'L7K"#O8D%"L7F*D8+*D*s+rO#*rO"(EP*Q"%$*E+rO#*"7KL8MD%"L7*D7E*7L*'LE+*LC%"M"tD%"L7P*D7E*D*!+(+DF+*rO"(EP*Q"%$*(+FF*E+rO#*"7KL8MD%"L7*D7E*$"#$*LC%"M"tD%"L7 p$"F*#8LOC*'D7*D(FL*r+*OF+E*%L*F+%*OC*E"KK+8+7%*LC%"M"tD%"L7*(+u+(Fv KL8*+NDMC(+P*D*s+rO#!+(*'L7K"#O8D%"L7*Q"%$*$"#$+8*LC%"M"tD%"L7*%$D7*s+rO#*rO%*(LQ+8*%$D7*!+(+DF+ *w7L%$+8*+NDMC(+*"F*MO(%"C(+*uD8"D7%F*LK*9LO8*DCC("'D%"L7*OF"7#*E"KK+8+7%*E+u"'+*E8"u+8F x++*%$+*!+D(y"+Q*EL'OM+7%D%"L7*DuD"(Dr(+*D%*$%%Cz{{QQQ D8M 'LM{EL'OM+7%D%"L7{p8D'+|s+rO#{"7E+N $%M(*L8*8+K+8*%L*L7("7+*$+(C*KL8*KO8%$+8*"7KL8MD%"L7*L7*%$"F*FOr}+'% *~ NCD7E*%$+*@>G*+7%89*r9*'("')"7#*%$+*C(OF*F"#7*%L*%$+*(+K%*LK*"%F*KL(E+8P*D7E*%$+7*F+(+'%*%$+*/42,04-1*FOr&M+7O*'LMCL7+7% 
  	
	 		
  		  !
"#$ %&'()*+,&+-.)(/.012334567894./:);<.&:.)(/.=8>?6@AB2>14A.CD:/.D:E.F/,/+).GA8362H6I894>2J4.K;LM.)(/.+L:)/N).M/:OP.DF.F(LQ:.&:.R&'O;/.S*ST$







 !"#$#%#&'( ")*)+,# -!#'./0!#1)*!2&'( ")*)+,#'./0!#1)*!234 56789:;<9=>?@A98<BCD9E<F<G:9=>?@A49H<F<G:9IJK9LM9N7C9O6<9OEP<Q9LM9N7C9R7CFQ9FLP<9:79S<TCLFQ9UFF4V;<97C:WC:97M9:;<9XCLFQ9WOB<9OWW<O6E9RL:;9E<Y<6OF98<EEOZ<E9Z<B<6O:<Q9OE9O96<ECF:97M9:;<9O::<8W:<Q9TCLFQD9OE9E;7RB9LB95LZC6<9[\[]49^M9<6676E9R<6<9W6<E<B:9LB9N7C69E7C6G<9G7Q<D9:;<N9R7CFQ9T<9FLE:<Q9RL:;9:;<9G766<EW7BQLBZ9MLF<BO8<D9FLB<9BC8T<6D9OBQ9O9T6L<M9Q<EG6LW:L7B97M9:;<9<66764M^9OB9<66769LE9M7CBQD9:;<9_7Q<9WOB<97M9:;<9S<OF` L<R9a<TCZZ<697W<BE9:;<96<F<YOB:9E7C6G<9MLF<9RL:;9OB9O667R9W7LB:LBZ9:79OBQ9;LZ;FLZ;:LBZ9:;<9FLB<97M9E7C6G<9G7Q<9:;<9ML6E:9<667698<EEOZ<9LE96<M<6<BGLBZ49_766<G:9:;<9<6676D9EOY<9:;<987QLML<Q9E7C6G<9MLF<D9OBQ9:;<B96<TCLFQ9:;<9W67b<G:D9OBQ9G7B:LBC<9:;LE9W67G<EE9CB:LF9B79<6676E9O6<9W6<E<B:9CW7B9_78WLF<4
cdefghijkjlminhopqdhrishtfeehgiufdpviwoxhy4 M^9O9W67b<G:9LE9OF6<OQN9CW\:7\QO:<D9TCLFQLBZ9RLFF9B7:97GGC69R;<B9L:9LE96<zC<E:<Q49^M9N7C9RLE;9:79Q79O9M76G<Q96<TCLFQ97M9OFF9E7C6G<9MLF<ED9E<F<G:9{@J|}9M6789:;<9=>?@A98<BCD9R;LG;9Q<F<:<E9:;<96<F<YOB:97Tb<G:9MLF<ED9OBQ9:;<B9E<F<G:9~J>?@A@@9M6789:;<9=>?@A98<BC9:796<TCLFQ9:;<9<B:L6<9W67b<G:4 !"##%#!.,,)+,#)( .* )+,!0. )+,# -!#&'( ")* )'+)( .* '/#!/2.2#( .* '/U9EL8CFO:769O::<8W:E9:7987Q<F9:;<9<B:L6<9T<;OYL7697M9O9W67G<EE769LB9E7M:RO6<96CBBLBZ97B9N7C69W<6E7BOF9G78WC:<649798O::<69:;<9EW<<Q97M9N7C69_D9:;<6<9LE9B79EL8CFO:769R;LG;9GOB9EL8CFO:<9:;<98LG67W67G<EE76E96<OF\:L8<9T<;OYL76495C6:;<6D9:;<6<9LE9B79<:<6BOF9R76FQ9G788CBLGO:L7B9T<:R<<B9:;<9EL8CFO:769OBQ9N7C69:O6Z<:9ENE:<849H:L8CFCE9MLF<E98CE:9T<9G6<O:<Q9OBQ9CE<Q9:79EL8CFO:<9<:<6BOF9<Y<B:E4B9:;<97:;<69;OBQD9<8CFO:76E9:NWLGOFFN96<WFOG<9:;<9W67G<EE7697B9:;<9:O6Z<:9T7O6Q9OBQ9LB:<6MOG<9QL6<G:FN9RL:;9:;<9<:<6BOF9R76FQ49V;<9<8CFO:769W67YLQ<E9:;<9CE<69RL:;9OFF9:;<9M<O:C6<E97M9EL8CFO:L7B9WFCE9:;<9GOWOTLFL:L<E97M9LB:<6MOGLBZ9RL:;9:;<9<:<6BOF9R76FQ9OBQ96CBBLBZ9O:9MCFF9ENE:<89EW<<Q498CFO:76E9<LE:9LB9:R79M768E9a<TCZ9 7QCF<E9OBQ9^B\_L6GCL:98CFO:L7B9^_4V;<9a<TCZ9 7QCF<9OWW67OG;9G78TLB<E9OFF97M9:;<9<8CFO:769<F<G:67BLGE9OBQ9:;<9OG:COF9<8CFO:L7B9G;LW9LB:79O9ELBZF<9_XD9R;LG;9G7BB<G:E9:79:;<9:O6Z<:9TN96LTT7B9GOTF<ED9W67YLQLBZ9O9G7BB<G:769:;O:9GOB9WFCZ9LB:79OB9OG:COF9G;LW9WOGPOZ<97M9:;<9:O6Z<:9W67G<EE7649UFF9ELZBOFE9M769:;<9<8CFO:<Q98LG67W67G<EE769WOEE9:;67CZ;9:;<96LTT7B9GOTF<9:;O:9G7BB<G:E9:79:;<9:O6Z<:9ENE:<84
  	
	 		
  		  !








 !"#$%&' ()*+,-$.,/012(-*+1,/$31*),2$4,5$*66#*-7 $8#)#9+$+"#$:;< =>?< @AB$6-,9#77,-C$*7$7",D/$1/$E12(-#$FGHI $.)19J$K L$+,$-#+(-/$+,$+"#$.,//#9+1,/$.,/+-,)$31*),2$4,5 
MNOPQRSTUVWXSYZ[ P\] _^QS` _abNOPQ] N^_aScN]\_OSd_e
  	
	 		
  		  !
"# $%&%'()(*%)+,-./01)'*%'2)345)678%9)(*%)7:;%)(9%%#)<)7%=)>?;6&:(?47)43@%'(A)$?;:9;BCA)=?&&)3%)?7>(:7(?:(%8A):>)>*4=7)?7)D?E69%)"FGH#







 !"#$%&'#$()$*&+$,&-'#'$(*.&$."#$.-/0#. $!"#$%1//#*.$2&(*.$&3$#4#%1.(&*$()$('#*.(3(#'$56$."#$/#'$5&47$-)$)"&+*$(*$8(01/#$9:;< $!"#$%&'#$%1//#*.,6$5#(*0$'()2,-6#'$()$."#$5-)(%$(*(.(-,(=-.(&*$>&/$5&&.,&-'#/?$%&'#7$+"(%"$()$.62(%-,,6$+/(..#*$(*$-))#@5,6$,-*01-0# 
ABCDEFGHIJKLGMFNOPBFQGRFSDCCFEGTUVFGWNXFGQBYZG[UNVFVG\NECFY]^_`aabcadef^d]^gbac!"()$)#%.(&*$+(,,$.&1%"$&*$."#$5-)(%)$&3$'#5100(*0$3/&@$."#$)(@1,-.(&*$2&(*.$&3$h(#+ $!"#$2/(@-/6$0&-,$&3$."()$)#%.(&*$()$.&$,#-/*$."#$h#/6$5-)(%$3#-.1/#)$&3$."#$'#5100#/7$-)$."#(/$-22,(%-.(&*$(*$."#$3&,,&+(*0$#4-@2,#$()$/1'(@#*.-/6 i j2#*$."#$klmnopqrnqpsott$)&1/%#$3(,#$3&1*'$(*$."#$ssuvwxpy z{u|}~wxnluw}xop$'(/#%.&/6$1)(*0$."#$ $&2.(&*$1*'#/$."#$$@#*1  #,#%.$$3/&@$."#$$)15:@#*1$&3$."#$$@#*1$.&$'()2,-6$,(*#$*1@5#/)$(*$."#$@-/0(*)$&3$."#$)&1/%#$%&'# < #.$-$5/#-2&(*.$&*$,(*#$i97$."#$#h#/)($@$/#h#/)( ¡$).-.#@#*.7$56$'&15,#:%,(%(*0$.&$."#$,#3.$&3$."#$,(*#$*1@5#/ $¢$/#'$5/#-2&(*.$@-/#/$+(,,$-22#-/$.&$."#$,#3.$&3$."#$,(*#$*1@5#/7$-)$)"&+*$(*$8(01/#$9:;£$&*$2-0#$¤¥ ¢$kxpl¦twnq~$()$-$1)#/:'#3(*#'$).&22(*0$2&(*.$(*$-$2/&0/-@$."-.$()$(*)#/.#'$3&/$'#5100(*0$21/2&)#) $§/#-2&(*.)$-/#$-$@#."&'$#@5#''#'$'#h#,&2#/)$1)#$.&$0-(*$(*3&/@-.(&*$-5&1.$-$
  	
	 		
  		  
!"#$"%&'()"*+$'*,-'./.0),*#+1'2 )"*+$',3.'456789',3.'(.:.;#!."'0%+'./%&*+.',3.'*+,."+%;'0#+,.+,-'#<',3.'!"#0.--#"='&.&#">='".$*-,."-='.,01',#'.+-)".'!"#!."'#!."%,*#+1







 !"#$%&'("')*+,-./01*234*56(6'%*7 /89:*;<=>*%$6*'=3%6?%*>63@ *A$6*>BC=2<4*2<<2D*E"((*C6*24464*%=*%$6*E2%'$*E"34=EF*25*5$=E3*"3*G"#@<6*H&H 
IJKLMNOPQRPSOTNUVWJNXOYNZLKKNMO[ U\]^ O[ J_`aXb*cdefg*"5*2*h2<"2C(6*=<*6?i<655"=3*%$2%*D=@*<6j@"<6*%$6*46C@##6<*%=*4"5i(2D*2%*6h6<D*5%6i*=<*C<62)i="3%*5=*%$2%*D=@*'23*566*$=E*"%5*h2(@6*'$23#65 *A$6*k 2%'$*i236*"5*i2<%*=;*%$6*!62(l"6E*m6C@##6<*n=46*E"34=E*234*4"5i(2D5*%$6*E2%'$65*D=@*$2h6*46;"364 
  	
	 		
  		   








 !"#$%&'("')*+,-*+.*%$-*//01233455*67(8-9*",*%$-*!-7(:"-;*<-=8##->*? -@+>A*;",B+;*7,B*9-(-'%*CDEFCEG4EF2334DHH *I,%->*%$-*67(8-*JKLMJJJJJJ *N$-*? -@+>A*;",B+;*;"((*,+;*B"9O(7A*%$-*@-@+>A*9-#@-,%*'+,%-,%9*=-#",,",#*;"%$*%$-*7.+>-@-,%"+,-B*7BB>-99P*79*9$+;,*",*Q"#8>-*R&ST 
UVWXYZ[\]^ _ [`aZbcdVZe[fZgXWWZY[h Zi jYk[l VmnjeN$-*o pqrstuvwxyrv*B"9O(7A9*%$-*'+,%-,%9*+.*%$-*@-@+>"-9*z=+%$*Q(79$*7,B*{!|? }P*79*;-((*79*%$-*@-@+>A&@7OO-B*O->"O$->7(*'+,."#8>7%"+,*>-#"9%->9P*7%*-6->A*9%-O*+>*=>-7)O+",%*9+*%$7%*A+8*'7,*9--*$+;*"%9*67(8-*'$7,#-9 *N$-*@-@+>A*'+,%-,%9*@7A*7(9+*=-*@+B"."-B*%$>+8#$*%$"9*",%->.7'-*=A*9"@O(A*B+8=(-&'("')",#*%$-*67(8-*7,B*@+B".A",#*%$-*."-(B ~ .*A+8*7>-*B-=8##",#*;"%$*%$-*-@8(7%+>P*A+8*'7,*@+B".A*%$-*@-@+>A*'+,%-,%9*7%*~*7,B*%;"BB(-*%$-*I<9*+,*%$-*+>-? T*I67(87%"+,*+7>BP*%$89*9$+;",#*%$7%*A+8*$76-*B">-'%*7''-99*%+*%$-*+,&'$"O*O->"O$->7(9  .*A+8*;"9$*%+*>8,*%$-*'+@O(-%-*!-6->9"*z7(9+*),+;,*79*%$-((+}*#7@-*+,*%$-*+>-? T*<-6-(+O@-,%*"%P*'+,%",8-*;"%$*!8,,",#*%$-*!-6->9"*7@-*6"7*%$-*,&$"O*<-=8##->*+,*O7#-* *%$->;"9-P*-,B*%$-*B-=8##",#*9-99"+,*=A*9-(-'%",#*H1DE*.>+@*%$-*G4DE*@-,8 *
  	
	 		
  		  ! 












  		  !"
#$ %&'()*+,)-./0)(,123)4,5,6*)7890$):+,1)4,5,6*)-./0);)<=.>)?1@)&,*2&1)*')*+,)A'1BCD2&?*C'1)A'1*&'5)@C?5'D)E'F$G$ H,5,6*)*+,)IJK LMNK OP7)6+,6Q)E'F)21@,&)*+,)R?(,)*&,,$)S*)(?T)E,)1,6,44?&T)*'),FU?1@)*+,)JVOPK <)E&?16+)BC&4*3)?4)4+'W1)C1)%CD2&,)GXYZ$







 !""#"$%&'(% ()(*+#%,-. (%)#-%&'(%/"01'#2%3(4!$$(*56 789:;<=>?8=@ABACDEFGDEHIJKEJALGMN=OP98=QR=S898T>PUV=WXYZ[\]^_ [` X]aZ]b[c` Xa=Od:e=>?8=fXgh` =e8Ui6j6 k:UU8T>=>?8=7lmjnj=T:UU8T>:d=oj=>:=>?8=kpq 5=r:d>=:O=R:id=ok=iSPUV=;=S>;U<;d<=S>d;PV?>m>?d:iV?=S8dP;9=T;Q986n6 sd:e=>?8=fXgh` =e8Uit=S898T>=Whu=v:d=iS8=>?8=s55=S?:d>Ti>=w8Rx6=y?8d8=zP99=Q8=;U=PU<PT;>:d=PU=>?8=78;9{P8z=|8QiVV8d=S>;>iS=Q;d=z?PT?=PU<PT;>8S=>?;>=>?8=>;dV8>=PS=@}JJEJK=zP>?=;=Se;99=rd:Vd8SS=Q;d6~6 q PUPeP8=>?8=78;9{P8z=|8QiVV8d=>::966 ;PV;>8=>:=>?8=LL}CEGA<Pd8T>:dR=:U=>?8=yi>:dP;9=k|m7pq =;U<=<:iQ98mT9PTw=>?8=@ABACDELAMA=88Ti>;Q9866 od8SSPUV=l t=l t=l t=l t=:d=l 5=zP99=T:ee8UT8=>?8=V;e866 y:=8U<=>?8=V;e8t=S898T>=aZ]XhaZu=Od:e=>?8=fXgh` =e8Ui=v:d=iS8=>?8=l sy s=S?:d>Ti>=w8Rx66 |PST:UU8T>=Od:e=>?8=>;dV8>=QR=S898T>PUV=fZuuXa=Od:e=>?8=b[c` Xa=e8Ui6=>=PS=U:z=S;O8=>:=T9:S8=>?8=78;9{P8z=|8QiVV8d6 ¡ ¢£¤¥¦§ ©¨ª¢«¬­®y?8=:Q¯8T>=:O=>?8=V;e8=PS=>:=:zU=e:d8=rP8T8S=>?;U=R:id=:rr:U8U>=z?8U=>?8=V;e8=PS=:8d6=y?8=V;e8=PS=:8d=z?8U=U8P>?8d=r9;R8d=?;S=;=e:86=°Si;99Rt=>?PS=e8;US=>?8=Q:;d<=PS=Oi996=pU=R:id=>idUt=R:i=r9;T8=:U8=rP8T8=:U=>?8=Q:;d<=zP>?=R:id=T:9:d=O;TPUV=ir6=±:i=eiS>=r9;T8=>?8=rP8T8=S:=>?;>=R:id=:rr:U8U>²S=rP8T8t=:d=;=d:z=:O=R:id=:rr:U8U>²S=rP8T8St=PS=O9;Uw8<=QR=R:id=rP8T8S6=³99=:O=>?8=:rr:U8U>²S=rP8T8S=Q8>z88U=R:id=rP8T8S=;d8=>?8U=>idU8<=:8d=>:=Q8T:e8=R:id=T:9:d6´§µ  ¥¶«­·¢« £¸l ¹ o9;T8S=;=rP8T8l ¹ q :8S=>?8=r9;T8e8U>=Q:=>:=>?8=98O>=:U8=iUP>l 5¹ q :8S=>?8=r9;T8e8U>=Q:=>:=>?8=dPV?>=:U8=iUP>l ¹ q :8S=>?8=r9;T8e8U>=Q:=<:zU=:U8=iUP>l ¹ q :8S=>?8=r9;T8e8U>=Q:=ir=:U8=iUP>
  	
  
  !""#$%&# '"""#()*+*#$,-$./#01%%/,231%456789:89;78<:=>?7;7@ABC78D@E8FG7HBIG78@D96?78:F8J K8L?:MNOPQRS8E7CB<786A7?8ORTAU8D8@D=B@V8A<;7=78BA86A7E89:8A;:W89;78E79DBGA8:F87D<;8ORTX8Y;78@D=78BE7@9BFB7A89;78ORT8ID@Z89:8W;B<;89;78ORT8I7G:@VA8DA8W7GG8DA89;78>DB?B@V8D@E8>B@8>:GD?B9[8F:?8EBFF7?7@9BDG8ORTAXORT8@:=7@<GD96?7\8]=@8:?8OT 6HW^[]=@8BA8:@G[86A7E8F:?8ORTA89;D98DGA:8;DC78PPP8D<<7AAU8BX7XU8VG:IDG8>B@AX
_BV6?78M a`8:@8>DV78abc8D@E8YDIG78M a`8:@8>DV78abK8D?787H9?D<97E8F?:=89;78defghijk8D@E8defghijkl8ED9DA;779A8D@E8>?:CBE78>D<ZDV78<:@@7<9B:@A8F:?89;78J KMQLScbb8D@E8J KMQLabbb8E7CB<7AX












  	 ! "#





   	 	!"#	$
%%& '() '()%%* +,,-./ +,,-.0%%/ (, (,%%1 -2&3&45.* -26/().6+6%%7 -2&0345.* -26/8).6+6%%9 -2&0745.* -260().6+&%%0 -2&9:45.* -2608).6+&%%3 -2&9945.* -2&&().6+&%%: -2&9645.* -2&0().6+*%%&6 -2&7*45.* -2&18).6+*%%&& -2&1945.* -2&:8).6+*%%&* -2&/:45.* -2**().&+6%%&/ -2&//45.* -2*9().&+6%%&1 (, (,%%&7 (, (,%%&9 -2&**45.* -2/6().&+&%%&0 -2&&:45.* -2/68).&+&%%&3 -2&&045.* -2/*8).&+&%%&: (, (,%%*6 (, (,%%*& +,,-.& +,,-.*%%** '() '()
;<=>?@ABCD@E FAGHIJKK@<LM@E FAGHCKKK@NOPQP@H<RS<T?@UVLL?RWXVLY@ZUVLWXL[?M\] _^a`bcdef g hij]klll`mb_no^p_ g hij]qrll`mb_no^p_
  	
	
  	 ! "#$
%&' ()* +,,-&.%&/ ()* ),%&0 +,,-&/ ),%&1 -2'3456&/ ),%&7 -2'.856&/ ()*%&8 -2'.056&/ -241)*&4+4%&. -2'8.56&/ -2419*&4+4%&3 -2'8/56&/ +,,%&: -2'7856&/ +,,%&'4 -2'7456&/ -2'1)*&4+/%&'' -2'1756&/ -2':)*&4+/%&'/ -2'1156&/ ),%&'0 -2'0/56&/ ),%&'1 -2'/.56&/ +,,%&'7 -2'/856&/ +,,%&'8 -2'/056&/ ),%&'. -2'/'56&/ ),%&'3 -2''356&/ ()*%&': ), ),%&/4 +,,-&/ ),%&/' ()* ),%&// ()* +,,-&/





   	 	!"#	$
%& '() (*%+ ,**-%. (*%. (* (*%/ -01234%1 '()%5 -01634%1 '7718-011()%1,1%2 -0&+34%1 '77&8-0119)%1,1%: -0&534%1 '7%18-01&()%1,1%6 -0&;34%1 -0159)%1,1%; -0+/34%1 -0&19)%1,&%&1 -0.&34%1 -0&+9)%1,+%&& -0.;34%1 -0&2()%1,+%&+ -0/634%1 -0+.()%&,1%&. -05/34%1 -0+.9)%&,1%&/ -05634%1 -0+6()%&,&%&5 -02.34%1 -0+69)%&,&%&2 -02234%1 '%%&8-0./9)%&,&%&: -02634%1 '%718-0.5()%&,&%&6 -0:134%1 '%7&8-0.59)%&,&%&; (* '()%+1 (* (*%+& ,**-%& (*%++ '() (*
<=>?@ABCDEAF GBHIJKLLA=MNAF GBHIDLLLAOPQRQAI=ST=U@AVWMM@SXYWMZA[VWMXYM\@N]^_` abcdefg h ijk^ lmmmanc` op_q` h ijk^ rsmmanc` op_q`
  	
	
  	 ! """
#$ %##&'( )##* &+**,-.'( )##( )# /).#0 )# /1'*2&+$((-.'3%$#4 /). /11*2&+$(0-.'3%$#5 &+$,67', /).8#3 &+$067', /1'$2&+,$-.',%,#9 %## &+,4).',%,#: %## &+$,).',%$#$, &+(,67', &+$*).',%*#$$ &+(367', &+$5-.',%*#$* &+0(67', &+*,).'$%,#$( )# &+*0).'$%,#$0 %## &+*0-.'$%,#$4 %## /'#$2&+((-.'$%$#$5 )# /'',2&+(0).'$%$#$3 )# /).8#$9 /). /'1*2&+(5-.'*%,#$: )# &+0*).'*%,#*, )# /).#*$ )# )##** %##&'$ )#





   	 ! 	"#$	%
&' ()*'+,&-. /0&* ()**1/&-. ()'.'/&-23'&. /0 ()'.',&-23'&4 5/& ()'../&-23'&6 57718()119:-1 ()'.4/&-23'&; 577'8()1'9:-1 3< 32&2 57-18()1*9:-1 300,=7&> ()';9:-1 57018()1*/&-131&+ ()**9:-1 570'8()1*,&-131&'1 ()*>9:-1 ()'6/&-13*&'' ().69:-1 ()'6,&-13*&'* ()469:-1 ()*1,&-'31&'. ()619:-1 ()*6/&-'31&'4 ()669:-1 ()*2,&-'31&'6 ();'9:-1 5-018()../&-'3'&'; 5--'8()269:-1 300,=-&'2 5-718()2;9:-1 3< 3*&'> 5-7'8()229:-1 ().;/&-*31&'+ 5/& ()4*,&-*31&*1 /0 /0&*' /0 /0&** /0 /0
?@ABCDEFGHDI JEKLMNOOD@PQDI JEKLGOOODRSTUTDL@VW@XCDYZPPCV[\ZP]D^YZP[\P_CQ`abcdefghij k lmnaopppdqfcrsbtc k lmnauvppdqfcrsbtc
  	
	
  	 ! ""#
$% &'(%)*+,- &'%(.*+,./%$( *0 &'%(.1+,./%$- 2*+ *0$3 24,(5&'((31+,- &'%(61+,./%$7 244(5&'((71+,- &'%()1+,./%$8 2*+9 240(5&'%-(1+,./%$. 24,%5&':-;<,: /0'= 1>4$6 &'%.;<,: 2*+9$) &'(%;<,: &':)*+,:/%$%: &'(.;<,: &':)1+,:/%$%% &'-3;<,: &'%-1+,:/($%( &'33;<,: &'(%1+,%/:$%- &'7%;<,: &'(71+,%/:$%3 &'7.;<,: &'(.*+,%/:$%7 2,0%5&'.-;<,: 2*+9$%8 2,,:5&'.3;<,: /0'= 1>,$%. &'.%;<,: 2,,(5&'-.1+,(/:$%6 2,4(5&'.61+,% &'-)1+,(/:$%) &'6%1+,% &'-)*+,(/:$(: 2*+ &'3-1+,(/:$(% *0 &'3-*+,(/:$(( &'631+,% *0





   	 	!"#	$
%& '( '(%) *+)&,-./0 '(%0 *+)&,'./0 1((%2 *+))2'./0 *+&)3'./41&%, *+)),'./0 *+&)5'./41&%6 17 10 *+&0)'./41&%4 *+&&89/: *+&0:-./41&%3 ;<(:=*+:289/: 17 1:%5 ;<(&=*+:,89/: 1((*/:%&: *+),89/: 1((*/:%&& *+0689/: *+&0'./:1)%&) *+2)89/: *+)&'./&1:%&0 *+2589/: 1((*/&%&2 *+,689/: 1((*/&%&, ;/(:=*+4)89/: 17 1&%&6 *+6)89/: ;/()=*+03-./)1:%&4 17 1: *+04'./)1:%&3 *+43'./& *+2&'./)1:%&5 *+3&'./& *+2&-./)1:%): *+3)--/& 1((%)& '( '(%)) *+32'./& '(
>?@ABCDEFGCH IDJKLMNNC?OPCH IDJKFNNNCQRSTSCK?UV?WBCXYOOBUZ[YO\C]XYOZ[O^BP_`abcdefghi j klm` nooocpebqrasb j klm` tuoocpebqrasb
  	
	
  	 ! ""#
$% &'(%)*+,- &'%(-*+,./0$( &'(%)1+,- &'%(-1+,./0$- *2 *2$) &'(((*+,- &'%()1+,./0$3 &'(((1+,- &'%(31+,./0$4 $52(6&'((-1+,- &'%(41+,./0$. &'((-*+,- &'%-0*+,./%$7 $*+8 /22&,.$9 &'(-:;,0 $*+$%0 &'(9:;,0 /22$%% &'--:;,0 /22$%( &')4:;,0 /22$%- &'3(:;,0 /22$%) &'40:;,0 $*+$%3 $*+8 /22&,($%4 &'70*+,% &'-7*+,(/0$%. $,,(6&'.91+,% &')0*+,(/0$%7 &'.9*+,% &')01+,(/0$%9 &'7(*1,% &')31+,(/%$(0 &'731+,% *2$(% &'73*+,% &')71+,(/%$(( *2 &')41+,(/%





   	 	!"#	$
% & '( )*&+&',-./0% + '( )*&+&1,-./0% 2 /(( '(% 3 )*+&.1,-2 )*&+3',-./0% 4 )*+&51,-2 )*&+4',-./0% 6 )*++&',-2 )*&+6',-./0% . )*++&1,-2 78(&9)*&+011-./0% 5 /: /0 /(()-.% ; /(()-0 /((% &0 /(()-0 7',% && )*25<=-0 7',% &+ )*3.<=-0 7',% &2 /(()-0 7',% &3 /(()-0 /((% &4 /: /& /(()-+% &6 7-(+9)*501,-& 7((&9)*4011-+/&% &. )*5211-& )*33',-+/&% &5 )*5611-& )*331,-+/&% &; )*5.1,-& )*3;'1-+/&% +0 /(( )*34',-+/&% +& '( )*35',-+/&% ++ '( )*36',-+/&
>?@ABCDEFGCH IDJKLMNNC?OPCH IDJKFNNNCQRSTSCK?UV?WBCXYOOBUZ[YO\C]XYOZ[O^BP_`abcdefghi j klm` nooocpebqrasb j klm` tuoocpebqrasb
  	
	
  	 ! ""
#$ %&'$'()*+ (,#' %&'$'-)*+ %&$''-)*./0#+ (, %&$''()*./0#1 %&'$.()*+ 23*04%&$$5(-*./0#6 %&'$7()*+ 23804%&$$7()*9/$#9 %&'$9-)*+ 23*$4%&$$5--*./0#. %&'$9()*+ /,&: -;3#7 /,,%*+ 23,04%&$'0(-*./0#5 2() /,,#$0 /,, 2()#$$ /,, 2()#$' /,, 2()#$+ /,, 2()#$1 2() /,,#$6 /,,%*$ 2,,04%&60(-*'/$#$9 %&7+(-*$ 2,*$4%&6$--*'/$#$. %&79(-*$ 2,804%&6'(-*+/0#$7 %&50--*$ /,&: -;,#$5 %&7.()*$ 2,*04%&6$(-*'/$#'0 (, %&15--*'/$#'$ %&75-)*$ %&1.()*'/$#'' %&75()*$ %&1.-)*'/$





   	 	!"#	$
%& '()&&*+,- ./%) '()&&.+,- '(&&0.+,12&%- ./ '(&&3.+,12&%0 '()&4**,- 567)8'(&&3*+,12&%9 '()&-.+,- 567&8'(&&:*+,12&%1 '()&-*+,- 2//*;6%3 56/&8'()4<**,- '(&&1.+,12&%: 2//',- 56,)8'(&&1*+,12&%< 2// 2//%&4 5.+ 5.+%&& 5.+ 5.+%&) 5.+ 5.+%&- 5.+ 5.+%&0 2// 2//%&9 2//',& 5/,)8'(90**,-24%&1 5//&8'(<&**,& 5/7&8'(9)**,-24%&3 '(<4.*,& 5//)8'(99**,-24%&: '(::*+,& 2//*;/%&< '(::.+,& 5/7)8'(9-*+,-24%)4 '(<0.*,& '(9-.+,-24%)& '(<:.+,& '(91*+,-24%)) '(<:*+,& ./
=>?@ABCDEFBG HCIJKLMMB>NOBG HCIJEMMMBPQRSRBJ>TU>VABWXNNATYZXN[B\WXNYZN]AO^_ a`bcdefgh i jkl_mnnnbodapq`ra i jkl_stnnbodapq`ra
  	
	
  	 ! ""#
$% &' ()%%*+,-./%$0 ()011+,-2 ()%%%&,-./%$2 ()0%1&+-2 &'$* 34-15()016&+-2 34'05()%%7+,-./%$7 34815()019&,-2 ()%%2++-./%$. 34-%5()016++-2 ()%%0+,-./%$9 /'): +$4 ()%%0&,-./%$6 34'15()01;&+-2 /''(-.$; /'' /''$%1 3&, 3&,$%% 3&, 3&,$%0 3&, 3&,$%2 3&, 3&,$%* /'' /''$%7 3''15();%&+-% /''(-2$%. 3'-%5();0++-% ()7*&+-2/1$%9 3'815();2&+-% ()79&+-2/1$%6 ();.&+-% ()77&+-2/1$%; 3'-15();0&+-% ()79++-2/1$01 ();9+,-% &'$0% ();9&,-% ()7.&,-2/1$00 ();;&+-% ()76+,-2/1





   	 ! 	"#$	%
& ' () ()& * +,*--(./0 +,'''1./23'& 0 +,*-2(./0 +,''4(./23'& 5 678*9+,*-21./0 +,''0(1/23'& 4 678'9+,*-:1./0 +,'-;11/23-& 2 3))1<7 +,'-=1./23-& : +,*-4(./0 +,'-=(./23-& = 67/*9+,*-41./0 3))+/2& ; 3)) 6(.& '- 6(. 3))& '' 6(. 3))& '* 6(. 3))& '0 6(. 3))& '5 3)) 6(.& '4 6)/*9+,;411/' 3))+/0& '2 6)8'9+,;011/' 6./-9+,22(1/03'& ': 6))*9+,;211/' +,2-(./03'& '= +,'--11/' +,2-1./03'& '; 6)8*9+,;511/' +,2'1./03'& *- +,'-'11/' ()& *' +,;;11/' +,4;1./03-& ** () +,4=(./03-
>?@ABCDEFGCH IDJKLMNNC?OPCH IDJKFNNNCQRSTSCK?UV?WBCXYOOBUZ[YO\C]XYOZ[O^BP_`abcdefghi j klm` nooocpebqrasb j klm` tuoocpebqrasb
  	
	
  	 ! "#"
$% &'()%$*+, $-$( &'()%.*+, &'%%).*+/0)$, $- 0--$1 23-(4&'()1.*+, &'%)5$.+/0)$6 &'()1$*+, &'%)/$*+/0)$/ &'(),$*+, &'%)/.*+/0)$7 &'(),.*+, 28-)4&'%)1$.+/0)$9 0--&+, 0: 06$5 0-- 0--&+6$%) 2$* 0--&+6$%% 2$* &'91$*+60)$%( 2$* &'91.*+60)$%, 2$* 0--&+1$%1 0-- 0--&+1$%6 0--&+% 0: 0,$%/ &'56$.+% 0--.;*$%7 &'%))$.+% 2*+%4&'//..+,0%$%9 &'%)($*+% 2*-%4&'/6.*+,0%$%5 &'%)(.*+% &'/%$*+,0%$() $- 0--$(% &'%)%$.+% &'65$*+,0)$(( &'%),.*+% &'/(.*+,0%





   	 ! 	"#$	%
&' () ()&* +,'--&./0 +,''1(./231&0 +,'--(./0 ()&4 +,*1*(./0 +,'15&./231&5 +,*1*&./0 +,'15(./231&2 +,'-2&&/0 67)'8+,'14&&/231&9 +,'-0&&/0 3),: &;7&< 3))+/0 6(.=&- 6(. 67>*8+,'1'&&/53*&'1 3)) +,-*(./53'&'' 3)) +,-1(./53'&'* 3)) +,<*(./531&'0 3)) +,94(./43'&'4 6(. +,94&./43'&'5 3))+/' 6(.=&'2 6./18+,''*(&/' 3),: &;.&'9 +,'12(./' 3?@>6&'< +,'12&./' 6.)18+,25(./03'&'- +,'19&./' 6.>'8+,29&./03'&*1 () ()&*' +,'14&./' +,24&./03'&** +,'10(./' +,2*(./03'
ABCDEFGHIJFK LGMNOPQQFBRSFK LGMNIQQQFTUVWVFNBXYBZEF[\RREX]^\R_F`[\R]^RaESbcdefghijkl m nopcqrrrfshetudve m nopcwxrrfshetudve
  	
	
  	 ! "#$
%& '( '(%) *+&,-../0 *+&1-.2/341%0 4(( *+&1-'2/341%5 *+&,-'./0 67/&8*+&10.2/341%9 *+&,3'./0 67/18*+&10'2/341%3 *+&,0'./0 4: 43%- 67(18*+&,1'./0 4((.;7%< 4: 40 *+&1&'./94)%, 4((*/) *+,9../94&%&1 4((*/) *+,).2/94&%&& *+&5-%=/) *+,1.2/94&%&) *+&03%=/) *+<).2/941%&0 4((*/) *+-3'2/54&%&5 4((*/) *+-3.2/54&%&9 4: 4) 4: 45%&3 *+&&1'2/& >(?%&- 62/&8*+&&)../& 4.@: .%&< 62(&8*+&&&.2/& >%=>%&, *+&1-'2/& 62A18*+3-'2/04&%)1 4(( '(%)& *+&15'2/& *+35'2/04&%)) *+&19.2/& *+30.2/04&





   	 ! 	"#$	%
&' ()'*+,-./ 01&2 ()'*+0-./ 01&/ 01 30-&4 ()'*4,,./ 356'7()'82,-.9:8&; ()'*2,,./ 35687()'820-.9:8&9 351'7()'*8,,./ 30-<&= ()'*20,./ 35127()**,-.;:2&+ 30-< ()*;0,.;:'&* 35627()'+=>?.2 ()*'0-.;:'&'8 ()'9'>?.2 ()*',-.;:'&'' ()';;>?.2 ()+/0-.;:8&'2 ()'4'>?.2 ()+/,-.;:8&'/ ()'2*>?.2 ()==0-.4:'&'4 ()'24>?.2 ()==,-.4:'&'; 30-< ()9*0-.4:8&'9 ()''8,-.' 3-.27()9*,-.4:8&'= :@&63 &-(&'+ 3-187()'''0-.' 30-<&'* 3-6'7()''/,-.' &-)&28 01 30-&2' ()'8+,-.' 01&22 ()'8;0-.' ()9/0-./:'
ABCDEFGHIJFK LGMNOPQQFBRSFK LGMNIQQQFTUVWVFNBXYBZEF[\RREX]^\R_F`[\R]^RaESbcdefghijkl m nopcqrrrfshetudve m nopcwxrrfshetudve
  	
	
  	 ! "#$
%& '(&)*+,-. /0%1 '(&)*/,-. /0%. '(&)2/+-. /0%2 34-&5'(&6)+,-. 3/,%* 34-75'(&6)/,-. '(&77/,-*81%9 8: 81 34-15'(&77+,-*81%; '(&;)<=-1 '())/,-*81%6 '(&;&<=-1 '(66/,-*87%) '(&9*<=-1 '(66+,-*87%&7 '(&*)<=-1 '(6)/,-*87%&& '(&*&<=-1 '(67/,-28&%&1 '(&.;<=-1 '(6&/,-28&%&. '(&.2<=-1 '(6&+,-28&%&2 '(&16<=-1 '(;7/,-287%&* 8: 8& 3,015'(;7+,-287%&9 >0? '(96/,-287%&; 8+%: + 3,@15'(96+,-287%&6 ><=> >: =%&) 3,@75'(&&./,-& 3/,%17 /0 /0%1& '(&76/,-& /0%11 '(&7)+,-& /0





   	 ! 	"#$	%
&' () &))*+,&- () ()&. /(0 ()&1 /23'4*5'6670+. *586(0+9&-&9 /23:4*5'66(0+. /(0&, *5'61;<+- *581(0+9&'&= /2)-4*5'69;<+- *58170+9&'&6 *5',6;<+- &))&8 *5',.;<+- &))&': *5'9=;<+- *56870+9&:&'' *5'18;<+- *56:70+1&'&'- *5'1.;<+- *5=6(7+1&'&'. *5'.6;<+- ()&'1 *5'.';<+- &))&'9 *5'-9;<+- &))&', /0+-4*5''9;<+- ()&'= >0* ()&'6 /(0? /(0&'8 >05 ()&-: /(0 ()&-' () ()&-- *5':8(0+' &))*+.
@ABCDEFGHIEJ KFLMNOPPEAQREJ KFLMHPPPESTUVUEMAWXAYDEZ[QQDW\][Q E^_Z[Q\]Q`DRabcdefghijk l mnobpqqqergdstcud l mnobvwqqergdstcud
  	
	
  	 ! "#
$ % &' (&)$ * +,%-%.)/0 1''+/2$ 0 &' &'$ 3 (&) +,-4.)/51*$ 5 +,%4067/* +,-2&)/51*$ 2 (8/*9+,%4267/* +,-2.)/51*$ : +,%:*67/* +,42&)/51;$ 4 +,%:;67/* +,42.)/51;$ - +,%2367/* +,45.)/51;$ %; +,%5467/* +,45&)/51;$ %% +,%5067/* +,:4../31%$ %* +,%3*67/* +,:-&)/31%$ %0 +,%0567/* +,:-.)/31%$ %3 +,%0;67/* &'$ %5 ()'*9+,%%267/* &'$ %2 +,%*;67/* +,:%&)/31;$ %: ()<*9+,%%367/* +,:%.)/31;$ %4 => 7 &'$ %- (&) &'$ *; &' &'$ *% &' 1''+/0$ ** &' (&)





   	 ! 	"#$	%
&' ())*+, -./&0 *1'2'./+, -./&, .) ())*+3&4 *1'5067+0 *128./+3(0&3 -./ *1289/+3(0&: *1'8867+0 *12,./+3('&8 *1'8467+0 *12,9/+3('&5 ()) *158./+3(;&2 ()) *1589/+3(;&'; *1'3467+0 .)&'' *1'4567+0 .)&'0 *1'4;67+0 *183./+4('&', .) *1839/+4('&'4 ()) *180./+4(;&'3 ()) *1809/+4(;&': .) *18,./+4(;&'8 .) *18,9/+4(;&'5 -./ .)&'2 .) .)&0; .) ())*+4&0' .) -./&00 ())*+' -./
<=>?@ABCDEAF GBHIJKLLA=MNAF GBHIDLLLAOPQRQAI=ST=U@AVWMM@SXYWMZA[VWMXYM\@N]^_` abcdefg h ijk^ lmmmanc` op_q` h ijk^ rsmmanc` op_q`
  	
  
 !"#$% &'"()*+,-.//012+3-/456+20,-+778,94.9+51,-5:-9*0-;540< =>-?6.78.9+51-@5.42ABCDEFGHGIJKLGMN+O840-@PQ-51-/.O0-QRS-+778,94.90,-.-95/P70607-6+0T-5:-9*0-;540< =>-?6.78.9+51-@5.42A-N+O840-@PU-51-/.O0-QRQ-,*5T,-.-V5995WP70607-6+0T-5:-;540< =>-?6.78.9+51-@5.42AXCYGZ [\J]^ _G` abL^c)*0-40,9-5:-9*+,-.//012+3-,*5T,-9*0-:5775T+1O-+778,94.9+51,-5:-9*0-;540< =>-?6.78.9+51-@5.42dN+O840-@PR-51-/.O0-QRUd-< .+1-QAe-fg-UAe-fg-.12-RAR-f-=5T04-h8//7+0,N+O840-@Pi-51-/.O0-QRRd-N7.,*-.12-hj1k*45158,-hlm< -< 0W54+0,N+O840-@Pe-51-/.O0-QRid-< >mR=?nSS-N=om-p-qrs-@.1t,-SpUN+O840-@Pn-51-/.O0-QRed-< >mR=?nSS-N=om-p-qrs-@.1t,-RpeN+O840-@P>-51-/.O0-QRnd-< >mR=?nSS-N=om-p-qrs-@.1t,-np>N+O840-@Pu-51-/.O0-QR>d-v?w,-.12-=8,*P@89951-hT+9k*0,N+O840-@Px-51-/.O0-QRud-N=om-qrs-?3/.1,+51-y 0.204,N+O840-@PQS-51-/.O0-QRxd-zh@-q1904:.k0N+O840-@PQQ-51-/.O0-QiSd-lhPURU-.12-;m{-q1904:.k0,N+O840-@PQU-51-/.O0-QiQd-?9*04109-S-q1904:.k0N+O840-@PQR-51-/.O0-QiUd-?9*04109-Q-q1904:.k0
   	
  !"#$%!&'(#) * +!, -!'.!/' 0 12!3 * +'(4  56!"'78
  	
   !"#$ !%&&%' "()* +, %- .%/ 01 2)*%3' 4& !%56
   	


















































































































































































































































































































































































































































































































































































































38¾C44 8¾74458¾D46 8¾75478¾34A 8¾765E8¾45B
M995C
































































































































38¾C44 8¾74458¾D46 8¾75478¾34A 8¾765E8¾45B
M995C
































































































































































































?HKLMNH ?HKLMN< ?HKLMN; ?HKLMN: ?HKLMN9 ?HKLMN8
?<KLMNH ?<KLMN< ?<KLMN; ?<KLMN: ?<KLMN9 ?<KLMN8


































































































































































































































































































































































































>8@ABCD >8@ABC: >8@ABC;E>8@ABCE >8@ABC;F>8@ABCG>8@ABC; >8@ABCH >8@ABC;; >8@ABC;9 >8@ABC:9>8@ABC9 >8@ABC;G>8@ABC;7>8@ABC8 >8@ABCF >8@ABC;H>8@ABC;: >8@ABC::>8@ABC7 >8@ABC:D>8@ABC;D >8@ABC:;>8@ABC;8























































































































































































































































































































































































































=HIEJCK=HIEJC7 =HIEJC6 =HIEJC::=HIEJCL=HIEJCH =HIEJC:8=HIEJC:9=HIEJC:M =HIEJC:7=HIEJC9 =HIEJC8 =HIEJCN =HIEJC:6 =HIEJC:H =HIEJC:L=HIEJCM =HIEJC:
























































































































































































































?<BÑ:H ?;EU:L ?DAR:K ?;CU:N UÐ?>
Ó?:L ?@A?Ñ:K UwÑD
w
Ñ:L UDUMÒK UDU9Ï:L UDULÏH Óu;K>9 Óu;N>99 Óu;:
















































































































































































































































































































































































































































































































































































































































































































lE30 lVEG°>lV lE3/ lVEG°>lV







































































































































































5 _ 6 » 7 µ 8 Q 99
@ 99
ºm7» 98






































































<CD4<E4FG E45 <CD41<CD43 <CD42 <CDB9H 9DCBF:B58;
B<















<5G8<HD4< <HD43 <5H><HDB4I <HDB9H<HD42 <HD41 H>C=
?@ABCD<K ?@ABHD<K?@ABCD<J ?@ABHD<J

































































































































































































































































































=45 3>?4< 3>?41=4@A 3>?43 3>?42 3>?;BC B?>;@D;5EF
;2











































































































































































































Ô23 5AD133 22 11
531Y <N3bL
3 2
Ô22 5AD133 22 11
Ô21 5AD133 22 11
5312 <N3bL
3 2
Ô20 5AD133 22 11





































































































 !"#$ %&' # ( )*+ ,-&. %&'
  	
  
 !"#$%!&'( !$!)!*+,-!./', !01/',23
   	
  !"#$%!&'( !$!)!*+',!&'( !$
  	
   !"#$ %&' # ( )*&+ %&' #
   	
 
 !"#$%!&'( !$!)!*+, !*-'. !/0-'.12
  	










 !" #$% &'%() * '+%,'"&#"!-%.(//+ %' '+0123456781449:69;21;99<767=>??6=396@9A3;1A>46BCDDE<=6F9;=9<6?<EG6HIJJ6KLM L6=E6NIJJ6OLM LP6O>A1?1A6@1G9P6M E;:>56=3<EC236Q<1:>5L6B9R9<>46S>576E?6AE;=>A=1;26=396F9;=9<6?E44ESITU VWX YEC6A>;6AEGGC;1A>=965EC<6=9A3;1A>46ZC97=1E;76=E6EC<69G>146>::<9776>;:6<9A91R96>;7S9<76[>A86[569G>14P6?>\P6E<6D3E;9L6K47EP61?65EC63>R96:9712;6D<E[49G7P65EC6A>;69G>1465EC<6:9712;6?14976=E6<9A91R96>7717=>;A9L6] 96AE;7=>;=456GE;1=E<6=3969G>146>AAEC;=6=3<EC23EC=6=396:>5L6] 39;679;:1;265EC<6<9ZC97=6=E6C7P6D49>796[967C<96=E61;A4C:965EC<6?C446;>G9P6AEGD>;56;>G9P6>;:65EC<6AE;=>A=61;?E<G>=1E;6?E<69??1A19;=6D<EA9771;26E?65EC<6<9ZC97=L@396=9A3;1A>467CDDE<=69G>146>::<9776176=9A3^ >A=94LAEGL_`abc dC<6@9A3;1A>46BCDDE<=6F9;=9<6>;7S9<76>446A>447L6@396A9;=9<6<9=<19R9761;?E<G>=1E;P67CA36>765EC<6;>G9P6AEGD>;56;>G9P6D3E;96;CG[9<6>;:65EC<6ZC97=1E;P6>;:6=39;6177C976>6A>796;CG[9<L6@396F9;=9<6=39;6?E<S><:76=3961;?E<G>=1E;6=E6>6ZC9C96S39<96=396?1<7=6>R>14>[496>DD41A>=1E;69;21;99<6<9A91R976=396:>=>6>;:6<9=C<;765EC<6A>44L6@396D3E;963EC<76><96?<EG6HIJJ6KLM L6=E6NIJJ6OLM LP6O>A1?1A6@1G9P6M E;:>56=3<EC236Q<1:>5L6@396@9A3;1A>46BCDDE<=6;CG[9<76><9IefghijkhllegkgghmemhjgegFC7=EG9<76;99:1;26>7717=>;A96EC=71:96=396nB6=1G96oE;976A>;691=39<6AE;=>A=6=9A3;1A>467CDDE<=6R1>69G>146p=9A3^ >A=94LAEGq6E<6AE;=>A=6>64EA>467>4976E??1A9L6B>4976E??1A96417=1;276A>;6[96?EC;:6>=6SSSL>A=94LAEGrAE;=>A=rE??1A97r1;:9\L3=G4L
  	
  
 !"#$" %&'() "*"*") #+$,)-.,*%/0 "*"1!+$"%/02"343.5"6 ")!$,).*5711+# %/2"35, "%/.557-1 ,+$5%/83+.#69(:%0)*+);5%06"5)#,1 ,+$%& !"#$" %&!".6"#5%00<7-1"#5%/*.="#5%00>?5%@-"-+#=%00A>>5%1+2"#5711*,"5%03*+);6,.B#.-%01#+B#.--,$B%CDE40F0%G5)!"-. ,)5%0&5"*H "5 %0/1#+B#.--,$B%0/52, )!"5%I "5 1+,$ 5%00 "5 ,$B%0/1#+B#.--,$B%0/ +14*"J"*J,"2%75.B"%&KEL%0




 !"#$%&'()*+,-.*".*$%/0123$%&4 " -#5%66	711$%&&!-8"#+$!!9)"$%&6:9-,(+;)<=#< %&6!#-;,*+$!!-#*%&'&>&'6,$*- "#+$"#?),"%&'&"9",*#-.),+ <)9%&'6*",@.),<9+$!!-#*%&'&*"9"!@-."%&'68":$)*"%&'&!#-=#<  ).=%&A





   

 !"#$%&'(%)*+,'$-. +,)$/%)0%&12*345 567#3*,8$+9 &'#&':%;&<!= >6"?>" " -*,8$+9 &'3@@(%;/$%+)8*&)$&'<?  >!>" ! AB>C,)(+@D+,8&2E%:&'8%F&G /H-*/9 I&'(&H2#,''&HJ7"=6KL-7)%$&FM%)NF+9OP+)&Q55R S"T!5 "5= -U/VQ55R S"T!5 "54 W

XYZ#XI%8,[(FN>5U-"\5\"5XI%8,#P%I,H/\],-^+]H+"= -_/@/)OP+)&Q?"> 6>655=>T!T"-U/VQ?"> 6>655=>T!!?-111 >`@>/;$&(>;+9abcb#,%$&""52^1+O/;%d%;O(/;&-??e,&&)81/H23F9 %'/($HD+)NM+)NOP+)&Q?="?=!5! -U/VQ?="?=!5??-111>/;$&(>;+9 >;) ffffffffgfhigjk


















 !"# $%$! &'()*+', , -!./ 0123456789:;<48=> 0?@8A > 9@865;899B8076C123D8E 012345678F<G<H678933<3H65H3E A <2171338I65;31HE 06G123E F<G<H678JH<778B6K 126E L5MN1HOP:QQ71RS1H802<5H12E > 45<H423T".*U"-)'!"VE W0X98YZH<K <[1;89\> ]^ 8W6K <7C8024_13342E B4K Z6H<Q718` <Ha89\> ]bF> LRJ^E ?cOdeRP<H8\LJB892_a<H1_H:218=9\> fgbD8E ?cRP<H89\> h8L53H2:_H<458J1HE deRP<Hba:K Qh L53H2:_H<458J1H8E ?cRP<H8i5<j<1;8P:38L5H12j6_1E ?RJH6G180<Z17<518E ?cRP<H89ki8E ?cRP<H8> 1K 42C89;;2133<5G8\65G18E JH6H<_8YZ126H<45E lK Q1;;1;LBlR\b^ 8\167Rb<K 18F1Q:G8i5<H8E Sb9X8L5H12j6_18i5<Hm"n"op)VE W:77C8LK Z71K 15H1;8<58W0X98W6Q2<_E 9778> <_24Z24_133428LOY389f6<76Q718H48i312E i5<j<1;8P:38L5H12j6_18J<K Z7<j<138J4B8F13<G5E 9\> 865;8ba:K Q8L53H2:_H<458J1H38B658P18> <q1;rs# *+'tt !)"&*U-, pup"V*E 0249JLBh?8=> ]9?0D8E 0249JLB?l8=> ]9?0lD8E W:3<458=> ]9WJD8+.n)v"VpV*-n&*+p, 'u-)p n*+'tt !)E F<21_H7C8 J:ZZ42H1;8 `<Ha<58 Ha18 9_H178 k<Q124hL5H1G26H1;8F13<G58l5f<245K 15H8=LFlDE JC5Ha13<3w8JC5Z7<jCh865;8F13<G58B4K Z<712hE J<K :76H<45w8x<H67RB4K Z7<65H8xIFk8J<K :76H423865;YxLRB4K Z7<65H8x12<74G8J<K :76H423
y"!pop(-)p n*-n&* , tup-n("E B4K Z7<65H8` <Ha89\> fgb8LJ9E B4K Z6H<Q718` <Ha89\> ]bF> LRJ !"*y"!Vp nE ba<38 F6H63a11H8 F1j<5138 Ha18 W:5_H<4567<HC8 j42B421> 0]8fdz{z
|n)! &'()p nba18B421> 0]834jH8L08_4218<386589\> ]8j6K <7C8Z24_133424ZH<K <[1;8j428:318<589_H1789\> R216;C8W0X93865;8<3_4K Z6H<Q718` <Ha8Ha189\> ]bF> LRJz8i312383a4:7;821j128H4Ha18}~  ~ =FFL{c?g9R]b> LJR\gzZ;jD@8Z:Q7<3a1;8QC8Ha189\> 8B42Z426H<45@8j42;1H6<71;8<5j42K 6H<458458Ha189\> ]z8ba189\> ]8b\> 8<36f6<76Q718j428;4`5746;8j24K 8Ha189\> 8`1Q3<H186H```z62K z_4K zB421> 0]8<383:ZZ7<1;8` <Ha86589;f65_1;8> <_24_45H2477128P:392_a<H1_H:218=9> P9D89;f65_1;8I<GaR012j42K 65_18P:3=9IPD8_4K Z7<65H8` 26ZZ128j428<5_7:3<458<586589> P9RQ631;Z24_1334283C3H1K 83:_a8638Ha184518G15126H1;8QC8Ha189_H17B421B4534718L08F1Z74CK 15H8076Hj42K 8=LF0Dz




   ! "#$%&$'$( ) '*$+,+& -$./01%2-$34! #$5'6 %*76 %8+8 &&$29'2$55 &$9%(9$+ 56 ')8 $'):$*;+; $8)&,6 +2%)<$=9 $34! $'89%2 82, $%&$1'& :$)4 :,8 :$>)&2,82%)$? 2$6 +,2 $@4>?A$+%)8%+* &<$=9 &%6 +*%8%27$5$4>?$ &,*2&$%)$'$9%(9$%)&2,82%)$29,(9+,2'):$5'&2$ '*02%6  $%)2 ,+2$ &+)& $56 $'$&6 '**$'):8&20 55 82%B $+8 &&$8 <$"%+ *%) $2 89)%C, &$'  6 +*7 :$&$29'2$'**$+'2&$5$29 $+8 &&%)($'):$6  6 7&7&2 6 &$8')$+ '2 $8)2%),,&*7<$=7+%8'**7-$;9%* $) %)&2,82%)$%&$1 %)($ D 8,2 :-$%2&$&,88 &&$%&$1 %)(: 8: :-$'):$'$29%:$%)&2,82%)$%&$1 %)($5 289 :$566  6 7<$=9 $ ! "#$+8 &&$'*&$%6 +* 6  )2&$29 =9,6 1$%)&2,82%)$& 2-$;9%89$6 'E &$%2$%: '**7$&,%2 :$29%(90B*,6  $'++*%8'2%)&$;%29$6  6 7$ &2%82%)&-$'++*%8'2%)&$;9  $8: $: )&%27$%&$')$%&&, <$=9 $FG01%2$=9,6 1$%)&2,82%)$& 2$'++'89 &$2;%8 $29 : )&%27$5$&2'):':$34! $8: $;9%* $ 2'%)%)($6 &2$529 $34! $+ 56 ')8 $':B')2'( $B $'$2':%2%)'*FG01%2$+8 &&$,&%)($FG01%2$ (%&2 &<$=9%&$%&$+&&%1* 1 8',& $=9,6 1$8: $+ '2 &$)$29 $&'6  $./01%2 (%&2 $& 2$'&$34! $8: <$=9,6 1$8: $%&$'1* $2$ :,8 




 !" #$%! &'' !(!&)*&*+!,& !,(-./+-&*) -(0.)(1!(2 '(!)00+'*!(*.)-*/ 00 3)-1/)1+!'45  !" #$60 &7.)(1!(2 )'' 3-)-8)1+!9:5  !" #$& !)'' 3-)-8)1+!; -%(1<:5  !" #$/+-&*) -(0.)(1!(2 )'' 3-)-8)1+!= -%(1>:







 %! &'' !Y-*!/(&W)1-(0'
_2 6...Y_kX" (&! &00

























H PKI?P@HFOCJNKQG?CHHFOKLHFOFKIG@HFOG@HFOIRIHFOIRSTUHFOIRSVUHFOIJHFOKJOSTUHFOKJOSVUHFOP  KRHFOP  R
HFO@IJHFO NHFOHCHFOKNHFOHPHFOHPIJGHHKSWTXVUY HGGSWTXVUKHGGSWTXVUGFPKY KCINCZISTXVUKPSTXVUKGJNSTXVUKGJNP KILNILFCGF
N[A\I]  CI K^NAH DGAA
 ] [CA
 ] [ ] CA
EACA
GK 




     !"#  $%&$'(%  " ")((*+   " ",&)%$-    -(*""  ../01234  ())((./01234 5 .)) 6 5  &&$&*$*&7()%&89 6+ " 5 + ,&:7()%&89 656 5 5$&);$<7()%&89 6.# 5 + ,&:(%(7()%&89 6" 5 *(%()) 6 5 6&$&*<,,&). ! 5 ($'&8%) 5+ + = 5 " "$&,,*$(*&$<(%$*> 5+ + = 5 " "$&,,*$(*&$<(%(,*"=" 5 "?$)7()%&895"# 5 5(%7()%&89#/1234 5 " "(&5 5 " ")((&#@.A 5 "+ $*&>(%*)*)*$(&+ 5" 5 8<?)((,,&:($$*;&%%&8):(*(%)((,,&:($$A5 ! 5 A&$')(($*&&(*&65/1234 5 )*$($&)B)((B&*>*%%>%C"/1234 5 + ,&:($$8*)<.# 5 #?(($*&:7*BB9D ../01234 5 D *)((D " 5 )*$(8*($$
EFGHIJK L MNOPQRSTUVWXNYZN[PVSS\][PZNP^U_`abc  def ghijfkjl




    !"#$ $ %&' (&!)&%$ $ &*$ !+,!- .!&/ 0123#((!& ")+ %,%4%,%5," 67/89: ;<=: >?@A<BCDEFCGHA9BIBJBECBA: GEKGHL%4%,%5,-!&+!M",!%+% MMM2%&$ 2!$ N%"+ 89: A8JCDFOBCOKJB9BIBJBECBA : GEKGHPA MA %" 5 (#&%+ % MMM2%$ %'!"2!$ 2 .!&/ 01 (&!!& $ (,$ "    67/ 4Q%&  #& %"+ ",#+ 5!    RST5  67/" &# !" %"+ UVT5 #$ 5" &# !" 2WXYZ[\]ZZ.!&/ 01(&!!&% M!!(&% ") % ^_` abcdce RST5 fM!&+T%,)"+67/ " &# !"%&g# +"  % 2hijk labcdce UVT5 f%,-M!&+T%,)"+#$ 5" &# !"%&g# +"  % 2m"#$ 5 % f 0&!)&%$ .!#" &AL0.N#5 U !, 5 M"%, &"% %,-M!&+2nce&%" !"5 M"67/ %"+#$ 5 % +!"! %--  (&!!&$ !+!& &) &!" " 2]o [ZWp[\]ZZq!#%"M  !(&% ") % !- .!&/ 015 M"67/  % %"+#$ 5 % #") rs" &# !"2   +&5+ -#,,t "   89:8JCDFOBCOKJBA9BIBJBECBA: GEKGH26,,g( !"%"+,")(&-!&$ +"67/  % 2m-%"g( !"!#&"#$ 5 % f (&!!&&4&  !67/  % 2 &%" !"5%u !#$ 5 % !#&%# !$ % %,,t!"& #&"2  vw Z.!&/ 01(&!!&4M$ $ !&t%%,"%&!,, !"!-5t f"#$ 5&+"%"+")!&+&-&!$'&! ^x rt y !R!,+ -&  !&+M!&+2x rt Q !1!,+ !"+ !&+M!&+2x rt z !UU!,+  &+ !&+M!&+26, !#)5! {  ,|"+%"%"+r)|"+%"$ $ !&t-!&$ % %&#((!& +f &!$ $ "++ % t!##{  ,|"+%"-!&$ % 2}Z~vY.!&/ 01(&!!&#((!&  -!,,!M")+% % t(^x  !&+LRST5 Nx %,-M!&+LUVT5 Nx rt LzT5 N




 !"#$%"&'"()(*+),- !+ !,./$.'01'2 34%($5$(.%4%)(*+5),(".'(6."#-7$88'%9 :1'".$($ !$$($8;0"0'-<% .'0'(#( &$(*# =  !>/.: !>?: !>2?: !>$&:$(# !>"(#= $9 8$81"#'%'8#%"(/$8"'2 34%(("0$(#6.0'($:'4%(5)(".'($6."#4%(("0'6.0'('"(-
@ABC DAE 3%'8#%F'$9 G'"(+FG,-H(7I $:&J KLM'2 3$N'-5JO KPM.'($(%FG-H(<%"9 &$:&JLMN'-5JO K M.'($(%FG-H(0/8#9 '#:$('%:%Q$/#F'$9Q$"+QFQ,:$..&8-<%.'($(%.'(#'(.'#28$:$(#%9 '#&$/#$$"8'2%6.0'(%$.$"#(1'%."(9 '#-R"!%'4%7I $-
STUVWXYZ [ DA\ @]^ B_BA` a\ bB
a\ bBcBdBe@ABC DAE
a\ bB@ABC bBE
L PO!3fghi L   P O ! 3+FG,
jklmnopqkrpstuvpr
GFQ
L PO!3fgh>2?i>2? L>2?  >2? P>2? O>2? !>2? 3+FG,
GFQQFQ>2?
L PO!3fghi L   P O>/. !>/. 3+FG,
GFQQFQ>/.
L PO!3fghi L   P O>$& !>$& 3+FG,
GFQQFQ>$&
L PO!3fghi L   P O>? !>? 3+FG,
GFQQFQ>?
L PO!3fghi L   P O>"(# !>"(# 3+FG,
GFQQFQ>"(#




  ! "#$%$&'(#$&#$(#%# "#$)*$+,- #$%$#$./&)'&%! ! &%#0(&1$%11##$)$*)22)3(4'56 7('$'4&%2&'(#$&#8&9:&;6 <=6 +>$%1?<)(4$&@><A6 +B(4?,'(#$&@B,A6 =<>,&%&"%4?0><#8B,#8%40><>,#*)&%1/&(C(2'0! )0. ! "#$%$&'(#$&#$(##)34(4D(' &E.










=<>, =<>,><>,]*(^ =<>,><>,]#C1 =<>,><>,]%"$ =<>,><>,](&^ =<>,><>,] 40




   !" #$%&'()&'*+ ,)-./.()0(12-.(0-)0(3/.().4).'()567 )-./.()0(12-.(0-)28).'()94334:281):/;<)= &'*+ ,)-./.()0>?0@)/8A)567 )-./.()0>?0@)/0()2A(8.2B/3C)= &'*+ ,)-./.()DEF6)/8A)FEF6G)/8A)567 )-./.()DEF6)/8A)FEF6)/0()2A(8.2B/3C)= &'*+ ,)-./.()FE)+ /H-)48.4)567 )-./.()0IJC)= &'*+ ,)-./.()K6)+ /H-)48.4)567 )-./.()0ILC)= &'()&'*+ ,)-./.()ED)+ /H-)48.4).'()567 )-./.()ED)M0INOC)&'(-()0(3/.248-'2H-)/0()-'4:8)28)P21*0(QC
RS<)6(12-.(0-)0>?0@)/0()T84:8)/-).'()34:)0(12-.(0-C)6(12-.(0-)0U?0IN)/0()T84:8)/-).'()'21')0(12-.(0-C)VWXYZ[\] ^  $_!" #$% $%
!" # %`%a%b%c%d%e%f%g%h%i%a`%aa%abjkl%m%acnok$%m%adnl%$%" p!%m%aenp!%%l%$%" !$%mplnq l%$%" !$%mln
%`%a%b%c%d%e%f%g





  !"#$ %& '"# '"()*+(, * !%-. *(/ 0+1 -%-., 0"# 2'3)+"( *(/4#, )" 5,6  3#"7#*8  ,)*)5, #7+,)#, )0"44"9+(7: ; <"4/ ) '"(/+)+"( '"/ 04*7, ; !"()#"4 ) (*=4+(7 *(/ /+,*=4+(7 "0 +()##53), ; -) ) 3#"',,"# "3#*)+(7 8 "/  *##*(78 () "0 =+), +, ,"9( +( >+75#&6
?@A@?ABC DE FE !E *(/ G =+), *# ) '"(/+)+"( '"/ 04*7,6 H"5 '*( ,) ), =+), =I *#+)8 )+' *(/ 4"7+'*4 "3#*)+"(,6 04*7, '*( *4," = ,) =I $ -. *(/ JK$  +(,)#5')+"(,6  !"#$ %& 3#"',,"# ),), ), 04*7, )" /)#8 +( 9)# )"2'5) *( +(,)#5')+"(6L44 +(,)#5')+"(, '*( = 2'5)/ '"(/+)+"(*44I +( L.$  ,)*)6 M( 58 = ,)*)E "(4I ) N#*(' +(,)#5')+"( '*( =2'5)/ '"(/+)+"(*44I6 >"# 8 "# +(0"#8 *)+"( *="5) '"(/+)+"(*4 2'5)+"(E , ) OPQ ROSTUVWXTWYSXRPXZXSX[TXQ \[Y\]6 
_^`abcde f  B 
!"(/+)+"( !"/ >4*7, .,#1/ !"()#"4 N+),
g1#04"9F#"D7*)+1 "# J,, *( $ "/ N+),-)*) N+)>Mh K+,*=4M.h K+,*=4








  ! "#$ %& '(& )"!"%$)* $+ ,$- ./ +$ !(( - / 01%2* 32'" +$ " - /45.678 #%2 $)(9 *:''$"* ",$- ./; 1!%!)"<  :"%(%=!"%$) !)0 '+$& !)2 $+ " 1!%!)"* ! *$#) %) !>(? $) '!@6<
 AB ,$- ./;0 %* 2$)+%@:0 #%" !(( +!":* $+ "4C- /D- EF;<  1!%!)" %)2$'$!"* " +:(( 0>:@+:)2"%$)!(%"9 $+ " 4C- /D- EF; !)0 %* +:((9 2$& '(%!)"#%" C!(G%# CGD;H CGDIH !)0 $" 4C-  *$+"#!0>:@ "$$(*< A ,$- ./; %* $'"%& %=0 +$ & !3%& :&  *'0 !)0& %)%& :&  !!H !)0 !* " *!&  +!":* !* ,$- ./;032'" "!" %" 0$* )$" %)2(:0 " E,JFC 0>:@ >($2KH" 4. 2$)"$((H $ " 2$'$2**$ %)"+!2 !)0 %*L%""( J)0%!) $)(9H "$ 0:2 " *%= $+ " 2$< %*& !)* "!" " *"!)0!0 0>:@ "$$(* 2!))$" > :*0#%" "%* 1!%!)" $+ ,$- ./<MNOPQ%* %* " & $*" $>1%$:* 2!!2"%*"%2 $+ " ,$- ./;1!%!)"< $ 0:2 !!H " D>:@ J& >000E,JFC& !2$2((H " J& >000E,JFC 4. 2$)"$((H !)0 "*2!) ($@%2 !1 >) $'"%& %=0 $:"< %* & !)* "!"*"!)0!0 *$+"#! 0>:@ "$$(* 2!))$" > :*0 #)"* 1!%!)"* $+ " ,$- ./ ! %)*"!)"%!"0< R** $+"* 1!%!)"* 2!) :* " 2$& '!!>( 1!%!)" "!"%)2(:0* 0>:@ +$ 01($'& )"H !)0 #) "!''(%2!"%$) !* >) +:((9 "*"0 !)0 0>:@@0H $) $+
"* 1!%!)"* 2!) > %)*"!)"%!"0 "$ 0:2 !! %) "+%)!( *%''%)@ '$0:2"<MSTUVT 2$'$2**$ %)"+!2 %* ! !(9 :*0 +!": %)4C- / +!& %(9 & %2$'$2**$* !)0 !* >) & $10+$&  " ,$- ./; 1!%!)" "$ & %)%& %= !!< WXYBZX[- $*" & %2$'$2**$F>!*0 *9*"& * :* L%""( J)0%!)>9" $0%)@<  $'"%$) $+ *(2"%)@ \%@ J)0%!) !*>) & $10 +$&  " ,$- ./; 1!%!)" "$ & %)%& %=!!< Z]^S_` Pa BO[_QbXTc$ & %)%& %= " !!H " ,$- ./ 1!%!)"* & !' "'$2**$ @%*" >($2K %)"$ $)F2%' C4- < C4-  >($2K*:*0 "$ %& '(& )" ,$- ./ @%*"* ! )$ ($)@!1!%(!>( +$ :* %) :* 0*%@)*<
defghijk l `_ mN U]A
4C- / ,.R ,$'$2**$;%@)!(*D!"!400**\:* ,$)"$(;%@)!(*




  !"# $%&'()&*"(+'+'"&'!,,&)',"!- ./0.)  !" !1'!) 2$ 34)!5- 1. $)+.,!"-  623$7(*)!4- 1..!!)8+1(.',&)'+"(&"0.)5&- 4!".(&1.!.3'&91+1(:&- ;)+.&!1,!)("',!";'&1./0.)<&="!23>?$@/.!!)';&.A !"# $%,&)'0!1'&'.!,.B?# ,&)'+1(.'.C"+44"8/DBC"+44"8+1(./%:'0;"( 3B,&)8C&0&'&1'.+1.&+.(!1.;'"(*&0+.4"!9"+- - &19AEFGHFIJ 3;"&19.(*)!4- 1.!,+1?$@/K=+'(:! 8+1;- ="!,'.+9'!,.'.&19- +5=;1(".+L1A&'0+1&1*!)*'!- 8!"+))8!,.,!))!C&19+44"!+0'MN D+"(C+"'&- ;)+.&!18;'&19O"&)!9!"OD3<N :!,.C+" '&- ;)+.&!18 ;'&19 + !'.K=+'(&1'.";0.&!1 '. '&- ;)+.!" 62::7 !, . :! P'4"!0''!"N D+"(C+"+1('!,.C+"0!K*"&,&0+.&!18;'&19+,;))5,;10.&!1+)- !()!,.4"!0''!"&1O"&)!98OD3<8!":Q 2?,!"- 8!";'&19+.!!)';0+':+- )''3;.!."+4&(4"!.!.54&190+4+=&)&.5!,?$@/'8!C*"8&1.9"+.&!1!,+"(C+"+1('!,.C+"!,.1!00;"'+")&"&1.:! (*)!4- 1.050),!"?$@/.+"9.'.+1&.C!;)(,!"/:2 .+"9.'A",!"8+"(C+"+1('!,.C+"0!K*"&,&0+.&!18C&00+1=*"5')!C8&'1!.+0"&.&0+)&'';R04.&1.- !'.0!- 4)R?$@/K=+'(:! 'A4)+11(+*+&)+=&)&.5!,/S# K=+'(:! '!);.&!1'.!/0.)?$@/0;'.!- "'10''&.+.'.+./0.)4"!*&(';44!".,!"..'.+44"!+0'('0"&=(+=!*A214+".&0;)+"8."'!;)(=+1- 4+'&'!14"!*&(&19'!);.&!1',!"+"(C+"'&- ;)+.&!1+1(,!"'!,.C+"'&- ;)+.&!1A/'!,.C+"'&- ;)+.&!1'!);.&!1&'+)"+(5+*+&)+=).!0;'.!- "'+'4+".!,.4"!4!'(/S# 4+0L+9A&'4+0L+90!1.+&1'.S+)O&C21'.";0.&!1:.:&- ;)+.!"8C&04"!*&('/S# %&1'.";0.&!1+00;"+.'&- ;)+.&!18+'C))+'4!C",;),+.;"'8';0+'&1.9"+.&!1C&..S+)O&C(=;99"A:;44!".,!"+"(C+"'&- ;)+.&!1&'+)'!4"!4!'(A !" !1'!):! 0!1,&9;"+.&!1;.&)&.54"!*&('+- +1',!".(*)!4".!'.&.0.!9."2$=)!0L';'&19+=;',+="&0!,0!&0A2.91"+.'+'5'.- .'.=1080!1."!))(=5+'0"&4.K("&*18=;',;10.&!1+)- !()6B?# 7!,./S# %4"!0''!"A/S# %B?# +))!C'.(*)!4".!- !())!CK)*)=;'."+1'+0.&!1'8C&0+))!C*"&,&0+.&!1!,0!110.&*&.5!,.*+"&!;'2$=)!0L'+1(.'5'.- - - !"5- +44"'1.(.!./S# %=5."'.!,.+"(C+"A




  !" #$$#%&'()*+!!  ##'%,!$    -$./+ 0)*+ 1, -$21'*#34#)*+ '





+  V ./+ 0Y.Z))#TT/.+*





56789:;^ _ = `ab AaJ?c AdeRfgRF
.%&V.-T&%/%(1 W%!
)*+ U#*TVT ()*+ (T!




 !"#$%&&'! !()* &+,- ./0- 1/0- 2  ")+,- .!(3$'14%&())*52  ")& )) 6!7$'7!()8
9:;9<;=>?@?ABC D=E=9F GH/0- 2  ")%!I& #I%! 2 %($)6+,- .J- KI41()) 62  ") $"# %%"! %((6 ')"$ '%"$*+,- !L#) 7MLNJO*2 $!1ABC D=P<=9;=A:$'*)2 !7& #+,- .!(3$'7!()(#%&"!QRS TUVS WXUYZ[\]Z^ _XRY Y`aY\ZYXS ^\b^_1/0- 2  ")$'*)c()*1d:GeK! #"# %# 3"(2 %)(!"c!$)2 (!2& #%# 3"!72 ') /0- 5(/0- #%!7)(!7'(7"&!"fg/0- 4#%O(!7'(7g !h1#%!7)(!7'(7(!!(6# *2 # '#5#("&# 2 *2 # '#f6 #6 'i!7 &c%""((h5(!" 6(& #3!1d;jk9l;me/0- 73(%(M&()!"( !(!" &(#'!1$(" !6#(!* &c%""((#("i&()" #! 1no;<</0- '%% #$ $7(!"))I!"(!2 2  #* !&7'#( !10 #$*(!"()&6 #"#(!&#5#("(!"6#"((&# 2 M (%%# %#("(()(!1p;::G=dGG:/0- (($)* 6(& ## &6 +,- .!##'%)! $#77#"5$& #%# "!76#2 (!"# &#%1
qe=;=r;;:/0- 7!#( '%'2 (7  ! ) &2 ')( !  )(!"() 7!#((%)(!c) 7&)1PC =d:G=qee;& )) 6!7#% 2 2 (!"(#"&!"& #'$*/0- 8F ;F F G 2 2 (!"'" ( (()($)5#%#!!7(*2 # '#56(2 2  #*2 (%) ( !1 #/0- #% 2 2 (!"2 (*%#& #2 ( ) ( !6!# '#$*#&#!!7)($)(!"(#7# &&#)(3 $((""#1ds2 2 2 (%# '#t!(2 $(t(""#uvwxyz{| (#!7 !(!!7'#I&#!")*!(!!(2  &# '#$!7("10 #/0- #%7!#("(' 2 (())*$*} #} ! )5!(2  ##% !" !(!!(2  &( (" #!7!#("'$*2 L#) 7 #LNJO1~{vy{vv$((""# &# '#5!c("2 ()1 :; 2 2 (!"('/0-  %#& #2 (6# (%&" &&56!2 2  #*2 (%#(!7 &(%&"*2 # '#1ds6#6"# '#t!(2 $*t &&"((u (i !!'2 #("3()' & 5N5 #/5& #6 #"5()&6 #"5 #$*1vwxyz{| (#!7 !(!!7'#I&#!")*!(!!(2  &# '#$!7("5("&!"$*'#!2 2  #*2 (%f6!!%' } #} ! )h1~yv &&&# 2 $( &# '#5!$*1K%&"((c("2 ()3()'1{{"(( $6#!1K%&"((c("2 ()3()'1nsF G;6# 3" } "u




   ! "#$# #$"$$$%&  #' "#($"$' ##)*+,-.#&##/ 0'/$$12 34567 #89$: %;%#%$#&#%9$&#%#0')<=>?@AB #((#C$#9' $##0(%$0'#  #' "D&"E#E9F)GH5?II<5$$$# 0$##%0')J"$K 989)L.M NO#: 8EPQ1RSRT   ! "#$# #$"$$$%&  #' "#($"$' ##% "##89&K"89"#8)*+,-.#7&##/ 0'/$$12 34567 #89$: %;%#%$#&#%9$&#%#0')<=>?@AB #((#C$#9' $##0(%$0'#  #' "D&"E#E9F)GH5?II<5$$$# 0$##%0')J"$K 989)4A5AK"#)J"$K 989)L.M NO#7: 8EPQUUPPVVWW1NXOO  9'#"$99#Y890)  99&# #0$#0 7)99&%$#K "9%"99&($##'00%&9(#(89$#090(#)




   !"#$"#%&'%&(  )'**+,!$#-"#( ''&.$/"*0!!1'"  $.&'% 00*%2'".&$.&'32&%$$#"$#%&%( ". &-#"( &#' )!*"!10)4567 89:; <=>7='$#"?0'% @%( $*.'!%'"-&AB C 4@%( $*D"E.'0 &''!&" '&'%( %'&%&'",  ).#F" $%)GH4I &''2'&( +&0?*"$##J.#'&,"A!&*IK!"#'L& AEGM/GMM% 0&E"#NAB4OPQPRSSTUVS=E"#E" '"*%'%!!''&"%0%&%3%'"-A!&*IK!"#'% 0%*'&"-%&&#3.&'-"#%!!"#4'%&&#3.&'%#"#)% W0%!!"#0 )&"&DKIBI'$!-!%&" + X Y4"#@%( $*+ &!%'"-&E"#NAB+&%&&#3.&',".*0 0!%&&%&&#%#&##)'&#'+%' %3*Z4
%'0" &'%&&#3.&'+E"#E" '"*!% 0&#(  &%&, ) #%& )& '!#$&+&#%#&#*"!%&" '!"##'$" 0 )&"&NAB&%&!% 3%!!''04I &'!%'+ " "-&#)'&#'%#B[ +'"&# ,**  "& 3 % 2 '*-\!!1 ) &%& !%  3$#-"#( 0 -"# & NAB4 ]?#&*''+ & 3.'&#% '%!&" '0"&%1$*%!% 0&!2!*'( %23?,0 %,%?-"#( "-&'( .*%&"#4;  ^T_; 780') #( .'&-0 &( ( "#2( %$"-&D"E&"E"#E" '"*4`.# )&''&%)+&%3'"*.&%00#''#% )'"-&?%#".''2'&( #'".#!' &AB C( ( "#2( %$%#-0 4A*'"+.'#\-# 0*2 '&% ! %( '"-&'#'".#!'%#-0 4"#@%( $*+&.'#!".*0-0&( ( "#2( %$ -"#( %&"  &"E"#E" '"*&%&')?  %3*H4%'0 "  &  -"#( %&"    %3*H+ E"#E" '"*) #%&'&D"E'.3'2'&( !"##'$" 0 )&"&A!&*IK!"#'$#' &4I&%*'") #%&'% '!#$&+,!%!!'''%**&#)'&#' &A!&*IK!"#'4
OT^ a==^ T>^aI &'@%( $*+&.'#'*!&'% AB C%'&$#"!''"#"-!"! E"#E" '"*4  &''$!-!%&" " *2#*%&'&"AB C49V=:7UTaaS^ .'#( %2'*!&" "-% .( 3#"-3.'-%3#!' E"#E" '"*4"#@%( $*+&.'#!".*0'*!&A AAb\Y&4b",?#+&''*!&" '##*?% &-"#&AB C +%'&'!" !# 0" *2,&) #%& ) %&?AB C3.'3%'0&#% '%!&" '4RVS^  7Sa9:; aT8SSA&&'$" &+%? )#. E"#E" '"*&"!"( $*&" +% '!#$&*&'%?%*%3*4',".*0*""1'"( & )*1&-"**", )LcdefghgiecjgklmcnjdghgiecjgogpplcdefghgiecjgqlmcnjdghgresgtkguulcdefsvdswghgresguulQV9:;0?*"$#!% #. & ,&&%.&"( %&!'!#$&"#0&&'!#$&&"$.& 3.'&#% '%!&" '&"/-#"( % 2 ,*")!&%&%'3 %000&"&D"E4"#@%( $*+&#% '%!&" '&"/-#"( &#)'&#' & ,x0"E"0!3*"!1!".*03%0004 '1*&"  '2'&( \*?* &'&3 !+ ) #%&0 32E"#E" '"*+!".*0%*'"3( "0-0+&"%00'"( @&# %*#'".#!'y4)4+( "0*'"-DDBA % 0*%'z% 0'"( )\*?*&%'1'4N$" #.   )&'2'&( '( .*%&" +( ''%)'%$$%# &!" '"*, 0","-&'( .*%&" &""*4
{|}~  >^T<RQRSSTUVS=          ¡ ¢ £  ¡  




  !"#$%& !"'()(& ) *% )+ ,-')  )./0 012302 & !"4(")(& () 5!!6"7)8896"7)8: !'(":;96"7)8< !'(":;96"7)8= !'(":89(!46"7)8> !'(":8.3??/0 012










  !"##!$%& %'(%#%'")*++,!"&  )$'##-)$*(%$%#. "$+$-$$ !"##!%'$!,-"%#& %$$+%'& #$+ )/& '$#,$!0 123
456 789:;<=>? @  
789:;<=>A @ 456 
BC1D1E
1')1'0 FGH1IGH1'J11'FDKI1EL
$%#" #$-!$ $%" #$-!$$M" '% $" '%$M" "%) $" "%)$M" "%) $" "%)
BC'NLH'LFH'FGIGNOELOGKP





  !" #  
$%&'()*+'()(*,-&'(),./01234'()-$&5'()$67 7 /.5'()$67 7 *.'()*8)01234
9:;<=>?9@ 9:A<=>?9@9:;<=>?9@ 9:A<=>?9@9:;<=>?9@ 9:A<=>?9@9BC<=>;9DE9 9BA<=>;9DE99BC<=>;9DE9 9BA<=>;9DE9
 !F #  
$%&'()/$&,8'()/7 G5'()/'H
'()/'6








   !!"#$ $$%$&' $( $"%%$) * $ "%+'"",$& !  $&-$#.,-/#$ * %0 $ $12&33 4 !"&"&!& $ " "5*3$ ! "6!*3$*&1 "   !!   !"& "&!  $ &! &!  $&!* %0& $  $1&!  $&!"( *$& $"&*4*#&*&$&  0#$3&!  $& " "!&&! *4 $$ !0! 7! "  "&  ("7 &*4 !"'*4 $ "&*1 "  "! "% 0 $( &!  $&!" "!%$)*!#*$ $( &!  $&!" !0! 7!#*.3$("7 #%43"!! $"&( &"%7 7 $0)"!5*/13"  "  *!" "%%0!& ,-!"&"&! $"!! $!$3&$7 #$ "& $ !4"! 3$& &**7 "&!(" %0 !"7 1!$%*! %%! *) "7 $& $#$"7 &&&$&  " !0! 7 $) "&&!  $&! !7 %" $ " &!$& *$! 12&""! *&&'$&7 & ! !"7 1
"*'"& "!$3!& ,-#$ "89 :"*)""!!5*0"!0! 7 3$ ! !6!*3$*19 ;$! " "&*!0! 7 ! " "&("7 &*'" ,-#$ 19  " !0! 7 *$!&$ "' $&&&&$* $! " *17 $& $#$"7 3$("7 #%5! " !$7  " !$!"&&&&$*3$ 7 $& $#$"7  $&19 "* $&"% "+#$& ! "&* )" #$& ! ""'"%"%19 <&6#!$!"&!##%7 & *19 =$("7 #%4    !!"&$&6#7 "$6%% $&"& *&3"% !"'"%"%19  !#""  >  $ $7 7 &"  )   7 $& $#$"7 !&$ 5*1*&$3  " !0! 7 5! 3$%%$)&89 ?;$! $7 # &&&@ &*$)! $& *!$3 )"9 &A7 ***2;A?$ $$%;$&' 4"!#"" $()$&' ! !"%& 3" $!&"%!$7 #" %)  ,-& 3""&*" " !0! 7 ) ",-& 3""&*"&   $7 #%"& $1
BCDEFGHIJIK ELMNOKPBQBNPKRSTNBPKUVWXKYZV[KZRPRSOK\]^ _ ` abBcdEFGeIfK gRPRSOK\]^ _BVKXLMNOKhVSBZVWKiQWRXK ` jab KBcDEFeIfK ELMNOKhVSBZVWKUVWXKBR[LKYZV[KZRPRSOK\]^ _ kab K `BCHIeflmn opq\^rsKRSTNBKPLBNTKBVKZRPRSOK\]^ tab u `BCDIelmnK opq\^rs_RSTNBKUVWXKYZV[KZRPRSOK\]^ _ ` abBCHIeIfK opqvwKopqx y_RSTNBKPLBNTKBVKZRPRSOK\]^ _ z{b K `BCDIeIfK opqvwKopqx y_RSTNBKUVWXKYZV[KZRPRSOK\]^ _ ` abBcdIEcK gRPRSOK\]^ _BVKopq|_iQWRXK ` }ab KBcDIEcK opq|_UVWXKBR[LKYZV[KZRPRSOK\]^ _ kab K `BcdEFGHIJIK gRPRSOK\]^ _BVKXLMNOKPBQBNPKiQWRXK jab K `BcDEFGHIJIK ELMNOKPBQBNPKUVWXKBR[LK kab K `




     !"#$% &'& #(&#)( *+,-) ./ ... ))//+, ))..)..012345678,..-../-)//+9 :#;:)<//)-+=1>2?78,.. .$ /(@A /.+=1>4 578,./) (@A:#;:-.  )+













    !"#"$% &'"($"$  $()*+ ,-.+ /01234562782-59:;<9=>*5?545;952+ =;@=>ABC% DDEFGHBIJ" KBC%L J( (M((M($(N($ N N$% &'"($"$"  (OBP$( ( #(  $N"($"$"   $  $% &'$N (   ((( "  $( ($(Q #$$% &'N    #$(! ($ $ J$($( (" $ $NR$#($ $ ($$(  ($% &'$NS" (( ("$ M(" $$(   (M(" "$$K(($($  " J((" J(  $ ( NBK( ( Q (  M("    (##   ($ N $($ $(#"$( ((ANNJ((((  I$($(QANNJ( $"#IN( ($(Q (  "(TU  (  "  ( ##$$% &'  NVBW #"(K $X"$    "M  ( ##$$ (N








  !"#$%&#'()% (* +,$%&#-+.% ( (!"./0(0!"#'()% ()%"$%(-1+23%/$()% (* +,45%/"((0#%0%6"%0)% ()%"$%(46'!.'!$!7(&% & ((#8'##98::6662.#(2.%; :./$#$/9:/90#($:.% (.%"$%(:2<%/."$% (=/($##'#)% ()%"$%()1>6'!.'!"./0($)% (* +,?7(; !(0#%5%/2@ABCA3'(&%%6!"D#7(!$#$. !#!..'"D($#'#6( (; 0(!"#'(./  ("#( $!%"%&#'(0%./; ("#2
EACBA-"% 0( #%9 %!0(#'(#($#!"&% ; #!%"#%0($!D"( $4$%; (0#$'((#$ (9/7!$'(07(&% (0#'$7(("&/5.' .#( !F(021#$'((#$ (0($!D"#(0$G+ %0/.#H !(&4GG0".(04G"0G+ %0/.#!%"2G3'(0(&!"!#!%"$%&#'($(.#(D% !($ ($&%%6$8IJKL3'(9 %0/.#7 !(&!$$/; ;  !F(0( $!%"%&"0".(0% 9 %0/.#!%"0#$'((#.%"#!"!"DD("( 9 %0/.#!"&% ; #!%"23'!$7 !(&$/; ;  !F($$9(.!&!.0(!.("0&; !5!"&% ; #!%"&% /" (($(09 %0/.#$2MNK3'!$0#$'((#( $!%".%"#!"$!"!#!($#!; #(0!"&% ; #!%"7$(0%"$!; /#!%"4%#'( 9 %0/.#$40(!.($4% $9((0D 0($23'!$!"&% ; #!%"."7(/$(0$($#!; #($47/#"%#&% 9 %0/.#!%"2O PQRJKS3'!$0#$'((#( $!%".%"#!"$!"&% ; #!%"#'#!$.%"$!0( (0#%7(&!"2

TUVWXVTY  Z[Y\VWTYW UY]WXVTYW^
_ [\a`bc defghijkeljmnoephojkqprjstuvwwjqxyz{|epqzxb adrhj}~mljtmxpqzxegj zohg}jlhpqzxjkeljmnoephob ia`ba drhjoepelrhhpjkeljmnoephojpzjqxgmohjtmlqzxjoh` qhlb sdefghijkeljmnoephob adrhj}z{h je{qexpl}jlhpqzxjkeljmnoephob ica`bi defghijkeljmnoephob aa`bw drhj}zjzn{zhllz{jxph{yeh}jlhpqzxjkeljmnoephob icdrhj}qppghjxoqexjxg}jlhpqzxjkeljmnoephob ic
 	























Appendix 6: Passive measurement infrastructure 
 
 
A Distributed Passive Measurement
Infrastructure
Patrik Arlos, Markus Fiedler, and Arne A. Nilsson
Blekinge Institute of Technology, School of Engineering,
Karlskrona, Sweden
{patrik.arlos,markus.fiedler,arne.nilsson}@bth.se
Abstract. In this paper we describe a distributed passive measurement
infrastructure. Its goals are to reduce the cost and configuration effort per
measurement. The infrastructure is scalable with regards to link speeds
and measurement locations. A prototype is currently deployed at our
university and a demo is online at http://inga.its.bth.se/projects/dpmi.
The infrastructure differentiates between measurements and the analysis
of measurements, this way the actual measurement equipment can focus
on the practical issues of packet measurements. By using a modular
approach the infrastructure can handle many different capturing devices.
The infrastructure can also deal with the security and privacy aspects
that might arise during measurements.
1 Introduction
Having access to relevant and up-to-date measurement data is a key issue for
network analysis in order to allow for efficient Internet performance monitoring,
evaluation and management. New applications keep appearing; user and proto-
col behaviour keep evolving; traffic mixes and characteristics are continuously
changing, which implies that traffic traces may have a short span of relevance
and new traces have to be collected quite regularly.
In order to give a holistic view of what is going on in the network, passive
measurements have to be carried out at different places simultaneously. On this
background, this paper proposes a passive measurement infrastructure, consist-
ing of coordinated measurement points, arranged in measurement areas.
This structure allows for a efficient use of passive monitoring equipment in
order to supply researchers and network managers with up-to-date and relevant
data. The infrastructure is generic with regards to the capturing equipment,
ranging from simple PCAP-based devices to high-end DAG cards and dedicated
ASICs, in order to promote a large-scale deployment of measurement points.
The infrastructure, which currently is under deployment at our university,
was designed with the following requirements in mind:
1. Cost. Access to measurement equipment should be shared among users, pri-
marily for two reasons: First, as measurements get longer (for instance for
detecting long-range dependent behaviour) a single measurement can tie
2up a resource for days (possibly weeks). Second, high quality measurement
equipment is expensive and should hence have a high rate of utilization.
2. Ease of use. The setup and control of measurements should be easy from the
user’s point of view. As the complexity of measurements grows, we should
hide this complexity from the users as far as possible.
3. Modularity. The system should be modular, this to allow independent devel-
opment of separate modules. With separate modules handling security, pri-
vacy and scalability (w.r.t. different link speeds as well as locations). Since
we cannot predict all possible uses of the system, the system should be
flexible to support different measurements as well as different measurement
equipment.
4. Safety and Security. Measurement data should be distributed in a safe and
secure manner, i.e. loss of measurement data should be avoided and access
to the data restricted.
To solve these requirements we came up with an infrastructure consisting of
three main components,Measurement Point (MP), Consumer andMeasurement
Area (MAr). The task of the MP is to do packet capturing, packet filtering, and
distribute measurement data. The approach to the second design requirement
was to use a system with a web interface. Through this interface users can add
and remove their desired measurements. The MAr then handles the communica-
tion with the MPs. The cost for implementing this architecture is not very high,
compared to a normal measurement setup you need two additional computers
and an Ethernet switch of suitable speed, and this basic setup can grow as the
requirements change.
There are several other monitoring and capturing systems available, here we
describe only a few.
CoralReef [1] is a set of software components for passive network monitoring,
it is available for many network technologies and computer architectures. The
major difference between CoralReef and our infrastructure is that CoralReef
does not separate the packet capturing and analysis as we do. Furthermore, the
CoralReef trace format does not include location information as our does.
IPMON [2] is a general purpose measurement system for IP networks. IP-
MON is implemented and deployed by Sprint. IPMON separates capturing from
analysis, similar to our infrastructure. On the other hand, the IPMONs store
traces locally and transfer them over a dedicated link to a common data repos-
itory. The repository is then accessed by analyzers.
Gigascope [3] uses a similar approach as IPMON, by storing captured data
locally at the capturer. This data is then copied, either in real time or during
off-peak hour, to a data warehouse for analysis. It uses GSQL as an interface to
access the data.
The IETF has (at least) two work groups that are relevant for this work;
Packet Sampling (PSAMP) [4] and IP Flow Information Export (IPFIX) [5].
PSAMP works on defining a standard set of capabilities for network elements to
sample subsets of packets by statistical and other methods. Recently an Internet
draft was published [6], which describes a system at a higher level than our in-
3frastructure, but they are very similar and our system could benefit by adjusting
somewhat to the PSAMP notation. The IPFIX group is interesting since they
deal with how to export measurement data from A to B, thus it is interesting
with regards to consumers.
In Section 2 we will discuss the components and how they interact. This
is followed by Section 3 where we describe how the system handles rules and
filters. In Section 4 we discuss privacy and security related to the infrastructure.
In Section 5 we describe two cases where the system has been deployed. In
Section 6 we describe some of the ongoing and future work. And in Section 7 we
conclude the paper.
2 Components
The three main components in the infrastructure will be described in the follow-
ing subsections.
2.1 Measurement Point
In Figure 1 the components of a schematic MP are shown. This is the device
that does the actual packet capturing. It is managed from a Measurement Area
Controller (MArC) and transfers the captured data to consumers attached to
the Measurement Area Network (MArN). The MP can either be a logical or a
physical device. A logical MP is simply a program running on a host, whereas a
physical MP could either use a dedicated computer or custom hardware in order

















Fig. 1. Schematic overview of a MP.
A MP can tap one or more links; each link is tapped via a wiretap. For
full-duplex Ethernets, a wiretap has two outputs, one for each direction. These
are connected to separate capture interfaces (CI). A receiver listens to a CI and
filters the packets according to the filter rules stated by the MArC. If the CI
4hasn’t timestamped the packet the receiver will do so. The packets are then
delivered to the sender, which is responsible for sending the captured packets
to the appropriate consumers. Such a measurement frame can contain several
packets, where the number of packets is controlled by the maximum transfer
unit (MTU) of the MArN. Each MP also has a controller that is responsible
for the configuration of the MP and the communication with the MArC. A
time synchronization client (TSC) is used to keep all the MPs with in a MAr
synchronized, which can be done using a dedicated device or a simple NTP
server.
The filter rules used by the receiver specify, in addition to packet properties,
a consumer and the amount of the packet to be captured (currently the upper
limit is 96 bytes). For each frame that passes the filter, the MP attaches a cap-
ture header (Figure 2). In this header, we store a CI identifier, a MP identifier,
a timestamp when the packet was captured (supporting an accuracy of picosec-
onds), the packet length, and the number of bytes that actually were captured.
The filters are supplied to the MP from the MArC, and they will be discussed
in Section 3. Once a packet matches a filter, it is stored in a buffer pending
transmission. Once the buffer contents reaches a certain threshold the buffer is
transmitted using Ethernet multicast. This way, it is simple to distribute frames
to several consumers in one transmission. The duplication of data is done by the
MArN. This approach will also reduce the probability of overloading the MArN,
and hence preventing loss of measurement frames as far as possible. However, in
order to detect frame loss each measurement frame is equipped with a sequence
number that is checked by the consumer upon reception. If a measurement frame
is lost it is up to the consumer to handle this particular loss and notify the
MArC. Given this information the MArC can take actions to prevent future
losses. Actions can be to alter filters as well as requesting additional switching
resources inbetween the MPs and the Consumers. The current implementation






Fig. 2. Capture Header.
The capture header enables us to exactly pinpoint by which MP and on what
link the frame was captured, which is vital information when trying to obtain
spatial information about the network’s behaviour. This also enables us to use
several MPs to measure a single link, which is interesting when the measurement
5task of a link speed becomes too great for a single MP to handle. This would
require a device that is capable of distributing the packets such that the wiretap
feeds different MPs in a round robin approach.
2.2 Measurement Area
In Figure 3 an example of a MAr is shown. The MAr provides a common point of
control for one or more MPs. It uses a dedicated network in between MPs and the
MAr subsystems for reasons of performance and security. A MAr consists of the
following subsystems: a MArC, a time synchronization device (TSD), a MArN
and at least one consumer and one MP. The MArC is the central subsystem
in a MA. It supplies the users with a GUI for setting up and controlling their
measurements. It also manages the MPs by supplying filters and by keeping
track of their status. The TSD supplies all the MPs in the MA with a common
time and synchronization signal. It can utilize the existing Ethernet structure to

















Fig. 3. Simple overview of a MA with three MPs, four consumers, one MArC and a
time synchronization unit.
The capacity of the MArN should be such that it can handle the peak rate
of the measured traffic. Assume that a MP monitors a 10Base-T link, with a
frame rate of 800 fps where each frame is 1500 bytes long (≈ 9.6 Mbps). From
each frame we collect 96 bytes, add a capture header of 36 bytes and store the
data in a measurement frame, see Figure 4. Given a MArN MTU of 1500, a
measurement frame can contain 1480 bytes of measurement data, consisting of
capture headers and frames, the remaining 20 bytes are used by a measurement
header (MH). In the current example we can store 11 frames in each measurement
frame (11 ∗ (36 + 96) = 1452 ≤ 1480 bytes), causing the MP to send only
800/11 ≈ 72 fps into the MArN, see Figure 5. If the monitored link would have a
6frame rate of 14000 fps, each frame would only be 85 bytes long (≈ 9.6 Mbps), the
measurement frame would contain 12 frames (12∗(36+85) = 1452 ≤ 1480 bytes),
yielding a frame rate of 14000/12 ≈ 1167 fps. However, if the MArN MTU was
9000, the measurement frame could contain 74 frames, yielding a frame rate of
189 fps.
CH CH Frame j+nFrame j+1 CH Frame j+2 ...MH
MTU MArN
36 0-1500
Fig. 4. Measurement frame encapsulation.




Fig. 5. After capturing N frames one measurement frame is sent from the MP.
A consumer that attaches to the MArN should not request more data than the
link that it is attached to can handle. For instance a consumer C1 is the recipient
of two measurement streams, S1 and S2, each generating 1272 measurement
frames per second. As long as the total frame rate of S1 and S2 is less or equal
to the capacity offered by link and switch there should be no problems, but if the
consumer desires to get full frames it might run into problems quite fast, since the
MP adds a capture header to each captured frame potentially generating more
traffic than it captures. The current implementation addresses this problem by
having a maximum capture size of 96 bytes. The MArC also provides the user
with an estimation of the frame rate on the links that the MPs are monitoring,
giving the user an indication of the amount of traffic that his consumer might
receive.
The example in Figure 3 contains a consumer network (CN). It is placed on
a separate switch to minimize processing required by the MArN, thus enabling
additional consumers to be easily connected to the MArN, for instance new
probes, analyzers etc. to be evaluated in parallel. If the number of consumers is
low, the MArN switch might handle them directly, and no CN switch is necessary.
This would be the normal setup, see Figure 6. In Figure 7 a minimal MAr is



















Fig. 7. Minimal MAr
2.3 Consumer
A consumer is a user-controlled device that accepts packets according to the
format specified by the system. A consumer should filter the content of the
measurement frame that it receives, since the MP merges multiple user requests
some filters will capture packets that match several requests. Such a joint filter
might not perfectly match the desired frame description; this is discussed in the
following section.
83 Filters and Rules
A user supplies rules to the MArC. These rules describe what data the user
desires to collect, where the data should be collected, when the data should be
collected and where to send the data. The MArC uses this information to create
filters that the MPs understand. The filters that the MP uses are a combination
of all the user supplied rules, combined in such a manner that all requests are met
in a best effort style. The MArC keeps track of the MPs and their capabilities,
thus it knows how many filters a MP can handle before it runs into performance
problems. The MArC also monitors the performance of the MArN and reject
user rules that could cause performance problems within the MArN. If a MP is
to obtain a filter list that would push it into a region of potential performance
problems, the MArC will alter the filters in order to minimize the number of
filters. By doing this the load on the MP is kept at a reasonable level, but this
approach requires the consumers to do some filtering of their own. Hence, it is
up to the user to supply the desired Consumer with a filter. The filters within a
MP are arranged in such a manner that no packet is reported twice by the MP.
Let’s give a simple example, we have one MP and two consumers C1 and C2.
Initially we have two rules (using BPF syntax):
R1 {tcp host A.a} which sends its data to C1.
R2 {ip net A} which targets C2
Here two approaches are possible; the first during low load would have the fol-
lowing filters sent to the MP:
F1 {tcp host A.a}→ M1
F2 {ip net A}→ C2
Here M1 is a multicast address that C1 and C2 listens to. If the load on the MP
approaches a high level then only one filter would be sent to the MP
F1 {ip net A}→ M1
In this case the C1 consumer would need to perform filtering in order to select
the TCP segments of host A.a. By default a consumer should always filter the
measurement data that it receives, ensuring that it passes a correct stream to
the analysis/storage entity.
4 Privacy & Security Issues
A MP will see all the traffic passing on a link that it is tapping, which can be
viewed as a intrusion of privacy. Furthermore, since the majority of the network
protocols used today were not designed with security in mind, user credentials
might pass on the link and be clearly visible to the MP. This can be an intrusion
of privacy and should require special care on behalf of the measurement system
and its users. If the data collected from the system is only intended for internal
9use, it might be enough that all users and the network-owner have agreed to
that their traffic can be monitored to allow for measurements. However, if the
data is to be shared with researchers in other organizations, the data should be
deprivatized. Deprivatization [7] can be done on various levels, from the removal
of parts in the application data to the removal of all network data. We believe
that the system should minimize the alternation of the captured data and leave
the anonymization to the consumers. If the MP would anonymize the data, e.g.
through scrambling of addresses [8], some consumers such as intrusion detection
systems or charging systems might not be able to operate anymore. However, if
the system does deprivatization by default, this should be done in the MPs. If
address scrambling is utilized, this causes problems when the user specifies the
measurement rules. If the unscrambled address was used, the user will obtain
scrambled addresses matching his requirement and then it is possible to reverse-
engineer the scrambling system. If the scrambled address was used, the user
would need to know how to create that scrambled address. Probably, the first
method should be chosen. In that case, the only person that is capable of reverse-
engineering the packet trace is the user requesting the trace, since he knows
both scrambled and unscrambled address. Now, if the packet trace is stolen, the
thief cannot match packets to individual hosts/users unless he has access to a
descrambler and the scrambling key.
Privacy issues will probably have to be addressed by specialized consumers.
For instance, we have two consumers, a intrusion detection system (IDS) and a
link utilization estimator (LUE). The IDS needs undistorted information. The
LUE could on the other hand use deprivatized data, but since the MP will not
send two copies of the same packet there is a problem. It is probable that a
network owner would like to have control of the information that leaves his net-
work, so it would be easier for the network owner to supply an export consumer
that deprivatizes the data according to his own policies, which might not meet
the particular desires of the user. For our own measurements, the agreement we
made with the system owner was the following: The MPs are only allowed to
capture headers, not user payload. Furthermore, the data leaving a consumer
may only be in statistical form, or deprivatized in such a manner that it is im-
possible to reverse-engineer the data to obtain information that allows you to
identify a particular individual.
From a security point of view, all components in the system should be pro-
tected from unauthorized access. The simplest way to do this is to have the sys-
tem operating on a separate network, with no connection to any other networks.
This would however be expensive and unpractical in measurements distributed
over a wide area. The solution to this it to utilize Super Measurement Areas
(SMAr), see Figure 8. SMAr’s are used to connect to MAr’s at different loca-
tions using existing infrastructure. A SMAr can be seen as a MAr at a higher
level, the MAr’s MP becomes SMArFilters (specialized consumers that attach
to the MArN), the MArs consumers are called SMArConsumers. Between the
SMArFilters and SMArConsumers TCP is used to provide reliable communica-
tion. The MPs and the MArN need to be protected from unauthorized access,
10
both physical and logically. Physical protection of the MAr subsystems is the
first requirement in giving logical protection; the consumers and the MArC need











Fig. 8. Example of a SMAr.
5 Examples of Use
As of writing two MAr have been implemented and used. One is available online
via http://inga.its.bth.se/projects/dpmi and is mainly used in a controlled envi-
ronment. The second MAr consisted of two measurement points each monitoring
a gigabit link on a campus network. In both cases only one physical consumer
was used, but it was sufficient to handle up to eight logical consumers. Examples
of consumers are: estimation of traffic distribution (at link, network, transport
and application level); link utilization; packet inter arrival time; communication
identification; and bottleneck identification [9]. At the time of writing we are
preparing a third MAr to be deployed in an ISP network, where it will initially
be used for bottleneck identification. In Figure 9 we visualize the result from a
analyzer that identifies bottlenecks. It uses two consumers to estimate the link
bit rate over a given time intervall, these are then transferred to a database
which is accessed by the visualizer that estimates the bottleneck.
In Figure 10 the MArC (prototype) interface for adding a rule is shown. In
this implementation all tasks are done manually, the goal was to develop the MP
not the MArC. The following filtering options are availible, the MASK fields are
used to mask the packet value.
– CI: Physical interface identifier.
– VLAN TCI: VLAN number and priority.
– ETH TYPE: Ethernet type.
– ETH SRC/DST: Ethernet source/destination address.
– IP PROTO: IP payload type.
– IP SRC/DST: IP source/destination address.
11












Fig. 9. Example of a consumer: Visualization of a bottleneck through bitrate histogram
difference plots (c.f. [9]).
12
– SRC/DST PORT: Transport protocol source/destination port numbers (if
applicable).
– DESTADDR: What Ethernet address should receive the measurement data?
– TYPE: Which type of transport should the MP use? Ethernet, UDP or TCP.
– CAPLEN: How much of each captured frame should we store?
FilterID is a number that specifies in which order the MP should check its filters,
starting with number zero. Index will indicate which fields that are used in the
rule specification. For instance if we wish to collect all packets caught on a specific
CI the index would be 512, and the CI field would hold a string identifying the
CI. If we would like to capture IP packets caught on a specific CI, index would
be 640, ETH TYPE=2048 and CI a string specifying the interface.
Fig. 10. User interface for adding rules.
13
6 Ongoing and Future Work
Initial experiences with the system are encouraging, and development of con-
sumers is currently ongoing. The experience of the demo has indicated that the
MP’s software needs to be changed in such a manner that the MPs periodically
flush their measurement buffers, in order to prevent consumers from waiting
long times. We are considering a modification of the system so that the MArC
supplies the consumers automatically with the information that they need with
regards to filters and multicast addresses.
To handle the increased link speeds, new devices with better timestamping
accuracy are needed. Even if we can obtain this accuracy, a single device will
probably run into problems when measuring such a link. Hence another task
would be to investigate how to distribute the measurement task of a link onto
several MPs. Compression of frame data is also considered to be implemented,
this would could enable us to do full frame capturing without requiring a MArN
that is more powerful that the observed link. We also need to evaluate the
performance of a MArN.
The infrastructure is being considered as a part of the EuroNGI WP.JRA.4.3
[10] Measurement tool. This tool will support traffic generation, measurement,
analysis and visualization.
7 Conclusions
In this paper we have presented a distributed passive measurement infrastruc-
ture, which has separate components for packet capturing, control and analysis.
We discussed how the system deals with multiple users and their request for
data. Since the infrastructure is passive we addressed the security and privacy
issues associated with this. Furthermore, we gave examples of current usage and
future work.
References
1. CAIDA: CoralReef. (2005) http://www.caida.org/tools/measurement/coralreef
(Verfied in January 2005).
2. Sprint: IPMON (2005) http://ipmon.sprint.com (Verified in January 2005).
3. AT&T: Gigascope (2005) http://www.research.att.com/info/Projects/Gigascope
(Verified in January 2005).
4. IETF: PSAMP Workgroup. (2005) http://www.ietf.org/html.charters/psamp-
charter.html (Verfied in January 2005).
5. IETF: IPFIX Workgroup. (2005) http://www.ietf.org/html.charters/ipfix-
charter.html (Verfied in January 2005).
6. IETF: A Framework for Packet Selection and Reporting. (2005)
http://www.ietf.org/internet-drafts/draft-ietf-psamp-framework-10.txt (Ver-
fied in January 2005).
14
7. Pang, R., Paxson, V.: A high-level programming environment for packet trace
anonymization and transformation. In: SIGCOMM ’03: Proceedings of the 2003
conference on Applications, technologies, architectures, and protocols for computer
communications, ACM Press (2003) 339–351
8. Xu, J., Fan, J., Ammar, M., Moon, S.B.: On the design and performance of prefix-
preserving ip traffic trace anonymization. In: IMW ’01: Proceedings of the 1st ACM
SIGCOMM Workshop on Internet Measurement, ACM Press (2001) 263–266
9. Fiedler, M., Tutschku, K., Carlsson, P., Nilsson, A.A.: Identification of performance
degradation in ip networks using throughput statistic. In: Proceedings of the 18th
nternational Teletraffic Congress (ITC-18), ELSEVIER (2003) 399–408
10. EuroNGI: Homepage (2005) http://www.eurongi.org (Verified in January 2005).
11. TCPDUMP Public Repository: Homepage. (2005) http://www.tcpdump.org (Ver-
fied in January 2005).
12. Endace Measurement Systems: Homepage. (2005) http://www.endace.com (Veri-
fied in January 2005).

























All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
Haute Ecole Valaisanne – route du Rawyl 47 – cp 2134 – 1950 Sion 2 – Suisse 
Tél. 0041 27 606 85 00 - Fax 0041 27 606 85 15 
       
PROJECT  : 
MAC Ethernet for specific application 
(MAC+) 
DOCUMENT TITLE : IO-MAC design report 
DOCUMENT NUMBER : SPAM-RPT-006-HEV 







 NAME FUNCTION SIGNATURE DATE 
PREPARED BY F. SEBASTIEN Project Engineer  October, 2007 
CHECKED BY F. CORTHAY Technical Manager  October, 2007 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
D I S T R I B U T I O N  L I S T  







HES-SO : F. Corthay 0 
F. Sébastien 0 
M. Clausen 0 
  
  
C H A N G E  R E C O R D  
ISSUE / 
REVISION 
DATE PAGES MODIFICATION 
1/- July 2007 All First Edition 
2/- October 2007 All Second Edition 
     
     
     
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
C O N T E N T S  
PAGE 
 
CONTENTS ................................................................................................................................................... II 
PAGE ............................................................................................................................................................. II 
1 INTRODUCTION ................................................................................................................................. 5 
2 WORK ................................................................................................................................................... 6 
2.1 OBJECTIVES......................................................................................................................................... 6 
2.2 PARSING.............................................................................................................................................. 6 
3 THE USED FRAME.............................................................................................................................. 7 
3.1 GLOBALITY ......................................................................................................................................... 7 
3.2 ETHERNET FIELD ................................................................................................................................. 7 
3.3 SIMAP FIELD ....................................................................................................................................... 7 
3.4 OTHERS PARTS .................................................................................................................................... 8 
4 GLOBAL FUNCTIONING ................................................................................................................... 9 
5 CONTENT OF DESIGN ..................................................................................................................... 10 
6 INTERFACE ETHERNET ................................................................................................................. 11 
6.1 FUNCTIONALITY ................................................................................................................................ 11 
6.2 CONTENT SUMMARY .......................................................................................................................... 11 
6.3 CONTENT DESCRIPTION ...................................................................................................................... 12 
6.3.1 receiver ................................................................................................................................... 12 
6.3.1.1 Functionality....................................................................................................................................... 12 
6.3.1.2 Content summary ................................................................................................................................ 12 
6.3.1.3 Content description ............................................................................................................................. 13 
6.3.1.3.1 data to word .............................................................................................................................. 13 
6.3.1.3.2 crc32 ........................................................................................................................................ 13 
6.3.1.3.3 synchronizer ............................................................................................................................. 14 
6.3.1.3.4 reset synch ................................................................................................................................ 14 
6.3.1.3.5 ram dp ...................................................................................................................................... 14 
6.3.1.3.6 mux ram data ............................................................................................................................ 14 
6.3.1.3.7 receiver controller ..................................................................................................................... 15 
6.3.2 transmitter ............................................................................................................................... 17 
6.3.2.1 Functionality....................................................................................................................................... 17 
6.3.2.2 Content summary ................................................................................................................................ 17 
6.3.2.3 Content description ............................................................................................................................. 18 
6.3.2.3.1 byte to nibble ............................................................................................................................ 18 
6.3.2.3.2 crc32 ........................................................................................................................................ 18 
6.3.2.3.3 synchronizer ............................................................................................................................. 18 
6.3.2.3.4 reset synch ................................................................................................................................ 18 
6.3.2.3.5 ram dp ...................................................................................................................................... 19 
6.3.2.3.6 mux ram data ............................................................................................................................ 19 
6.3.2.3.7 transmitter controller ................................................................................................................. 20 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
7 CONTROLLER SIMAP ..................................................................................................................... 22 
7.1 FUNCTIONALITY ................................................................................................................................ 22 
7.2 CONTENT SUMMARY .......................................................................................................................... 23 
7.3 CONTENT DESCRIPTION ...................................................................................................................... 24 
7.3.1 controller ................................................................................................................................. 24 
7.3.1.1 Functionality....................................................................................................................................... 24 
7.3.1.2 State machine summary....................................................................................................................... 24 
7.3.2 reader address registers ........................................................................................................... 25 
7.3.2.1 Functionality....................................................................................................................................... 25 
7.3.3 checker .................................................................................................................................... 25 
7.3.3.1 Functionality....................................................................................................................................... 25 
7.3.4 work register............................................................................................................................ 25 
7.3.4.1 Functionality....................................................................................................................................... 25 
7.3.5 selector register ....................................................................................................................... 25 
7.3.5.1 Functionality....................................................................................................................................... 25 
7.3.6 blocks: mux and demux ............................................................................................................ 25 
7.3.6.1 Functionality....................................................................................................................................... 25 
7.3.7 application address registers .................................................................................................... 25 
7.3.7.1 Functionality....................................................................................................................................... 25 
7.3.8 group config addressing ........................................................................................................... 26 
7.3.8.1 Functionality....................................................................................................................................... 26 
7.3.9 group config memory ............................................................................................................... 26 
7.3.9.1 Functionality....................................................................................................................................... 26 
7.3.9.2 Notice................................................................................................................................................. 26 
7.3.10 writer address registers ....................................................................................................... 26 
7.3.10.1 Functionality.................................................................................................................................. 26 
8 APPLICATION ................................................................................................................................... 27 
8.1 FUNCTIONALITY ................................................................................................................................ 27 
8.2 CONTENT SUMMARY .......................................................................................................................... 27 
8.3 CONTENT DESCRIPTION ...................................................................................................................... 28 
8.3.1 blocks: mux and demux ............................................................................................................ 28 
8.3.1.1 Functionality....................................................................................................................................... 28 
8.3.2 blocks: ROM registers, params registers, program memory, groupe value registers, groupe 
description registers .............................................................................................................................. 28 
8.3.2.1 Functionality....................................................................................................................................... 28 
8.3.3 application test ........................................................................................................................ 28 
8.3.3.1 Functionality....................................................................................................................................... 28 
8.3.4 event register ........................................................................................................................... 28 
8.3.4.1 Functionality....................................................................................................................................... 28 
9 TEST BENCH ..................................................................................................................................... 29 
9.1 RECEIVER_TB .................................................................................................................................... 29 
9.1.1 Info on the test ......................................................................................................................... 29 
9.1.2 Test sequence ........................................................................................................................... 29 
9.1.2.1 Part: Reset sequence............................................................................................................................ 29 
9.1.2.2 Part: Detail of a valid frame without error ............................................................................................ 30 
9.1.2.3 Part: CRC error and multiple Rx errors. ............................................................................................... 31 
9.1.2.4 Part: Fill the RAM and test the limit of free RAM. ............................................................................... 32 
9.1.2.5 Part: Fill the RAM and test the limit of free RAM. ............................................................................... 34 
9.1.2.6 Part: Test if reader can move correctly. ................................................................................................ 36 
9.1.3 Notice ...................................................................................................................................... 38 
9.2 TRANSMITTER_TB .............................................................................................................................. 39 
9.3 MAC_PLUS_TB ................................................................................................................................. 40 
9.3.1 Little description of MAC_plus_tester_fas.vhd .......................................................................... 40 
9.3.2 Test sequence ........................................................................................................................... 40 
9.3.2.1 Part: Send only writing frames............................................................................................................. 40 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
9.3.2.2 Part: Send only reading frames ............................................................................................................ 41 
9.3.2.3 Part: Send only event .......................................................................................................................... 41 
9.3.2.4 Part: Send all frames with not SimAP frame ........................................................................................ 41 
9.3.2.5 Part: Send with transmission error ....................................................................................................... 42 
9.3.2.6 Part: Transmission loss........................................................................................................................ 42 
9.3.2.7 Part: Others......................................................................................................................................... 42 
10 TEST OF DEMO ................................................................................................................................. 43 
10.1 EQUIPMENT .................................................................................................................................. 43 
10.2 NOTICE ......................................................................................................................................... 43 
11 IMPROVEMENTS TO MAKE........................................................................................................... 44 
11.1 RECEIVER...................................................................................................................................... 44 
11.2 TRANSMITTER ............................................................................................................................... 44 
11.3 CONTROLLER ................................................................................................................................ 45 
11.4 MEMORIES .................................................................................................................................... 45 
11.5 APPLICATION................................................................................................................................. 45 
11.6 TEST ............................................................................................................................................. 46 
11.7 OTHERS......................................................................................................................................... 46 
11.8 MISC ............................................................................................................................................. 46 
12 WHY THESE CHOICES ? ................................................................................................................. 47 
12.1 INTERFACE ETHERNET ........................................................................................................... 47 
12.1.1 receiver ............................................................................................................................... 47 
12.1.1.1 crc32 ............................................................................................................................................. 47 
12.1.1.2 RAM dp ........................................................................................................................................ 48 
12.1.1.3 receiver controller .......................................................................................................................... 49 
12.1.2 transmitter .......................................................................................................................... 50 
12.1.2.1 transmitter controller ...................................................................................................................... 50 
12.2 CONTROLLER SIMAP ............................................................................................................... 51 
12.2.1 controller ............................................................................................................................ 51 
12.2.1.1 parsing........................................................................................................................................... 52 
12.2.1.1.1 physical addressing mode .......................................................................................................... 54 
12.2.1.1.2 group addressing mode.............................................................................................................. 56 
12.3 APPLICATION............................................................................................................................ 57 
12.3.1 mux and demux.................................................................................................................... 57 
12.3.2 blocks: ROM registers, params registers, program memory, groupe value registers, groupe 
description registers .............................................................................................................................. 57 
12.3.3 application_test ................................................................................................................... 57 
12.3.4 event_registers .................................................................................................................... 57 
13 APPENDICES ..................................................................................................................................... 58 
13.1 ABBREVIATION ............................................................................................................................. 58 
13.2 FILES AND FOLDERS FOR THE PROJECT ........................................................................................... 59 
13.3 RAM STRUCTURE ......................................................................................................................... 60 
13.3.1 Structure ............................................................................................................................. 60 
13.3.2 Header ................................................................................................................................ 60 
13.3.2.1 Empty header ................................................................................................................................. 60 
13.3.2.2 Error header ................................................................................................................................... 61 
13.3.2.3 Frame header ................................................................................................................................. 61 
13.4 ABREVIATIONS TIRÉE DU 802.3 ...................................................................................................... 62 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




In this document, there is a lot of abbreviation. To know the signification of these, it 
must to go on: "appendices" and to see: "abbreviation". 
 
The network topology is quite similar to a standard EIB infrastructure. 
The following illustration shows a typical SimAP installation: 
 
 
Figure 1: SAoE network topology 
 























  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




To realize a design that can be downloaded in a FPGA of a SD so it can 
communicate with other SD. 
All devices are connected with Ethernet. 
The communication is based on SimAP. 
 
So the design must to receive Ethernet frames, to work with these frames respecting 
the protocol SimAP and be able to send Ethernet frames. 
 
2.1 Objectives 
The device can realise a simple Ethernet node without processor. The IOs are 
directly connected on the device. The used protocol is SimAP (Simple Automation 
Protocol). The design of the device must be composed be three parts: an Ethernet 




  To receive correctly the frames 
  To be synchronized with Rx clock 
  To store the frames 
  To calculate CRC 
  To check all errors on the frames 
 
 Transmitter 
  To be synchronized with Tx clock 
  To read the frames 
  To calculate CRC 
  To send correctly the frames 
 
 Controller 
  To read the received frames 
  To get the events 
  To identify the frames 
  To work with the registers or the memories 
  To create frames 
  To store the created frames 
 
 Application specific 
  To work with the outputs or the inputs 
  To work with the registers or the memories 
  To store the events 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
3 THE USED FRAME 
3.1 Globality 
The complete Ethernet frame that it is possible to see on the twisted pair Rx or Tx: 
SSD Preamble SFD 
Ethernet 
field 
Data PAD FCS Extension ESD IFG 
1 6 1 14 0 - 1500 46-0 4 ? 1 >11 
 
On SimAP project, the used frame to work with the SimAP protocol and the PHY 






Data PAD FCS 





3.2 Ethernet field 
Destination Address Source Address Type 
6 bytes 6 bytes 2 bytes 
 
The Ethernet field is composed of 3 parts: 
 - Destination Address : it’s the MAC address from recipient. 
 - Source Address  : it’s the MAC address from issuer. 
 - Type    : it's to know the contents of data. 
3.3 SimAP field 
 
PCF GID NPCI TPCI APCI 
1 byte 2 bytes 2 bytes 1 byte 4 bytes 
 
The SimAP field is composed of 5 major parts: 
 - PCF  : it’s to have information about the frame. 
 - GID  : it’s the group identifier. 
 - NPCI : it’s to have information about the data. 
 - TPCI  : it’s the transport protocol control information. 
 - APCI : it’s to know how to use the data. 
 
Notice: 
The parts: PCF, GID, NPCI, TPCI and APCI are composed by small parts that 
depend from addressing mode. 
(To know contents, see part: 13.2.1.1 parsing) 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
3.4 Others parts 
The others parts: 
 - SSD  : it's to indicate the start of stream of frame. 
 - Preamble : it's for physical medium stabilization and synchronization. 
 - SFD  : it’s the start frame delimiter. 
 - Data  : it’s data of the frame. 
 - PAD  : it’s used to complete the frame so as to have the min length. 
 - FCS  : it’s to check and to validate the frame sequence. 
 - Extension : it’s an extension for the frame. 
 - ESD  : it's to indicate the end of stream of frame. 




  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 

















Figure 2: Global functioning 
 
 
1: The PHY receives the stream of a frame from the twisted pair Rx. 
2: The PHY transmits a frame with some signals drivers to the receiver. 
The receiver stores a frame with her frame header in a RAM. 
3: The controller reads a stored frame. 
The controller parses a read frame. 
4: The controller stores data in registers or memories. 
The application reads data in registers or memories. 
The application stores events. 
The controller gets the next event. 
The application stores data in registers or memories. 
The controller reads data in registers or memories. 
5: The controller stores a created frame with her frame header in a RAM. 
6: The transmitter reads a frame. 
The transmitter sends a frame with some signals drivers to the PHY. 
7: The PHY transmits the stream of a frame on the twisted pair Tx. 
8: The application sets outputs. 










Application IN / OUT 4 8 
1 / 7 
2 3 
6 5 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
5 CONTENT OF DESIGN 
 
The following figure shows the SimAP architecture. Each block will be described in 


















Figure 3: SimAP architecture 
 
For this project, there are 3 important libraries: 
 - interface_Ethernet_lib (block: interface) 
 - controller_SimAP_lib (block: controller_SimAP) 
 - application_SimAP_lib (block: application_SimAP_example) 
 
In the library: interface_Ethernet_lib, there are all elements to make the reception of 
frames with the storage and to make the transmission of frames with the storage. 
 
In the library: controller_SimAP_lib, there are all elements to communicate respecting 
the protocol: SimAP and to store data in registers or memories. 
 
In the library: application_SimAP_lib, there are only the elements to make a little 










MII   Rx 
data 




















sel reg block 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
6 INTERFACE ETHERNET 
6.1 Functionality 
The interface receives data from PHY Ethernet chip and saves them on a RAM. 
A structure is created to recognize what is saved (See part: 14.3 RAM structure). 
To read correct data, it’s necessary to set the signals: base address and address. 
 
A signal will be transmitted when the SFD (Start Frame Delimiter) is detected. 




And interface transmits data to PHY Ethernet chip. 
6.2 Content summary 
 
The following figure shows the interface architecture. Each block will be described in 





































  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




6.3 Content description 
6.3.1 receiver 
6.3.1.1 Functionality 
The receiver receives data from PHY Ethernet chip. 
 
When the SFD (Start Frame Delimiter) is detected, a pulse is sent. 
(This signal isn’t synchronize.) 
 
He checks the received data to detect a CRC error or the transmission error signal. 
With signal: base address, it’s possible to check free memory. 
 
He writes data in RAM with a specific format (see part: 14.3 RAM structure). 
 
These data can be read by changing address. 
 



















































  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
6.3.1.3 Content description 
6.3.1.3.1 data to word 
6.3.1.3.1.1 Functionality 
He adapts the parallel bits number. 
 
6.3.1.3.1.2 Notice 
At this moment, it’s only possible to have at entry a parallel bits number smaller than 







He calculates CRC as long as calculate is high and enable is high. 
He compares CRC with residue as long as enable is low. 
 
6.3.1.3.2.2 Notice 
crc32 is created with crcgen.pl (Version: 2.0) 




Specifications of CRC 32 
constant input_width : positive :=  8; 












  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 









6.3.1.3.4 reset synch 
6.3.1.3.4.1 Functionality 




6.3.1.3.5 ram dp 
6.3.1.3.5.1 Functionality 
It’s a ram with dual port. 
A port works with rx clock and he is used for the writing. 
The other port works with system clock and he is used for the reading. 
6.3.1.3.5.2 Notice 




6.3.1.3.6 mux ram data 
6.3.1.3.6.1 Functionality 
He picks a data input to set the output. 
6.3.1.3.6.2 Notice 
In this case, he is used to make believe that the data read are that of an empty 







  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




6.3.1.3.7 receiver controller 
6.3.1.3.7.1 Functionality 
He guides and drives all signals to have the receiver functionality. 
(He is the receiver brain.) 



























To see content of all data type ( valid header, error header, frame data and init data ), 
open HDL designer and open receiver controller struct. 
 
 
6.3.1.3.7.3 Content description 































  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
He sends a pulse when the SFD (Start Frame Delimiter) is detected. 
(This pulse is asynchronous.) 
 
6.3.1.3.7.3.2 rc data register 
6.3.1.3.7.3.2.1 Functionality 
It’s a register to delay the data frame signals because in this case it’s necessary to 
have 16 bits to write data frame in RAM. 
 
6.3.1.3.7.3.3 rc address registers 
6.3.1.3.7.3.3.1 Functionality 
He is constituted 3 registers (for current address, begin address and end address) 
and process driven by rc heart to control the registers. 
 
This is used to check and to send the state of the RAM. 
 
6.3.1.3.7.3.4 rc errors registers 
6.3.1.3.7.3.4.1 Functionality 
He is used to store, to check and to send the state of current error and previous 
error. 
 
6.3.1.3.7.3.5 rc mux data to write 
6.3.1.3.7.3.5.1 Functionality 
He picks a data input to set the output. 
6.3.1.3.7.3.5.2 Notice 
In this case, he is used to select data type which will be written in RAM. 
 
6.3.1.3.7.3.6 rc heart 
6.3.1.3.7.3.6.1 Functionality 
He directs all rc (receiver controller) internal blocks to realize a sequence of work. 
(He is the receiver controller heart.) 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 







The transmitter reads a frame in RAM with a specific format (see part: 14.3 RAM 
structure). 
 
He calculates the CRC. 
He sends the stream of a frame with all signals control to the PHY. 
 
When all data are sent, a pulse is created. 
(This signal: end of frame isn’t synchronized.) 
 
























































  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
6.3.2.3 Content description 
6.3.2.3.1 byte to nibble 
6.3.2.3.1.1 Functionality 
He adapts the parallel bits number. 
 
6.3.2.3.1.2 Notice 





He calculates CRC as long as calculate is high and enable is high. 
 
6.3.2.3.2.2 Notice 
crc32 is created with crcgen.pl (Version: 2.0) 




Specifications of CRC 32 
constant input_width : positive :=  8; 





He synchronizes data input to tx clock. 
 
 
6.3.2.3.4 reset synch 
6.3.2.3.4.1 Functionality 
He synchronizes reset input to tx clock. 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
6.3.2.3.5 ram dp 
6.3.2.3.5.1 Functionality 
It’s a ram with dual port. 
A port works with tx clock and he is used for the writing. 
The other port works with system clock and he is used for the reading. 
6.3.2.3.5.2 Notice 
The implementation is based on XST User Guide (xst.pdf) page 147. 
 
6.3.2.3.6 mux ram data 
6.3.2.3.6.1 Functionality 
He picks a data input to set the output. 
6.3.2.3.6.2 Notice 
In this case, he is used to make believe that the data read are that of an empty 




  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




6.3.2.3.7 transmitter controller 
6.3.2.3.7.1 Functionality 
He guides and drives all signals to have the transmitter functionality. 
(He is the transmitter brain.) 























Figure 8: Transmitter controller architecture 
 
6.3.2.3.7.3 Content description 
6.3.2.3.7.3.1 tc address registers 
6.3.2.3.7.3.1.1 Functionality 
He is constituted 3 registers (for current address, begin address and end address) 
and process driven by tc heart to control the registers. 
 
This is used to check and to read the state of the RAM. 
word to 
data 




end of frame 
data 








  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
6.3.2.3.7.3.2 tc IFG counter 
6.3.2.3.7.3.2.1 Functionality 
He is used to wait a minimum time before to send the next frame. 
 
6.3.2.3.7.3.3 word to data 
6.3.2.3.7.3.3.1 Functionality 
He adapts the parallel bits number. 
 
6.3.2.3.7.3.4 tc heart 
6.3.2.3.7.3.4.1 Functionality 
He directs all tc (transmitter controller) internal blocks to realize a sequence of work. 
(He is the transmitter controller heart.) 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
7 CONTROLLER SIMAP 
7.1 Functionality 
There are 2 information sources: 
 - Rx RAM  (from Ethernet) 
 - event register (from inputs) 
 
And there are 2 storing places: 
 - Tx RAM  (for Ethernet) 
 - registers and memories (for outputs) 
 
With that, it is possible to have various functionalities: 
 - an event leads a broadcasted frame on Ethernet. 
 - a frame with physical addressing can be write or read anything in registers or 
   memories and returns a response on Ethernet. 
 - a frame with group addressing can be write or read anything in registers (not 
   in memories) and returns a response on Ethernet. 
 
So the controller reads the frames in the Rx RAM. 
He gets the events. 
He parses the frames using the structure (See part: 14.3 RAM structure). 
He reads or writes in registers or memories. 
He stores the created frames in the Tx RAM. 
 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 






7.2 Content summary 
 
The following figure shows the controller SimAP architecture. Each block will be 
























Figure 9: Controller SimAP architecture 
 
Notice: 






start of frame 


















rx base address 
         rx address 
rx data 
tx base address 






































  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
7.3 Content description 
7.3.1 controller 
7.3.1.1 Functionality 
The controller guides and drives all signals to have the controller SimAP functionality. 
(It’s the brain of controller SimAP.) 










init all RAMs 
frames 
1: Rx RAM not empty 
& Tx RAM not full 
2 : new event 
& Tx RAM not full 
3: others 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
7.3.2 reader address registers 
7.3.2.1 Functionality 
He is constituted 3 registers (for current address, begin address and end address) 
and process driven by controller to control the registers. 
 




This block compares data combined with a mask to a value. 
 
7.3.4 work register 
7.3.4.1 Functionality 
The work register stores data. 
 
7.3.5 selector register 
7.3.5.1 Functionality 
The selector register selects a memory so as to work with. 
 
7.3.6 blocks: mux and demux 
7.3.6.1 Functionality 
They are used to direct the data flow. 
 
7.3.7 application address registers 
7.3.7.1 Functionality 
He is constituted 3 registers (for current address, begin address and end address) 
and process driven by controller to control the registers. 
 
This is used to write or to read memory block. 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
7.3.8 group config addressing 
7.3.8.1 Functionality 
He adapts the address to read the correct part of config RAM. 
 
7.3.9 group config memory 
7.3.9.1 Functionality 
It’s a ram with dual port. 
Where is stored the GID and the EIB flags. 
 
7.3.9.2 Notice 
The implementation is based on XST User Guide (xst.pdf) page 147. 
 
7.3.10 writer address registers 
7.3.10.1 Functionality 
He is constituted 3 registers (for current address, begin address and end address) 
and process driven by controller to control the registers. 
 










  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 






The block: "application SimAP example" has been created so as to have a functional 
demo. 
 
8.2 Content summary 
 
The following figure shows the application SimAP example architecture. Each block 
























Figure 11: Application SimAP example architecture 
 
Notice: 
It’s only an example of something that runs. 




All memories or registers : 
 - ROM registers, 
 - params registers, 
 - program memory, 
 - groupe value registers, 
 -group description registers. 



















sel reg block 
event nb 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
8.3 Content description 
8.3.1 blocks: mux and demux 
8.3.1.1 Functionality 
They are used to direct the data flow. 
 
8.3.2 blocks: ROM registers, params registers, program memory, groupe 
value registers, groupe description registers  
8.3.2.1 Functionality 
It is necessary that they are readable or writable as a RAM from controller interface. 
And from application, it is possible to read or to write as a RAM or as a register. 
 
8.3.3 application test 
8.3.3.1 Functionality 
The application test is an example to use the registers with IOs. 
 
8.3.4 event register 
8.3.4.1 Functionality 
It is an example to store and to send events. 
 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
9 TEST BENCH 
9.1 receiver_tb 
9.1.1 Info on the test 
A table is used to describe the test of receiver. 
Table contents: 
 
addr (hex) content (hex)total time run time
RAM
what occurs  
Regularly, a little sentence summarizes the part of test and why it’s tested. 
And some time, there is a graph of waves. 
9.1.2 Test sequence 
To start, the test of reader is locked to address: 0 hex and to base_address : 0 hex. 
 
9.1.2.1 Part: Reset sequence 
The test begins with a reset. 
It’s to check signals and state of RAM. 
0 to 1999  => don't know XXX XXXX
2000 ns  => begin of reset XXX XXXX








  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
9.1.2.2 Part: Detail of a valid frame without error 
The writing of a valid frame. 
It’s to check if all data of frame is written in RAM. 
7540 5324 ns => begin of frame NC NC
640 ns => SFD (Start Frame Delimiter) NC NC
196 ns => write first byte of the frame 001 FFFF
160 ns => write next byte of the frame 002 FFFF
160 ns => write next byte of the frame 003 FFFF
… to 01E ADF
13176 4480 ns => write first byte of CRC 01F E625
160 ns => write second byte of CRC 020 C4C7
160 ns => write empty header 021 0000
13576 80 ns => write frame header 000 8021  
 
Rem: 
NC   : Not Change 








  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
9.1.2.3 Part: CRC error and multiple Rx errors. 
The writing of an invalid frame (CRC error). 
It’s to check if after the writing of frame, he places correctly the new empty header 
and correctly writes the error header. 
6480 ns => write empty header 022 0000
20136 80 ns => write error header: CRC error 021 1001  
 
An Rx error during the writing of a valid frame. 
It’s to check the detection of Rx error and the validation of previous error header. 
5480 ns => write empty header 023 0000
80 ns => validation of the previous error header 021 9001
25736 40 ns => write error header: Rx error 022 2001  
 
An Rx error during the writing of a valid frame. 
It’s to check the detection of a same error, the counter of error and if the error header 
is correctly places. 
6360 ns => write empty header 023 0000
32216 120 ns => write error header: second Rx error 022 2002  
 
An Rx error during the writing of a valid frame. 
It’s to check a second time. 
6400 ns => write empty header 023 0000






  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




9.1.2.4 Part: Fill the RAM and test the limit of free RAM. 
A complete frame is written in RAM to easily see where the pointer of writing is in 
RAM. 
 
The writing of a valid frame. 
It’s to check if all data of frame is written in RAM and previous error header are 
correctly validated. 
7240 ns => write empty header 044 0000
120 ns => validation of the previous error header 022 A003
46136 40 ns => write frame header 023 8021  
 
At this moment, the test of reader stays locked but the address becomes 47 hex and 
the base_address becomes 47 hex in order to fill quickly the buffer and to see if 
anything is write at base_address. 
 
The writing of a valid frame. 
It’s to check detection of full buffer and if the security of 1 RAM line is sufficient. 
1480 ns => write empty header 045 0000
47696 80 ns => write error header: buffer is full (first time) 044 4001  
 
The writing of a valid frame. 
It’s to check a second time the security of 1 RAM line. 
6240 ns => write empty header 045 0000
54056 120 ns => write error header: buffer is full (second time) 044 4002  
 
The writing of a valid frame. 
It’s to check a second time the security of 1 RAM line. 
6400 ns => write empty header 045 0000
60576 120 ns => write error header: buffer is full (third time) 044 4003  
 
The writing of a valid frame. 
It’s to only to increment error counter. 
6360 ns => write empty header 045 0000
67056 120 ns => write error header: buffer is full (fourth time) 044 4004  
 
The writing of a valid frame with an Rx error. 
It’s to check the priority when the buffer is full. 
5640 ns => write empty header 045 0000
72816 120 ns => write error header: buffer is full (fifth time) 044 4005  
 
The writing of a valid frame. 
It’s to check if this error is considered as another error. 
7120 ns => write empty header 045 0000
80056 120 ns => write error header: buffer is full (sixth time) 044 4006  
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
The writing of a valid frame. 
It’s to only to increment error counter. 
6400 ns => write empty header 045 0000
86576 120 ns => write error header: buffer is full (seventh time) 044 4007  
 
The writing of a valid frame with an Rx error. 
It’s to check a second time the priority when the buffer is full. 
5600 ns => write empty header 045 0000
92296 120 ns => write error header: buffer is full (eighth time) 044 4008  
 
The writing of a valid frame with an Rx error. 
It’s to check when Rx error is sent 2 times. 
6400 ns => write empty header 045 0000
98816 120 ns => write error header: buffer is full (ninth time) 044 4009  
 
The writing of a valid frame. 
It’s to only to increment error counter. 
7120 ns => write empty header 045 0000







  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
9.1.2.5 Part: Fill the RAM and test the limit of free RAM. 
This part is different of the previous part because it starts with Rx error and not buffer 
is full. 
At this moment, the test of reader stays locked but the address becomes 49 hex and 
the base_address becomes 49 hex in order to fill quickly the buffer and to see if 
anything is write at base_address. 
 
 
The writing of a valid frame with an Rx error. 
5640 ns => write empty header 046 0000
80 ns => validation of the previous error header 044 C00A
111816 40 ns => write error header: Rx error 045 2001  
 
The writing of a valid frame with an Rx error. 
7080 ns => write empty header 046 0000
119016 120 ns => write error header: second Rx error 045 2002  
 
The writing of a valid frame. 
It’s to check detection of full buffer and if the security of 1 RAM line is sufficient. 
6320 ns => write first word of frame 046 0000
240 ns => write empty header 047 0000
80 ns => validation of the previous error header 045 A002
125696 40 ns => write error header: buffer is full (first time) 046 4001  
 
The writing of a valid frame. 
6200 ns => write empty header 047 0000
132016 120 ns => write error header: buffer is full (second time) 046 4002  
 
The writing of a valid frame with an Rx error. 
It’s to check the priority when the buffer is full. 
5680 ns => write empty header 047 0000
137816 120 ns => write error header: buffer is full (third time) 046 4003  
 
The writing of a valid frame. 
7080 ns => write empty header 047 0000
145016 120 ns => write error header: buffer is full (fourth time) 046 4004  
 
The writing of a valid frame with an Rx error. 
It’s to check the priority when the buffer is full. 
5680 ns => write empty header 047 0000
150816 120 ns => write error header: buffer is full (fifth time) 046 4005  
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 









  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
9.1.2.6 Part: Test if reader can move correctly. 
At this moment, the test of reader becomes unlocked and starts checking of data to 
place correctly the base_address at the next reading point. 
And, the base_address and the address become 0 hex. 
 









  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




In a first time, only frames of mode: group addressing are sent. 
(It’s not necessary to have frames of type: physical addressing to test receiver. When 
the block: interface Ethernet is connected to the block: controller SimAP, it’s 
necessary to have all possible frames.) 
 




  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 





I would not describe this part because I haven’t correctly made this part. 




  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




9.3.1 Little description of MAC_plus_tester_fas.vhd 
A small index                : from line 1 to line 20 
Definition of all signals  : from line 27 to line 160 
 
Clocks signals               : from line 168 to line 187 
Reset process               : from line 191 to line 208 
Process to create and to send an Ethernet frame: from line 218 to line 452 
 
Test sequence               : from line 456 to line 2363 
 
9.3.2 Test sequence 
The test sequence is composite by 7 parts: 
     - Send only writing frames                      => line: 467 
     - Send only reading frames                     => line: 608 
     - Send only event                                    => line: 701 
     - Send all frames with not SimAP frame => line: 770 
     - Send with transmission error                => line: 900 
     - Transmission loss                                 => line: 1069 
     - Others                                                   => line: 1947 
 
9.3.2.1 Part: Send only writing frames 
No event for this part (no buttons). 
Reset and wait end of reset before send anything. 
 
Sent frames: 
     - configure the device 
     - write dimming 
     - write led0 switching on 
     - write led0 switching off 
     - write led0 switching on 
     - write led0 switching on 
     - write led1 switching on 
 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
9.3.2.2 Part: Send only reading frames 
No event for this part (no buttons). 
No reset because this part uses the previous information. 
 
Sent frames: 
     - read the configuration of the device 
     - read dimming 
     - read led0 switching 
     - read led1 switching 
 
9.3.2.3 Part: Send only event 
See the design of application_test because, it’s special.  
 
No reset because this part uses the configuration of the device. 
 
Buttons pressed: 
     - all in same time => 1 frame is transmitted 
     - all 1 by 1 => 3 frames are transmitted (two buttons have the same event 
number) 
     - button 0 a long time => 1 frame is transmitted 
     - button 2 => see effect of full Tx RAM 
 
9.3.2.4 Part: Send all frames with not SimAP frame 
Init buttons positions (all to low). 
Reset and not wait end of reset before send anything. 
 
Sent frames and buttons pressed: 
     - a frame with false SFD (Start Frame Delimiter) 
     - button 0 
     - configure the device with false SFD and with false destination address 
     - other Ethernet Type 
     - other address type 
     - button 2 
 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
9.3.2.5 Part: Send with transmission error 
No event for this part (no buttons). 
Reset and not wait end of reset before send anything. 
 
Sent frames: 
     - configure the device 
     - write dimming 
     - read dimming 
     - write led0 switching on with wrong CRC 
     - write led0 switching on with rx error 
     - write led0 switching on with rx error 
     - write led0 switching on 
     - read led0 switching 
     - read led0 switching with rx error 
     - read led0 switching with a biggest size 
 
9.3.2.6 Part: Transmission loss 
Init buttons positions (all to low). 
Reset and wait end of reset before send anything. 
 
In a first time a lot of frames are sent with a lot of events. 
In a second time a lot of frames are sent. 
 
In two times, it’s possible to change the length of the frame, the number of the frames 
and (only for the first time) the number of times that the button 2 stays at high. 
 
9.3.2.7 Part: Others 
Init buttons positions (all to low). 
Reset and wait end of reset before send anything. 
 
Sent frames: 
     - configure the device with an offset 
     - write anything in RAM of uP with offset 
     - send a fluid situation (from line 2056 to line 2193) 




  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
10 TEST OF DEMO 
10.1 Equipment 
From Planet: www.planet.com.tw 
A Ethernet switch PoE: FSD-804P 
A PoE splitter 5V: POE-151S-5V 
 
Software: Ethereal or WireShark (To parse all frames) 
 
From school 
2 boards: FPGA-EBS 
2 boards: HEB_ETHERNET_PHY 
2 boards: HEB_LCD_I2C 
(It’s 2 devices. When the design is loaded in FPGA, it’s 2 SDs). 
 
With software, frames are created and sent. 
 
10.2 Notice 
This test is made with a switch because it must work with mode: full duplex (no CRS 




  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
11 IMPROVEMENTS TO MAKE 
11.1 receiver 
     - to standardize the streaming (nibble -> byte -> word) so that this be more easy 
       to use the GBits Ethernet. 
     - to add a system to know the number of valid byte at the last line of structure in 
       Rx RAM (and that must be correct with generic RAM). 
     - to update to work with the mode: “half-duplex” => with HUB (CRS, COL, …) 
     - to manage the signals: PRIO and ACK 
     - to not store the part: CRC in Rx RAM 
     - to add generic value so to know the limits of the used Ethernet frame and to add 
       the checking of these limits. 
     -  
 
11.2 transmitter 
     - to standardize the streaming (nibble -> byte -> word) so that this be more easy 
       to use the GBits Ethernet. 
     - to add a system to know the number of valid byte at the last line of structure in 
       Rx RAM (and that must be correct with generic RAM). 
     - to update to work with the mode: “half-duplex” => with HUB 
            => to check CRS before to send a frame. 
            => to send JAM when a collision is detected. 
            => to wait the timing who be calculate with the rule: “Binary exponential 
                 Backoff” before to resend a frame. 
            => to update RTRY when a frame is resent. 
            => … 
     - to manage the signals: PRIO and ACK 
     - to add generic value so to know the limits of the used Ethernet frame and to add 
       the checking of these limits. 
     - to manage error header to use the signal: “Tx error”. 
     - (to add the PAD when the frame is smaller as the min Ethernet frame 
            => I think:”This is not his job.”.) 
     -  
 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




     - to use the MAC address stored in the parameters registers block. 
       (Currently, the MAC address is wrote in design.) 
     - to add a system to know the number of valid byte at the last line of structure in 
       Rx RAM (and that must be correct with generic RAM). 
     - to manage PRIO and ACK (and the management to resend a previous frame). 
     - to define if a device can have more one resister with the same GID. 
       (Currently, only the first found GID is used.) 
     - to define the constants in lib to remove the values in design. 
            => code more readable. 
     - to check part to enable or disable (communication, read, write, transmit, update). 
     - to update the block to easily modify generics. 
     - to parse and to use a frame in physical addressing mode with EIB mode. 
     - to check all possible data in all field of an frame. 
     -  
 
11.4 memories 
To make a discussion about all memories because I haven’t correctly understood the 
documentation: SimAP. 
     - to choose which memories are in the block: “controller_SimAP “ or which are in  
       the block: “application_SimAP_example”. 
     - to define were are the information to define a GID (EIS, ECMD, PRIO, ACK, …). 
     - to add a memory block to enable or to disable (communication, read, write, 
       transmit, update). 
     - to define how use the program memory block. 
     - to develop a system to work with offset and various sizes of RAM. 
     - to update memories types => initializable RAM => EEPROM 
     - to define the result on memories block after a reset 
       (to restore the default value => MAC address, … ). 
     -  
 
11.5 application 
     - to add all registers to test all possible data define in SimAP. 
     - to modify the block: “application_test” to use all possible data. 
     -  
 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




     - to add at the receiver test bench all possible Ethernet frames. 
     - to make a new transmitter test bench. 
     - to make test for the reception and the transmission of a string. 
     - to make test for the reception and the transmission of a register > 8 bits. 
     -  
 
11.7 others 
     - to create a generic to enable or disable the debug mode. 
     - to update the doc: SimAP (before make that, see part: 11.4 memories). 
     - (to add an auto reset for all RAM to be sure to do not stay with a full RAM.)  
     -  
 
11.8 misc 
The small frames are favoured by the checker of free space in RAM.  
 
A GID has only a data type. 
 






  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
12 WHY THESE CHOICES ? 
The device doesn’t work in mode: “half duplex”. 
 
The big problem is when the transmitter sends a frame and receives the signal of a 
collision. 
He must to send JAM (This is 32 bits send for all devices can detect the collision.). 
He must to calculate the waiting time before to resend the frame (To calculate this 
waiting time, it is necessary to use the rule: “Binary exponential Backoff”.). 
 
So the interface works in mode: “full duplex” to simplify the management. 
In this case, the signals: CRS and COL aren’t used. 
 
To have a simple management, this interface doesn’t work with neither the priority of 
a frame and nor acknowledge. 
 
12.1 INTERFACE ETHERNET 
Currently, the interface only works correctly with frames that have an even number of 
bytes.  
(Because at the beginning, I haven’t created the header with an indication of the 
number of the valid bytes at the last line of the frame in the RAM.) 
 
12.1.1 receiver 
The receiver doesn’t check the length of received frame because I’m not sure that is 
only used with an Ethernet frame without extension. 
 
12.1.1.1 crc32 
The Ethernet frame length is 64 to 1'518 bytes. 
And because that, if one takes 16 bits to 16 bits (or more), it is necessary to have 
signals to indicate how many bits are valid. 
 
So to have the signals minimum, the data length of the block: crc32 is 8 bits. 
 
This is why, the block: data_to_word was created. 
(He assembles two received nibbles (4 bits) to have a word of 8 bits). 
 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
12.1.1.2 RAM dp 
 
There is a RAM dp for 2 reasons. 
 
The first, as soon as the data are stored, it's possible to take the received data any 
time, in any order and many times. 
 
The second, it is of more easily being able to coordinate the data between the 
Ethernet interface and the SimAP controller. The RAM makes it possible to 
synchronize the two clocks (rx_clock and sys_clock) and there is not many signals to 
drive communication, only a specific structure (see part: 14.3 RAM structure). 
 
Because the maximum length of an Ethernet frame is 1’518 bytes (12’144 bits) and 
the RAM width is 16 bits (choice to have a sufficient gap in order to write the header 
data), the maximum space taken in RAM is 759 lines. 
With the valid header and the empty header, there is 761 occupied lines. 
 
So it’s necessary to have 10 bits to write the length of a frame and 10 bits, it’s too the 
minimum number of RAM address (with 10 bits, there is 1’024 lines in RAM). 
 
In this case, the data length is 16 bits and the address length is 10 bits. 
 
This is why, the block: rc_data_register was created. 
(He delays a word of 8 bits so that it is assembled with current word of 8 bits to have 
a data of 16 bits). 
 
As it’s not possible (I haven’t found) to init a RAM dual port for a FPGA: Spartan II, 
the block: mux_ram_data was created. 
(He makes it possible to mislead the reader so that it reads an empty header during 
the RAM initialization.) 
 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
12.1.1.3 receiver controller 
 
To not have a too complicated schema, all blocks to drive the receiver are in receiver 
controller. 
 
The block: rc_heart coordinates all others blocks in the block: receiver. So to not 
have memory elements in the heart of the receiver, the blocks: rc_data_registers, 
rc_address_registers and rc_errors_registers were created. 
 
The block: rc_heart has only time: interframe gap to build the RAM structure. 
Because it's the min time during which the data stream is stopped. 
 
Notice: interframe gap (from wikipedia) 
Ethernet devices must allow a minimum idle period between transmission of Ethernet 
frames known as the interframe gap (IFG) or interpacket gap (IPG). It provides a brief 
recovery time between frames to allow devices to prepare for reception of the next 
frame. The minimum interframe gap is 96 bit times (the time it takes to transmit 96 
bits of raw data on the medium), which is 9.6 μs for 10 Mbit/s Ethernet, 960 ns for 
100 Mbit/s (fast) Ethernet, and 96 ns for 1 Gbit/s (gigabit) Ethernet. 
 
In this specific case, the block: interface_Ethernet is connected with the LXT972A 
that is an IEEE compliant Fast Ethernet PHY Transceiver. 
He transmits nibble by nibble (4 bits by 4 bits) each clock blow. And because the 
minimum interframe gap is 96 bits, it’s possible to build the RAM structure of the 




  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




The transmitter is similar to the receiver (The main difference is the direction of data 
stream).  
 
The transmitter doesn’t create the padding of transmitted frame because I’m not sure 
that is only used with an Ethernet frame without extension. 
 
12.1.2.1 transmitter controller 
 
To not have a too complicated schema, all blocks to drive the transmitter are in 
transmitter controller. 
 
The block: tc_heart coordinates all others blocks in the block: transmitter. So to not 
have memory elements in the heart of the transmitter, the block: 
tc_address_registers was created. 
 
The block: tc_IFG_counter is used to create the interframe gap timing. 
 
In this specific case, the block: interface_Ethernet is connected with the LXT972A 
that is an IEEE compliant Fast Ethernet PHY Transceiver. 
The transmitter sends nibble by nibble (4 bits by 4 bits) each clock blow. And he 





  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
12.2 CONTROLLER SIMAP 
The controller SimAP is connected with others parts as RAMs. 
 
To not have a too complicated schema, all blocks to drive the controller SimAP are in 
controller. 
 
The block: controller coordinates all others blocks in the block: controller SimAP. So 
to not have memory elements in the controller of the controller SimAP, the blocks: 
reader_address_registers, writer_address_registers, application_address_registers, 
selector_registers checker and work_register were created. 
 
For the first version, the config memory is included in the block: controller_SimAP 
because this memory isn’t used in the block: application_SimAP_example. 
But he doesn’t used a part of config memory 
 
12.2.1 controller 
For the first version: 
     - the controller works only with the MAC address which is implemented in design. 
     - he works without constants. 
     - he checks only the minimum part of SimAP field to use or not the frame. 
       (Look below, the part: 13.2.1.1parsing.) 
     - he doesn’t work with a physical addressing frame when the EIB mode is 
       selected. 
       (Because, I don’t know how use this frame.) 
     - he doesn’t resend a frame even if she wasn’t sent. 
     - he doesn’t work with the part of config to enable or to disable (communication, 






  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




1) Read the line header in the Rx RAM. 




2) Wait on the flag: “header valid” 




3) Check error name 
     a) if the frame hasn’t an error then 
to continue the parsing. 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0







     b) if the frame has an error then to 
go to the next line to read the next 
header 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
1 - -
next header
error frame number with this error
 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
4) Check Ether Type 
     a) if the frame is a SAoE frame then 
to continue the parsing. 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
1 0 0 0 - -
Destination MAC Address (part 1)
Destination MAC Address (part 0)
Source MAC Address (part 2)
frame length +1
Destination MAC Address (part 2)
Source MAC Address (part 1)








     b) if the frame is not a SAoE frame 
then to go to the next header 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0




Destination MAC Address (part 2)
Destination MAC Address (part 1)
Destination MAC Address (part 0)
Source MAC Address (part 2)
Source MAC Address (part 1)






  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
   Contents of SAoE field. 
PCF GID (part 1)
APCI (part 0)
GID (part 0) NPCI (part 1)




5) Check addressing mode in part PCF 
AM - - - - R
GID (part 0) NPCI (part 1)






If AM = 0 then the frame is in physical addressing mode 
else (AM = 1)  the frame is in group addressing mode. 
 
 




12.2.1.1.1 physical addressing mode 
6) Check destination address 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
1 0 0 0 - -











Source Address (part 2)
Source Address (part 1)










  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
7) Check protocol mode 















     a) if PM = 1 then 8) check TPCI. 












     b) if PM = 0 then to go to the next 
header 
0 - - - - R
0 0 - - - -
- - - -
- - - - - - - - - - - - - - - -









     a) if TPCI = 0x00 then to get size. 






ACK size (part 1)
size (part 0) 0x00
PRIO
     b) if TPCI != 0x00 then to go to the 
next header 
0 - - - - R
0 1
PRIO GID (part 1)








9) Check the selected register and get the offset of registers. 
0 - - - - R
0 1
PRIO GID (part 1)
GID (part 0) ACK size (part 1)
size (part 0) 0x00
RBSEL RBOFF
RBOP RBSIZE  
 
10) Check the selected operation and get the size of data. 
0 - - - - R
0 1
PRIO GID (part 1)
GID (part 0) ACK size (part 1)
size (part 0) 0x00
RBSEL RBOFF
RBOP RBSIZE  
 
End of parsing 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
12.2.1.1.2 group addressing mode 
6) Check broadcast. 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
1 0 0 0 - -
1 - - - - R
1 - - - - - - -
- - - -
- - - - - - - - - - - - - - - -
- - - - - - - - - - - -ECMD
Source Address (part 1)












7) Get GID 
1 - - - - R
1 - - - - - - -
- - - -
- - - - - - - - - - - - - - - -







8) Search GID in config memory 
     if GID is in the config memory then to continue the parsing. 
     else (GID isn’t in config memory) to go to the next header. 
 
9) Check EIS and TPCI 
1 - - - - R
1 - - - - - - -
- - - -
- - - - - - - - - - - - - - - -








     a) if EIS and TPCI are correct then 
check ECMD. 
1 - - - - R
1 - - - - - - -
- - - -
- - - - - - - - - - - - - - - -





     b) if EIS and TPCI aren’t correct 
then to go to the next header 
1 - - - - R
1 - - - - - - -
- - - -
- - - - - - - - - - - - - - - -






End of parsing 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 




The application_SimAP_example receives and transmits data as a RAM with her 
selector. 
He sends an event when the signal: “get_next_event” is high.  
 
This part is not too complicate because it’s only a basic example to make test and to 
have a small demo. 
 
12.3.1 mux and demux 
They are here so that the controller_SimAP see only a RAM with her selector. 
 
12.3.2 blocks: ROM registers, params registers, program memory, 
groupe value registers, groupe description registers 
For this part, I have chosen blocks with registers or a RAM to display a part of 
memories that be can used. 
 
Each of these blocks has only a writer (the controller_SimAP or the application_test). 
 
12.3.3 application_test 
This block has a simple connectivity between registers and IOs. 
He assigns an event number at a state of an input. 
 
12.3.4 event_registers 
The tail is used to store the event until be called. 




  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 





APCI Application Protocol Control Information 
CRC Cyclic Redundancy Check 
ESD End of Stream Delimiter 
ET Ethertype 
FCS Frame Check Sequence 
GID Groupe ID 
ID IDentifier 
IFG Inter-frame gap 
IP Internet Protocol 
MAC Medium Access Control 
MII Media Independent Interface 
NPCI Network Protocol Control Information 
PAD  
PCF Packet Control Field 
PHY PHYsical layer entity sublayer 
SAoE Simple Automation over Ethernet 
SAoIP Simple Automation over IP 
SD SAoE Device 
SFD Start-of-Frame Delimiter 
SimAP Simple Automation Protocol 
SNB SAoE/SAoIP Network Bridge 
SPDA Shared Physical Destination Address 
SPSA Shared Physical Source Address 
SSD Start-of-Stream Delimiter 




  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
13.2 Files and folders for the project 
 
The folder where all information about this project must be store: 
I:\Institut\Projets\MAC 
 
The folder to find information about the board with PHY (Intel chip: LXT972A): 
P:\PCB\Produit\Logical\FPGA-EBS-ETH 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
13.3 RAM structure 
To read data in RAM, there are specific headers. 
 
A header indicates when he is valid, when there’s an error and where are the 
beginning and the end. 
 
There are 3 headers: 
§ empty header 
§ frame header 
§ error header 
 
13.3.1 Structure 








If it’s a frame valid: 
1. frame header 
2. frame data 
3. empty header 
 
By adding the length from frame 
header to address of frame header, 
one obtains address of empty header. 
If an error is occurred: 
1. error header 
2. empty header 
 
 
To have address of empty header, it is 




13.3.2.1 Empty header 
15 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
 
 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
13.3.2.2 Error header 
15 14 12 9 0
HV 0 0error name error number
 
 
HV: Header Valid 
 
Error name: 
§ “000” : nothing 
§ “001” : CRC error 
§ “010” : Rx error 
§ “100” : buffer is full 
 
13.3.2.3 Frame header 
15 9 0
HV 0 0 0 0 0 length
 
 




  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
 
13.4 Abreviations tirée du 802.3 
 
10P label to indicate “pertains to 10PASS-TS port-type” 
10P/2B label to indicate “pertains to 10PASS-TS and 2BASE-TL port-types” 
2B label to indicate “pertains to 2BASE-TL port-type” 
2-PAM two level pulse amplitude modulation 
8802-3 ISO/IEC 8802-3 (IEEE Std 802.3) 
8802-5 ISO/IEC 8802-5 (IEEE Std 802.5) 
AIS Alarm Indication Signal 
ANSI American National Standards Institute 
ASIC application-specific integrated circuit 
ASN.1 abstract syntax notation one as defined in ISO/IEC 8824: 1990 
AUI attachment unit interface 
BER bit error ratio 
BERT Bit Error Ratio Tester 
BIP Bit Interleaved Parity 
BPSK binary phase shift keying 
BR bit rate 
BT bit time 
CAT3 Category 3 balanced cable 
CAT4 Category 4 balanced cable 
CAT5 Category 5 balanced cable 
CD0 clocked data zero 
CD1 clocked data one 
CDR clock and data recovery 
CID Consecutive Identical Digit 
CJPAT continuous jitter test pattern 
CMIP common management information protocol as defined in ISO/IEC 9596-1: 
1991 
CMIS common management information service as defined in ISO/IEC 9595: 1991 
CMOS complimentary metal oxide semiconductor 
CO central office 
CPE customer premises equipment 
CPR coupled power ratio 
CRC cyclic redundancy check 
CRPAT continuous random test pattern 
CRV code rule violation 
CS0 control signal zero 
CS1 control signal one 
CVH clocked violation high 
CVL clocked violation low 
CW continuous wave 
DA destination address 
DCD duty cycle distortion 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
DDJ data dependent jitter 
DFE decision feedback equalizer 
DJ deterministic jitter 
DMT discrete multi-tone 
DSL digital subscriber line 
DTE data terminal equipment 
EFM Ethernet in the first mile 
EIA Electronic Industries Association 
ELFEXT equal-level far-end crosstalk 
EMI Electromagnetic Interference 
EPD End_of_Packet delimiter 
ERDI Enhanced Remote Defect Indication 
FC-PH Fibre Channel—Physical and Signaling Interface 
FDDI fibre distributed data interface 
FEC forward error correction 
FEXT far-end crosstalk 
FIFO first in, first out 
FLP fast link pulse 
FOIRL fiber optic inter-repeater link 
FOMAU fiber optic medium attachment unit 
FOMDI fiber optic medium dependent interface 
FOPMA fiber optic physical medium attachment 
FOTP fiber optic test procedure 
FSW frame synchronization word 
GMII Gigabit Media Independent Interface 
HH header hub 
IB indicator bits 
IEC International Electrotechnical Commission 
IH intermediate hub 
IPG inter-packet gap 
IRL inter-repeater link 
ISI penalty intersymbol interference penalty 
ISO International Organization for Standardization 
LACP Link Aggregation Control Protocol 
LACPDU Link Aggregation Control Protocol Data Unit 
LAG Link Aggregation Group 
LAG ID Link Aggregation Group Identifier 
LAN local area network 
LCD Loss Of Code-Group Delineation 
LLC logical link control 
LLID logical link identifier 
LOF Loss Of Framing 
LOP Loss Of Pointer 
LOS Loss Of Signal 
LSDV link segment delay value 
LT line termination 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
LVDS Low-Voltage Differential Signals 
MAN Metropolitan Area Network 
MAU medium attachment unit 
MC message code 
MDELFEXT multiple-disturber equal-level far-end crosstalk 
MDFEXT multiple-disturber far-end crosstalk 
MDI medium dependent interface 
MDIO management data input/output 
MDNEXT multiple-disturber near-end crosstalk 
MIB management information base 
MMD MDIO Manageable Device 
MMF multimode fiber 
MP message page 
MPCP multipoint control protocol 
MPS Maintain Power Signature 
Mux Multiplexer 
NEXT Near-end Crosstalk 
NLP normal link pulse 
NPA next page algorithm 
NRZI non return to zero and invert on ones 
NT network termination 
NTT Need To Transmit 
OAM operations, administration, and maintenance 
OAMPDU operations, administration, and maintenance protocol 
ODN optical distribution network 
OFL overfilled launch 
OFSTP optical fiber system test procedure 
OH overhead 
OIF Optical Internetworking Forum 
OLT optical line terminal 
OMA Optical Modulation Amplitude 
ONU optical network unit 
ORLT optical return loss tolerance 
P2MP point to multipoint 
P2P point to point 
P2PE point-to-point emulation 
PAF PME aggregation function 
PAM pulse amplitude modulation 
PCB printed circuit board 
PCS physical coding sublayer 
PD Powered Device 
PDU Protocol Data Unit 
PDV path delay value 
PI Power Interface 
PICS protocol implementation conformance statement 
PIPO parallel in parallel out 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
PISO parallel in serial out 
pk-pk peak-to-peak 
PLL phase locked loop 
PLM Path Label Mismatch 
PLS physical signaling sublayer 
PMA physical medium attachment 
PMD physical medium dependent 
PME physical medium entity 
PMI physical medium independent 
PMS-TC physical media specific - transmission convergence 
ppd peak-to-peak differential 
PRBS pseudo random bit sequence 
PSD power spectral density 
PSE Power Sourcing Equipment 
PVV path variability value 
RD running disparity 
REI Remote Error Indication 
RFI radio frequency interference 
RIN relative intensity noise 
RJ random jitter 
ROFL radial overfilled launch 
RS reconciliation sublayer 
SA source address 
SDH Synchronous Digital Hierarchy 
SDV segment delay value 
SEF Severely Errored Frame 
SELV Safety Extra Low Voltage 
SERDES serializer and deserializer circuit 
SES Severely Errored Second 
SHDSL single-pair high-speed digital subscriber line 
SIPO serial in parallel out 
SMF single-mode fiber 
SMSR side mode suppression ratio 
SNR signal-to-noise ratio 
SONET Synchronous Optical Network 
SPD Start_of_Packet delimiter 
SPE Synchronous Payload Envelope 
SR symbol rate 
ST symbol time 
STA station management entity 
STP shielded twisted pair (copper) 
STS Synchronous Transport Signal 
SVV segment variability value 
TBI Ten-Bit Interface 
TC transmission convergence 
TCM trellis coded modulation 
  Doc. Ref: MAC-RPT-000-HEV 
 MAC Project Issue/rev: 2/- 
  Date: October, 2007 




All information contained in this document is the property of the Hes-so. 
Its contents cannot be reproduced or divulged without the school's approval. 
 
TDR time domain reflectometer 
TIA Telecommunications Industry Association 
TLV Type/Length/Value 
TPS-TC transport protocol specific transmission convergence sublayer 
TSS Test Signal Structure 
UCT unconditional transition 
UI unit interval 
UP unformatted page 
UPBO upstream power backoff 
UTP unshielded twisted pair 
VC Virtual Container 
VDSL very high speed digital subscriber line 
VLAN Virtual Bridged Local Area Network (see IEEE P802.1Q) 
VTU VDSL transceiver unit 
VTU-O VTU at the central office end 
VTU-R VTU at the remote end 
WAN Wide Area Network 
WCMB worst-case modal bandwidth 
WIS WAN Interface Sublayer 
WWDM wide wavelength division multiplexing 
XAUI 10 Gigabit Attachment Unit Interface 
xDSL generic term covering the family of all DSL technologies 
XGMII 10 Gigabit Media Independent Interface 
XGXS XGMII Extender Sublayer 
XS Extender Sublayer 
XSBI 10 Gigabit Sixteen-Bit Interface 
 
 












Appendix 8: Time and frequency synchronization 
 
 












The research described in this thesis has been accomplished 
with the support from many people – mentors, colleagues - whom 
we would like to fully acknowledge. Your support, ideas, 
comments and energy were essential in allowing them to 




Patrick ARLOS, supervisor of the thesis. We would like to 
thank you for the time and energy you invested. You guided them 
through our first steps in electrical research, your advices and ideas 
were useful to complete this project. Your drive is contagious. We 




Oliver A. GUBLER, former graduate student. Your 
contribution helps them to solve specific issues we had in VHDL 




Jörgen ANDERSSON, universitetadjunkt. Your explanation 
guided them to understand VHDL language. Thanks also always 
for being available when we needed your help. 
 
 
Karoliina HÄKKINEN, International coordinator exchange 
student. You warmly welcomed them in Blekinge Institute of 
















1. Introduction  5 
 1.1 Global Positionning System 6 
 1.2 Field of Programmable Gate Arrays 8 
 1.3 Other components 10 
  1.3.1 RS-422 10 
  1.3.2 RJ45 11 
  1.3.3 Edge connector 11 
  1.3.4 DB-25 connector 12 
 1.4 VHDL 13 
 1.5 UART 
 
14 
2 Design 16 
 2.1 Functional description 17 
 2.2 Hardware design 19 
 2.3 
  2.3.1 
  2.3.2 









3 Implementation 33 






4 Results obtained 
 
36 
 Conclusion 38 
 










 Appendix A        Abbreviations 
 
A 2 
 Appendix B        Schematics 
 
A 4 
 Master  
 
A 4 






 Appendix C       VHDL Programs 
 
A 9 
 Master program 
 
A 9 
 Slave program 
 
A 14 
 Client program 
 
A 21 
 Appendix D       FPGAs table address 
 
Master’s FPGA table address 
 
Slave’s FPGA table address (4 RJ45) 
 
Slave’s FPGA table address (6 RJ45) 
 
Client’s FPGA table address                            
 





















1. Introduction  
 
 
 Clock synchronization is a well-known problem in distributed 
systems. All algorithms are more or less sensitive to the drift of the 
network’s internal clock. There are different types of 
synchronizations: it can be absolute, relative, global (through the 
entire network) or local, depending on its needs. Certain solutions 
just use information provided by a close environment. In our 
project, we will use a GPS solution. 
 
 
 Work stations, and even office automation are more and more 
networked. The synchronization problem on devices like these is 
important. Indeed, when you create a file on a station, it is 
physically created on a server at the server’s date and not the 
station’s one. Thus, if both are not synchronized, we can have files 




 To solve this problem, we have to synchronize every single 
device on a universal time basic: UTC (coordinated universal 
time), and receive data via a GPS. 
 
 
 Many applications require synchronization between the 
elements of a network. For instance account to account flow of 
money between banks must be synchronized to insure security. 
There is also synchronized data exchange between several 
manufactures of the same brand located on different places which 
could be useful to save money. 
 
 
 In the following part you will find all the explanation on the 
devise we used to build our solution and a presentation of the 











 1.1 Global Positioning System (GPS) 
 
 
 To measure time, it is necessary to have a scale of time, an 
origin on this scale, and an interval of time which will be used as 
unit. Any series of reproducible events can be used as scale of 
time. Astronomy provides us several of them:  rotation of the earth 
on itself or around the sun. 
 
  
 Once the scale defined, we need to check specific properties 
allowing us to scientific work: 
 
 
- Universality, this scale of time must be used and understood by a 
lot of people. 
 
- Reliability, it is necessary that this scale cannot be stopped, and to 
create holes in the measurement of time. 
 
- Precision, the reading must be as precise as possible. 
 
- Uniformity, the measurement value shouldn’t depend on the time 
or the place it has been done. 
 
 
 If we take as oscillator the rotation of the earth on itself, we can 
see that this rotation is not uniform over a few days. That’s the 
reason why we have to find another solution, more reliable. 
 
  
 Since 1955 with the appearance of the atomic clocks we 
noticed a drift of the seconds defined thanks to natural clocks. 
Today, we use artificial oscillators, more precise than quartz clocks 
crystal controlled and the atomic clocks. Those are used more as 




 There are two interesting ways to achieve this synchronization. 
We are able to design the solution through the internet. On the 
basis that we cannot synchronize computers with a great accuracy, 
utilization of a more precise clock via the internet is required. The 
drift is too important when using high-speed networks. 
 





 On the other hand, a Global Positioning System (GPS) 
approach is more suitable in terms of price and accuracy. 
  
  
 Each satellite is equipped of an atomic clock with a precision 
of 1 picosecond (1*10^-12 s). Then we can transport the precision 
of the satellite towards the receiver by synchronization signal: the 
satellite and the receiver generate signals having the same form. 
The receiver compares its signal with that received from the 
satellite and appreciates the shift between the two coded signals. 
This operation makes it possible to be sure to measure the time in 
the same way to the ends and, being sure of the signal course 




 The atomic clocks on the satellites are set to "GPS time", 
which is the number of seconds since 00:00:00 UTC, January 6, 
1980. In 2006, GPS time is 14 seconds ahead of UTC, because it 
does not follow leap seconds. Receivers thus apply a clock-
correction offset (which is periodically transmitted along with the 
other data) in order to display UTC correctly, and optionally adjust 
for a local time zone.  
 
 
In order to get the time needed later in the device we had to use 
The Acutime™ 2000 GPS smart antenna designed by Trimble 
Company.  
 
This antenna is designed for long-term reliability and features 
Trimble's latest GPS technology. It generates a pulse-per-second 
(PPS) output synchronized to UTC within 50 nanoseconds, 
outputting a timing packet for each pulse. 
 
It is the ideal solution for precise timing and synchronization of 
data networks and provides a cost-effective and independent 









1.2 Field of Programmable Gate Arrays 
 
 A field-programmable gate array or FPGA is a semiconductor 
device containing programmable logic components and 
programmable interconnects. The programmable logic components 
can be programmed to duplicate the functionality of basic logic 
gates (such as AND, OR, XOR, NOT) or more complex 
combinatorial functions such as decoders or simple math functions. 
In most FPGAs, these programmable logic components (or logic 
blocks) also include memory elements, which may be simple flip-
flops or more complete blocks of memories. 
 
 
 A hierarchy of programmable interconnects allows the logic 
blocks of an FPGA to be interconnected as needed by the system 
designer, somewhat like a one-chip programmable breadboard. 
These logic blocks and interconnects can be programmed after the 
manufacturing process by the customer/designer (hence the term 
"field-programmable") so that the FPGA can perform whatever 
logical function is needed. 
 
 
 FPGAs are generally slower than their application-specific 
integrated circuit (ASIC). However, they have several advantages 
such as a shorter time to market, ability to re-program in the field 
to fix bugs, and lower non-recurring engineering costs.  
 
 
 To define the behavior of the FPGA you need a hardware 
description language (HDL) or a schematic design. Common 




 Applications of FPGAs include DSP, software-defined radio, 
aerospace and defense systems, ASIC prototyping, medical 
imaging, computer vision, speech recognition, cryptography, 
bioinformatics, and a growing range of other areas. FPGAs 
originally began as competitors to CPLDs and competed in a 




 As their size, capabilities and speed increased they began to 
take over larger and larger functions to the state where they are 





now marketed as competitors for full systems on chips. They now 
find applications in any area or algorithm that can make use of the 
massive parallelism offered by their architecture. 
 
 
 There are 4 principal categories of architecture (see figure 1). 











































1.3 Other Components  
 
 
     1.3.1) RS-422 
 
 
RS-422, is a serial data communication protocol which 
specifies 4 wire, full-duplex, differential line, multi-drop 
communications. It provides for balanced data transmission with 
unidirectional/non-reversible, terminated or non-terminated 
transmission lines. RS-422 does not allow multiple drivers but only 
multiple receivers. You can see on the figure 3 below the RS-422 








Several key advantages offered by this standard include the 
differential receiver defined in RS-423, a differential driver and 
data rates as high as 10 Mega baud. 
 
The mechanical connections for this interface are mostly 
specified by DB-25 connector, however devices exist which have 4 
screw-posts to implement transmit and receive pair only. The 
maximum cable length is 1200 m. Maximum data rates are 10 
Mbaud/s at 12 m or 100 kbit/s at 1200 m. RS-422 cannot 
implement a truly multi-point communications network, although 
only one driver can be connected to up to ten receivers. A common 
use of EIA-422 is for RS-232 extenders. 
 
 






    1.3.2) RJ45 
 
 
RJ45 (Registered Jack 45) is a physical interface often used for 
terminating twisted pair type cables. It has eight "pins" per 
connector. 
 
   1.3.3) Edge connector 
 
An edge connector is the portion of a printed circuit boards 
consisting of traces leading to the edge of the board that are 
intended to plug into an edge connector socket as you can see on 
figure 4 below. 
An edge connector socket, often popularly referenced simply as 
a "slot", is any type of female electrical connector for use with 
printed circuit boards having matching edge connectors. They 
consist of a plastic "box" open on one side, with pins on one or 
both side(s) of the longer edges, sprung to push into the middle of 
the open center. 
The edge connector is a money-saving device because it only 
requires a single female connector, and they also tend to be fairly 
robust. For a time they were used in the vast majority of connectors 
found in computers, but modern computers have demanded many 
more pins than can easily be accommodated on the edge of a 
reasonable size board, and today more traditional male/female 
connectors are more common. 
 
Fig. 4: Edge connector 





    1.3.4) DB-25 Connector 
 
The DB-25 connector (named for its "B"-size "D"-shaped shell 
and 25 pins) is practically ubiquitous in the electronics industry.  
The DB-25 connector is used for a variety of purposes.  Two 
common applications are the parallel printer interface on the IBM 
PC and the RS-232 connections.  
Figure 5 is a good set of figures for DB-25 male and female 




























1.4 VHDL  
 
 
VHDL or VHSIC Hardware Description Language is 
commonly used as a design-entry language for field-programmable 
gate arrays (FPGA) and application-specific integrated circuits in 
electronic design automation of digital circuits. 
Hardware description language 
 
In electronics, a hardware description language or HDL is any 
language from a class of computer languages for formal 
description of electronic circuits. It can describe the circuit's 
operation, its design, and tests to verify its operation by means of 
simulation. 
 
An HDL is a standard text-based expression of the temporal 
behavior and circuit structure of an electronic system. In contrast to 
a software programming language, an HDL's syntax and semantics 
include explicit notations for expressing time and concurrency 
which is the primary attributes of hardware. Languages whose only 
characteristic is to express circuit connectivity between hierarchies 
of blocks are properly classified as net list languages. 
 
HDLs are used to write executable specifications of some piece 
of hardware. A simulation program, designed to implement the 
underlying semantics of the language statements, coupled with 
simulating the progress of time, provides the hardware designer 
with the ability to model a piece of hardware before it is created 
physically. It is this executability that gives the illusion of HDLs 
being a programming language. Simulators capable of supporting 
discrete event (digital), and continuous time (analog) modeling 









1.5 UART  
 
 
A UART or Universal Asynchronous Receiver-Transmitter is a 
piece of computer hardware that translates between parallel bits of 
data and serial bits. A UART is usually an integrated circuit used 
for serial communications over a computer or peripheral device 
serial port. UARTs are now built into some microcontrollers 
 
Basics 
Bits have to be moved from one place to another using wires or 
some other medium. Over many miles, the expense of the wires 
becomes large. To reduce the expense of long communication links 
carrying several bits in parallel, data bits are sent sequentially, one 
after another, using a UART to convert the transmitted bits 
between sequential and parallel form at each end of the link. Each 
UART contains a shift register which is the fundamental method of 
conversion between serial and parallel forms. 
By convention, teletype-style UARTs send a "start" bit, five to 
eight data bits, least-significant-bit first, an optional "parity" bit, 
and then a "stop" bit. The start bit is the opposite polarity of the 
data-line's normal state. The stop-bit is the data-line's normal state, 
and provides a space before the next character can start.  
A stretched "stop" bit also helps resynchronization. The parity 
bit can either make the number of bits odd, or even, or it can be 
omitted. Odd parity is more reliable because it assures that there 
will always be a data transition, and this permits many UARTs to 
resynchronize. 
Speeds for UARTs are in bits per second (bit/s or bps), 
although often incorrectly called the baud rate. Standard 
mechanical teletype rates are 45.5, 110, and 150 bit/s. Computers 
have used from 110 to 230,400 bit/s. Standard speeds are 110, 300, 
1200, 2400, 4800, 9600, 19,200, 28,800, 38,400, 57,600, and 
115,200 bit/s. Concerning our project we will use 9600 bps speed. 
The UART usually does not directly generate or receive the 
voltage levels that are put onto the wires interconnecting different 
equipment. An interface standard is used, which defines voltage 
levels and other characteristics of the interconnection. Examples of 
interface standards are EIA, RS 232, RS 422 and RS 485. 
Depending on the limits of the communication channel to which 





the UART is ultimately connected, communication may be "full 
duplex" (both send and receive at the same time) or "half duplex" 
(devices take turns transmitting and receiving). Beside traditional 
wires, the UART is used for communication over other serial 
channels such as an optical fiber, infrared, wireless Bluetooth in its 
Serial Port Profile (SPP) and the DC-LIN for power line 
communication 
 
Today, UART is commonly used with RS232 for embedded 
systems communications. It is useful to communicate between 
microcontrollers and also with PCs. Many chips provide UART 
functionality in silicon, and low cost chips exist to convert uart to 




































 The most important point in our solution was the clock’s 
accuracy and reliability. The solution had to synchronize the 
different units towards a single input source: GPS receptions. All 
devices had to use the same time format, that’s the reason why we 
chose to use UTC. Indeed, this format is easy to manage and 
compatible with different hardware configurations. 
 
 In order to make easier future upgrades, our solution had to be 
scalable. That’s the reason why we managed to design boards as 
small as possible. Each unit, also called tier, also had to run 
without any other source than the Master’s. An adapted solution 
was also required to face to different setups. 
   
 Each unit should run on a single power source except the 
master which uses two sources. Each unit should be able to detect 
erroneous timing signals in order to prevent spreading of incorrect 
information. 
 
 The GPS acquisition was done by the Trimble Acutime 2000 kit 
[4], based on a multi-channel receiver which needs to be outside at 
the beginning to see if the GPS was working and to configure the 
Port A. The accuracy of the system depends on the satellites’ 
accessibility: we can’t of course receive signals from every 
satellite. In the best case the system accuracy should be around 50 
ns. 
  
 For each tier, the utilization of an FPGA  is required as you can 
see on figure 6 below. We used three Spartan 3 FPGA kits [5], [6] 
operating at a frequency of 50 MHz based on Epson SG-8002JF 
crystal oscillator. Unfortunately and because of climatic conditions 
(temperature, humidity, etc…), these devices do not operate at 
exactly the same frequency. So we always had to check and 
measure their exact frequency. By using the GPS reference of 1 
pulse per second, we just had to increment a counter at each FPGA 
clock’s pulsation. After 1 PPS we noted the number of pulsation 
which gives us the exact Fog’s frequency (f = 1/T). By default we 
should have 50×106 oscillations. 







Fig.6: System’s overview 
 
 
2.1 Functional description 
 
 The solution suggested by Henrik Forsberg in his thesis 
consists of a hierarchical approach centralized by the first tier 
where the time source is. The tiers are named: 
 
· 1st tier: Master. Receiving the PPS, which are the highest 
accurate reference signal used and the UTC from GPS. 
 
· 2nd tier: Slaves, dispatching the signals from the master to 
different clients.  
 
· 3rd tier: Clients (or measurement points). In our final 
design, we can have up to 6 Clients per Slave. 
 
 We receive signals from the GPS station on the first tier 
(Master) and then transmit it to the Slaves which can be servers of 
different networks, in the end leading us to the third and last tier, 
what we call Clients: workstations for instance. We can process 
without slave if the distance is shorter than 1200m or if only four 





clients are requested. In our application the client receive directly 






Fig.6.1: Functional description 
 
 As you can see on this figure, the Master communicates with 
the GPS Antenna. The Master sends data to configure the antenna 
(with Trimble Acutime in our case) and to enable the 
communication and receives all the data from it. With those data 
the Master obtains a Time and PPS. It will transmit that 
information to all the boards linked to it. For the Time we use two 
UARTs. The first to decode the data send by the antenna, then we 
choose the appropriate data we need, and finally the second UART 
allow to send those data to Clients or Slaves 
 The Master receives Delay request from Clients or Slaves. 
When it receives this request (a bit high), it can resend directly this 
bit or wait few seconds before to resend it if there is a delay due to 
the wire between the Antenna and it (this delay is a constant that 
we can define in our code). 
 
 When the Client receives the answer from the Master, it can 
calculate its delay (due to the wire) dividing the time between 
sending and receiving by two. It also receives Time and PPS from 
the Master. With an appropriate UART we decode the Time sends 
by the Master and adding the Delay we obtain the correct time. We 
can display this time on the FPGA or use it by a different way. 
 
 The Slave allows to connect more Clients and to increase the 
distance between Clients and Master. It receives Time and PPS 
that it transmits directly to the Clients linked to it. It also calculates 
the Delay between Master and it. When it receives the delay 
request from one its Clients, the Slave wait during the delay due to 
the wire between Master and it before resending the bit. 







2.2 Hardware design 
 
 
We designed three boards; the schematics are presented in 
appendix (from page A4 to A8) In Table 1 we list the equipment 
needed to build the boards.  In Figure 7, 8 and 9 we show an 










































































Fig. 7: Master board 






























































































































































































Fig. 9: Client board 
 
In order to reach the objectives we needed different software 
and tools. Find a list of below:  
 
- Proteus Software 
- PCB Express (freeware: http://www.expresspcb.com ) 






- Cutting pliers 
- Soldering station 
- Soldering pump 
- Multimeter 
- Electric cables of different colors 
 
Moreover we needed the components we described before. Thanks 
to documentations we founded [2],[3]we made a list of all the 
items -the number needed are specified in the table below. Plastic 
boards are also requested to solder components on it. You need a 
100mm*160mm for Master and Slave and a smaller 80 mm*60mm 
for the Client one. 
 
 Elfa Reference Master Slave Client Total 
DIN 25 FCC17B25PE-A50 2   2 
RJ45  FRJA-408 4 1 1 6 
RJ45 dual FRJA-408-02  3  3 
Socket 16 pins 0-0390261-4 5 5 1 11 





1 1  2 
Power supply 
GPS 
 1   1 
LED 204-10SURD 2 1 2 5 
Resistor 
100ohms 
RD18JN100TJ2 1 1 1 3 
RS422 quad 
transmitter 
DS26LS31CN 3 3  6 
RS422 quad 
receiver 
DS26LS32ACN 2 2 1 5 
RS422 single 
transmitter 
SN75176A 4 7 1 12 
RS422 single 
receiver 
SN7517A  3  3 
Table 1: Equipment used in board construction 
 





2.3 Software design 
 
Objectives of the software part: 
   
- All the clients have to be synchronized on time. 
- The slave have to calculate is own delay with the master. 
- The client have to calculate is own delay with the slave. 
- The GPS send the PPS. Master and slave have to transmit it. 
Master, slave and client must post it. 
- Calculate continuously the number of seconds since the 
creation of the UTC Time (6th January 1980) (32 bits) 
- Calculate fraction of second (64 bits). 
 
In order to build the VHDL programs for each tier, we needed to 
understand exactly how master, slave and client worked. Thus we 
have built module and schematics for each tier. Module helped 
them to understand the global operation, ways in and ways out for 
the PPS, time and delay when the schematics where useful to build 







The Master receives and treats the data of time and frequency. It 
is the starting point of our solution and the only source of time that 
must synchronize all the other devices thereafter.  
It receives the PPS, which is the highest accurate reference signal 





You can see this module on figure 10. Each circle represents a 
module of our program. Arrows are the inputs and outputs required 
by every module to work. Concerning the Master, we have got 5 
different modules: Clock, PPS handler, GPS configuration & 
control, Delay and Time handler. 
 
The module Clock is a 32 bits counter which counts each FPGA 
Pulse from the CLK and gives the counter value. This one 
represents the oscillation of the FPGA Clock. 
 
The PPS Handler needs the PPS GPS (the Pulse Per Second 
coming from the GPS Antenna) and the Clock counter (described 





above) to calculate the Frequency of the FPGA Clock. It also 
transmits the PPS with PPS OUT.  
 
The DELAY module allows the calculation of the delay time due 
to the wire between the master and the board linked to (Slave or 
Client). So it needs a signal DELAY BIT IN (the number indicate 
on which RJ45 the signal come from) coming from the Slave or 
Client.   
 
 
When the Master receives it, it sends another signal DELAY BIT 
OUT to the Slave or Client (calculating the time between the bit 
sent and the one received, it could know its delay). We also have a 
constant called OWN DELAY which can indicate the theoretical 
delay between the Master board and the GPS Antenna. 
 
Then we have the TIME HANDLER which transforms the GPS 
TIME (coming from the GPS Antenna) in a TIME OUT 
transmitted to the linked board. 
 
Finally we have the GPS Configuration & Control which permit 
the communication GPS – Computer thanks to the FPGA. 
 












To understand each module, we need to take a look inside and 
describe any single operation, what we called the schematics. 
 
On the Master’s Clock, see figure 11, you can see how works the 
32 bits counter. We have the Frequency (which is the oscillation of 
the FPGA Clock) and we count each pulse. Then we transmit this 






































Delay bit in 1 
Delay bit in 2 
Delay bit in 3 
Delay bit in 4 
Own delay 
Delay bit out 1 
Delay bit out 2 
Delay bit out 3 






RS232 Port B in 
RS232 Port A in 
RS422 Port A in 
RS422 Port B in 
RS232 Port B out 
RS232 Port A out 
RS422 Port B out 
 [0.1] 






Fig.11: Master’s clock 
 
 
For the PPS Handler, on figure 12, we need the Clock (32 bits 
value) and the PPS. With the software (piece of code you can see 
into the Master Program in the Appendix) we put the value of 
Clock into a LATCH for the first PPS goes high. For the second 
PPS we put the value into another latch. Then we do a subtraction 
with the two Latch to know the number of pulse during one second 


















The Time handler permits to transform the Time received by the 
GPS Antenna into a time easier to transmit. For that we use two 
UART as shown on figure 13. The Time coming from the GPS is a 
serial signal, so we need a UART Receiver to have a parallel 
message. Then we can transform the data and just keep the 
interesting part. When we got it, we transform the parallel message 
into a serial signal with the UART Transmitter and we have the 















Fig 13:  Master’s Time handler 
 
The Delay module is very easy to understand. When we receive a 
Bit coming from the board linked to the Master (called Delay PPS 
in) we wait during OWN DELAY (its value is 0 in theory) and 
resend it, see figure 14. 
 
 
Fig 14: Master’s Delay 
8 









The Slave is connected to the Master. We could have many 
slaves, but chose to focus on only one. Its accuracy must not 
depend on the distance from the Master. Finally it has to keep the 
time and frequency synchronization as precise as possible, and 
transmit it to the Clients. It acts as a relay between the Master and 
Clients and is very useful when working on long distances (more 




You can see this module on figure 15. It is the same kind of 
figure than the Master’s module. We have just 4 modules in this 
case. CLOCK is exactly the same than the master.  
PPS HANDLER does the same operation but doesn’t return the 
Frequency (in our Slave Program in the Appendix we calculate the 
Frequency so we can use it later, or just display it on a screen) 
TIME HANDLER just relay the TIME from the Master to the 
Client. 
Finally the DELAY is the only part really different from the 
Master. Delay bit in is the signal received from the client and 
Delay bit out is the signal sent to it (the number indicate which 
RJ45 we are using). Delay bit out M is the signal that the Slave 
sends to the Master and of course Delay bit in M is the signal 
received from it.   










Slave’s Clock and the Slave’s PPS Handler is exactly the same 
than the Master’s Clock and the Master’s PPS Handler. 
 
Slave’s Time Handler just relay the time received from the master 
and sends it to the client, see figure 16. 
 
Fig. 16:  Slave’s Time Handler 
 
 
The Delay works like on the Master but the Wait statement is not 
define by a constant (like OWN DELAY), see figure 17. Actually 
the Slave calculates his “OWN DELAY”.  For that every X second 











Signal [0. 1] 
Signal [0. 1] 
Counter Value 
Signal [0. 1] 
Signal [0. 1] 
PPS HANDLER 
PPS IN PPS OUT 
CLOCK CLK 
DELAY 
Delay bit in 1 
Delay bit in 2 
Delay bit in 3 
Delay bit in 4 
Delay bit in M Delay bit in M 
Delay bit out 1 
Delay bit out 2 
Delay bit out 3 
Delay bit out 4 
TIME HANDLER Time in Time out 
Serial Data 
Time in Time out 





Slave send a bit (Delay Bit Out M) with the BIT GENERATOR. 
When it send the bit we start the COUNTER 32 bits and we put its 
value into a Latch (Latch 32 bits) when we receive the bit from the 
Master (Delay Bit in M). Then we DIVIDE BY 2 to have to delay in 
the wire in one way. Here we have the delay needed to implement 
the WAIT. Like in the Master when we receive a bit from the Client 
(Delay BIT in) we wait during this delay before sending it back 












Clients are our measurement points. They are connected to the 
Slave or the Master and located at the last tier of our hierarchy. 
Their purpose is obviously to give us information on the overall 
system performance by measuring time and frequency. We tested 
our final design with only 2 clients. Of course we could have a 
better idea of the solution's performance by multiplying Clients, 
but we would also need more FPGAs, which are quite expensive. 
However, we can plug up to 6 Clients on the Slave, increasing by 











You can see this module on figure 18.  
 
CLOCK and PPS HANDLER are exactly the same than those in 
the Master. 
The DELAY module is quiet similar than the Slave one. We send 
a bit (Delay bit out) and when we receive the bit from the Slave or 
the Master (delay bit in) with the CLK and the Frequency 
(calculate into the PPS Handler) we can calculate the DELAY 
ESTIMATION. 
In the TIME HANDLER we receive the time coming from the 




Fig. 18: Client’s module 
Parallel Data Serial Data 
[0. 1] [0. 1] 
 [0. 1] 
 [0. 1] 
Frequency value 
Counter value 
Signal [0. 1] 









Delay bit in 
Delay bit out 
TIME HANDLER 
Time in System Time 
§ 32-bit: Number of 
second 
§ 64-bit: Fraction of 









Client’s Clock and the Client’s PPS Handler is exactly the same 
than the Master’s Clock and the Master’s PPS Handler. 
 
We receive the Time (Time in) into the TIME HANDLER, as you 
can see on figure 19. Then we use a UART receiver to transform the 
serial into a parallel message and we use a Time Builder to get the 
format we want. Finally we add Delay estimation to have the correct 
time. 
 




The DELAY, figure 20 below, is almost the same than the Slave 
one. We generate a bit and start (or reset) a Counter. When we 
receive the bit from the Master or the Slave we put the counter value 
into a Latch. We divide by two to have the delay in one way. At this 
moment we have the delay in number of pulse. We divide by the 























3.1 Hardware implementation 
 
The first job was to understand the way the RS 422 worked 
both in transmitter and receiver. Thus we made test on IDL-600 
Analog Lab device with RS 422 on test board linked with 
oscilloscope to see the evolution of the signal on the different pins.  
 
 
Once we had understood and validated the exact operation of 
that device we had to determine the number needed for each board 
before building the schematics. 
 
 
Then we have started drawing the schematics through Proteus 
software first. After a lot of modifications due to some 
improvements, a first set of boards was drawn. 
 
 
According to the schematics we have built the three first tiers 
and tested and validated it with the different FPGAs (Find the list 
of test in the software part – See chapter 3.4 page 31) Find the tiers 





Fig. 218: Master’s board 











Fig. 23: Client’s board 
 
We continuously improve the boards thus we succeed in 
reducing the number of entrance data in the FPGA which helped 
them to facilitate the programmation. 
 
Finally we have drawn the final boards through PCB software. 
It allowed the building of printed circuit boards instead of cable 
boards. (Find the schematics in appendix B from page A 4 to A 8). 
 
 





3.2 Software implementation 
 
 
The main aim was to build a VHDL program for each master, 
slave and client. In order to reach this goal, we made several 
programs, helped with books [7], [8], to improve our programming 
skills first and to help to build the final one for each tiers. 
 
 
Here is the list of all the programs we made before building the 
final one. 
 
- Xilinx tutorials to know how to use ISE 7.1 
  
In depth tutorial 
 Quick start tutorial 
 
- Connector polarity test 
 
- FPGA Communication 
  
LED utilization 
 Switch utilization 
 Expansion connector utilization for FPGA´s external 
communication 
 FPGA´s clock utilization 
 Time reception test 
 PPS reception test 
 FPGA´s serial port communication test (We used 
HyperTerminal software to observe the received signals) 
 Bit generation test 
 Frequency calculation test 
 UART test 
  
Once all those programs built, we started to program the final 
code for each master, slave and client. Thanks to the module and 
schematics drew before and the programming skills developed 
with the different previous programs we succeeded in 
programming the codes for each tiers. Find the three codes in 
appendix C (Comments are added in the different programs to 
explain the different parts) 
 
 





4. Results obtained 
 
 
We built one Master board, two Slaves - one featuring 4 RJ45 
and the other 6 RJ45 - and also two Clients and all of them are 
working properly. 
  
We also drawn all the schematics corresponding to those 
boards in cable configuration as well as in printed circuit 
configuration in case of a future industrialization 
 
We succeeded in calculate delays for each tier. To sum up we 
send a bit and start a counter simultaneously. When the upper level 
tier (Master for slave and slave for client) receive this bit, it sends 
it back to the transmitter tier. We stop the counter when we receive 
the bit back. The delay is the time needed to realize this operation. 
 
 
We also succeeded in transmitting and posting the PPS for each 
tier. 
 
We are able to send the Port A on the three different tiers but 
we didn’t treat the data received because UART doesn’t work. We 








If  we the decision to use mechanical UART is taken, the main 
work to do at this step of the project will be to look forward how to 
introduce UARTs on the boards in understanding properly  how it 






Create a UART receiver to receive the Port A on the Master 
and treat the data of the 0x8F-AB 
(http://www.diamondpoint.co.uk/manuals/gps/trimble/Acutime200
0.pdf, see page 181) to select only the useful data and send those 
ones to the client thanks to a UART transmitter.  






The client, helped with a third UART, will treat and post the 
message received. It will receive 96 bits of data (32 bits for the 
number of second and 64 bits for the fraction of second) 
 
 
For instance for the number of second, the master select the 8F-
AB packet and keep only the useful data such Time of week 
(TOW), Week number,UTC Offcet and UTC Time and send the 
selected data to the client which use the formulate below to 
calculate the number of second. 
 
 
Number of second = UTC Time + GPS Week number*number of 
second in a week + Time of Week + UTC Offset 
 
 










One interest of this project was to improve our skills in 
working in a team in an international environment. Indeed each 
member worked on a different part, thus forced us to work hand by 





We also improved our knowledge in project management after 
building a project plan at the beginning, we tried to follow it as 




We learned a lot in electrical engineering after carried out a 
project of five months in this specific department and more 




Unfortunately we didn’t succeed in finishing the whole project, 
even if we did a lot of work. We needed a bit more time to 
conclude the unit. We hope this will be done by our successors 
thanks to our work and this project will be useful for a possible 
industrialization to answer issues of synchronization for many 
applications. 
 
