资料介绍
Table of Contents
AD9250 Evaluation Board, ADC-FMC Interposer & Xilinx Reference Design
Introduction
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
Supported Devices
Supported Carriers
Quick Start Guide
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.
Required Hardware
- KC705/VC707/ZC706 board
- AD9250-EBZ board & Power supply (AD9250-250EBZ, AD9250-170EBZ)
- ADC FMC interposer board (CVT-ADC-FMC-INTPZB)
- Signal/Clock generator (reference clock input, 250MHz)
- Signal generator (analog input, for data capture)
Required Software
- Xilinx ISE Design Suite 14.4
- A UART terminal (Tera Term/Hyperterminal), Baud rate 57600 (115200 for ZC706).
Board Modifications
The reference design contains UCF files for the Rev. B board, CVT-ADC-FMC-INTPZB.
- NET rxdata_p[1] LOC = “B6”;
- NET rxdata_n[1] LOC = “B5”;
- NET rxdata_p[0] LOC = “D6”;
- NET rxdata_n[0] LOC = “D5”;
- NET rxsync_p LOC = “C29” | IOSTANDARD = “LVDS_25”;
- NET rxsync_n LOC = “B29” | IOSTANDARD = “LVDS_25”;
- NET rxsysref_p LOC = “D29” | IOSTANDARD = “LVDS_25”;
- NET rxsysref_n LOC = “C30” | IOSTANDARD = “LVDS_25”;
- NET spi_ctrl LOC = “K13” | IOSTANDARD = “LVCMOS25”;
- NET spi_csn[0] LOC = “B18” | IOSTANDARD = “LVCMOS25”;
- NET spi_csn[1] LOC = “A18” | IOSTANDARD = “LVCMOS25”;
- NET spi_clk LOC = “G17” | IOSTANDARD = “LVCMOS25”;
- NET spi_mosi LOC = “A17” | IOSTANDARD = “LVCMOS25”;
- NET spi_miso LOC = “A16” | IOSTANDARD = “LVCMOS25”;
Please do the following modifications on the AD9250 evaluation board.
- Remove R609
- Remove R610
- Remove R604
- Remove R601
- Remove R551*
- Remove R552*
- Populate R549*
- Populate R550*
* The reference design uses REFCLK2 as the reference clock source. If the board defaults to REFCLK1, follow these instructions to switch to REFCLK2.
Running Demo (SDK) Program
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
- Connect the AD9250-EBZ board to the FMC Interposer board.
- Connect the interposer board to the FMC-HPC connector of KC705/(FMC1-HPC if VC707)/ZC706 board.
- Connect power to KC705/VC707/ZC706 and the AD9250-EBZ boards. Make sure both are turned on.
- Connect two USB cables from the PC to the JTAG and UART USB connectors on KC705/VC707/ZC706. Do not run/load any software yet.
- Connect an external clock source 250MHz (5dBm) to AD9250-EBZ board's J505 SMA connector. Make sure this is active/on.
- Connect signal generators to the AIN-A and/or AIN-B, J301/J303 SMA connectors.
- Load the FPGA image/SDK with your favorite Xilinx Tool.
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:
- open Chipscope and press the Open Cable/Search JTAG Chain button (the leftmost button located under the File menu)
- open the Chipscope/AD9250.cpj project
- start the data capture
This is how the output of the ADC looks like.
Using the HDL reference design
Functional description
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.
Registers
Please refer to the regmap.txt file in the pcores directory.
Good To Know
The PN9/PN23 sequences are not compatible with O.150. Please use the equations given in the reference design.
Using the Software Reference Design
The Software Reference Design contains an example on how to:
- Initialize the AD9250 evaluation board
- Initialize the JESD204B HDL core
- Test the ADC communication using the test patterns and PRBS sequences generated by the AD9250
- Capture data from the AD9250 using DMA transfers
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.
AD9250 Software Driver
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. |
Software Setup
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:
- Copy the SDK_Workspace folder on your PC. Make sure that the path where it is stored does not contain any spaces.
- Copy the no-OS drivers source code to the SDK_Workspace/sw/src folder.
- Open the Xilinx SDK. When the SDK starts it asks you to provide a folder where to store the workspace. Any folder can be provided.
- In the SDK select the File→Import menu option to import the software projects into the workspace.
- In the Import window select the General→Existing Projects into Workspace option.
- In the Import Projects window select the SDK_Workspace folder as root directory. After the root directory is chosen the projects that reside in that directory will appear in the Projects list. Press Finish to finalize the import process.
- The Project Explorer window now shows the projects that exist in the workspace and the files for each project. The SDK should automatically build the projects and the Console window will display the result of the build. If the build is not done automatically select the Project→Build Automatically menu option.
- At this point the software project setup is complete, the FPGA can be programmed and the software can be downloaded into the system.
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.
Downloads
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:
Reference Design Contents
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. |
More information
- AD7490 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- AD7656-1 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- AD7658-1 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- CN0202 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- AD9833 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- AD5755 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- AD9671评估板、ADC-FMC转接器和Xilinx KC705参考设计
- AD5780 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- AD5449 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- CN0204 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- AD7980 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- AD5254 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- AD8403 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- AD7988-1 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- AD7683 FMC-SDP转接器和评估板/Xilinx KC705参考设计
- 使用Xilinx FPGA实现OFDM系统 850次阅读
- 配合MAX9217/MAX9218/MAX9247/MAX9248/MAX9250评估板工作 2117次阅读
- 使用MAXQ2010评估板读取温度 616次阅读
- 系统演示平台简化了从评估到原型设计的过渡 646次阅读
- 关于高速ADC测试和评估应用 1063次阅读
- Xilinx FPGA的FMC介绍 5643次阅读
- dfrobot可插拔传感器转接器简介 1043次阅读
- dfrobotWiiChuck转接器简介 1104次阅读
- 飞凌嵌入式JTAG转接板介绍 1614次阅读
- digilent FMC Pcam适配器介绍 2731次阅读
- digilent FMC-HDMI:双HDMI输入扩展子板介绍 4286次阅读
- 天嵌科技LVDS转接板-TTL-LVDS转接板规格 3772次阅读
- 2.5 GSPS高性能数模转换器——AD9739A DAC 4675次阅读
- 关于FPGA的FMC接口的详细介绍 1.1w次阅读
- 非插入式器件如何测量? 1573次阅读
下载排行
本周
- 1电子电路原理第七版PDF电子教材免费下载
- 0.00 MB | 1491次下载 | 免费
- 2单片机典型实例介绍
- 18.19 MB | 95次下载 | 1 积分
- 3S7-200PLC编程实例详细资料
- 1.17 MB | 27次下载 | 1 积分
- 4笔记本电脑主板的元件识别和讲解说明
- 4.28 MB | 18次下载 | 4 积分
- 5开关电源原理及各功能电路详解
- 0.38 MB | 11次下载 | 免费
- 6100W短波放大电路图
- 0.05 MB | 4次下载 | 3 积分
- 7基于单片机和 SG3525的程控开关电源设计
- 0.23 MB | 4次下载 | 免费
- 8基于AT89C2051/4051单片机编程器的实验
- 0.11 MB | 4次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 2PADS 9.0 2009最新版 -下载
- 0.00 MB | 66304次下载 | 免费
- 3protel99下载protel99软件下载(中文版)
- 0.00 MB | 51209次下载 | 免费
- 4LabView 8.0 专业版下载 (3CD完整版)
- 0.00 MB | 51043次下载 | 免费
- 5555集成电路应用800例(新编版)
- 0.00 MB | 33562次下载 | 免费
- 6接口电路图大全
- 未知 | 30320次下载 | 免费
- 7Multisim 10下载Multisim 10 中文版
- 0.00 MB | 28588次下载 | 免费
- 8开关电源设计实例指南
- 未知 | 21539次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935053次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 78.1 MB | 537793次下载 | 免费
- 3MATLAB 7.1 下载 (含软件介绍)
- 未知 | 420026次下载 | 免费
- 4OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 5Altium DXP2002下载入口
- 未知 | 233046次下载 | 免费
- 6电路仿真软件multisim 10.0免费下载
- 340992 | 191183次下载 | 免费
- 7十天学会AVR单片机与C语言视频教程 下载
- 158M | 183277次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138039次下载 | 免费
评论
查看更多