From 04246d376e36861e0866f78838a8b7e0f782ba90 Mon Sep 17 00:00:00 2001 From: Michael Boehmer Date: Sat, 4 Dec 2021 14:51:47 +0100 Subject: [PATCH] added clock description --- trb3/DS_LinkEstablishment.tex | 28 ++++++++------- trb3/DS_PLLandCDR.tex | 58 ++++++++++++++++++++++++++++++ trb3/DS_SignalDescription.tex | 66 +++++++++++++++++------------------ trb3/main.tex | 14 +++++--- 4 files changed, 115 insertions(+), 51 deletions(-) create mode 100644 trb3/DS_PLLandCDR.tex diff --git a/trb3/DS_LinkEstablishment.tex b/trb3/DS_LinkEstablishment.tex index 9d86817..a2730c6 100644 --- a/trb3/DS_LinkEstablishment.tex +++ b/trb3/DS_LinkEstablishment.tex @@ -24,24 +24,26 @@ The link establishment process is explained on a hub FPGA slave port as example: \begin{itemize*} \item The hub FPGA is in reset while no fiber is connected or the master port it is connected - to has its TX{\_}DIS line set. - \item HUB SP: A stream of IDLE kommas is received, so the RX reset sequence is completed + to has its \texttt{TX{\_}DIS} line set. + \item \textbf{CTS MP:} the \texttt{TX{\_}DIS} is released once the SerDes TX channel is ready, + and a stream of IDLE kommas is sent to initiate the link. + \item \textbf{HUB SP:} A stream of IDLE kommas is received, so the RX reset sequence is completed and a lock to incoming kommas by the FPGA internal state machine is made. - \item HUB SP: Once WAP=0 is achieved, the RX reset control will declare the RX recovered clock stable, - and initiate the TX reset sequence. LINK{\_}RX{\_}READY is set, while toggling IDLEs are received, + \item \textbf{HUB SP:} Once WAP=0 is achieved, the RX reset control will declare the RX recovered clock stable, + and initiate the TX reset sequence. \texttt{LINK{\_}RX{\_}READY} is set, while toggling IDLEs are received, the uplink is stable now. - \item HUB SP: The TX reset sequence waits for all QUADs in use to lock on the TX reference clock (i.e. - the recovered RX clock from slave port), and sync all TX Serializers to bit 0. LINK{\_}TX{\_}READY is set. - \item HUB SP: The TX control sends a togglinge idle sequence after the downlink is stable. - \item HUB SP: The RX LSM will check for a sequence of toggling IDLEs, and after detection set the - LINK{\_}HALF{\_}DONE signal. - \item CTS MP: the toggling IDLEs are received, a RX reset sequence is performed and a lock - to WAP=0 made. This will set LINK{\_}RX{\_}READY in the master port, and change the toggling IDLEs in the uplink + \item \textbf{HUB SP:} The TX reset sequence waits for all QUADs in use to lock on the TX reference clock (i.e. + the recovered RX clock from slave port), and sync all TX Serializers to bit 0. \texttt{LINK{\_}TX{\_}READY} is set. + \item \textbf{HUB SP:} The TX control sends a togglinge idle sequence after the downlink is stable. + \item \textbf{HUB SP:} The RX LSM will check for a sequence of toggling IDLEs, and after detection set the + \texttt{LINK{\_}HALF{\_}DONE} signal. + \item \textbf{CTS MP:} the toggling IDLEs are received, a RX reset sequence is performed and a lock + to WAP=0 made. This will set \texttt{LINK{\_}RX{\_}READY} in the master port, and change the toggling IDLEs in the uplink to steady IDLEs (IDLE1). - \item HUB SP: The RX LSM detects a series of steady IDLEs, and sets LINK{\_}FULL{\_}DONE internally. + \item \textbf{HUB SP:} The RX LSM detects a series of steady IDLEs, and sets \texttt{LINK{\_}FULL{\_}DONE} internally. The TX control is instructed to send steady IDLEs now. Both UP and DL are considered stable, and TrbNet payloads (as well as special kommas) can be sent and received now. - \item CTS MP: The RX LSM detects a series of steady IDLEs, and sets to LINK{\_}FULL{\_}DONE internally. + \item \textbf{CTS MP:} The RX LSM detects a series of steady IDLEs, and sets to \texttt{LINK{\_}FULL{\_}DONE} internally. Both UP and DL are considered stable, and TrbNet payloads as well as special kommas are enabled now. \end{itemize*} diff --git a/trb3/DS_PLLandCDR.tex b/trb3/DS_PLLandCDR.tex new file mode 100644 index 0000000..0ec4bad --- /dev/null +++ b/trb3/DS_PLLandCDR.tex @@ -0,0 +1,58 @@ +\subsection{PLLs and CDRs} + +A few notes on how CDRs (Clock Data Recovery) and PLLs (Phase Locked Loop) inside the SerDes +are being used, and why this works this way. + +\subsubsection{RX CDR} + +The CDR inside the individual RX channels of the SerDes units is the key element in the +clock propagation business. Basically, this unit takes care of recovering the RX clock from +a bit data stream of the SerDes input and driving a PLL on it, which provides a bit clock and +--- in cooperation with the Word Alignment block --- a byte (10bit) clock for the deserialized +data. + +As a special functionality, the RX CDR block is fed with a local clock (in terms of frequency +identical to the RX recovered clock) from an oszillator. While the SerDes input does not recognize +a bit data stream with a sufficient number of signal transitions (\texttt{RX{\_}LOS} signal), the +RX CDR PLL will lock on the local clock, so in any case, a suitable clock will be forwarded to +\texttt{rx{\_}full{\_}clk{\_}chX{\_}c} outputs of the SerDes channel. + +With a valid data stream arriving at the RX SerDes inputs, the RX CDR will lock on the recovered +bit clock, but in terms of frequency, the RX CDR PLL will not have to adjust to a new frequency, +but most likely a new phase, so only a small phase shift operation will be necessary to adjust the +RX CDR PLL and lock it. + +In general, for successful RX clock recovery, all RX CDR blocks \textbf{need to} be operated with +a suitable local clock source, which is available all times. + +This is mandatory for TX PLL operation. + +\subsubsection{TX PLL} + +The TX PLL is basically providing a byte clock for the SerDes TX path to FPGA fabric, as well +as a bit clock for the SerDes output. This clock will be the recovered RX clock on the next FPGA, +so the source of this clock will depend on the nature of the FPGA design. + +In a root master port, a local clock source (oscillator) will provide the TX PLL clock input. + +In hub devices, the recovered RX clock of the SP will be provide the TX PLL clock input. + +In general, the recovered RX clock (if any) will be provided to all QUAD TX PLLs. + +Running uplink and downlink on the same (recovered RX) clock allows a simple delay measurement +on all links without messing around with SerDes loopback modes. + +\subsubsection{Rules of Engagement for clocks} + +A simple set of rules defines on how to use clocks in the new DeepSea approach: + +\begin{itemize*} + \item The \texttt{fpga\_rxrefclk\_chX} input of \textbf{all} SerDes channels in a FPGA is driven + by the local reference clock (either from oscillator, or from PLL), independent of + the nature of the FPGA design (root CTS, hub, FE). + \item If a SP is available in the FPGA design, its \texttt{rx\_full\_clk\_chX} signal will + source \textbf{all} \texttt{fpga\_txrefclk} inputs of \textbf{all} SerDes blocks used in the design. + \item If no SP is available, the same local clock as used for RX reference clock will be used for this. + \item All MPs are held in reset (including the \texttt{TX{\_}DIS} signals) while no stable recovered RX + clock is available. The \texttt{SFP{\_}LOS} signal is used for generating this reset. +\end{itemize*} diff --git a/trb3/DS_SignalDescription.tex b/trb3/DS_SignalDescription.tex index cfb8c4b..c21132f 100644 --- a/trb3/DS_SignalDescription.tex +++ b/trb3/DS_SignalDescription.tex @@ -7,49 +7,49 @@ The signals used in the SerDes TX and RX state machines are taken from the Latti example code available on the web. These state machines behave the same, but have been extended to include TX channel serializer synchronization and RX channel WordAlignment. -\subsubsection{\texttt{med\_ecp3\_sfp\_sync\_all\_RS}} +\subsubsection{\texttt{med{\_}ecp3{\_}sfp{\_}sync{\_}all{\_}RS}} \begin{itemize*} - \item \texttt{RX\_DLM\_OUT} -- DLM komma received, per channel.\newline - Signal is set for one clock cycle of \texttt{RXI\_CLK}. - \item \texttt{RX\_DLM\_WORD\_OUT} -- DLM data byte received, per channel. - \item \texttt{TX\_DLM\_IN} -- send one DLM komma.\newline + \item \texttt{RX{\_}DLM{\_}OUT} -- DLM komma received, per channel.\newline + Signal is set for one clock cycle of \texttt{RXI{\_}CLK}. + \item \texttt{RX{\_}DLM{\_}WORD{\_}OUT} -- DLM data byte received, per channel. + \item \texttt{TX{\_}DLM{\_}IN} -- send one DLM komma.\newline Data byte must be valid when this signal is set for one clock cycle - of \texttt{TXI\_CLK}. - \item \texttt{TX\_DLM\_WORD\_IN} -- DLM data byte to be sent.\newline + of \texttt{TXI{\_}CLK}. + \item \texttt{TX{\_}DLM{\_}WORD{\_}IN} -- DLM data byte to be sent.\newline A SP needs to connect these ports directly together to implement \texttt{DLM} komma ping functionality, used for link delay measurements. - \item \texttt{RX\_RST\_OUT} -- RST komma received, per channel (only for SP). - \item \texttt{RX\_RST\_WORD\_OUT} -- RST data byte received (only for SP).\newline + \item \texttt{RX{\_}RST{\_}OUT} -- RST komma received, per channel (only for SP). + \item \texttt{RX{\_}RST{\_}WORD{\_}OUT} -- RST data byte received (only for SP).\newline Can be used directly as reset lines. - \item \texttt{TX\_RST\_IN} -- send one RST komma, is only forwarded to MPs.\newline + \item \texttt{TX{\_}RST{\_}IN} -- send one RST komma, is only forwarded to MPs.\newline RST kommas can not be sent on SPs.\newline - In configurations with one SP and at least one MP, these \texttt{RX\_RST} ports - of SP must be connected to \texttt{TX\_RST} ports of all Quads with MPs. - \item \texttt{TX\_RST\_WORD\_IN} -- RST data byte to be sent. - \item \texttt{WORD\_SYNC\_IN} -- byte/word alignment input for MPs.\newline + In configurations with one SP and at least one MP, these \texttt{RX{\_}RST} ports + of SP must be connected to \texttt{TX{\_}RST} ports of all Quads with MPs. + \item \texttt{TX{\_}RST{\_}WORD{\_}IN} -- RST data byte to be sent. + \item \texttt{WORD{\_}SYNC{\_}IN} -- byte/word alignment input for MPs.\newline On root MP, this input must be static high, on hub MPs it connects to - SP \texttt{WORD\_SYNC\_OUT} to keep links word aligned. - \item \texttt{WORD\_SYNC\_OUT} -- only valid if a SP is in the MI. Connects to - \texttt{WORD\_SYNC\_IN} of all Quads containing MPs. - \item \texttt{MASTER\_CLK\_IN} -- clock used on TX PLL inside Quad. - \item \texttt{MASTER\_CLK\_OUT} -- recovered RX clock, if SP is available in the Quad. - \item \texttt{GLOBAL\_RESET\_IN} -- used for initial Quad reset (\texttt{RST\_QD\_C}) and keeping - SerDes related function blocks in reset. Usually connects to \texttt{GLOBAL\_RESET\_OUT} of + SP \texttt{WORD{\_}SYNC{\_}OUT} to keep links word aligned. + \item \texttt{WORD{\_}SYNC{\_}OUT} -- only valid if a SP is in the MI. Connects to + \texttt{WORD{\_}SYNC{\_}IN} of all Quads containing MPs. + \item \texttt{MASTER{\_}CLK{\_}IN} -- clock used on TX PLL inside Quad. + \item \texttt{MASTER{\_}CLK{\_}OUT} -- recovered RX clock, if SP is available in the Quad. + \item \texttt{GLOBAL{\_}RESET{\_}IN} -- used for initial Quad reset (\texttt{RST{\_}QD{\_}C}) and keeping + SerDes related function blocks in reset. Usually connects to \texttt{GLOBAL{\_}RESET{\_}OUT} of the SP. - \item \texttt{GLOBAL\_RESET\_OUT} -- only valid on SP, signal is derived from \texttt{SFP\_LOS} signal + \item \texttt{GLOBAL{\_}RESET{\_}OUT} -- only valid on SP, signal is derived from \texttt{SFP{\_}LOS} signal on uplink. Used to keep FPGA logic in hard reset. - \item \texttt{TX\_PLL\_LOL\_IN} -- wired or of all \texttt{TX\_PLL\_LOL} signals of all Quads used in - the FPGA. Usually originates from \texttt{main\_tx\_reset\_RS} component. - \item \texttt{TX\_PLL\_LOL\_OUT} -- TX PLL lock signal from SerDes inside the MI. Usually connected to - the corresponding input of \texttt{main\_tx\_reset\_RS} component. - \item \texttt{TX\_CLK\_AVAIL\_OUT} -- only valid on SP. Signals valid recovered RX clock is available. - Usually connected to \texttt{main\_tx\_reset\_RS} component. - \item \texttt{TX\_PCS\_RST\_IN} -- reset for TX PCS blocks inside the Quad. Usually connected to - \texttt{main\_tx\_reset\_RS} component. - \item \texttt{SYNC\_TX\_PLL\_IN} -- TX Serializer sync signal. Usually connected to \texttt{main\_tx\_reset\_RS} + \item \texttt{TX{\_}PLL{\_}LOL{\_}IN} -- wired or of all \texttt{TX{\_}PLL{\_}LOL} signals of all Quads used in + the FPGA. Usually originates from \texttt{main{\_}tx{\_}reset{\_}RS} component. + \item \texttt{TX{\_}PLL{\_}LOL{\_}OUT} -- TX PLL lock signal from SerDes inside the MI. Usually connected to + the corresponding input of \texttt{main{\_}tx{\_}reset{\_}RS} component. + \item \texttt{TX{\_}CLK{\_}AVAIL{\_}OUT} -- only valid on SP. Signals valid recovered RX clock is available. + Usually connected to \texttt{main{\_}tx{\_}reset{\_}RS} component. + \item \texttt{TX{\_}PCS{\_}RST{\_}IN} -- reset for TX PCS blocks inside the Quad. Usually connected to + \texttt{main{\_}tx{\_}reset{\_}RS} component. + \item \texttt{SYNC{\_}TX{\_}PLL{\_}IN} -- TX Serializer sync signal. Usually connected to \texttt{main{\_}tx{\_}reset{\_}RS} component. - \item \texttt{DESTROY\_LINK\_IN} -- one bit signal per channel, only used for MPs. If set, the - \texttt{SFP\_TX\_DISABLE} line to SFP is set and all connected boards will be forced into + \item \texttt{DESTROY{\_}LINK{\_}IN} -- one bit signal per channel, only used for MPs. If set, the + \texttt{SFP{\_}TX{\_}DISABLE} line to SFP is set and all connected boards will be forced into hard reset. \end{itemize*} diff --git a/trb3/main.tex b/trb3/main.tex index f5e156c..2a406db 100644 --- a/trb3/main.tex +++ b/trb3/main.tex @@ -283,13 +283,17 @@ \cleardoublepage \part{DeepSea TrbNet} \section{Redefining TrbNet} - \input{DS_Nomenclature.tex} - \input{DS_GoingSynchronous.tex} - \input{DS_NewResets.tex} - \input{DS_LinkEstablishment.tex} - \input{DS_SignalDescription.tex} + \input{DS_Nomenclature} + \input{DS_GoingSynchronous} + \section{Changes introduced} + \input{DS_NewResets} + \input{DS_LinkEstablishment} + \section{Technical details} + \input{DS_SignalDescription} + \input{DS_PLLandCDR} \cleardoublepage +\part{Appendix} \begin{appendices} \section{TDC Online Calibration} \input{TdcOnlineCalibration.tex} -- 2.43.0