]> jspc29.x-matter.uni-frankfurt.de Git - daqdocu.git/commitdiff
several structural changes
authorJan Michel <mail@janmichel.eu>
Thu, 5 Jan 2023 11:32:15 +0000 (12:32 +0100)
committerJan Michel <mail@janmichel.eu>
Thu, 5 Jan 2023 11:32:15 +0000 (12:32 +0100)
 disentangle Trb3-specific things from general remarks

trb3/SyncMediaInterface.tex
trb3/Trb3FurtherInformation.tex [new file with mode: 0644]
trb3/Trb3GeneralRemarks.tex
trb3/Trb5Addons.tex [new file with mode: 0644]
trb3/main.tex
trb3/sctrladdresses.tex

index 65346e66c14c37db72223c5c27528281a214d714..c9c3668eb875d2c9af4211a45c3332d2b2b5b867 100644 (file)
@@ -1,3 +1,4 @@
+\begin{warning}This is a concept description only and was not implemented\end{warning}
 \subsection{Central Aspects}
 \begin{itemize*}
  \item All FPGA run on a central clock, each network node recovers the clock from the optical link and uses it as the main clock source for all design components.
diff --git a/trb3/Trb3FurtherInformation.tex b/trb3/Trb3FurtherInformation.tex
new file mode 100644 (file)
index 0000000..244e6af
--- /dev/null
@@ -0,0 +1,49 @@
+\subsection{Testing Procedure for New Trb3 Boards}
+\begin{itemize*}
+ \item Visual Inspection
+ \item Add sticker with serial number
+ \item Power-up - current should be around 0.25A at 48V
+ \item Check if fixes (Flash 0R) are done
+ \item Load set of configuration files (no Flash programming for FPGAs, only load design)
+ \item Also note that you need to issue an \verb!trbcmd reset! after JTAG programming in order to have the FPGAs obtain the correct local number identification reported by an info trbcmd broadcast (5 for central, 0-3 for peripheral FPGAs).
+ \item Check basic TrbNet functionality
+ \item Program Flash ROMs via TrbNet
+ \item Reboot Board to see if all FPGA boot from Flash
+ \item Add the five unique IDs to the \files{serials\_trb3.db} in the cvs (see \ref{Trb3BoardID})
+ \item Add board as tested to wiki page
+\end{itemize*}
+
+
+\subsection{JTAG}
+
+The pin-out of the JTAG connector on TRB3 (1x8 pin-header near the power supply):
+\begin{description*}
+ \item[1] VCC (3.3V, red)
+ \item[2] TMS (violet)
+ \item[3] TCK (white)
+ \item[4] TDI (orange)
+ \item[5] TDO (brown)
+ \item[6] GND (black)
+ \item[7] GND (n/c)
+ \item[8] GND (n/c)
+\end{description*}
+
+Pin 1 is next to the 2x6 pin-header. Note that TDO and TDI are switched compared to the labels and layout on all other boards. 
+
+\subsection{TRB3 Trigger \& Clock Input}
+Both trigger and clock input (RJ-45 connectors) are equipped with a configurable fan-out chip. Its control signals can be set in slow-control register 0xd300 (currently in CTS only, but should also be present in other central FPGA).
+\begin{description*}
+ \item[Bit 0] Trigger select (local signal: 1, external signal: 0
+ \item[Bit 8] Clock select (Input 0 or 1)
+ \item[Bit 19 -- 16] 4 User signals on trigger fan-out
+ \item[Bit 27 -- 24] 4 User signals on clock fan-out
+\end{description*}
+
+\subsection{TRB3 Power Consumption}
+The TRB3 with linear supplies and typical TDC designs needs
+\begin{itemize*}
+\item 3.3V - 1.25A
+\item 2.5V - 0.5A
+\item 1.2V - 8A
+\end{itemize*}
+
index 11e870efe40b6db755b8adb6b5cbe68c16657342..6b5cba0eebf10f476daa7fc4d11176060e7fb9c6 100644 (file)
@@ -13,9 +13,13 @@ the front end and transport it to the central FPGA, which is your *special*
 case (only one TRB3) is the same FPGA as the CTS is running in. There the data
 is collected from all 4 peripheral FPGAs and then combined to a UDP-frame,
 which is then sent via many Ethernet-packets to the Eventbuilder.
+
+A similar scheme is implemented in a Trb3sc/Trb5sc crate system: One central 
+"master" FPGA board is surrounded by up to 9 "slave" modules.
+
 The Eventbuilder-PC linux is combining the packets to a UDP-frames which then
-goes to the eventbuilder process (dabc), which combines many sources (in your
-case only one source) to coherent events via the unique event-numbers the CTS
+goes to the eventbuilder process (dabc), which combines many sources 
+to coherent events via the unique event-numbers the CTS
 has generated in the first place.
 The Evenbuilder can be on any computer in the same network (we use directly
 the MAC). For small setups this can be the same computer you run the slow
@@ -53,10 +57,8 @@ boards if something goes wrong in the fever of a beam time.
 
 
 \subsection{Hardware Information}
-\begin{itemize*}
- \item TRB3 \href{http://jspc29.x-matter.uni-frankfurt.de/trbweb/?action=page&url=schematics}{Schematics}
- \item Pin-out file for all FPGAs vary based on the AddOns in use and can be found in the git repositories,  \verb!pinout/*.lpf!.
-\end{itemize*}
+Schematics of all boards can be found here:
+ \href{http://jspc29.x-matter.uni-frankfurt.de/trbweb/?action=page&url=schematics}{Schematics}
 
 
 \subsection{Board Identification}
@@ -96,82 +98,44 @@ Second, the upper 16 Bit of the Hardware Version register as described below is
   image!
 \end{warning}
 
-\subsection{Design Identification}
-\label{sec:Identification}
-The TrbNet endpoint has a generic setting \signal{Regio\_Hardware\_Version} (register 0x42) that has to be set according to the following rules:  
-The upper 16 Bit are used by the software to identify the hardware before programming the Flash to prevent loading invalid designs and have to contain one of the following values. The last digit should be used to denote the hardware revision. 
-\begin{description*}
- \item[9000] design for Trb3 central FPGA, \verb!trb3_central!
- \item[9100] design for Trb3 peripheral FPGAs, \verb!trb3_periph!
- \item[9200] design for CBM Rich, \verb!cbm_rich!
- \item[9300] design for CBM Tof, \verb!cbm_tof!
- \item[9500] design for Trb3sc, \verb!trb3sc!
- \item[9600] design for DiRich, \verb!dirich! 
- \item[9700] design for DiRich Combiner module, \verb!combiner!
- \item[9900] design for Munich Skyroc boards
- \item[9A00] design for DiRICH5s, \verb!dirich5s!
- \item[9B00] design for FaRICH1, \verb!farich!
- \item[9C00] design for DiRICH1, \verb!dirich!
 
- \item[A500] design for TRB5sc, \verb!trb5sc!
- \item[A600] design for MDC central, \verb!mdcoep!
- \item[A700] design for MDC TDC, \verb!mdctdc!
- \item[A800] design for TOMcat, \verb!tomcat!
-\end{description*}
+\subsection{Network Addresses and Data Unpacker}
+\label{Data_Unpacking}
 
-The lower 16 Bit are used to identify the contents of the design and the AddOn boards they should be used with. Combine 
-as many values as you like by logical or.
-Please note that these values have been partly superseded by the IncludedFeatures register described below. This 
-register should only be used to describe hardware-related features, like the needed AddOn Board.
+For proper automatic detection of data in software, the 16bit network addresses in a TRB set-up should have their first hex digit representing their function: 'C' for the CTS, '8' for a hub, '0' or '1' for TDCs.
 
-\begin{description*}
-\item[Trb3 central]~
-\begin{description*}
-  \item[cXX0]  contains a CTS
-  \item[cXX1]  contains a CTS, use with AddOn for trigger signals
-\end{description*}
-\item[Trb3 peripheral, Trb3sc]~
-\begin{description*}
-  \item[0XXX]  use with ADA adapter board AddOn version 1
-  \item[1XXX]  use with ADA adapter board AddOn version 2
-  \item[2XXX]  use with multi-purpose test AddOn
-  \item[3XXX]  use with SFP hub AddOn
-  \item[4XXX]  use with Padiwa adapter AddOn
-  \item[5XXX]  use with General Purpose AddOn - with NIM connectors
-  \item[6XXX]  use with Nxyter
-  \item[7XXX]  use with 32PinAddOn
-  \item[9XXX]  use with ADC AddOn
-  \item[AXXX]  use with SFP AddOn v2
-  \item[BXXX]  onboard connectors
-  \item[XX9X]  for MVD converter board 2013
-\end{description*}
+The middle two digits are often chosen to equal the serial number of the board while the last digit enumerates the FPGAs on one board / one crate. Another typical scheme is to encode the position of the board in the detector (e.g. station / sector / subgroup). Chose whatever fits your needs.
+
+These network addresses also show up in the event data in the form of SubEvent-IDs and SubSubEvent-IDs.
+SubSubEvent-IDs are identical to the network address of each board, e.g. the TDCs. The SubEvent-IDs identify one subsystem and should be equal to the network address of the FPGA sending the data on Ethernet (e.g. central FPGA on Trb3 or master FPGA in a crate). The SubEvent-IDs must be configured manually together with all other Ethernet-related settings, they are not set automatically.
+
+On the software side, the first digit of each SubSubEvent-ID should be sufficient to determine 
+how the following data has to be handled:
 
-\item[Trb5sc]~
 \begin{description*}
-  \item[1000]  use with ADA adapter (80pin KEL)
-  \item[2000]  use with 4conn adapter (40 pin KEL)
-  \item[4000]  use with RJ45 adapter
-  \item[0100]  use with HDMI adapter
-\end{description*}
+\item[0..1] Unpack as TDC data
+\item[5555](fixed) The only SubSubEvent-ID starting with 5 is 5555 at the end of each SubEvent, marking the beginning of the status information word for this SubEvent .
+\item[7] Special TDCs (like beam detectors, not part of the system under test)
+\item[8] Skip this SubSubEvent-Header. Note: Only the header, the next word should be another valid SubSubEvent-Header.
+\item[C] Unpack as CTS data
+\item[D..E] Other read-out formats, no TDC data included
 \end{description*}
 
-\subsection{Included Features}
-Basic Information about included features should be put to a generic setting named IncludedFeatures. This should be set 
-in the config.vhd file of each project according to the following table. The values are available from registers 0x41 
-(lower 32 Bit) and 0x43 (upper 32 Bit) on TrbNet. The uppermost 8 Bit define a set of definitions that defines the 
-meaning of the remaining 56 Bit in the word.
+The data format is shown in later sections.
+Note that these groups are only default suggestions. You can chose arbitrary ranges, but these need to be configured manually in the unpacking software.
 
-Fields marked as ``version'' should be increased after any bigger change in the design or major bug fixes.
 
-\begin{center}
-  \LTXtable{\textwidth}{IncludedFeaturesTable}
-\end{center}
 
-\subsection{Network Addresses}
-For proper automatic detection of data in software, the network addresses in a TRB set-up need to have their first hex digit representing their function: 'C' for the CTS, '8' for a hub, '0' or '1' for TDCs. See \ref{Data_Unpacking}.
+\section{Design and Board Identification}
+\subsection{Design Features}
+All FPGA can be loaded with a multitude of different design files and may contain any subset of available features. There are two main starting points to get information about the design contents:
+
+First, the design file name. The file name currently loaded to an FPGA can be read using the \verb!trbflash info! command.
+Second, the "Network Map" page on the web server. Hover your pointer over any field in the table to get additional information!
 
 
-The middle two digits are often chosen to equal the serial number of the board while the last digit enumerates the FPGAs on one board / one crate.
+\subsection{Default Network Addresses}
+
 
 All boards of a given type are accessible by a broadcast address (0xFE\_\_) at the same time. This is set by \signal{Broadcast\_Special\_Addr} in the TrbNet endpoint:
 
@@ -243,41 +207,86 @@ The initial address set with \signal{Regio\_Init\_Address} can be chosen in the
 \end{itemize*}
 
 
-\subsection{Testing Procedure for New Trb3 Boards}
-\begin{itemize*}
- \item Visual Inspection
- \item Add sticker with serial number
- \item Power-up - current should be around 0.25A at 48V
- \item Check if fixes (Flash 0R) are done
- \item Load set of configuration files (no Flash programming for FPGAs, only load design)
- \item Also note that you need to issue an \verb!trbcmd reset! after JTAG programming in order to have the FPGAs obtain the correct local number identification reported by an info trbcmd broadcast (5 for central, 0-3 for peripheral FPGAs).
- \item Check basic TrbNet functionality
- \item Program Flash ROMs via TrbNet
- \item Reboot Board to see if all FPGA boot from Flash
- \item Add the five unique IDs to the \files{serials\_trb3.db} in the cvs (see \ref{Trb3BoardID})
- \item Add board as tested to wiki page
-\end{itemize*}
 
+\subsection{Hardware Types}
+\label{sec:Identification}
+\begin{information}Section mainly for developers. Users can find this information decoded in the Network Map on the web server\end{information}
+The TrbNet endpoint has a generic setting \signal{Regio\_Hardware\_Version} (register 0x42) that has to be set according to the following rules:  
+The upper 16 Bit are used by the software to identify the hardware before programming the Flash to prevent loading invalid designs and have to contain one of the following values. The last digit should be used to denote the hardware revision. 
+\begin{description*}
+ \item[9000] design for Trb3 central FPGA, \verb!trb3_central!
+ \item[9100] design for Trb3 peripheral FPGAs, \verb!trb3_periph!
+ \item[9200] design for CBM Rich, \verb!cbm_rich!
+ \item[9300] design for CBM Tof, \verb!cbm_tof!
+ \item[9500] design for Trb3sc, \verb!trb3sc!
+ \item[9600] design for DiRich, \verb!dirich! 
+ \item[9700] design for DiRich Combiner module, \verb!combiner!
+ \item[9900] design for Munich Skyroc boards
+ \item[9A00] design for DiRICH5s, \verb!dirich5s!
+ \item[9B00] design for FaRICH1, \verb!farich!
+ \item[9C00] design for DiRICH1, \verb!dirich!
 
-\subsection{JTAG}
-Since programming of FPGAs can be done via GbE, the JTAG connector is usually not used. In case of corrupted designs it provides the only access to reconfigure FPGAs. Loading a design directly to the FPGA is quite fast (25 s) but loading it to the Flash ROM is deadly slow (5 minutes) - better: first load the design to the FPGA via JTAG, then flash it using TrbNet.
+ \item[A500] design for TRB5sc, \verb!trb5sc!
+ \item[A600] design for MDC central, \verb!mdcoep!
+ \item[A700] design for MDC TDC, \verb!mdctdc!
+ \item[A800] design for TOMcat, \verb!tomcat!
+\end{description*}
+
+The lower 16 Bit are used to identify the contents of the design and the AddOn boards they should be used with. Combine 
+as many values as you like by logical or.
+Please note that these values have been partly superseded by the IncludedFeatures register described below. This 
+register should only be used to describe hardware-related features, like the needed AddOn Board.
+
+\begin{description*}
+\item[Trb3 central]~
+\begin{description*}
+  \item[cXX0]  contains a CTS
+  \item[cXX1]  contains a CTS, use with AddOn for trigger signals
+\end{description*}
+\item[Trb3 peripheral, Trb3sc]~
+\begin{description*}
+  \item[0XXX]  use with ADA adapter board AddOn version 1
+  \item[1XXX]  use with ADA adapter board AddOn version 2
+  \item[2XXX]  use with multi-purpose test AddOn
+  \item[3XXX]  use with SFP hub AddOn
+  \item[4XXX]  use with Padiwa adapter AddOn
+  \item[5XXX]  use with General Purpose AddOn - with NIM connectors
+  \item[6XXX]  use with Nxyter
+  \item[7XXX]  use with 32PinAddOn
+  \item[9XXX]  use with ADC AddOn
+  \item[AXXX]  use with SFP AddOn v2
+  \item[BXXX]  onboard connectors
+  \item[XX9X]  for MVD converter board 2013
+\end{description*}
 
-The pin-out of the JTAG connector on TRB3 (1x8 pin-header near the power supply):
+\item[Trb5sc]~
 \begin{description*}
- \item[1] VCC (3.3V, red)
- \item[2] TMS (violet)
- \item[3] TCK (white)
- \item[4] TDI (orange)
- \item[5] TDO (brown)
- \item[6] GND (black)
- \item[7] GND (n/c)
- \item[8] GND (n/c)
+  \item[1000]  use with ADA adapter (80pin KEL)
+  \item[2000]  use with 4conn adapter (40 pin KEL)
+  \item[4000]  use with RJ45 adapter
+  \item[0100]  use with HDMI adapter
+\end{description*}
 \end{description*}
 
-Pin 1 is next to the 2x6 pin-header. Note that TDO and TDI are switched compared to the layout on all other boards. 
+\subsection{Included Features}
+\begin{information}Section mainly for developers. Users can find this information decoded in the Network Map on the web server\end{information}
+Basic Information about included features should be put to a generic setting named IncludedFeatures. This should be set 
+in the config.vhd file of each project according to the following table. The values are available from registers 0x41 
+(lower 32 Bit) and 0x43 (upper 32 Bit) on TrbNet. The uppermost 8 Bit define a set of definitions that defines the 
+meaning of the remaining 56 Bit in the word.
+
+Fields marked as ``version'' should be increased after any bigger change in the design or major bug fixes.
+
+\begin{center}
+  \LTXtable{\textwidth}{IncludedFeaturesTable}
+\end{center}
+
+\subsection{JTAG}
+Since programming of FPGAs can be done via GbE, the JTAG connector is usually not used. In case of corrupted designs it provides the only access to reconfigure FPGAs. Loading a design directly to the FPGA is quite fast (25 s) but loading it to the Flash ROM is deadly slow (5 minutes) - better: first load the design to the FPGA via JTAG, then flash it using TrbNet.
 
 If you experience strange behaviour of the programming procedure and think you might have destroyed the cable: It's most likely a software issue - reboot your PC!
 
+
 Note that the programming cable can only be used as root by default in most Linux flavours. You can either change permissions on the device in /dev/ by hand or put this (as one line!)
 \\\verb!SUBSYSTEMS=="usb", ATTRS{idVendor}=="1134", SYMLINK+="lattice_cable",!
 \\\verb!GROUP="users", MODE="0666"'! 
@@ -296,46 +305,3 @@ You can unload it automatically using a udev-rule by adding (as one line)
 \\\verb!echo $RESULT:1.0 >/sys/bus/usb/drivers/ftdi_sio/unbind"!
 \\into \files{/etc/udev/rules.d/91-usb-hardware.rules} 
 
-
-
-\subsection{Data Unpacker}
-\label{Data_Unpacking}
-The data stream contains SubEvent-IDs and SubSubEvent-IDs to identify the sender 
-of each block of data. While SubSubEvent-IDs are equal to the network address of 
-the corresponding board by design, the SubEvent-IDs can be chosen freely, but are 
-defined to be equal to the network address of the board sending the SubEvent via 
-Gigabit Ethernet. The first digit of each SubSubEvent-ID is sufficient to determine 
-how the following data has to be handled:
-\begin{description*}
-\item[0..1] Unpack as TDC data
-\item[5555] The only SubSubEvent-ID starting with 5 is 5555 at the end of each SubEvent, marking the beginning of the status information word for this SubEvent.
-\item[7] Special TDCs (like beam detectors, not part of the system under test)
-\item[8] Skip this SubSubEvent-Header. Note: Only the header, the next word should be another valid SubSubEvent-Header.
-\item[C] Unpack as CTS data
-\item[D..E] Other read-out formats, no TDC data included
-\end{description*}
-The data format is shown in later sections.
-
-
-\subsection{TRB3 Trigger \& Clock Input}
-Both trigger and clock input (RJ-45 connectors) are equipped with a configurable fan-out chip. Its control signals can be set in slow-control register 0xd300 (currently in CTS only, but should also be present in other central FPGA).
-\begin{description*}
- \item[Bit 0] Trigger select (local signal: 1, external signal: 0
- \item[Bit 8] Clock select (Input 0 or 1)
- \item[Bit 19 -- 16] 4 User signals on trigger fan-out
- \item[Bit 27 -- 24] 4 User signals on clock fan-out
-\end{description*}
-
-\subsection{TRB3 Power Consumption}
-The TRB3 with linear supplies and typical TDC designs needs
-\begin{itemize*}
-\item 3.3V - 1.25A
-\item 2.5V - 0.5A
-\item 1.2V - 8A
-\end{itemize*}
-
-
-%%% Local Variables: 
-%%% mode: latex
-%%% TeX-master: "main"
-%%% End: 
diff --git a/trb3/Trb5Addons.tex b/trb3/Trb5Addons.tex
new file mode 100644 (file)
index 0000000..ec3a843
--- /dev/null
@@ -0,0 +1,11 @@
+\begin{description}
+\item[4conn] 4x 40pin KEL connectors (Padiwa compatible)
+\item[80pin] 2x 80pin KEL connectors (similar to Trb3 AddOn)
+\item[RJ] 9x RJ-45 connectors for shielded signal input
+\item[HDMI] 7x HDMI connectors with 5 differential pairs each
+\end{description}
+
+As far as space allows, these Addons have one of two additional SFP ports,
+which might be used e.g. for Ethernet, but are not active in most designs.
+
+The pin-out of the AddOns is very similar. Most designs should be mostly compatible to any AddOn.
index d9f5e9453f416bb27fbbd8662e605a80bafc1760..e1e9d7cfca7dc1ed0217b376bbc2141df89aa6f0 100644 (file)
       \input{Trb3KnownBugs}
     \subsection{Clock and Trigger Distribution}
       \input{Trb3ClockTriggerDistribution}
+    \input{Trb3FurtherInformation}  
     \clearpage
   \section{Trb3sc}
     \input{Trb3scBasics}
     \clearpage  
     \subsection{Padiwa}
       \input{WasaFrontend}
-
+  \section{Trb5* AddOns}
+    \input{Trb5Addons}
   \cleardoublepage
 
 \part{Design Components}
 \input{trb3qs_part}
 \input{hldfileformat}
 
-\cleardoublepage
-\part{Synchronous TrbNet}
-  \section{Media Interfaces}
-    \input{SyncMediaInterface}
 
 \cleardoublepage
 \part{DeepSea TrbNet}
 \begin{appendices}
  \section{TDC Online Calibration}
   \input{TdcOnlineCalibration.tex}
+  \section{Synchronous TrbNet}
+    \input{SyncMediaInterface}  
 \end{appendices}
 %\begin{appendices}
 % \section{TDC Calibration}
index 6282d3821a3f420db6558056e5783362e446dd98..f160e952162399a027e105d1b5a465aafa3b7235 100644 (file)
@@ -1,3 +1,7 @@
+All settings are done using 32bit wide registers accessible with 16 bit addresses.
+The definitions of most registers can be found on the various web pages (there are pop-up help texts on most fields in the tables!). You can also generate a PDF with a listing of registers from the files in \verb!daqtools/xml-db!.
+
+
 
 \begin{table}[htbp]
 \begin{center}