OpenCores
URL https://opencores.org/ocsvn/core1990_interlaken/core1990_interlaken/trunk

Subversion Repositories core1990_interlaken

[/] [core1990_interlaken/] [trunk/] [documentation/] [protocol_survey_report/] [Sections/] [Obtaining_and_building.tex] - Diff between revs 8 and 9

Show entire file | Details | Blame | View Log

Rev 8 Rev 9
Line 1... Line 1...
\section{Core1990}
\section{Core1990}
 
\label{Appendix:Core1990}
Core1990 is a point-to-point communication protocol using the royalty-free Interlaken protocol as it's foundation. It is designed by engineers and students of the Electronics Department of Nikhef (Amsterdam, The Netherlands) with large experiments at CERN (e.g. ATLAS) in mind. \\
Core1990 is a point-to-point communication protocol using the royalty-free Interlaken protocol as it's foundation. It is designed by engineers and students of the Electronics Department of Nikhef (Amsterdam, The Netherlands) with large experiments at CERN (e.g. ATLAS) in mind. \\
The development of Core1990 was intended to publish an open source protocol providing high throughput with a small percentage of overhead. Certain features like flow control and error detection are included.
The development of Core1990 was intended to publish an open source protocol providing high throughput with a small percentage of overhead. Certain features like flow control and error detection are included.\\
 
 
 
This document will describe setting up the core including configurations of IP-cores included in the design. During development and writing this document a Xilinx VC707 evaluation board is used and sometimes certain IO's will be referred to. This is of course board dependent and these are mentioned as examples to clear things up.
 
 
\begin{figure}[H]
\begin{figure}[H]
        \centering
        \centering
        \includegraphics[width=.7\textwidth]{Core1990_logo.jpg}
        \includegraphics[width=.7\textwidth]{Core1990/Core1990_logo.jpg}
        \caption{Core1990 logo}
        \caption{Core1990 logo}
        \label{fig:Core1990_logo}
        \label{fig:Core1990_logo}
\end{figure}
\end{figure}
 
 
\subsection{Features}
\subsection{Features}
        Core1990 is packet with a lot of features providing data integrity and detection of errors while transmitting. These features are designed to be compliant with those featured in the interlaken protocol definition.
        Core1990 is packed with a lot of features providing among others data integrity and detection of errors while transmitting. These features are designed to be compliant with those featured in the Interlaken protocol definition.
 
 
        \begin{itemize}
        \begin{itemize}
                \item Lane rate transceiver dependent
                \item Lane rate transceiver dependent
                \item Support framing consistent with the Interlaken Protocol Definition
                \item Support framing consistent with the Interlaken Protocol Definition
                \item Generates CRC-24 and CRC-32 for error checking
                \item Generates CRC-24 and CRC-32 for error checking
