Commit 6e5c588f authored by serrano's avatar serrano

Changes after initial wave of feedback.


git-svn-id: http://svn.ohwr.org/fmc-adc-100m14b4cha/trunk@17 ddd67a1a-c8ad-4635-afe9-0b8a11d8f8e4
parent 4064c26d
% This document specifies how our ADCs should be implemented % This document specifies how our ADCs should be implemented
% using FMC cards and blocks of HDL in our PCIe and VME64x carriers. % using FMC cards and blocks of HDL in our PCIe and VME64x carriers.
% History:
% 26 April 2010:
% First release submitted bor comments
% 27 April 2010:
% Added ADCSTATR for state machine monitoring
% Added TRIGPOSR for circular buffer support
% Added endianness support in BANKSELR
% 28 April 2010:
% Using subsubsections for each register to improve clarity.
% Added power good, shutdown and current & voltage aqn for supplies.
% Added Vadj control: 0 for 1V, 0xffff for 3.3V
% Added DMA, filling host buffers in a non-interleaved way.
% Added IQR sources list in IRQ controller subsection.
\documentclass{article} \documentclass{article}
\usepackage[pdftex]{graphicx} \usepackage[pdftex]{graphicx}
...@@ -21,7 +35,7 @@ ...@@ -21,7 +35,7 @@
\section{Introduction} \section{Introduction}
This document gives information needed by HDL and driver/library developers to support the FMCADC100M14b4cha FPGA Mezzanine Cards\footnote{See \href{http://www.ohwr.org/projects/fmc-adc-100m14b4cha}{http://www.ohwr.org/projects/fmc-adc-100m14b4cha}.} in the PCIe FMC carrier\footnote{See \href{http://www.ohwr.org/projects/fmc-pci-carrier}{http://www.ohwr.org/projects/fmc-pci-carrier}.} designed by BE-CO-HT at CERN. The support for this module must be as generic as possible in order to benefit from this effort for other ADC FMC cards and carriers. In particular, the sample width, number of channels and sampling rate should all be configurable parameters in the design. Another important aspect is to preserve insofar as possible the re-usability of developments between PCIe and VME64x uses, knowing that the VME64x carrier can host two mezzanines whereas the PCIe carrier has only one FMC site. This document gives information needed by HDL and driver/library developers to support the FMCADC100M14b4cha FPGA Mezzanine Cards\footnote{See \href{http://www.ohwr.org/projects/fmc-adc-100m14b4cha}{http://www.ohwr.org/projects/fmc-adc-100m14b4cha}.} in the PCIe FMC carrier\footnote{See \href{http://www.ohwr.org/projects/fmc-pci-carrier}{http://www.ohwr.org/projects/fmc-pci-carrier}.} designed by BE-CO-HT at CERN. The support for this module must be as generic as possible in order to benefit from this effort for other ADC FMC cards and carriers. In particular, the sample width, number of channels and sampling rate should all be configurable parameters in the design. Another important aspect is to preserve insofar as possible the re-usability of developments between PCIe and VME64x uses, knowing that the VME64x carrier can host two mezzanines whereas the PCIe carrier has only one FMC site.
This HDL specification is deliberately informal and placed halfway between a functional and a technical specification. A functional specification would be rather thin since the mezzanine and the carrier to be used have already been specified. A technical specification is almost a contract of how things must be done, leaving no room for surprises or improvements. Since this is the first project using the two boards, it seems better to suggest how a complete ADC system could be done from the available building blocks, with enough information for an HDL designer to start a design but also with as little rigidity as possible. So some definitions of registers are deliberately let loose without compromising functionality. This design will jump over the functional specification phase to gain some time. This document should be read as a functional and technical specification in one. Users are of course welcome to challenge both functional and technical aspects before approval.
The PCIe carrier board has a Spartan 6 XC6SLX150T FPGA at its heart, surrounded by a host of peripherals for different applications. In particular, there is a fair amount of SRAM, DDR3 RAM, a PLL chip, a DDS and Flash ROM. The FPGA is connected to a VITA 57 FPGA Mezzanine Card (FMC) slot, covering all pins of the Low Pin Count (LPC) connector. The purpose of this document is to specify how this carrier and the FMCADC100M14b4cha 4-channel 100 MS/s ADC mezzanine card can be used to build a complete ADC solution through appropriate configuration of the FPGA in the carrier. An important aspect to bear in mind is that this proposal takes the fastest path to get a fully working system to cover immediate needs in the accelerators, while trying to preserve the investments made in HDL development. The design will no doubt evolve in the future, once the short term needs are covered. The PCIe carrier board has a Spartan 6 XC6SLX150T FPGA at its heart, surrounded by a host of peripherals for different applications. In particular, there is a fair amount of SRAM, DDR3 RAM, a PLL chip, a DDS and Flash ROM. The FPGA is connected to a VITA 57 FPGA Mezzanine Card (FMC) slot, covering all pins of the Low Pin Count (LPC) connector. The purpose of this document is to specify how this carrier and the FMCADC100M14b4cha 4-channel 100 MS/s ADC mezzanine card can be used to build a complete ADC solution through appropriate configuration of the FPGA in the carrier. An important aspect to bear in mind is that this proposal takes the fastest path to get a fully working system to cover immediate needs in the accelerators, while trying to preserve the investments made in HDL development. The design will no doubt evolve in the future, once the short term needs are covered.
...@@ -35,12 +49,12 @@ The proposed internal structure of the FPGA design can be seen in figure~\ref{fi ...@@ -35,12 +49,12 @@ The proposed internal structure of the FPGA design can be seen in figure~\ref{fi
\end{figure} \end{figure}
\section{FPGA blocks} \section{FPGA blocks}
For each internal block, we give a summary description of its function along with internal registers which can be read of written from the Wishbone master. Registers are presented in tables with their name, address offset (in 32-bit long words), access mode and description. The address offset is the offset of a given register with respect to the beginning of the memory area pointed to by a given Base Address Register (BAR). In this card, we will use two BARs, one for registers and one for sample memory. For each internal block, we give a summary description of its function along with internal registers which can be read of written from the Wishbone master. Registers are presented in tables with their name, address offset (in 32-bit long words), access mode and description. The address offset is the offset of a given register with respect to the beginning of the memory area pointed to by a given PCIe Base Address Register (BAR). This design only supports full 32-bit reads and writes. Even if some of the registers described below use different bits for different things, that does not mean they can be written to independently from the rest of the word, so care should be taken in each write to affect all bits in an appropriate way.
\subsection{GN4124 to Wishbone bridge} \subsection{GN4124 to Wishbone bridge}
This block is a slave of the external GN4124 local bus and a master of the internal Wishbone bus. The GN4124 from Gennum is a PCIe to local bus bridge, capable of using 4 PCIe lanes for fast communication with the host and with DMA capability as well. In addition, the GN4124 can be used to reprogram the on-board FPGA. This block is a slave of the external GN4124 local bus and a master of the internal Wishbone bus. The GN4124 from Gennum is a PCIe to local bus bridge, capable of using 4 PCIe lanes for fast communication with the host and with DMA capability as well. In addition, the GN4124 can be used to reprogram the on-board FPGA.
In our case, for the reasons exposed above, we will not use the DMA engine and stick to normal PCIe access from the host. PCIe bursts will be converted in this block to Wishbone bursts. A one-tick-long positive pulse from the interrupt controller will trigger generation of a message-based PCIe interrupt. PCIe bursts will be converted in this block to Wishbone bursts. A one-tick-long positive pulse from the interrupt controller will trigger generation of a message-based PCIe interrupt.
\subsection{Board control and status} \subsection{Board control and status}
This block contains all control and status registers related to the carrier board independently of the application. Table~\ref{tab:stat_control} shows the list of registers in this block. This block contains all control and status registers related to the carrier board independently of the application. Table~\ref{tab:stat_control} shows the list of registers in this block.
...@@ -64,7 +78,11 @@ This block contains all control and status registers related to the carrier boar ...@@ -64,7 +78,11 @@ This block contains all control and status registers related to the carrier boar
\hline \hline
CARRTEMPR & & RO & Carrier temperature \\ CARRTEMPR & & RO & Carrier temperature \\
\hline \hline
STATUSR & & RO & Carrier status \\ STATUSR & & RO & Carrier and power supply status \\
\hline
SUPCTRLR & & R/W & Power supply control \\
\hline
SUPAQNR & & RO & Power supply voltage and current \\
\hline \hline
CONTROLR & & R/W & Carrier control \\ CONTROLR & & R/W & Carrier control \\
\hline \hline
...@@ -73,7 +91,80 @@ This block contains all control and status registers related to the carrier boar ...@@ -73,7 +91,80 @@ This block contains all control and status registers related to the carrier boar
\label{tab:stat_control} \label{tab:stat_control}
\end{table} \end{table}
The CARRTYPER register uses bits [31..16] for a carrier type identifier and bits [15..0] for the PCB version, typically signaled to the FPGA through optional pull-up resistors in the PCB. The SIIDLR and SIIDHR registers contain respectively the low and high parts of the 64-bit Silicon ID read from the Maxim DS18B20 1-Wire digital thermometer after system reset. BSTREAMTR uses bits [31..16] for defining an FPGA bit stream type and [15..0] for a sequential number indicating the bit stream version. BSTREAMDR contains the 32-bit UTC time when the bit stream was generated. CARRTEMPR contains the carrier temperature as read from the DS18B20 every second. The Board control and status block will set a bit to '1' for one clock tick after every reading if the temperature exceeds 60$^\circ$ Celsius. This bit will be connected to the interrupt controller so that the user can get a temperature interrupt if enabled. STATUSR contains the carrier status, and in particular the status of power supplies and the detection of presence of a card in the FMC slot. CONTROLR will allow control operations on the carrier, such as setting the Vadj supply voltage for the FMC slot through bits [31..16] and setting the system clock frequency through bits [15..0]. \subsubsection{CARRTYPER}
The CARRTYPER register uses bits [31..16] for a carrier type identifier and bits [7..0] for the PCB version, signaled to the FPGA through optional pull-up resistors in the PCB.
\subsubsection{SIIDLR and SIIDHR}
The SIIDLR and SIIDHR registers contain respectively the low and high parts of the 64-bit Silicon ID read from the Maxim DS18B20 1-Wire digital thermometer after system reset.
\subsubsection{BSTREAMTR and BSTREAMDR}
BSTREAMTR uses bits [31..16] for defining an FPGA bit stream type and [15..0] for a sequential number indicating the bit stream version. BSTREAMDR contains the 32-bit UTC time when the bit stream was generated.
\subsubsection{CARRTEMP}
CARRTEMPR contains the carrier temperature as read from the DS18B20 every second. The Board control and status block will set a bit to '1' for one clock tick after every reading if the temperature exceeds 60$^\circ$ Celsius. This bit will be connected to the interrupt controller so that the user can get a temperature interrupt if enabled.
\subsubsection{STATUSR}
STATUSR contains the carrier status, and in particular the status of power supplies and the detection of presence of a card in the FMC slot. Power supplies in the carrier are extensively monitored, and most of them provide a Power Good (G) signal. The internal structure of the STATUSR register is as follows:
\begin{enumerate}
\item Bits [31..11] are unused.
\item Bits [10..0] are (starting from bit 10): FMC\_PRESENT, 3V3\_FMC\_G, VADJ\_G, 1V8\_G, 1V5\_G, CLEAN\_1V8\_G, CLEAN\_3V3\_G, 5V\_G, M2V\_G, M5V2\_G and M12V\_G.
\end{enumerate}
\subsubsection{SUPCTRLR}
The carrier has several power supplies that can be enabled or disabled individually from the FPGA. They are controlled from the SUPCTRLR register, which is a bit field made of individual Enable (E) bits. In addition, some bits in this register are used to select which power supply voltage and current are monitored through the SUPAQNR register.
\begin{enumerate}
\item Bits [31..8] are unused.
\item Bits [7..4] contain an unsigned 4-bit number which selects a power supply for voltage and current monitoring. Starting at 0: 3V3\_PCIe, 12V\_PCIe, 3V3\_FMC, VADJ, 1V8, 1V5, VTTDDR, 1V2\_CORE, 1V2\_GTP,\linebreak CLEAN\_1V8, CLEAN\_3V3, 5V, M2V, M5V2 and M12V.
\item Bits [3..0] are (starting from bit 3): VADJ\_E, M2V\_E, M5V2\_E, M12V\_E.
\end{enumerate}
\subsubsection{SUPAQNR}
The SUPAQNR register holds a voltage and current consumption value resulting from on-board measurements using 16-bit ADCs. The selection of power supply to monitor is done in SUPCTRLR. Bits [31..16] hold an unsigned word representing voltage, while bits [15..0] are used for current consumption. To get Volts and Amperes from the raw measurements, different conversion factors must be used for each supply, as described in table~\ref{tab:conv_fact}.
\begin{table}[htbp]
\centering
\begin{tabularx}{\textwidth}{|X|l|l|}
\hline
\textbf{SUPPLY} & \textbf{Voltage factor (V/count)} & \textbf{Current factor (A/count)} \\
\hline
\hline
3V3\_PCIe & & \\
\hline
12V\_PCIe & & \\
\hline
3V3\_FMC & & \\
\hline
VADJ & & \\
\hline
1V8 & & \\
\hline
1V5 & & \\
\hline
VTTDDR & & \\
\hline
1V2\_CORE & & \\
\hline
1V2\_GTP & & \\
\hline
CLEAN\_1V8 & & \\
\hline
CLEAN\_3V3 & & \\
\hline
5V & & \\
\hline
M2V & & \\
\hline
M5V2 & & \\
\hline
M12V & & \\
\hline
\end{tabularx}
\caption{Conversion factors for voltage and current consumption.}
\label{tab:conv_fact}
\end{table}
\subsubsection{CONTROLR}
CONTROLR will allow control operations on the carrier, such as setting the Vadj supply voltage for the FMC slot through bits [31..16] and setting the system clock frequency through bits [15..0]. Vadj will change from 1V (0x0000) to 3.3V (0xFFFF). The frequency control word will drive a 16-bit DAC connected to a VCXO with 25 MHz center frequency and a span of 10 ppm. It is anticipated that any fixed value will do for our application, and that an internal PLL multiplying this 25 MHz by 5 will generate a 125 MHz system clock which will guarantee an absence of FIFO overflows from the 100 MS/s ADC chip.
\subsection{Interrupt controller} \subsection{Interrupt controller}
The interrupt controller receives interrupt requests from different blocks, combines them and sends an interrupt request to the GN4124/Wishbone bridge. For each interrupt input, it sets a bit in the IRQSRCR register upon detection of a rising edge. These bits are cleared on read. Care must be taken at design time to avoid race conditions in which a rising edge does not result in setting a bit because of the overriding effect of a concurrent read. Detection of a rising edge in any of the bits can result in the generation of an interrupt if the associated bit in the IRQENR register is set. The interrupt sent to the GN4124/Wishbone bridge is a one-tick-long positive pulse. The interrupt controller receives interrupt requests from different blocks, combines them and sends an interrupt request to the GN4124/Wishbone bridge. For each interrupt input, it sets a bit in the IRQSRCR register upon detection of a rising edge. These bits are cleared on read. Care must be taken at design time to avoid race conditions in which a rising edge does not result in setting a bit because of the overriding effect of a concurrent read. Detection of a rising edge in any of the bits can result in the generation of an interrupt if the associated bit in the IRQENR register is set. The interrupt sent to the GN4124/Wishbone bridge is a one-tick-long positive pulse.
...@@ -94,8 +185,11 @@ The interrupt controller receives interrupt requests from different blocks, comb ...@@ -94,8 +185,11 @@ The interrupt controller receives interrupt requests from different blocks, comb
\label{tab:irq_control} \label{tab:irq_control}
\end{table} \end{table}
\subsubsection{IRQSRCR and IRQENR}
The IRQSRCR and IRQENR are both bit fields with the same internal structure. The upper bits (except bit 31 of IRQSRCR, see below) are reserved for future use. Lower bits, staring at 0, include: DMA completion, carrier over-heating, ADC trigger, ADC shot taken, FMC ID I2C R/W completion and FMC Si570 I2C R/W completion. If an interrupt fires more than once before IRQSRCR is read, bit 31 of IRQSRCR will be set, for debugging purposes. This bit is also cleared on read.
\subsection{Dual port DDR RAM controller} \subsection{Dual port DDR RAM controller}
This block handles access to the MT41J128M16HA-15E DDR3 RAM chip from Micron. This chip has a data width of 16 bits and can hold 32 MSamples per channel in our application. The fact that only one sample can be written at a time means that the RAM must work at least four times faster than the ADCs, and this should be no problem. To avoid mapping a large memory into the host address space unnecessarily, only a selectable 8MB window will be exposed to the Wishbone bus at any time. The pointer to this window can be set from the Wishbone master. Another important aspect is to avoid collisions between Wishbone read requests (going to port 2 of the core) and ADC write requests (going to port 1). Taking into account that continuous read applications are not typical for such high-speed sampling systems, we will just allow reading while the state machine of the ADC core (see figure~\ref{fig:state_machine}) is in the Idle state. An attempt to read while the ADC is in any other state will result in a bus error. This block handles access to the MT41J128M16HA-15E DDR3 RAM chip from Micron. This chip has a data width of 16 bits and can hold 32 MSamples per channel in our application. The fact that only one sample can be written at a time means that the RAM must work at least four times faster than the ADCs, and this should be no problem. To avoid mapping a large memory into the host address space unnecessarily, and unload the host for reading, the core also implements a DMA engine. Another important aspect is to avoid collisions between Wishbone read requests and ADC write requests. Taking into account that continuous read applications are not typical for such high-speed sampling systems, we will just allow reading while the state machine of the ADC core (see figure~\ref{fig:state_machine}) is in the Idle state. An attempt to read while the ADC is in any other state will result in a bus error.
\begin{table}[htbp] \begin{table}[htbp]
\centering \centering
...@@ -104,13 +198,30 @@ This block handles access to the MT41J128M16HA-15E DDR3 RAM chip from Micron. Th ...@@ -104,13 +198,30 @@ This block handles access to the MT41J128M16HA-15E DDR3 RAM chip from Micron. Th
\textbf{NAME} & \textbf{OFFSET} & \textbf{MODE} & \textbf{DESCRIPTION} \\ \textbf{NAME} & \textbf{OFFSET} & \textbf{MODE} & \textbf{DESCRIPTION} \\
\hline \hline
\hline \hline
BANKSELR & & R/W & Sample memory bank select\\ DMACSTARTR & & R/W & DMA start address in the carrier\\
\hline
DMAHSTARTR & & R/W & DMA start address in the host\\
\hline
DMALENR & & R/W & DMA read length in 32-bit long words\\
\hline \hline
\end{tabularx} \end{tabularx}
\caption{Register set for the DDR RAM controller block.} \caption{Register set for the DDR RAM controller block.}
\label{tab:ddr_control} \label{tab:ddr_control}
\end{table} \end{table}
Memory will be organized as a circular buffer, with all 4 channels being logged in an interleaved way, starting with channel 1 at offset 0. When the host receives the end of shot interrupt, it can get the address of the channel 1 sample corresponding to the trigger moment in the TRIGPOSR register of the ADC controller.
\subsubsection{DMACSTARTR}
The DMACSTARTR register uses bits [30..0] as a start address in the carrier for the DMA transfer. Bit 31 selects the endianness of the readings, either little ('0') or big ('1'). Setting DMACSTARTR triggers the DMA operation as well, so DMAHSTARTR and DMALENR should be set before. The DMA engine will send samples to the host for a given channel, i.e. it will jump by 4 locations in the DDR for every read. The initial address set in DMACSTARTR will therefore select the channel to be read as well. DMACSTARTR, as well as other registers referencing a location in the DDR (such as TRIGPOSR), should use an address offset (from the begining of the DDR) pointing to a 16-bit word, i.e. an address which increments by 1 for every sample in the DDR.
\subsubsection{DMAHSTARTR}
Register DMAHSTARTR selects the start address for the DMA access in the host.
\subsubsection{DMALENR}
Register DMALENR selects the length of the reading in 32-bit words, i.e. two samples per word. How the samples are arranged inside the word depends on the endianness setting.
The end of a DMA access generates an interrupt request towards the interrupt controller.
\subsection{ADC controller} \subsection{ADC controller}
The ADC controller handles all communication with the ADC FMC. It has a Wishbone slave for configuration registers and a dedicated output connection to the DDR RAM controller for samples. It can also drive interrupt requests into the interrupt controller. These interrupts are all one-tick-long positive pulses. The sampling state machine is depicted in figure~\ref{fig:state_machine}. The ADC controller handles all communication with the ADC FMC. It has a Wishbone slave for configuration registers and a dedicated output connection to the DDR RAM controller for samples. It can also drive interrupt requests into the interrupt controller. These interrupts are all one-tick-long positive pulses. The sampling state machine is depicted in figure~\ref{fig:state_machine}.
...@@ -121,22 +232,42 @@ The ADC controller handles all communication with the ADC FMC. It has a Wishbone ...@@ -121,22 +232,42 @@ The ADC controller handles all communication with the ADC FMC. It has a Wishbone
\label{fig:state_machine} \label{fig:state_machine}
\end{figure} \end{figure}
The START, STOP, and SOFT\_TRIG commands can be used to provoke transitions in the state machine from the PCIe bus, by writing appropriate patterns into the ADCCTRLR register. A STOP command will always take the state machine to the Idle state, regardless of what its current state is. The state machine will drive two pulse-like signals into the IRQ controller. One will be a trigger interrupt and the other an end of shot interrupt, generated once the state machine reaches the Idle state after an acquisition. Both of these interrupts can be enabled/disabled in the interrupt controller block. The ADC controller is also in charge of controlling two LEDs: power good and trigger (100 ms width).
The TRIGGER condition in the figure is to be interpreted as an 'OR' of hardware and software (SOFT\_TRIG) triggers. Trigger configuration is handled through the TRIGCFGR register. Bits [31:16] are used for a threshold in case of internal trigger, bit 0 selects between internal and external trigger and bit 1 selects positive or negative slope. Hardware and software triggers can be enabled using bits 2 and 3 respectively. A trigger applies to all 4 channels. Bits 4 and 5 in TRICFGR select a channel to use for the case of internal hardware trigger. \subsubsection{ADCCTRLR}
The START, STOP, and SOFT\_TRIG commands can be used to provoke transitions in the state machine from the PCIe bus, by writing appropriate patterns (1, 2 and 3 respectively) into the least signisicant byte of the ADCCTRLR register. A STOP command will always take the state machine to the Idle state, regardless of what its current state is. A write of '1' to bit 31 of ADCCTRLR will reset the sample counter in ADCCNTR (see below).
The state machine will drive two pulse-like signals into the IRQ controller. One will be a trigger interrupt and the other an end of shot interrupt, generated once the state machine reaches the Idle state after an acquisition. Both of these interrupts can be enabled/disabled in the interrupt controller block. \subsubsection{ADCSTATR}
The current state in the state machine can be read from the ADCSTATR register. Idle~=~0, Pre-trigger Count~=~1, Wait Trigger~=~2 and Wait End of Shot~=~3.
Controlling the offset and gain of each ADC we have the ADCxOFFSR and ADCxGAINR registers, where x ranges from 1 to 4. The ADCxOFFSR registers are used to load a 16-bit DAC in the mezzanine, so only bits [15..0] are used. ADCxGAINR are in fact bit mask registers, with each bit controlling an independent switch. These switches are used in normal operation to set gains, but can also be used for disconnecting the input signal from the ADC for automatic calibration purposes. \subsubsection{TRIGCFGR}
The TRIGGER condition in the figure is to be interpreted as an 'OR' of hardware and software (SOFT\_TRIG) triggers. Trigger configuration is handled through the TRIGCFGR register. Bits [31:16] are used for a threshold (treated as 2's complement and compared to the raw ADC data) in case of internal trigger, bit 0 selects between internal ('0') and external ('1') trigger and bit 1 selects positive ('0') or negative ('1') slope. Hardware and software triggers can be enabled using bits 2 and 3 respectively. A trigger applies to all 4 channels. Bits 4 and 5 in TRIGCFGR select a channel to use for the case of internal hardware trigger.
The ADC FMC card has two I2C busses connected to it from the carrier FPGA through the FMC connector. The first one grants access to an identification EEPROM on the mezzanine. It is read and written using registers ADCIDADDR and ADCIDDATR. The FPGA puts the address plus a R/W flag into the ADCIDADDR register and then reads or writes from/to the ADCIDDATR. A read to ADCIDDATR must only be performed after the I2C controller has had time to get the data from the EEPROM. A write also has to be performed carefully, only after the previous write has succeeded. The I2C controller inside the ADC controller signals read and write completion through an interrupt request to the IRQ controller block. There is a separate I2C bus for controlling the Si570 clock generator in the mezzanine. Our application assumes it will be programmed to provide a constant 100 MHz frequency. Registers ADCCLKADDR and ADCCLKDATR are used in the same way as the EEPROM ones to read and write from/to the Si570 clock generator. Effective sampling rate is obtained by dividing the nominal 100 MHz from the Si570 by a variable amount, i.e. the FPGA will get data constantly at 100MS/s and will decimate it before writing into RAM. The decimation factor will be stored in bits [15..0] of SRATER. \subsubsection{TRIGPOSR}
This register contains the trigger position in DDR RAM (using the same address offset convention as DMACSTARTR) for the sample in channel 1 corresponding to the trigger instant.
The number of samples to be acquired before and after the trigger are common to all channels and stored in the ADCxPRER and ADCxPOSTR registers respectively, with x ranging from 1 to 4. \subsubsection{ADCxOFFSR and ADCxGAINR}
Controlling the offset and gain of each ADC we have the ADCxOFFSR and ADCxGAINR registers, where x ranges from 1 to 4. The ADCxOFFSR registers are used to load a 16-bit DAC in the mezzanine, so only bits [15..0] are used. ADCxGAINR are in fact bit field registers, with each bit controlling an independent switch. These switches are used in normal operation to set gains, but can also be used for disconnecting the input signal from the ADC for automatic calibration purposes. More information can be found in \href{http://www.ohwr.org/projects/fmc-adc-100m14b4cha}{http://www.ohwr.org/projects/fmc-adc-100m14b4cha}. For the purpose of this specification, it is enough to say that there are seven switches per analog input channel and they will be mapped to the least significant bits of the ADCxGAINR registers, starting with SW1 in bit 0 and ending with SW7 in bit 6.
For diagnostics and time-correlation purposes, the ADC controller hosts a 32-bit free-running counter which gets reset at power up and optionally following a command. This clearing uses a bit in the ADCCTRLR register, so it can be used in combination with any command. The value of the counter is incremented at the effective sampling rate, i.e. after decimation, and can be read in the ADCCNTR register. \subsubsection{ADCIDADDR and ADCIDDATR}
The ADC FMC card has two I2C busses connected to it from the carrier FPGA through the FMC connector. The first one grants access to an FMC identification EEPROM on the mezzanine, which can be used to read/write the type of mezzanine, in agreement with the FMC standard. It is read and written using registers ADCIDADDR and ADCIDDATR. The FPGA puts the address plus a R/W flag into the ADCIDADDR register and then reads or writes from/to the ADCIDDATR. The location used for the read ('0') or write ('1') flag is bit 31. A read to ADCIDDATR must only be performed after the I2C controller has had time to get the data from the EEPROM. A write also has to be performed carefully, only after the previous write has succeeded. The I2C controller inside the ADC controller signals read and write completion through an interrupt request to the IRQ controller block.
\subsubsection{ADCCLKADDR and ADCCLKDATR}
There is a separate I2C bus for controlling the Si570 clock generator in the mezzanine. Our application assumes it will be programmed to provide a constant 100 MHz frequency. Registers ADCCLKADDR and ADCCLKDATR are used in the same way as the EEPROM ones to read and write from/to the Si570 clock generator.
\subsubsection{SRATER}
Effective sampling rate is obtained by dividing the nominal 100 MHz from the Si570 by a variable amount, i.e. the FPGA will get data constantly at 100MS/s and will decimate it before writing into RAM. The decimation factor will be stored in bits [15..0] of SRATER.
\subsubsection{ADCPRER and ADCPOSTR}
The number of samples to be acquired before and after the trigger are common to all channels and stored in the ADCPRER and ADCPOSTR registers respectively.
\subsubsection{ADCCNTR}
For diagnostics and time-correlation purposes, the ADC controller hosts a 32-bit free-running counter which gets reset at power up and optionally following a command. This clearing uses bit 31 in the ADCCTRLR register, so it can be used in combination with any command. The value of the counter is incremented at the effective sampling rate, i.e. after decimation, and can be read in the ADCCNTR register.
\subsubsection{ADCSHOTCNTR}
Another counter running at the same rate counts the number of samples for a given shot. It is reset on START, counts up to the number of pre-trigger samples, waits for a trigger and continues counting up to pre-trigger + post-trigger samples. Its value can be accessed in the ADCSHOTCNTR register. Another counter running at the same rate counts the number of samples for a given shot. It is reset on START, counts up to the number of pre-trigger samples, waits for a trigger and continues counting up to pre-trigger + post-trigger samples. Its value can be accessed in the ADCSHOTCNTR register.
\subsubsection{ADCxVALR}
The current ADC output value can also be read from a dedicated register for each channel. This value is accessible in the ADCxVALR registers. The current ADC output value can also be read from a dedicated register for each channel. This value is accessible in the ADCxVALR registers.
\begin{table}[htbp] \begin{table}[htbp]
...@@ -148,8 +279,12 @@ The current ADC output value can also be read from a dedicated register for each ...@@ -148,8 +279,12 @@ The current ADC output value can also be read from a dedicated register for each
\hline \hline
ADCCTRLR & & R/W & ADC state machine control\\ ADCCTRLR & & R/W & ADC state machine control\\
\hline \hline
ADCSTATR & & RO & ADC status \\
\hline
TRIGCFGR & & R/W & Trigger configuration \\ TRIGCFGR & & R/W & Trigger configuration \\
\hline \hline
TRIGPOSR & & RO & Trigger position in memory \\
\hline
ADC1OFFSR & & R/W & ADC1 offset \\ ADC1OFFSR & & R/W & ADC1 offset \\
\hline \hline
ADC1GAINR & & R/W & ADC1 gain \\ ADC1GAINR & & R/W & ADC1 gain \\
...@@ -176,21 +311,9 @@ The current ADC output value can also be read from a dedicated register for each ...@@ -176,21 +311,9 @@ The current ADC output value can also be read from a dedicated register for each
\hline \hline
SRATER & & R/W & Sample rate decimation \\ SRATER & & R/W & Sample rate decimation \\
\hline \hline
ADC1PRER & & R/W & ADC 1 pre-trigger samples requested \\ ADCPRER & & R/W & ADC 1 pre-trigger samples requested \\
\hline
ADC1POSTR & & R/W & ADC 1 post-trigger samples requested \\
\hline \hline
ADC2PRER & & R/W & ADC 2 pre-trigger samples requested \\ ADCPOSTR & & R/W & ADC 4 post-trigger samples requested \\
\hline
ADC2POSTR & & R/W & ADC 2 post-trigger samples requested \\
\hline
ADC3PRER & & R/W & ADC 3 pre-trigger samples requested \\
\hline
ADC3POSTR & & R/W & ADC 3 post-trigger samples requested \\
\hline
ADC4PRER & & R/W & ADC 4 pre-trigger samples requested \\
\hline
ADC4POSTR & & R/W & ADC 4 post-trigger samples requested \\
\hline \hline
ADCCNTR & & RO & ADC global sample counter \\ ADCCNTR & & RO & ADC global sample counter \\
\hline \hline
...@@ -209,6 +332,4 @@ The current ADC output value can also be read from a dedicated register for each ...@@ -209,6 +332,4 @@ The current ADC output value can also be read from a dedicated register for each
\label{tab:adc_control} \label{tab:adc_control}
\end{table} \end{table}
The ADC controller is also in charge of controlling two LEDs: power good and trigger (100 ms width).
\end{document} \end{document}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment