The AD9250 is a dual, 14-bit ADC with sampling speeds of up to 250 MSPS. It is designed to support communications applications where low cost, small size, wide bandwidth and versatility are desired. The ADC cores feature a multistage, differential pipelined architecture with integrated output error correction logic. This reference design includes the device data capture via the JESD204B serial interface and the SPI interface. The samples are written to the external DDR-DRAM on the carrier. It allows programming the device and monitoring its internal registers via SPI.
A native FMC card with the AD9250 can be found FMCJESDADC1 Board
The reference design zip file contains a bit file and a SDK elf file for a quick demonstration of the programming and data capture. The reference design has been tested with KC705, VC707 and ZC706. The notes below refer to KC705, the procedure is same for the other boards. Please make sure you are using the correct reference design for the board(s) that you have.
The reference design contains UCF files for the Rev. B board, CVT-ADC-FMC-INTPZB.
Please do the following modifications on the AD9250 evaluation board.
* The reference design uses REFCLK2 as the reference clock source. If the board defaults to REFCLK1, follow these instructions to switch to REFCLK2.
To begin make the following connections (see image below):
For proper operation, it is important that the steps must be done in this exact order
The quick start bit file configures the AD9250 for all test modes and verifies the captured data accordingly. After the hardware setup, turn the power on to the KC705/VC707/ZC706 and the AD9250-EBZ boards.
Run the download.bat script located in the “SDK/SDK_Workspace/bin” folder provided within the HDL Reference Design. This script uses XMD to program the FPGA with the HDL Reference Design and download the Software Reference Design into the DDR.
Note: The download.bat script assumes that the Xilinx ISE Design Suite 14.4 is installed at this path: C:/Xilinx/14.4. If the installation path on your computer is different please modify the script accordingly.
If programming was successful, you should be seeing messages appear on the terminal as shown in figure below. After programming the AD9250, the program checks data capture on various test modes.
After the ADC test patterns and PRBS sequences are verified, if no errors are present, the reference design continuously reads data from the ADC. The ADC data can be viewed using the Chipscope project located in the “Chipscope” folder provided in the HDL Reference Design. These are the steps than need to be followed to view the ADC data in Chipscope:
This is how the output of the ADC looks like.
The reference design is built on a microblaze based system parameterized for linux. A functional block diagram of the design is given below.
The reference design consists of two pcores. The JESD204B core consists of the GTX units and the Xilinx JESD204B IP core. The AD9250 core consists of three functional modules, the ADC interface, a PN9/PN23 monitor and a DMA interface.
The ADC interface captures and buffers data from the JESD204B core. The DMA interface then transfers the samples to the external DDR-DRAM. The capture is initiated by the software. The status of capture (overflow, overrange) are reported back to the software.
The JESD204B core and AD9250 core has an AXI lite interface that allows control and monitoring of the capture process.
The reference design also includes the HDMI cores to run GTX eye scan.
Please refer to the regmap.txt file in the pcores directory.
The PN9/PN23 sequences are not compatible with O.150. Please use the equations given in the reference design.
The Software Reference Design contains an example on how to:
The software project contains 2 components: the AD9250-EBZ reference design files and the AD9250 driver. All the components have to be downloaded from the links provided in the Downloads section.
Below is presented a short description of all the functions provided in the driver.
Function | Description |
---|---|
int32_t ad9250_setup(int32_t spiBaseAddr, int32_t ssNo) | Configures the device. Receives as parameters the SPI peripheral AXI base address and the slave select line on which the slave is connected. Returns negative error code or 0 in case of success. |
int32_t ad9250_read(int32_t registerAddress) | Reads data from a register. Receives as parameter the address of the register to be read and returns the read data or negative error code. |
int32_t ad9250_write(int32_t registerAddress, int32_t registerValue) | Writes data into a register. Receives as parameters the address of the register to be written and the value to be written into the register. Returns 0 in case of success or negative error code. |
int32_t ad9250_transfer(void) | Initiates a transfer and waits for the operation to end. Returns the negative error code or 0 in case of success. |
int32_t ad9250_soft_reset(void) | Resets all registers to their default values. Returns negative error code or 0 in case of success. |
int32_t ad9250_chip_pwr_mode(int32_t mode) | Configures the power mode of the chip. Receives as parameter the power mode(0 - normal operation, 1 - power-down, 2 - standby). Negative error code or the set power mode. |
int32_t ad9250_select_channel_for_config(int32_t channel) | Selects a channel as the current channel for further configurations. Receives as parameter the channel index(1 - channel A, 2 - channel B, 3 - channel A and B). Returns negative error code or the selected channel. |
int32_t ad9250_test_mode(int32_t mode) | Sets the ADC's test mode. Receives as parameter the test mode{0, 1, 2, 3, 4, 5, 6, 7, 8, 15}. Returns the set test mode or negative error code. |
int32_t ad9250_offset_adj(int32_t adj) | Sets the offset adjustment. Receives as parameter the offset adjust value in LSBs from +31 to -32. Returns negative error code or the set offset adjustment. |
int32_t ad9250_output_disable(int32_t en) | Disables (1) or enables (0) the data output. Returns the negative error code or the output disable state. |
int32_t ad9250_output_invert(int32_t invert) | Activates the inverted (1) or normal (0) output mode. Returns the negative error code or the set output mode. |
int32_t ad9250_output_format(int32_t format) | Specifies the output format. Receives as parameter the output format and returns the negative error code or the set output format. |
int32_t ad9250_reset_PN9(int32_t rst) | Sets (1) or clears (0) the reset short PN sequence bit(PN9). Returns the negative error code or the set PN9 status. |
int32_t ad9250_reset_PN23(int32_t rst) | Sets (1) or clears (0) the reset long PN sequence bit(PN23). Returns the negative error code or the set PN23 status. |
int32_t ad9250_set_user_pattern(int32_t patternNo, int32_t user_pattern) | Configures a User Test Pattern. Receives as parameters the patterns to be configured, range 1..4 and the user's pattern. Returns negative error code or the selected user pattern. |
int32_t ad9250_bist_enable(int32_t enable) | Enables(1) or disables(0) the Build-In-Self-Test. Returns negative error code or the state of the enable bit. |
int32_t ad9250_bist_reset(int32_t reset) | Resets the Build-In-Self-Test. Receives as parameters the reset option. Negative error code or the state of the reset bit. |
int32_t ad9250_jesd204b_setup(void) | Configures the JESD204B interface. Returns negative error code or 0 in case of success. |
int32_t ad9250_jesd204b_pwr_mode(int32_t mode) | Configures the power mode of the JESD204B data transmit block. Receives as parameter the power mode(0 - normal operation, 1 - power-down, 2 - standby) Returns negative error code or the set power mode. |
int32_t ad9250_jesd204b_select_test_injection_point(int32_t injPoint) | Selects the point in the processing path of a lane, where the test data will be inserted. Receives as parameter the point in the processing path(1 - 8B/10B Encoder output, 2 - scramble input). Returns negative error code or the status of the data injection point bit. |
int32_t ad9250_jesd204b_test_mode(int32_t testMode) | Selects a JESD204B test mode. Receives as parameter the test mode{0, 1, 2, 3, 4, 5, 6, 8, 12, 13}. Returns the set test mode or negative error code. |
int32_t ad9250_jesd204b_invert_logic(int32_t invert) | Inverts the logic of JESD204B bits. Receives as parameter the invert option(1 - invert, 0 - non-invert). Returns negative error code or the set mode. |
int32_t ad9250_fast_detect_setup(void) | Configures the Fast-Detect module. Returns negative error code or 0 in case of success. |
int32_t ad9250_dcc_enable(int32_t enable) | Enables DC correction for use in the output data signal path. Receives as parameter the enable option (0 - correction off, 1 - correction on). Returns negative error code or the status of the enable bit. |
int32_t ad9250_dcc_bandwidth(int32_t bw) | Selects the bandwidth value for the DC correction circuit. Receives as parameter the DC correction bandwidth, range 0..13. Returns negative error code or the state of the bandwidth bits. |
int32_t ad9250_dcc_freeze(int32_t freeze) | Freezes DC correction value. Receives as parameter the freeze option(0 or 1). Returns negative error code or the status of the freeze bit. |
The HDL Reference Design for each supported Xilinx FPGA board contains a folder called SDK_Workspace which stores the Xilinx SDK project files needed to build the no-OS software and also the .bit files with the HDL design that must be programmed into the FPGA. These are the steps that need to be followed to recreate the software project:
The example code is located in the ”main.c” file and the implementations of the test routines can be found in the “cf_ad9250.c” file.
The HDL Reference Designs and the no-OS Software can be downloaded from the Analog Devices github.
Only Xilinx coregen xco files are provided with the HDL Reference Design. You must regenerate the IP core files using this file. See generating Xilinx netlist/verilog files from xco files for details.
The software project contains 2 components: the AD9250-EBZ reference design files and the AD9250 driver. All the components have to be downloaded from the links below.
HDL Reference Designs:
no-OS Software:
Board Files:
HDL Reference Design | |
---|---|
license.txt | ADI license & copyright information. |
system.mhs | MHS file. |
system.xmp | XMP file (use this file to build the reference design). |
data/ | UCF file and/or DDR MIG project files. |
docs/ | Documentation files (Please note that this wiki page is the documentation for the reference design). |
sw/ | Software (Xilinx SDK) & bit file(s). |
cf_lib/edk/pcores/ | Reference design core file(s) (Xilinx EDK). |
Software Reference Design | |
cf_ad9250.h | Header file containing the registers definitions for the AD9250 HDL core. |
cf_ad9250.c | Implementation of the AD9250 HDL core access functions and ADC test and capture functions. |
spi.h | Header file for the Xilinx AXI SPI driver. |
spi.c | Implementation file for the Xilinx AXI SPI driver. |
main.c | Implementation of the program's main function. |
AD9250 Software Driver | |
AD9250.h | AD9250 software driver header file. |
AD9250_cfg.h | AD9250 software driver configuration file. |
AD9250.c | AD9250 software driver implementation file. |
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
全部0条评论
快来发表一下你的评论吧 !