Line 38... Line 42...
                [Core1990
                [Core1990
                        [constraints]
                        [constraints]
                        [scripts]
                        [scripts]
                        [simulation]
                        [simulation]
                        [sources
                        [sources
                                [Interlaken\_Interface.vhd, file, label=right: \small{The main file}]
                                [Interlaken\_Interface.vhd, file]
                                [ip\_cores
                                [ip\_cores
                                        [clk\_40MHz.xci, file]
                                        [clk\_40MHz.xci, file]
                                        [RX\_FIFO.xci, file]
                                        [RX\_FIFO.xci, file]
                                        [Transceiver\_10g\_64b67b.xci, file]
                                        [Transceiver\_10g\_64b67b.xci, file]
                                        [TX\_FIFO.xci, file] ]
                                        [TX\_FIFO.xci, file] ]
Line 87... Line 91...
        \end{forest}
        \end{forest}
 
 
        \vspace{1mm}
        \vspace{1mm}
        For building the project Vivado has to be opened and the vivado\_import\_virtex7.tcl has to be executed. This can be done by changing the directory in the tcl console to the scripts folder and then giving the command 'source vivado\_import\_virtex7.tcl'. This will add the project folder to the directory tree and contains the just generated project.
        For building the project Vivado has to be opened and the vivado\_import\_virtex7.tcl has to be executed. This can be done by changing the directory in the tcl console to the scripts folder and then giving the command 'source vivado\_import\_virtex7.tcl'. This will add the project folder to the directory tree and contains the just generated project.
 
 
 
        When the project has been imported in vivado the structure should match the one depicted in Figure \ref{fig:Core1990_VivadoCore}.
 
 
 
        \begin{figure}[H]
 
                \centering
 
                \includegraphics[width=\textwidth]{Core1990/Core1990_VivadoCore.png}
 
                \caption{Structure of the project in Vivado}
 
                \label{fig:Core1990_VivadoCore}
 
        \end{figure}
 
 
\newpage
\newpage
\subsection{Transceiver IP Core}
\subsection{Transceiver IP Core}
        Configuring the transceiver is an essential step in setting up the core. This will describe the correct settings to use for the functional behavior of the protocol. In case the transceiver is configured in a wrong way, no data or corrupted data will arrive at the receiving side. This section will guide the user to set up the transceiver in an easy way without adjusting too many clocks, targeting the VC707 board.\\
        Configuring the transceiver is an essential step in setting up the core. This will describe the correct settings to use for the functional behavior of the protocol. In case the transceiver is configured in a wrong way, no data or corrupted data will arrive at the receiving side. This section will guide the user to set up the transceiver in an easy way without adjusting too many clocks, targeting the VC707 board.\\
 
 
        The transceiver core can be configured by browsing through a separate window that will pop up. The fist tab named GT Selection should already have the GTX as GT Type selected and the shared logic should be included in the core, not the example design.
        The transceiver core can be configured by browsing through a separate window that will pop up. The fist tab named GT Selection should already have the GTX as GT Type selected and the shared logic should be included in the core, not the example design.
 
 
        After this the second tab will provide more important options. The line rate should be set to 10 Gbps while the reference clock can be set at 125 MHz. This clock is available on the board at IO pins AH7 and AH8, REFCLK0\_Q0. Using the QPLL GTX X1Y2 can be used. Figure \ref{fig:IP_TransceiverConf1} shows the correct configuration.
        After this the second tab will provide more important options. The line rate should be set to 10 Gbps while the reference clock can be set at 125 MHz. This clock is available on the board at IO pins AH7 and AH8, REFCLK0\_Q0. Using the QPLL GTX X1Y2 can be used. Figure \ref{fig:IP_TransceiverConf1} shows the correct configuration.
 
 
        \begin{figure}[H]
        \begin{figure}[H]
                \centering
                \centering
                \includegraphics[width=\textwidth]{IP_TransceiverConf1.png}
                \includegraphics[width=\textwidth]{Core1990/IP_TransceiverConf1.png}
                \caption{Transceiver lane rate and reference clock selection}
                \caption{Transceiver lane rate and reference clock selection}
                \label{fig:IP_TransceiverConf1}
                \label{fig:IP_TransceiverConf1}
        \end{figure}
        \end{figure}
 
 
        The encoding and clocking tab shows other important settings. For both the TX and RX, the external data width should be set at 64-bits while the internal data width is 32 bits. Encoding has to be set at 64B/67B with Internal Sequence Counter and decoding has to be set at 64B/67B. The DRP/System Clock Frequency has to be set at 40 MHz. Figure \ref{fig:IP_TransceiverConf2} shows the right settings.
        The encoding and clocking tab shows other important settings. For both the TX and RX, the external data width should be set at 64-bits while the internal data width is 32 bits. Encoding has to be set at 64B/67B with Internal Sequence Counter and decoding has to be set at 64B/67B. The DRP/System Clock Frequency has to be set at 40 MHz. Figure \ref{fig:IP_TransceiverConf2} shows the right settings.
 
 
        \begin{figure}[H]
        \begin{figure}[H]
                \centering
                \centering
                \includegraphics[width=0.95\textwidth]{IP_TransceiverConf2.png}
                \includegraphics[width=0.95\textwidth]{Core1990/IP_TransceiverConf2.png}
                \caption{Transceiver encoding and system clock selection}
                \caption{Transceiver encoding and system clock selection}
                \label{fig:IP_TransceiverConf2}
                \label{fig:IP_TransceiverConf2}
        \end{figure}
        \end{figure}
 
 
        The other tabs are not important and no settings should be changed in these tabs. Figure \ref{fig:IP_TransceiverConf3} shows a complete summary of the features included with the transceiver when this core will be generate. The user should have the same settings on screen.
        The other tabs are not important and no settings should be changed in these tabs. Figure \ref{fig:IP_TransceiverConf3} shows a complete summary of the features included with the transceiver when this core will be generate. The user should have the same settings on screen.
 
 
        \begin{figure}[H]
        \begin{figure}[H]
                \centering
                \centering
                \includegraphics[width=0.95\textwidth]{IP_TransceiverConf3.png}
                \includegraphics[width=0.95\textwidth]{Core1990/IP_TransceiverConf3.png}
                \caption{Transceiver summary of configuration}
                \caption{Transceiver summary of configuration}
                \label{fig:IP_TransceiverConf3}
                \label{fig:IP_TransceiverConf3}
        \end{figure}
        \end{figure}
 
 
\newpage
\newpage
 
 
\subsection{System Clock IP Core}
\subsection{Clocking Wizard IP Core}
        The system clock will be generated using a 200 MHz input at IO pins E18 and E19. The frequency will be scaled down using the Xilinx Clocking Wizard which generates an IP core. This is one of the clocks that will be used by the transceiver.
        The system clock will be generated using a clock input provided to the chip. In this case this is a 200 MHz input at IO pins E18 and E19. The frequency will be scaled down using the Xilinx Clocking Wizard which generates an IP core. Two clocks will be provided in this case. One will end up being the DRP clock of the transceiver and another clock will be the clock selected by the user. This clock can be connected to external user logic, for example a data generator, or the FIFO write and FIFO read on respectively the TX and RX side.
 
 
        \begin{figure}[H]
        \begin{figure}[H]
                \centering
                \centering
                \includegraphics[width=\textwidth]{IP_CLK40Conf1.png}
                \includegraphics[width=\textwidth]{Core1990/IP_CLK40Conf1.png}
                \caption{System clock setting the board interface}
                \caption{Clocking wizard input clock(s) and features}
                \label{fig:IP_CLK40Conf1}
                \label{fig:IP_CLK40Conf1}
        \end{figure}
        \end{figure}
 
 
        The input clock is differential and this should be configured like seen in Figure \ref{fig:IP_CLK40Conf1}. The second tab contains clocking options and this core makes use of a MMCM (Mixed-Mode Clock Manager). From clocking features only Frequency synthesis and phase alignment are selected. The jitter optimization is balanced and the input frequency of the primary clock is 200MHz. The secondary clock is not important. Figure \ref{fig:IP_CLK40Conf2} shows this configuration.
        The first tab of the clocking wizard provides some basic information on the input clock which in this case will be a 200 MHz differential clock. It is important to select 'differential clock capable pin' under source here. This core makes use of a MMCM (Mixed-Mode Clock Manager). From clocking features only Frequency synthesis and phase alignment are selected. The jitter optimization is balanced and the input frequency of the primary clock is 200MHz. There is no secondary clock to use thus this is not selected and relevant. Figure \ref{fig:IP_CLK40Conf1} shows the configuration on the first tab. \\
 
 
 
        The second tab will provide more configuration on the output clocks. Like depicted in Figure \ref{fig:IP_CLK40Conf2} there will be one 40 MHz clock and this has to stay at 40 MHz. Another clock is set at 150 MHz but this is the clock available for user logic like mentioned earlier. This can be configured as reference frequency to send data packets at. It is up to the user to determine whether this clock will be used and at which frequency it will run. However the maximum frequency of this clock also determines on the lane rate of the transceiver and at which speed the Interlaken interface itself runs. The example design in \ref{Appendix:Core1990_ExampleDesign} will also use this clock and describe more on it's usage. All clocks use a duty cycle of 50\% and from the optional outputs only the reset and locked pins are required.
 
 
        \begin{figure}[H]
        \begin{figure}[H]
                \centering
                \centering
                \includegraphics[width=\textwidth]{IP_CLK40Conf2.png}
                \includegraphics[width=\textwidth]{Core1990/IP_CLK40Conf2.png}
                \caption{System clock setting the options}
                \caption{Clocking wizard output clocks}
                \label{fig:IP_CLK40Conf2}
                \label{fig:IP_CLK40Conf2}
        \end{figure}
        \end{figure}
 
 
 
        The last important tab is the summary tab. This should give an overview that contains the same information and values as depicted in Figure \ref{fig:IP_CLK40Conf3}. However if the second output clock is set at another frequency this will of course give a different value is the overview.
 
 
        \begin{figure}[H]
        \begin{figure}[H]
                \centering
                \centering
                \includegraphics[width=\textwidth]{IP_CLK40Conf3.png}
                \includegraphics[width=\textwidth]{Core1990/IP_CLK40Conf3.png}
                \caption{System clock configuring the output clock}
                \caption{Clocking wizard summary}
                \label{fig:IP_CLK40Conf3}
                \label{fig:IP_CLK40Conf3}
        \end{figure}
        \end{figure}
 
 
        Only one output clock is required so this one will be selected with a 40MHz output. The duty cycle should remain 50\% which can be seen in Figure \ref{fig:IP_CLK40Conf3}. From the optional outputs only the reset and locked pins are required.
        \newpage
 
 
 
\subsection{FIFO IP Cores}
 
        The Core1990 design contains two FIFO's which are used for the to be transmitted and received data. These two FIFO's have a different purpose but their configurations are nearly identical. This is why they are both described in one section.\\
 
 
        The summary tab give an overview that contains the same information and values as depicted in Figure \ref{fig:IP_CLK40Conf4}. When another value is noted in the summary, there is a chance the clock won't be of the same frequency.
        The TX side FIFO stores all user data transmitted to the interface. Configuring the FIFO starts at the basic tab which allows the user to define the interface type and implementation of the FIFO. Figure \ref{fig:IP_FIFOTXConf1} depicts the first tab. In this case the native interface is used in combination with an independent clocks distributed RAM and two synchronization stages. This way the FIFO can also be used for data crossing clock domains.
 
 
        \begin{figure}[H]
        \begin{figure}[H]
                \centering
                \centering
                \includegraphics[width=\textwidth]{IP_CLK40Conf4.png}
                \includegraphics[width=\textwidth]{Core1990/IP_FIFOTXConf1.png}
                \caption{System clock summary of configuration}
                \caption{FIFO generator basic settings}
                \label{fig:IP_CLK40Conf4}
                \label{fig:IP_FIFOTXConf1}
        \end{figure}
        \end{figure}
 
 
        \newpage
        The second configuration tab, as seen in Figure \ref{fig:IP_FIFOTXConf2}, offers more settings on the data width, read mode and initialization. This is meant as a standard FIFO so this option is selected, the only difference with the other mode is interface has to wait one clock cycle after read enable contains a logic high input.\\
 
 
\subsection{FIFO IP Cores}
        The FIFO has a data width of 69 bits. This value has been chosen because all essential information now fits in a single packet entering the FIFO. Such packet fits the user data, Start Of Packet, End Of Packet and End Of Packet validbytes. \\
 
 
\subsection{Simulating the core}
        The write depth of the FIFO can be selected according to user preference. In the example 32 packets have been chosen to be sure enough space is available but this could possibly be lowered. Besides this the FIFO contains a reset pin and the output resets to zero. The reset is also synchronized in the core.
        Simulation of the core1990 protocol can easily be configure by running the simulation script. This can be done by browsing to the scripts folder again and running the tcl command 'source simulation.tcl'. After this a short explanation of the command this script accepts should appear. For example if the user would like to simulate the decoder, this can be done by giving the command 'simulate decoder' in the tcl console. \\
 
 
        \begin{figure}[H]
 
                \centering
 
                \includegraphics[width=\textwidth]{Core1990/IP_FIFOTXConf2.png}
 
                \caption{FIFO generator data port and initialization configuration}
 
                \label{fig:IP_FIFOTXConf2}
 
        \end{figure}
 
 
 
        In the third tab, depicted in Figure \ref{fig:IP_FIFOTXConf3}, several status flags can be enabled which are very useful. The read port for example uses a valid flag in case the data is really valid. This prevents the interface to transmit duplicated while there is no new data. When valid is a logic low then data will not be read. There are also a few valid programmable flags. In this case Multiple Programmable Full Threshold Constants are used which are useful in combination with flow control.
 
 
        If the link doesn't behave as expected or is malfunctioning, the situation can be analyzed in simulation. This makes locating the error easier.
        \begin{figure}[H]
 
                \centering
 
                \includegraphics[width=\textwidth]{Core1990/IP_FIFOTXConf3.png}
 
                \caption{FIFO generator status flags}
 
                \label{fig:IP_FIFOTXConf3}
 
        \end{figure}
 
 
 
        The fourth tab contains setting on reading the data count in the FIFO. As usual a summary like the one depicted in Figure \ref{fig:IP_FIFOTXConf4} will always be visible in the last tab. Here you can check whether the necessary settings are configured correctly.
 
        \begin{figure}[H]
 
                \centering
 
                \includegraphics[width=\textwidth]{Core1990/IP_FIFOTXConf4.png}
 
                \caption{FIFO generator summary}
 
                \label{fig:IP_FIFOTXConf4}
 
        \end{figure}
 
 
 
        \newpage
\subsection{Example design}
\subsection{Example design}
        During the design stage of Core1990 multiple tests have been run to inspect how the link behaves, whether the correct data arrives or how robust the link itself is. These tests have been performed by implementing a data generator connected to the Core1990 inputs. A VIO (Virtual Input/Output) is used to control the length of bursts and an ILA (Integrated Logic Analyzer) is used to sample the input and output data (ChipScope). The input data will be pipelined for alignment between the two. This will make it easier to detect errors and ensure data integrity.\\
        \label{Appendix:Core1990_ExampleDesign}
 
        During the design stage of Core1990 multiple tests have been run to inspect how the link behaves, whether the correct data arrives or how robust the link itself is. These tests have been performed by implementing a data generator connected to the Core1990 inputs. A VIO (Virtual Input/Output) is used to control the length of bursts and an ILA (Integrated Logic Analyzer) is used to sample the input and output data (ChipScope). The input data will be pipelined for alignment between the two. This will make it easier to detect errors and ensure data integrity.
 
 
 
        The example design can be generated by running the 'source ./vivado\_import\_virtex7\_exa\\mpledesign.tcl' command from the tcl console.
 
 
        \begin{forest}
        \begin{forest}
                pic dir tree,
                pic dir tree,
                where level=0{}{% folder icons by default; override using file for file icons
                where level=0{}{% folder icons by default; override using file for file icons
                        directory,
                        directory,
Line 190... Line 235...
                                        [Core1990\_Test.vhd, file]
                                        [Core1990\_Test.vhd, file]
                                        [data\_generator.vhd, file]
                                        [data\_generator.vhd, file]
                                        [pipeline.vhd, file] ]  ] ]
                                        [pipeline.vhd, file] ]  ] ]
        \end{forest}
        \end{forest}
 
 
        \vspace{1mm}
        \vspace{2mm}
        The additional IP cores and VHDL components are all included in the Core1990\_Test.vhd file. This top level only requires two clocks to run, two differential signals for RX and TX are defined and a valid signal is noted as an output and connected to an external led.
        The additional IP cores and VHDL components are all included in the Core1990\_Test.vhd file. This top level only requires two clocks to run, two differential signals for RX and TX are defined and two output signals indicating locked status and valid compared data are used and connected to an external led. However during testing another clock appeared to be better suited for this purpose (156,25 MHz from the Si570). This requires two additional in- and outputs which are added in the Core1990 file.\\
 
 
 
        The example design realized in Vivado for the VC707 uses 6861 LUT (LookUp Tables), 15599 FF (FlipFlops) and 89 BRAM (Block RAM). Power consumption of the complete design is about 1,3 W.
 
        \begin{figure}[H]
 
                \centering
 
                \includegraphics[width=\textwidth]{Core1990/Core1990_ExDesUsage.png}
 
                \caption{Resource usage by the example design}
 
                \label{fig:Core1990_ExDesUsage}
 
        \end{figure}
 
 
 
        When the example design is opened in Vivado the structure of the project should look similar to what is depicted in Figure \ref{fig:Core1990_VivadoExDes}.
 
 
 
        \begin{figure}[H]
 
                \centering
 
                \includegraphics[width=\textwidth]{Core1990/Core1990_VivadoExDes.png}
 
                \caption{Structure of the example design in Vivado}
 
                \label{fig:Core1990_VivadoExDes}
 
        \end{figure}
 
 
 
 
        \newpage
        \newpage
 
 
 No newline at end of file
 No newline at end of file
 
        \subsection{Simulating the core}
 
        If the link doesn't behave as expected or is malfunctioning, the situation can be analyzed in simulation. This simplifies the process of locating errors.
 
        Simulation of the core1990 protocol can easily be configured by running the simulation script. This can be done by browsing to the scripts folder again and running the tcl command 'source simulation.tcl'. After this a short explanation of the command this script accepts should appear. For example if the user would like to simulate the decoder, this can be done by giving the command 'simulate decoder' in the tcl console. Simulation of the interface itself van be done by 'simulate interface' and to simulate the example design it is 'simulate core1990'.\\
 
 
 
        When running the simulation.tcl script all testbenches will be added to the project. Besides running a specific command to simulate a part it is of course also possible to just start a simulation by selecting the top level in the Vivado GUI in the simulation sources. All added testbench files and the waveform configuration file can be seen in Figure \ref{fig:Core1990_Simulation}.
 
 
 
        \begin{figure}[H]
 
                \centering
 
                \includegraphics[width=\textwidth]{Core1990/Core1990_Simulation.png}
 
                \caption{Structure of the simulation files in Vivado}
 
                \label{fig:Core1990_Simulation}
 
        \end{figure}
 
 
 No newline at end of file
 No newline at end of file

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.