

## Series XMC730 Multifunction Module

## **USER'S MANUAL**

ACROMAG INCORPORATED

30765 South Wixom Road Wixom, MI 48393-2417 U.S.A. Tel: (248) 295-0310 Email: solutions@acromag.com

Copyright 2018, Acromag, Inc., Printed in the USA. Data and specifications are subject to change without notice.

8501115D

# Table of Contents

| 1.0 | RELATED PUBLICATIONS9                             |
|-----|---------------------------------------------------|
| 2.0 | GENERAL INFORMATION9                              |
|     | Intended Audience9                                |
|     | Preface                                           |
|     | Trademark, Trade Name and Copyright Information10 |
|     | Class A Product Warning10                         |
|     | Environmental Protection Statement10              |
|     | Overview                                          |
|     | Ordering Information11                            |
|     | DAC Key Features                                  |
|     | ADC Key Features                                  |
|     | Counter/Timer Key Features13                      |
|     | Digital Input/Output Key Features14               |
|     | Key Features PCIe Interface15                     |
|     | Signal Interface Products15                       |
|     | Software Support 15                               |
|     | Windows®16                                        |
|     | VxWorks®16                                        |
|     | Linux®16                                          |
| 3.0 | PREPARATION FOR USE                               |
|     | Unpacking and Inspecting17                        |
|     | Installation Considerations18                     |
|     | Board Configuration                               |
|     | Non-Isolation Considerations19                    |
|     | P15 Primary XMC Connector 19                      |
|     | Table 3.1 P15 Primary XMC Connector20             |
|     | P16 Secondary XMC Connector 20                    |
|     | Table 3.2 P16 Secondary XMC Connector21           |

|     | Front Field I/O Connector                                                         |
|-----|-----------------------------------------------------------------------------------|
|     | Table 3.3 Front Field I/O Connector                                               |
|     | Rear P4 Field I/O Connector 23                                                    |
|     | Table 3.4 Rear P4 Field I/O Connector23                                           |
|     | Noise and Grounding Considerations 24                                             |
| 4.0 | PROGRAMMING INFORMATION25                                                         |
|     | CONFIGURATION REGISTERS                                                           |
|     | Table 4.1 Configuration Registers                                                 |
|     | BAR0 MEMORY MAP                                                                   |
|     | Table 4.2 Memory Map27                                                            |
|     | CDMA MEMORY MAP                                                                   |
|     | Table 4.3 CDMA Memory Map                                                         |
|     | SCATTER GATHER MEMORY MAP 28                                                      |
|     | Table 4.4 Scatter Gather Memory Map   28                                          |
|     | AXI-CDMA                                                                          |
|     | Table 4.5 AXI-CDMA29                                                              |
|     | CDMA Control Register                                                             |
|     | Table 4.6 CDMA Control Register (Read/Write) - + 0x0000)                          |
|     | CDMA Status Register                                                              |
|     | Table 4.7 CDMA Status Register (Read/Write) – (BAR0 + 0x0004)32                   |
|     | CDMA Current Descriptor Pointer Register                                          |
|     | Table 4.8 CDMA Current Descriptor Pointer Register (Read/Write) - (BAR0 + 0x0008) |
|     | CDMA Tail Descriptor Pointer Register                                             |
|     | Table 4.9 CDMA Tail Descriptor Pointer Register (Read/Write) - (BAR0 + 0x0010)36  |
|     | CDMA Source Address Register                                                      |
|     | Table 4.10 CDMA Source Address Register (Read/Write) – (BAR0 + 0x0018)            |
|     | CDMA Destination Address Register                                                 |
|     | Table 4.11 CDMA Destination Address Register (Read/Write) – (BAR0 + 0x0020)       |
|     | CDMA Bytes to Transfer Register                                                   |
|     | Table 4.12 CDMA Bytes to Transfer Register (Read/Write) – (BAR0 + 0x0028)         |
|     |                                                                                   |

| Scatter Gather Transfer Descriptor Definition                       |  |
|---------------------------------------------------------------------|--|
| Table 4.13 Scatter Gather Transfer Descriptor Definition         39 |  |
| Transfer Descriptor NXTDESC_PNTR                                    |  |
| Table 4.14 Transfer Descriptor NXTDESC_PNTR40                       |  |
| Transfer Descriptor Source Address 40                               |  |
| Table 4.15 Transfer Descriptor Source Address         40            |  |
| Transfer Descriptor Destination Address 40                          |  |
| Table 4.16 Transfer Descriptor Destination Address         40       |  |
| Transfer Descriptor CONTROL Word 41                                 |  |
| Table 4.17 Transfer Descriptor CONTROL Word41                       |  |
| Transfer Descriptor Status Word 41                                  |  |
| Table 4.18 Transfer Descriptor Status Word         41               |  |
| Simple CDMA Programming Example 43                                  |  |
| AXI-BAR0 Aperture Base Address 44                                   |  |
| Table 4.19 AXI-BARO Aperture Base Address44                         |  |
| PCLe AXI Bridge Control 45                                          |  |
| Table 4.20 PCLe AXI Bridge Control    45                            |  |
| PHY Status/Control Register (Read) – (BAR0 + 0x1144)                |  |
| Table 4.21 PHY Status/Control Register46                            |  |
| AXI Base Address Translation Configuration Register                 |  |
| Interrupt Controller                                                |  |
| Table 4.22 Interrupt Controller                                     |  |
| Interrupt Status Register (Read/Write) – (BAR0 + 0x2000)            |  |
| Table 4.23 Interrupt Status (Read/Write) – (BAR0 + 0x2000)49        |  |
| Interrupt Pending Register (Read/Write) – (BAR0 + 0x2004)           |  |
| Table 4.24 Interrupt Pending (Read/Write) – (BAR0 + 0x2004)50       |  |
| Interrupt Enable Register (Read/Write) – (BAR0 + 0x2008)            |  |
| Table 4.25 Interrupt Enable (Read/Write) – (BAR0 + 0x2008)51        |  |
| Interrupt Acknowledge Register 51                                   |  |
| Table 4.26 Interrupt Acknowledge (Read/Write) – (BAR0 + 0x200C)52   |  |
| Set Interrupt Enable Register (Read/Write) – (BAR0 + 0x2010)52      |  |

| Table 4.27 Set Interrupt Enable (Read/Write) – (BAR0 + 0x2010)53                                                                      |
|---------------------------------------------------------------------------------------------------------------------------------------|
| Clear Interrupt Enable Register (Read/Write) – (BAR0 + 0x2014)                                                                        |
| Master Enable Register                                                                                                                |
| AXI XADC Analog to Digital Converter (System Monitor)54<br>Table 4.30 AXI XADC Analog to Digital Converter (System Monitor)55         |
| Firmware Revision Register 55                                                                                                         |
| ADC, Digital I/O, and Counter Memory Map55<br>Table 4.31: ADC/Digital/Counter Memory Map55                                            |
| Global Interrupt Status Clear Register (Read/Write) - (Base + 7000H)                                                                  |
| Global Interrupt Enable Register (Read/Write) - (Base + 7004H)58<br>Table 4.33 Global Interrupt Enable Register58                     |
| ADC Control Register (Read/Write) - (Base + 7008H)58<br>Table 4.34 ADC Control Register                                               |
| ADC Range Select Channel Enable Register and Corresponding Digital Output Codes<br>(Read/Write) - (BAR0 + 0x700C) and (BAR0 + 0x7010) |
| ADC Conversion Timer Register (Read/Write) - (BAR0 + 0x0000 7014)                                                                     |
| ADC FIFO Full Threshold Register (Read/Write) - (BAR0 + 0x0000 7018)64                                                                |
| ADC Start Conversion Register (Write) - (BAR0 + 0x0000 701C)64                                                                        |
| ADC FIFO Channel Data and Tag Register (Read/Write) - (BAR0 + 0x0000 7020) 64<br>Table 4.36 ADC FIFO Channel Data and Tag Register65  |
| Modes of Conversion                                                                                                                   |
| Single Conversion Mode                                                                                                                |
| Continuous Conversion Mode                                                                                                            |
| Automatic DMA Transfer                                                                                                                |

| Programming Considerations                                                                                    |
|---------------------------------------------------------------------------------------------------------------|
| Continuous Conversion Mode with Interrupt Example                                                             |
| Single Conversion Mode Example 68                                                                             |
| Automatic DMA Mode Example 68                                                                                 |
| Digital Input/Output Registers (Read/Write) - (Base + 7040H)                                                  |
| Digital Direction Control Register (Read/Write) - (Base + 7044H)                                              |
| Interrupt Type (COS or H/L) Configuration Register (Read/Write) - (Base + 7048H) 70                           |
| Interrupt Polarity Registers (Read/Write) - (Base + 704CH)                                                    |
| Debounce Enable Register (Read/Write) (Base + 7050H)                                                          |
| Debounce Duration Select Register (Read/Write) (Base + 7054H)                                                 |
| Counter Trigger, Stop, Load Read Back, and Toggle Register (Write) - (BAR0 + 0x0000<br>7070)                  |
| Counter Control Register (Read/Write) - (BAR0 + 0x0000 7074)                                                  |
| Quadrature Position Measurement                                                                               |
| Pulse Width Modulation       78         Table 4.40 Counter Control Register (Pulse Width Modulation)       79 |
| Watchdog Timer Operation                                                                                      |
| Table 4.41 Counter Control Register (Watchdog Timer)                                                          |
|                                                                                                               |
| Table 4.41 Counter Control Register (Watchdog Timer)                                                          |

| Input Period Measurement                                                                                    |
|-------------------------------------------------------------------------------------------------------------|
| Table 4.45 Counter Control Register (Period Measurement)         89                                         |
| One Shot Bulse Mede                                                                                         |
| One-Shot Pulse Mode                                                                                         |
| Table 4.46 Counter Control Register (One-Shot Mode)                                                         |
| Counter Interrupt Information Register (Read Only) - (BAR0 + 0x0000 7078)                                   |
| Table 4.47 Counter Interrupt Information Register92                                                         |
|                                                                                                             |
| Counter Read Back Register (Read Only) - (BAR0 + 0x0000 707C)                                               |
| Counter Constant A Register 1 (Read/Write) - (BAR0 + 0x0000 7080)                                           |
|                                                                                                             |
| Counter Constant A Register 2 (Read/Write) - (BAR0 + 0x0000 7084)                                           |
|                                                                                                             |
| Counter Constant B Register 1 (Read/Write) - (BAR0 + 0x0000 7088)                                           |
| Counter Constant B Register 2 (Read/Write) - (BAR0 + 0x0000 708C)                                           |
| Counter Constant B Register 2 (Read/ Write) - (BAR0 + 0x0000 708C)                                          |
| ADC Offset Register (Read/Write) - (BAR0 + 0x70A0 to 0x70DC)                                                |
| Table 4.48 Offset Constant Number Formant                                                                   |
|                                                                                                             |
| ADC Gain Register (Read/Write) - (BAR0 + 0x70E0 to 0x711C)96                                                |
| Table 4.49 Gain Constant Number Formant         96                                                          |
| Flash Memory                                                                                                |
| Flash Memory                                                                                                |
| Flash Data Register (Read/Write) - (BAR0 + 0x0000 7204)                                                     |
| Table 4.50     Flash Data Register     98                                                                   |
|                                                                                                             |
| Flash Chip Select (Write Only) - (BAR0 + 0x0000 7208)                                                       |
|                                                                                                             |
| DAC Registers                                                                                               |
| Table 4.51 DAC Registers       99         Figure 4.2 AD5761 D/A Converter Interface Block Diagram       101 |
| Figure 4.2 AD5761 D/A Converter Interface Block Diagram                                                     |
| Addressing Sample Memory101                                                                                 |
|                                                                                                             |
| Channel X Start Address101                                                                                  |
| Table 4.52 Channel X Start Address                                                                          |
| Channel X End Address102                                                                                    |
| Table 4.53 Channel X End Address                                                                            |
| Table 4.55 Chainer & Enu Audress                                                                            |
| Channel X FIFO                                                                                              |
| Table 4.54 Channel X FIFO102                                                                                |

|     | Channel X Control Resistor                                       |
|-----|------------------------------------------------------------------|
|     | Table 4.55 Channel X Control Resistor                            |
|     | Channel X Status Resistor103                                     |
|     | Table 4.56 Channel X Status Resistor                             |
|     | Channel X DAC Direct Access104                                   |
|     | Table 4.57 Channel X DAC Direct Access104                        |
|     | Table 4.58 Data Format106                                        |
|     | Control Register (Read/Write) - (BAR0 + 0x0004 0200)106          |
|     | Table 4.59 Control Register106                                   |
|     | Timer Divider Register (Read/Write) - (BAR0 + 0x0004 0204)107    |
|     | Table 4.60 Timer Divider107                                      |
|     | Software Trigger Register (Read/Write) - (BAR0 + 0x0004 0208)107 |
|     | Table 4.61 Software Trigger   107                                |
| 5.0 | DAC USE OF CALIBRATION DATA 108                                  |
| 5.0 |                                                                  |
|     | Uncalibrated Performance108                                      |
|     | Calibrated Performance108                                        |
|     | Table 5.1 Ideal slope and zero values for supported ranges       |
| 6.0 | ADC USE OF CALIBRATION DATA 110                                  |
|     | Uncalibrated Performance110                                      |
|     |                                                                  |
|     | Calibrated Performance110                                        |
|     | Calibration Programming Example112                               |
|     | Determination of CountCALLO Value112                             |
|     | Determination of <i>CountCALHI</i> Value112                      |
|     | Calculate the Calibration Constants to Store in Flash113         |
| 7.0 | FLASH MEMORY MAP114                                              |
| -   | Table 7.1 DAC Calibration Coefficient Map                        |
|     | Table 7.2 ADC Calibration Coefficient Map                        |
|     | Table 7.3 Flash ASCII String Identifier                          |
|     |                                                                  |

| 8.0  | DAC SUGGESTED PROGRAMMING FOR STREAMING MODE 120 |
|------|--------------------------------------------------|
| 9.0  | THEORY OF OPERATION 123                          |
|      | PCI INTERFACE LOGIC                              |
|      | System Monitor124                                |
|      | Clock Generation124                              |
|      | 128Mb Serial Flash124                            |
|      | Counter Timer                                    |
|      | Digital Input/Output124                          |
|      | Analog Input125                                  |
|      | Analog Output125                                 |
| 10.0 | SERVICE AND REPAIR 126                           |
| 10.0 | SERVICE AND REPAIR                               |
|      | Service and Repair Assistance126                 |
|      | Preliminary Service Procedure126                 |
|      | Where to Get Help126                             |
| 11.0 | SPECIFICATIONS 127                               |
|      | Physical127                                      |
|      | Power Requirements127                            |
|      | Environmental Considerations127                  |
|      | Operating Temperature                            |
|      | Other Environmental Requirements                 |
|      | Relative Humidity                                |
|      | Isolation                                        |
|      | Vibration and Shock Standards128                 |
|      | EMC Directives                                   |
|      | FCC US/Canada128                                 |
|      | Reliability Prediction129                        |
|      | Table 8.1 XMC730                                 |
|      |                                                  |

| DAC Analog Output         | 129 |
|---------------------------|-----|
| ADC Analog Input          | 130 |
| Counter/Timers            | 131 |
| PCIe Bus Specifications   | 132 |
| CERTIFICATE OF VOLATILITY |     |
| REVISION HISTORY          |     |

All trademarks are the property of their respective owners.

### IMPORTANT SAFETY CONSIDERATIONS

It is very important for the user to consider the possible adverse effects of power, wiring, component, sensor, or software failures in designing any type of control or monitoring system. This is especially important where economic property loss or human life is involved. It is important that the user employ satisfactory overall system design. It is agreed between the Buyer and Acromag, that this is the Buyer's responsibility.

## **1.0 RELATED PUBLICATIONS**

The following manuals and part specifications provide the necessary information for in depth understanding of this product.

| ADC Data Sheet | LTC2333-16 Buffered 8-Channel , 16-Bit, 800ksps Differential +/- 10.24V |
|----------------|-------------------------------------------------------------------------|
| DAC Data Sheet | AD5761 Multiple Range, 16-Bit, Bipolar/Unipolar                         |

## 2.0 GENERAL INFORMATION

#### **Intended Audience**

This users' manual was written for technically qualified personnel who will be working with I/O devices using the XMC module. It is not intended for a general, non-technical audience that is unfamiliar with XMC module and their application.

### Preface

The information contained in this manual is subject to change without notice, and Acromag, Inc. (Acromag) does not guarantee its accuracy. Acromag makes no warranty of any kind with regard to this material, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. Further, Acromag assumes no responsibility for any errors that may appear in this manual and makes no commitment to update, or keep current, the information contained in this manual. No part of this manual may be copied or reproduced in any form, without the prior written consent of Acromag,

### Trademark, Trade Name and Copyright Information

© 2018 by Acromag Incorporated.

All rights reserved. Acromag is a registered trademark of Acromag Incorporated. All other trademarks, registered trademarks, trade names, and service marks are the property of their respective owners.

### **Class A Product Warning**

This is a Class A product. In a domestic environment this product may cause radio interference, in which case the user may find it necessary to take adequate corrective measures.

### **Environmental Protection Statement**

This product has been manufactured to satisfy environmental protection requirements where possible. Many components used (structural parts, circuit boards, connectors, etc.) are capable of being recycled. Final disposition of this product after its service life must be conducted in accordance with applicable country, state, or local laws or regulations.

#### **Overview**

The XMC730 series modules are XMC modules with the capability to monitor 16 differential analog input channels to 16-bit resolution. In addition, eight 16-bit analog output voltage channels are provided. Lastly, one independent multifunction 32-bit counter/timer is available with 16 digital input/output channels.

These modules include the interface to PCIe bus via four high speed serial lanes on the XMC P15 connector. The PCIe interface supports a one lane Gen 1 PCIe implementation with one DMA channel for data transfer between the PCIe bus and the XMC730.

The P16 I/O connector will provide external connection to all ADC, DAC, and digital signals on the XMC730CC model. The P4 connector will be used on the XMC730CC model to also access the digital signals. The XMC730 front I/O model will provide access to all ADC, DAC, and digital signals via a front mounted 68 pin SCSI connector.

### **Ordering Information**

The following table lists the orderable models and their corresponding operating temperature range. Model XMC730 is a front I/O air cooled model without rear I/O. Model XMC730CC is conduction-cooled rear I/O model without front I/O.

| MODELS   |                   | OPERATING<br>TEMPERATURE RANGE       |
|----------|-------------------|--------------------------------------|
| XMC730   |                   | 0°C to + 70°C (200 LFM<br>airflow)   |
| XMC730E  |                   | -40°C to + 85°C (200 LFM<br>airflow) |
| XMC730CC | Rear (P16 and P4) | -40°C to +85° C cold-plate           |

### **DAC Key Features**

**High Channel Count** – Individual control of eight channels of Digital to Analog Converter (DAC) with voltage output is provided.

**Flexible Operating Modes** – Each channel may be independently configured to operate in direct access, single burst, continuous, or streaming (FIFO) mode.

**Flexible Trigger** – Each channel can be independently configured for software trigger, on-board timer trigger, or external trigger mode. The module can accept an external trigger or be the trigger source for synchronizing with other modules.

**Flexible Memory Allocation** – The on-board 64K x 16-bit sample memory is shared among the eight channels. The amount of memory allocated to each channel is configurable.

**Continuous Output Mode** - Continuous conversions are implemented by continuously cycling through the waveform memory, from Start Address to End Address, until halted by software. The interval between conversions is controlled by the interval timer. Conversions are initiated by issue of a software or external trigger.

**FIFO Output Mode** - Each of the channel's FIFOs can be filled/loaded with new data without stopping output waveform generation.

**Single Conversion Mode** - Conversions are started with the Start Address and can continue until the channel's End Address is reached.

**16-Bit Resolution** - Each channel contains its own 16-bit, Digital to Analog Converter (DAC) with 7.5uS output settling time.

**Software selectable output range** - Provides six voltage ranges:

0 to 10 Volts, 0 to 5 Volts, +/-10 Volts, +/-5 Volts, +/-3 Volts, - 2.5V to +7.5 Volts

**Reliable Software Calibration** - Calibration coefficients stored on-board provide the means for accurate software calibration of the module.

#### **ADC Key Features**

**ADC 16-Bit Resolution** - 16-bit capacitor-based successive approximation Analog to Digital Converter (ADC) with integral sample and hold and reference.

**1.264µsec Conversion Time** - A maximum conversion rate of 791,139.24Hz is supported.

**High Density** - Monitors up to 16 differential analog inputs (acquisition mode and channels are selected via programmable control registers).

**1026 Sample FIFO Buffer** – A single 1026 sample deep FIFO is available for buffering data from the 16 differential channels. This allows the external processor to service more tasks within a given time. Data tagging is implemented for easy channel identification. The FIFO buffer can be read through host generated PCIe read transactions or through DMA transactions.

**Interrupt Upon FIFO Threshold Reached** – FIFO interrupt generation is also supported. Upon reaching a FIFO programmable threshold condition an interrupt can be generated to minimize CPU interaction.

Automatic DMA Transfers Upon FIFO Threshold Reached – In Auto DMA Mode, DMA transfers will automatically be started when the FIFO threshold has been met to minimize CPU interaction.

**FIFO Full, Empty and Threshold Reached Flags** – FIFO Full, Empty and Threshold Reached flag bits are available to implement software polling schemes for FIFO buffer data control.

**Programmable Control of Channels Converted** – Up to 16 differential analog inputs are monitored. Channels 0 to 7 are converted sequentially while channels 8 to 15 are simultaneously sequentially converted. Channels may be individually enabled/disabled for conversion.

**User Programmable Conversion Timer** – A programmable conversion timer is available to control the time between conversion of the next channel data. For example, with the two ADC devices, channel 0 and 8 are converted simultaneously upon trigger with channels 1 and 9 converted next after the programmed conversion time. This sequence continues to channels 2 and 10 etc. **Continuous Conversion Mode** – All channels selected for conversion are continually digitized with the interval between conversions controlled by the programmed conversion timer register. Scanning is initiated by a software or external trigger. Scanning is stopped by software control.

**Single Cycle Conversion Mode** – All channels selected for conversion are digitized once with the time between channels controlled by a programmable timer. Single cycle conversion mode is initiated by a software or external trigger.

**External Trigger Input or Output** – The external trigger input is assigned to a field I/O line. The external trigger output is assigned to another field I/O line. This external trigger may be enabled or disabled. As an output, this signal provides a means to synchronize other modules to a single XMC730 timer reference.

**Calibration Constants** – Factory calibration constants used to correct gain and offset errors are stored in on-board flash memory. Gain and offset correction constants are stored for each analog to digital channel and each of the supported ranges.

**ADC Ranges Selected via Control Register** - Both bipolar and unipolar ranges are programmable available via control register.

Bipolar ranges of +/-10.24, +/-10, +/-5.12, +/-5.0

Unipolar ranges of +10.24 to 0, +10.0 to 0, +5.12 to 0.

Selected range applies to each channel and can be individually selected on a per channel basis.

### **Counter/Timer Key Features**

**32-Bit Counter/Timer** – A multifunction 32-bit counter is provided for implementation of: waveform generation, event counting, watchdog timing, pulse-width measurement, or period measurement.

**Quadrature Position Measurement** – Three input signals can be used to determine bi-directional motion. The sequence of logic high pulses for two input signals, A and B, indicate direction and a third signal (index) is used to initialize the counter. X1, X2, and X4 decoding is also implemented. X1 decoding executes one count per duty cycle of the A and B signals, while X2, and X4 execute two and four counts per duty cycle, respectively.

**Pulse Width Modulation** – The counter can be programmed for pulse width modulation. The duration of the logic high and low levels of the output signal can be independently controlled. An external gate signal can also be used to start/stop generation of the output signal.

**Watchdog Timer** – The counter can be configured as a countdown timer for implementation as a watchdog timer. A gate-off signal is available for use

to stop the countdown operation. Interrupt generation upon a countdown to zero condition is available.

**Event Counter** – The counter can be configured to count input pulses or events. A gate-off signal is provided to control count-up or count down with each event. Interrupt generation upon programmed count condition is available.

**Frequency Measurement** – The counter can be configured to count how many active edges are received during a period defined by an external count enable signal. An interrupt can be generated upon measurement complete.

**Pulse-Width or Period Measurement** – The counter can be configured to measure pulse-width or waveform period. In addition, an interrupt can be generated upon measurement complete.

**One-Shot and Repetitive One-Shot** – A one-shot pulse waveform may also be generated by the counter. The duration of the pulse and the delay until the pulse goes active is user programmable. A repetitive one-shot can be initiated with repetitive trigger pulses.

**Programmable Interface Polarity** – The polarities of the counter's external trigger, input, and output pins are programmable for active high or low operation. These counter control signals are available through the board's field connector.

**Internal or External Triggering** – A software or hardware trigger is selectable to initiate quadrature position measurement, pulse width modulation, watchdog countdown, event counting, frequency measurement, pulse-width measurement, period measurement, or one shot operation.

**CMOS Compatible Thresholds** – Input and output signal thresholds are at 3.3 volt levels.

### **Digital Input/Output Key Features**

**16 Digital Input/Output Channels** – Interface with up to 16 input/output channels which can be configured as input or output in groups of eight channels.

**TTL Compatible Thresholds** – Input and output thresholds are at 5V TTL levels. Buffer input channels include hysteresis for increased noise immunity.

**Programmable Change of State/Level Interrupts –** Interrupts are software programmable for any bit Change-Of-State or level on all 16 channels.

**Power Up and System Reset is Failsafe** – For safety, the digital channels are configured for input upon power-up.

| Key Features PCIe Interface |                                                                                                                                                                                                                                                                                                                            |  |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                             | <b>PCIe Bus</b> – The PCI Express Generation 1 interface operates at a bus speed of 2.5 Gbps per lane per direction. The XMC730 has a 1 lane PCIe interface.                                                                                                                                                               |  |
|                             | <b>PCIe Bus Master</b> – The PCIe interface logic becomes the bus master to perform DMA transfers.                                                                                                                                                                                                                         |  |
|                             | <b>DMA Operation</b> – The example design includes a DMA controller to move data between the XMC730 memory and the PCIe bus interface.                                                                                                                                                                                     |  |
|                             | <b>Compatibility</b> – PCI Express Base Specification v2.1 compliant PCI Express<br>Endpoint. Provides one multifunction interrupt. The XMC730 series<br>modules are compatible with the XMC VITA 42.3 specification for P15.<br>Replacement of VITA42 connectors with VITA61 connectors is possible<br>(contact factory). |  |
| Signal Interface Products   |                                                                                                                                                                                                                                                                                                                            |  |
|                             | The XMC730 Module will mate directly to all Acromag XMC carriers. Once connected, the module is accessed via the front 68 pin SCSI connector or via rear I/O from the P16 and P4 connectors.                                                                                                                               |  |
|                             | Accessory cables and termination panels are also available. For optimum performance with the XMC730 module, use of the shortest possible length of shielded I/O cable is recommended.                                                                                                                                      |  |
| Software Support            |                                                                                                                                                                                                                                                                                                                            |  |
|                             | The XMC730 series products require support drivers specific to your operating system. Supported operating systems include: Linux, Windows, and VxWorks                                                                                                                                                                     |  |

| Windows® | Acromag provides software products (sold separately) to facilitate the development of Windows® applications interfacing with Acromag PMC, XMC, and VPX I/O board products, PCI and PCIe I/O Cards, and CompactPCI I/O Cards. This software (model PCISW-API-WIN) consists of low-level drivers and Dynamic Link Libraries (DLLs) that are compatible with a many programming environments. The DLL functions provide a high-level interface to boards eliminating the need to perform low-level reads/writes of registers, and the writing of interrupt handlers. |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VxWorks® | Acromag provides a software product (sold separately) consisting of VxWorks® software. This software (Model PMCSW-API-VXW) is composed of VxWorks® (real time operating system) libraries for all Acromag PMC, XMC, and VPX I/O board products, PCI and PCIe I/O Cards, and CompactPCI I/O Cards. The software is implemented as a library of "C" functions which link with existing user code to make possible simple control of all Acromag PCI and PCIe boards.                                                                                                |
| Linux®   | Acromag provides a software product consisting of Linux® software. This software (Model PMCSW-API-LNX) is composed of Linux® libraries for all Acromag PMC, XMC, and VPX I/O board products, PCI and PCIe I/O cards, and CompactPCI I/O cards. The software supports X86 only and is implemented as library of "C" functions which link with existing user code to make possible simple control of all Acromag PCI and PCIe boards.                                                                                                                               |

## 3.0 PREPARATION FOR USE

### IMPORTANT PERSONAL AND PRODUCT SAFETY CONSIDERATIONS



It is very important for the user to consider the possible safety implications of power, wiring, component, sensor, or software failures in designing any type of control or monitoring system. This is especially important where personal injury or the loss of economic property or human life is possible. It is important that the user employ satisfactory overall system design. It is understood and agreed by the Buyer and Acromag that this is the Buyer's responsibility.



**Unpacking and Inspecting** 

WARNING: This board utilizes static sensitive components and should only be handled at a static-safe workstation. This product is an electrostatic sensitive device and is packaged accordingly. Do not open or handle this product except at an electrostatic-free workstation. Additionally, do not ship or store this product near strong electrostatic, electromagnetic, magnetic, or radioactive fields unless the device is contained within its original manufacturer's packaging. Be aware that failure to comply with these guidelines will void the Acromag Limited Warranty.

Upon receipt of this product, inspect the shipping carton for evidence of mishandling during transit. If the shipping carton is badly damaged or water stained, request that the carrier's agent be present when the carton is opened. If the carrier's agent is absent when the carton is opened and the contents of the carton are damaged, keep the carton and packing material for the agent's inspection.

For repairs to a product damaged in shipment, refer to the Acromag Service Policy to obtain return instructions. It is suggested that salvageable shipping cartons and packing material be saved for future use in the event the product must be shipped.

This board is physically protected with packing material and electrically protected with an anti-static bag during shipment. However, it is recommended that the board be visually inspected for evidence of mishandling prior to applying power.

The board utilizes static-sensitive components and should only be handled at a static-safe workstation.

### Installation Considerations

| IMPORTANT: Adequate air<br>circulation must be provided to<br>prevent a temperature rise | Refer to the specifications for loading and power requirements. Be sure that<br>the system power supplies can accommodate the power requirements of<br>the carrier board, plus the installed XMC modules, within the voltage<br>tolerances specified.                                                                                                                                                                                                                |
|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| above the maximum operating<br>temperature.                                              | The dense packing of the XMC module to the carrier/CPU board restricts air<br>flow within the card cage and is cause for concern. Adequate air circulation<br>must be provided to prevent a temperature rise above the maximum<br>operating temperature and to prolong the life of the electronics. If the<br>installation is in an industrial environment and the board is exposed to<br>environmental air, careful consideration should be given to air-filtering. |
|                                                                                          | In a conduction cooled assembly, adequate thermal conduction must be provided to prevent a temperature rise above the maximum operating temperature.                                                                                                                                                                                                                                                                                                                 |
| Board Configuration                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                                          | Power should be removed from the board when installing XMC modules, cables, termination panels, and field wiring.                                                                                                                                                                                                                                                                                                                                                    |
| Counter Output pull-up voltage                                                           | Set DIP switch SW1 as needed to enable: +5V pullup voltage, +12V pullup voltage, or External voltage and pullup to MOSFET counter output.                                                                                                                                                                                                                                                                                                                            |

| Switch Function             | Switch SW1 Setting    |
|-----------------------------|-----------------------|
| +5V with 1K Pullup          | 1= ON, 4= ON          |
| +12V with 1K Pullup         | 3= ON, 4= ON          |
| External Voltage and Pullup | 6= ON, 1= ON or 3= ON |

Location of Switch on XMC730

Switch shows default setting with switch at locations 1 ON and 4 ON. Provides 1K pullup to 5 volts.



## Location of Switch on XMC730CC

Switch shows default setting with switch at locations 1 ON and 4 ON. Provides 1K pullup to 5 volts.



### **Non-Isolation Considerations**

The module is non-isolated, since there is electrical continuity between the logic and field I/O grounds. As such, the field I/O connections are not isolated from the system. Care should be taken in designing installations without isolation to avoid noise pickup and ground loops caused by multiple ground connections.

### P15 Primary XMC Connector

The P15 XMC connector is wired per the VITA 42.0 standard. The P15 connector provides the 4 lane PCI Express interface to the host processor, a JTAG interface, and an I<sup>2</sup>C interface to a serial memory device. The JTAG signals connect to the FGPA for configuration.

### Table 3.1 P15 Primary XMC Connector

| Pin | Α         | В         | С       | D      | E      | F       |
|-----|-----------|-----------|---------|--------|--------|---------|
| 1   | PET00+    | PETOO-    | +3.3V   | PET01+ | PET01- | VPWR    |
| 2   | GND       | GND       | TRST#   | GND    | GND    | MRSTI#  |
| 3   | PET02+    | PET02-    | +3.3V   | PET03+ | PET03- | VPWR    |
| 4   | GND       | GND       | ТСК     | GND    | GND    | MRSTO#  |
| 5   | N.C.      | N.C.      | +3.3V   | N.C.   | N.C.   | VPWR    |
| 6   | GND       | GND       | TMS     | GND    | GND    | +12V    |
| 7   | N.C.      | N.C.      | +3.3V   | N.C.   | N.C.   | VPWR    |
| 8   | GND       | GND       | TDI     | GND    | GND    | -12V    |
| 9   | N.C.      | N.C.      | N.C.    | N.C.   | N.C.   | VPWR    |
| 10  | GND       | GND       | TDO     | GND    | GND    | GA0     |
| 11  | PER00+    | PER00-    | MBIST#  | PER01+ | PER01- | VPWR    |
| 12  | GND       | GND       | GA1     | GND    | GND    | MPRSNT# |
| 13  | PER02+    | PER02-    | +3.3AUX | PER03+ | PER03- | VPWR    |
| 14  | GND       | GND       | GA2     | GND    | GND    | MSDA    |
| 15  | N.C.      | N.C.      | N.C.    | N.C.   | N.C.   | VPWR    |
| 16  | GND       | GND       | MVMRO   | GND    | GND    | MSCL    |
| 17  | N.C.      | N.C.      | N.C.    | N.C.   | N.C.   | N.C.    |
| 18  | GND       | GND       | N.C.    | GND    | GND    | N.C.    |
| 19  | REFCLK0_P | REFCLK0_N | N.C.    | WAKE#  | ROOT#  | N.C.    |

### P16 Secondary XMC Connector

The P16 secondary XMC connector connects directly to the ADC, DAC, Counter Timer, and digital I/O data signals. The ADC and DAC signals will be available on the VITA 46.9 X12d+X8d locations while the counter timer and digital signals will be made available on the VITA 46.9 X38s locations. For those carriers that do not make the X38s signals available the counter timer and digital signals will also be made available on the P4 connector.

ADC00+, ADC00- to ADC15+, ADC15- correspond to ADC differential input signals. DCh3 can be enabled as ADC Trigger Input. DCh4 can be enabled as DAC Trigger Input. DCh0, 1, and 2 are allocated to CNTInA, B, and C Counter Input control signals. DCh8 can be enabled as DAC trigger output. DCh9 can be enabled as ADC Trigger Output.

The XMC P16 Secondary connector is a 114-pin Samtec ASP-103614-05 connector. This connector complies with ANSI/VITA 42.3-2006.

### Table 3.2 P16 Secondary XMC Connector

| Pin | Α      | В      | С     | D      | E      | F     |
|-----|--------|--------|-------|--------|--------|-------|
| 1   | ADC00+ | ADC00- | Rsv   | ADC01+ | ADC01- | Rsv   |
| 2   | GND    | GND    | Rsv   | GND    | GND    | Rsv   |
| 3   | ADC02+ | ADC02- | Cout  | ADC03+ | ADC03- | Rsv   |
| 4   | GND    | GND    | Rsv   | GND    | GND    | Rsv   |
| 5   | ADC04+ | ADC04- | DCh14 | ADC05+ | ADC05- | DCh15 |
| 6   | GND    | GND    | Rsv   | GND    | GND    | Rsv   |
| 7   | ADC06+ | ADC06- | DCh12 | ADC07+ | ADC07- | DCh13 |
| 8   | GND    | GND    | Rsv   | GND    | GND    | Rsv   |
| 9   | ADC08+ | ADC08- | DCh10 | ADC09+ | ADC09- | DCh11 |
| 10  | GND    | GND    | Rsv   | GND    | GND    | Rsv   |
| 11  | ADC10+ | ADC10- | DCh8  | ADC11+ | ADC11- | DCh9  |
| 12  | GND    | GND    | Rsv   | GND    | GND    | Rsv   |
| 13  | ADC12+ | ADC12- | DCh6  | ADC13+ | ADC13- | DCh7  |
| 14  | GND    | GND    | Rsv   | GND    | GND    | Rsv   |
| 15  | ADC14+ | ADC14- | DCh4  | ADC15+ | ADC15- | DCh5  |
| 16  | GND    | GND    | Rsv   | GND    | GND    | Rsv   |
| 17  | DAC00+ | DAC01+ | DCh2  | DAC02+ | DAC03+ | DCh3  |
| 18  | GND    | GND    | Rsv   | GND    | GND    | Rsv   |
| 19  | DAC04+ | DAC05+ | DCh0  | DAC06+ | DAC07+ | DCh1  |

IMPORTANT: All unused analog input pins should be tied to analog ground. Floating unused inputs can drift outside the input range causing temporary saturation of the input analog circuits. Recovery from saturation is slow and affects the reading of the desired channels.

### Front Field I/O Connector

The front I/O connector provides the field I/O interface connections for the XMC730 models. It is a SCSI 68-pin female connector (AMP 787082-7 or equivalent) employing latch blocks and 30 micron gold in the mating area (per MIL-G-45204, Type II, Grade C). Connects to Acromag termination panel 5025-288 from the front panel via round shielded cable (Model 5028-432).

Table 3.3 Front Field I/O Connector

| Pin Description         | Pin | Pin Description          | Pin |
|-------------------------|-----|--------------------------|-----|
| Counter Output          | 1   | COMMON                   | 35  |
| Dig CH0/CNT InA         | 2   | Dig CH8/ DAC Trigger Out | 36  |
| Dig CH1/CNT InB         | 3   | Dig CH9/ ADC Trigger Out | 37  |
| Dig CH2/CNT InC         | 4   | Digital CH10             | 38  |
| Dig CH3/ ADC Trigger In | 5   | Digital CH11             | 39  |
| Dig CH4/ DAC Trigger In | 6   | Digital CH12             | 40  |
| Digital CH5             | 7   | Digital CH13             | 41  |
| Digital CH6             | 8   | Digital CH14             | 42  |
| Digital CH7             | 9   | Digital CH15             | 43  |
| COMMON                  | 10  | Analog Out CH4           | 44  |
| COMMON                  | 11  | Analog Out CH5           | 45  |
| Analog Out CH0          | 12  | COMMON                   | 46  |
| Analog Out CH1          | 13  | COMMON                   | 47  |
| Analog Out CH2          | 14  | COMMON                   | 48  |
| Analog Out CH3          | 15  | COMMON                   | 49  |
| COMMON                  | 16  | Analog Out CH6           | 50  |
| COMMON                  | 17  | Analog Out CH7           | 51  |
| COMMON                  | 18  | Not Used                 | 52  |
| Analog In CH15+         | 19  | Analog In CH15–          | 53  |
| Analog In CH14+         | 20  | Analog In CH14–          | 54  |
| Analog In CH13+         | 21  | Analog In CH13–          | 55  |
| Analog In CH12+         | 22  | Analog In CH12–          | 56  |
| Analog In CH11+         | 23  | Analog In CH11–          | 57  |
| Analog In CH10+         | 24  | Analog In CH10–          | 58  |
| Analog In CH9+          | 25  | Analog In CH9–           | 59  |
| Analog In CH8+          | 26  | Analog In CH8–           | 60  |
| Analog In CH7+          | 27  | Analog In CH7–           | 61  |
| Analog In CH6+          | 28  | Analog In CH6–           | 62  |
| Analog In CH5+          | 29  | Analog In CH5–           | 63  |
| Analog In CH4+          | 30  | Analog In CH4–           | 64  |
| Analog In CH3+          | 31  | Analog In CH3–           | 65  |
| Analog In CH2+          | 32  | Analog In CH2–           | 66  |
| Analog In CH1+          | 33  | Analog In CH1–           | 67  |
| Analog In CH0+          | 34  | Analog In Ch0–           | 68  |

IMPORTANT: All unused analog input pins should be tied to analog ground. Floating unused inputs can drift outside the input range causing temporary saturation of the input analog circuits. Recovery from saturation is slow and affects the reading of the desired channels.

### **Rear P4 Field I/O Connector**

The rear I/O P4 connector connect to the Counter Timer and digital I/O signals. These signals are also made available on the P16 connector.

This connector is a 64-pin female receptacle header (AMP 120527-1 or equivalent) which mates to the male connector on the carrier board (AMP 120521-1 or equivalent).

### Table 3.4 Rear P4 Field I/O Connector

| Pin Description          | Pin | Pin Description | Pin |
|--------------------------|-----|-----------------|-----|
| Counter Output           | 1   | COMMON          | 3   |
| COMMON                   | 2   | COMMON          | 4   |
| Dig CH0/ CNT InA         | 5   | COMMON          | 7   |
| Dig CH1/ CNT InB         | 6   | COMMON          | 8   |
| Dig CH2/ CNT InC         | 9   | COMMON          | 11  |
| Dig CH3/ ADC Trigger In  | 10  | COMMON          | 12  |
| Dig CH4/ DAC Trigger In  | 13  | COMMON          | 15  |
| Digital CH5              | 14  | COMMON          | 16  |
| Digital CH6              | 17  | COMMON          | 19  |
| Digital CH7              | 18  | COMMON          | 20  |
| Dig CH8/ DAC Trigger Out | 21  | COMMON          | 23  |
| Dig CH9/ ADC Trigger Out | 22  | COMMON          | 24  |
| Digital CH10             | 25  | COMMON          | 27  |
| Digital CH11             | 26  | COMMON          | 28  |
| Digital CH12             | 29  | COMMON          | 31  |
| Digital CH13             | 30  | COMMON          | 32  |
| Digital CH14             | 33  | COMMON          | 35  |
| Digital CH15             | 34  | COMMON          | 36  |
| Reserved                 | 37  | Reserved        | 39  |
| Reserved                 | 38  | Reserved        | 40  |
| Reserved                 | 41  | Reserved        | 43  |
| Reserved                 | 42  | Reserved        | 44  |
| Reserved                 | 45  | Reserved        | 47  |
| Reserved                 | 46  | Reserved        | 48  |
| Reserved                 | 49  | Reserved        | 51  |
| Reserved                 | 50  | Reserved        | 52  |

| Pin Description | Pin | Pin Description | Pin |
|-----------------|-----|-----------------|-----|
| Reserved        | 53  | Reserved        | 55  |
| Reserved        | 54  | Reserved        | 56  |
| Reserved        | 57  | Reserved        | 59  |
| Reserved        | 58  | Reserved        | 60  |
| Reserved        | 61  | Reserved        | 63  |
| Reserved        | 62  | Reserved        | 64  |

Noise and Grounding Considerations

The board is non-isolated, since there is electrical continuity between the logic and field I/O grounds. As such, the field I/O connections are not isolated from the system. Care should be taken in designing installations without isolation to avoid noise pickup and ground loops caused by multiple ground connections.

### 4.0 **PROGRAMMING INFORMATION**

This Section provides the specific information necessary to program and operate the XMC730 module.

The PCIe bus is defined to address three distinct address spaces: I/O, memory, and configuration space. The XMC730 module can be accessed via the PCIe bus memory space and configuration spaces, only.

The XMC730 configuration registers are initialized by system software at power-up to configure the card. The module is a Plug-and-Play PCIe card. As a Plug-and-Play card the board's base address and system interrupt request are not selected via jumpers but are assigned by system software upon power-up via the configuration registers. A PCIe bus configuration access is used to access the XMC730's configuration registers.

When the computer is first powered-up, the computer's system configuration software scans the PCIe bus to determine what PCIe devices are present. The software also determines the configuration requirements of the PCIe card.

The system software accesses the configuration registers to determine how many blocks of memory space the module requires. It then programs the board's configuration registers with the unique memory base address.

Since this board is not fixed in address space, its device driver must use the mapping information stored in the board's Configuration Space registers to determine where the board is mapped in memory space.

The configuration registers are also used to indicate that the board requires an interrupt request. The system software then programs the configuration registers with the interrupt request for the board.

### **CONFIGURATION REGISTERS**

The PCIe specification requires software driven initialization and configuration via the Configuration Address space. This board provides 512 bytes of configuration registers for this purpose. It contains the configuration registers shown in the following table to facilitate Plug-and-Play compatibility.

The Configuration Registers are accessed via the Configuration Address and Data Ports. The most important Configuration Registers are the Base Address Registers and the Interrupt Register which must be read to determine the base address assigned to the board and the interrupt request that goes active on a board interrupt request.

| Reg.<br>Num. | D31 D24                                                                                                                                                      | D23 [                               | 016  | D15       | D8     | D7    | D0      |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|------|-----------|--------|-------|---------|
| 0            | Devi                                                                                                                                                         | ce ID                               |      | Vendor ID |        |       |         |
|              |                                                                                                                                                              | 0x4471 XMC730(E)<br>0X4473 XMC730CC |      |           | 16D    | )5    |         |
| 1            | Sta                                                                                                                                                          | itus                                |      |           | Comm   | and   |         |
| 2            | (                                                                                                                                                            | lass Code=                          | 1180 | 00        |        | Rev   | ID=00   |
| 3            | BIST                                                                                                                                                         | Heade                               | er   | Late      | ncy    | Ca    | che     |
| 4:5          | 64-bit Memory Base Address for Memory Accesses to PCIe<br>interrupt, I/O registers, System Monitor registers, and<br>Flash memory.<br>1M Space <b>(BAR0)</b> |                                     |      |           |        |       |         |
| 6:10         |                                                                                                                                                              |                                     | Not  | Used      |        |       |         |
| 11           | Subsys                                                                                                                                                       | stem ID                             |      | Subs      | system | Vendo | r ID    |
|              | 0x4471 XMC730(E)<br>0X4473 XMC730CC                                                                                                                          |                                     |      |           | 16D    | )5    |         |
| 12           | Not Used                                                                                                                                                     |                                     |      |           |        |       |         |
| 13,14        | Reserved                                                                                                                                                     |                                     |      |           |        |       |         |
| 15           | Max_Lat                                                                                                                                                      | Min_G                               | nt   | Inter.    | Pin    | Inte  | r. Line |

This board is allocated a 1M byte block of memory (BARO), to access the PCIe interrupt, DAC registers, ADC registers, Counter Timer registers, Digital I/O registers, XADC registers, Flash memory. The PCIe bus decodes 1M bytes for BARO for this memory space.

Table 4.1 Configuration Registers

### BARO MEMORY MAP

The BAR0 memory address space is used to access the devices listed in the table below. Note that the base address for the board (BAR0) in memory space must be added to the addresses shown to properly access these registers.

| BAR0 Base Address       | Size | Description                                            |
|-------------------------|------|--------------------------------------------------------|
| 0x0000_0000→0x0000_0FFF | 4k   | CDMA (see Xilinx Document PG034)                       |
| 0x0000_1000→0x0000_1FFF | 4k   | PCIe AXI Bridge Control (see<br>Xilinx Document PG054) |
| 0x0000_2000→0x0000_2FFF | 4k   | Interrupt Controller                                   |
| 0x0000_3000→0x0000_3FFF | 4k   | XADC System Monitor (see Xilinx Document DS790)        |
| 0x0000_4000→0x0000_4FFF | 4k   | Firmware Revision Register                             |
| 0x0000_5000→0x0000_6FFF | 8k   | Reserved                                               |
| 0x0000_7000→0x0000_7FFF | 4k   | M07_AXI Custom (ADC,<br>Counter, Digital I/O)          |
| 0x0000_8000→0x0000_FFFF | 32K  | Reserved                                               |
| 0x0001_0000→0x0001_7FFF | 32k  | Block RAM                                              |
| 0x0001_8000→0x0003_FFFF | 164k | Reserved                                               |
| 0x0004_0000→0x0004_0213 | 1K   | DAC Registers                                          |
| 0x0004_0214→0x0005_FFFF | 127k | Reserved                                               |
| 0x0006_0000→0x0007_FFFF | 128k | Sample Memory<br>Part of DAC Memory space              |
| 0x0008_0000→0x000F_FFFF | 524K | AXI to PCIe BAR0                                       |

### Table 4.2 Memory Map

### CDMA MEMORY MAP

The Central Direct Memory Access (CDMA) controller can access the AXI to PCI bridge (BAR0), the ADC FIFO memory, and the DAC Sample Memory.

| Table 4.3 CDMA Memory Map |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <u> </u> |                                                        |  |  |  |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------|--|--|--|
|                           | BAR0 Base Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Size     | Description                                            |  |  |  |
|                           | 0x0000_1000→0x0000_1FFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 4k       | PCle AXI Bridge Control (see<br>Xilinx Document PG054) |  |  |  |
|                           | 0x0000_7000→0x0000_7FFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 4k       | M07_AXI Custom (ADC,<br>Counter, Digital I/O)          |  |  |  |
|                           | 0x0001_0000→0x0001_7FFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 32k      | Block RAM                                              |  |  |  |
|                           | 0x0004_0000→0x0004_0213                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1k       | DAC Registers                                          |  |  |  |
|                           | 0x0004_0214→0x0005_FFFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 127k     | Reserved                                               |  |  |  |
|                           | 0x0006_0000→0x0007_FFFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 128k     | Sample Memory                                          |  |  |  |
| SCATTER GATHER MEMORY MAP | The scatter-gather engine can access the block RAM Memory only. The scatter-gather descriptor list must be located in this memory. The block RAM can hold 512 descriptors (64 bytes/Descriptor).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |                                                        |  |  |  |
| Table 4.4 Scatter Gather  | BAR0 Base Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Size     | Description                                            |  |  |  |
| Memory Map                | 0x0001_0000→0x0001_7FFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 32k      | Block RAM                                              |  |  |  |
| AXI-CDMA                  | The AXI Central Direct Memory Access (CDMA) core is a soft Xilinx<br>Intellectual Property core. The CDMA provides direct memory access<br>between system memory over the PCIe bus and the memory resident on the<br>XCM730 module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |                                                        |  |  |  |
|                           | The basic mode of operation for the CDMA is Simple DMA. In this mode, the CDMA executes one programmed DMA command and then stops. This requires that the CDMA registers need to be set up by system software over the PCIe bus for each DMA operation required.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |                                                        |  |  |  |
|                           | Scatter Gather is a mechanism that allows for automated DMA transfer<br>scheduling via a pre-programmed instruction list of transfer descriptors. This<br>instruction list is programmed by the user software application into a<br>memory-resident data structure that must be accessible by the AXI CDMA<br>Scatter Gather interface. This list of instructions is organized into what is<br>referred to as a transfer descriptor chain. Each descriptor has an address<br>pointer to the next descriptor to be processed. The last descriptor in the<br>chain generally points back to the first descriptor in the chain but it is not<br>required. The AXI CDMA Tail Descriptor Pointer register needs to be |          |                                                        |  |  |  |

programmed with the address of the first word of the last descriptor of the chain. When the AXI CDMA executes the last descriptor, and finds that the Tail Descriptor pointer register contents matches the address of the completed descriptor, the Scatter Gather Engine stops descriptor fetching and waits. See the Xilinx AXI Central Direct Memory Access product guide PG034 for additional details for Scatter Gather operations.

| BAR0 Base Addr+ | Bit(s) | Description                                          |
|-----------------|--------|------------------------------------------------------|
| 0x0000_0000     | 31:0   | CDMA Control Register                                |
| 0x0000_0004     | 31:0   | CDMA Status Register                                 |
| 0x0000_0008     | 31:0   | <u>Current Descriptor Pointer</u><br><u>Register</u> |
| 0x0000_000C     | 31:0   | Reserved                                             |
| 0x0000_0010     | 31:0   | <u>Tail Descriptor Pointer</u><br><u>Register</u>    |
| 0x0000_0014     | 31:0   | Reserved                                             |
| 0x0000_0018     | 31:0   | Source Address Register                              |
| 0x0000_001C     | 31:0   | Reserved                                             |
| 0x0000_0020     | 31:0   | Destination Address Register                         |
| 0x0000_0024     | 31:0   | Reserved                                             |
| 0x0000_0028     | 31:0   | Bytes to Transfer Register                           |

Note that any registers/bits not mentioned will remain at the default value: logic low.

### Table 4.5 AXI-CDMA

### **CDMA Control Register**

This register provides software application control of the AXI CDMA

| Bit(s) | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0      | This bit is reserved for future definition and will always return zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| 1      | The bit will always return one.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 2      | Soft reset control for the AXI CDMA core. Setting this bitto a '1' causes the AXI CDMA to be reset. Reset isaccomplished gracefully. Committed AXI4 transfers arethen completed. Other queued transfers are flushed. Aftercompletion of a soft reset, all registers and bits are in theReset State.0Reset Not in Progress1Reset in Progress                                                                                                                                                                                                                                                                                                                           |  |
| 3      | 1Reset in ProgressThis bit controls the transfer mode of the CDMA. Setting<br>this bit to a '1' causes the AXI CDMA to operate in a<br>Scatter Gather mode.Note: This bit must only be changed when the CDMA<br>engine is IDLE (CDMA Status bit-1 = '1'). Changing the<br>state of this bit at any other time has undefined results.Note: This bit must be set to a 0 then back to 1 by the<br>software application to force the CDMA Scatter Gather<br>engine to use a new value written to the CDMA Current<br>Descriptor Pointer register.Note: This bit must be set prior to setting Bit-13 of this<br>CDMA Control register.0Simple DMA Mode1Scatter Gather Mode |  |
| 4      | This bit enables the keyhole read (FIXED address AXI transaction).<br><b>Note:</b> This value should not be changed when a transfer is in progress. This value should remain constant until all the descriptors are processed (for SG = 1). CDMA shows unexpected behavior if the value is changed in the middle of a transfer.                                                                                                                                                                                                                                                                                                                                       |  |

Table 4.6 CDMA Control Register (Read/Write) - + 0x0000)

|      | <b>Note:</b> It is the responsibility of the slave device to enforce the functionality.                                                                                                                                                                                                                                                                                                                                                                                                 |                                |  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--|
|      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Key Hole Read Disabled         |  |
|      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Key Hole Read Enabled          |  |
| 5    | Key Hole write. Writing 1 to this enables the keyhole write<br>(FIXED address AXI transaction). This value should not be<br>changed when a transfer is in progress. This value should<br>remain constant until all the descriptors are processed (for<br>SG = 1). CDMA shows unexpected behavior if this value is<br>changed in the middle of a transfer.                                                                                                                               |                                |  |
|      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Key Hole Write Disabled        |  |
|      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Key Hole Write Enabled         |  |
| 6    | <ul> <li>Cyclic BD Enable. When set to 1, you can use the CDMA in Cyclic Buffer Descriptor (BD) mode without any user intervention. In this mode, the Scatter Gather module ignores the Completed bit of the BD. With this feature, you can use the same BDs in cyclic manner without worrying about any errors.</li> <li>This bit should be set before updating the TAILDESC register. Changing this bit while the transfer is in progress will generate undefined results.</li> </ul> |                                |  |
|      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Cyclic BD Disabled             |  |
|      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Cyclic BD Enabled              |  |
| 11-7 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                |  |
|      | Interrupt on Complete Interrupt Enable. When set to '1', it allows an interrupt after completed DMA transfers.                                                                                                                                                                                                                                                                                                                                                                          |                                |  |
| 12   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Interrupt on Complete Disabled |  |
|      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Interrupt on Complete Enabled  |  |
| 13   | Interrupt on Delay Timer Interrupt Enable. When set to '1',<br>it allows a delayed interrupt out. This is only used with<br>Scatter Gather assisted transfers.                                                                                                                                                                                                                                                                                                                          |                                |  |
|      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Delayed Interrupt Disabled     |  |
|      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Delayed Interrupt Enabled      |  |

|       | lunt -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | www.mt.on Furen Internuet Frankla, Wilson aat to (4) it |  |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|--|--|
| 14    | Interrupt on Error Interrupt Enable. When set to '1', it allows an error to generate an interrupt out.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                         |  |  |
|       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Error Interrupt Disabled                                |  |  |
|       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Error Interrupt Enabled                                 |  |  |
| 15    | Res                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | erved                                                   |  |  |
| 23-16 | Interrupt Threshold value. This field is used to set the<br>Scatter Gather interrupt coalescing threshold. When<br>Interrupt On Complete interrupt events occur, an internal<br>counter counts down from the Interrupt Threshold<br>setting. When the count reaches zero, an interrupt out is<br>generated by the CDMA engine. <b>Note:</b> The minimum<br>setting for the threshold is 0x01. A write of 0x00 to this<br>register has no effect. If the CDMA is built with Scatter<br>Gather disabled (Simple Mode Only), the default value of<br>the port is zeros.                                                                                                                                                          |                                                         |  |  |
| 31-24 | Interrupt Delay Time Out. This value is used for setting the interrupt delay time out value. The interrupt time out is a mechanism for causing the CDMA engine to generate an interrupt after the delay time period has expired. This is used for cases when the interrupt threshold is not met after a period of time, and the CPU desires an interrupt to be generated. Timer begins counting when the CDMA is IDLE (CDMA Status bit-1 = '1'). This generally occurs when the CDMA has completed all scheduled work defined by the transfer descriptor chain (reached the tail pointer) and has not satisfied the Interrupt Threshold count.<br><b>Note:</b> Setting this value to zero disables the delay timer interrupt. |                                                         |  |  |

### **CDMA Status Register**

This register provides status of the AXI CDMA.

| Table 4.7 CDMA Status                |
|--------------------------------------|
| <b>Register (Read/Write) – (BAR0</b> |
| + 0x0004)                            |

| Bit(s) | Function                                                                                                                                                                                                                                                                                                                        |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | This bit is reserved for future definition and will always return zero.                                                                                                                                                                                                                                                         |
| 1      | CDMA Idle. Indicates the state of AXI CDMA operations.<br>When set and in Simple DMA mode, the bit indicates the<br>programmed transfer has completed and the CDMA is<br>waiting for a new transfer to be programmed. Writing to<br>the "Bytes to Transfer" register in Simple DMA mode causes<br>the CDMA to start (not Idle). |

|   | When set and in Scatter Gather mode, the bit indicates the<br>Scatter Gather Engine has reached the tail pointer for the<br>associated channel and all queued descriptors have been<br>processed. Writing to the tail pointer register automatically<br>restarts CDMA Scatter Gather operations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                             |  |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|--|
|   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Not Idle                                                                    |  |
|   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | CDMA is Idle                                                                |  |
| 2 | Res                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | erved                                                                       |  |
| 3 | Scatter Gather Included. This bit indicates the AXI CDMA<br>has been implemented with Scatter Gather support<br>included (C_SG_ENABLE = 1). This is used by application<br>software (drivers) to determine if Scatter Gather Mode can<br>be utilized.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                             |  |
| - | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Scatter Gather not included                                                 |  |
| - | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Scatter Gather is included                                                  |  |
| 4 | DMA Internal Error. This bit indicates that an internal error<br>has been encountered by the DataMover on the data<br>transport channel. This error can occur if a 0 value Byte to<br>Transfer register is fed to the AXI DataMover, or DataMover<br>has an internal processing error. A Bytes to Transfer register<br>value of 0 only happens if the register is written with zeros<br>(in Simple DMA mode) or a Bytes to Transfer register value<br>of zero is specified in the Control word of a fetched<br>descriptor (Scatter Gather Mode). This error condition<br>causes the AXI CDMA to gracefully halt. The CDMA Status<br>register bit-1 is set to '1'when the CDMA has completed<br>shut down. A reset (soft or hard) must be issued to clear the<br>error condition. |                                                                             |  |
| - | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | No CDMA Internal Errors<br>CDMA Internal Error detected. CDMA Engine halts. |  |
| 5 | DMA Slave Error. This bit indicates that an AXI slave error<br>response has been received by the AXI DataMover during<br>an AXI transfer (read or write). This error condition causes<br>the AXI CDMA to gracefully halt. The CDMA Status register<br>bit-1 is set to '1' when the CDMA has completed shut down.<br>A reset (soft or hard) must be issued to clear the error<br>condition.                                                                                                                                                                                                                                                                                                                                                                                       |                                                                             |  |

|    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                               | No CDMA Slave Errors                              |  |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|--|
|    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CDMA Slave Error detected. CDMA Engine halts.     |  |
| 6  | DMA Decode Error. This bit indicates that an AXI decode<br>error has been received by the AXI DataMover. This error<br>occurs if the DataMover issues an address that does not<br>have a mapping assignment to a slave device. This error<br>condition causes the AXI CDMA to halt gracefully. The<br>CDMA Status register bit-1 is set to '1' when the CDMA has<br>completed shut down. A reset (soft or hard) must be issued<br>to clear the error condition. |                                                   |  |
|    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                               | No CDMA Decode Errors                             |  |
|    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CDMA Decode Error detected. CDMA Engine halts.    |  |
| 7  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                   |  |
| 8  | Scatter Gather Internal Error. This bit indicates that an<br>internal error has been encountered by the Scatter Gather<br>Engine. This error condition causes the AXI CDMA to<br>gracefully halt. The CDMA Status register bit-1 is set to 1<br>when the CDMA has completed shut down. A reset (soft or<br>hard) must be issued to clear the error condition.                                                                                                   |                                                   |  |
|    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                               | No Scatter Gather Internal Errors                 |  |
|    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Scatter Gather Internal Error. CDMA Engine halts. |  |
| 9  | Scatter Gather Slave Error. This bit indicates that an AXI<br>slave error response has been received by the Scatter<br>Gather Engine during an AXI transfer (transfer descriptor<br>read or write). This error condition causes the AXI CDMA to<br>gracefully halt. The CDMA Status register bit-1 is set to 1<br>when the CDMA has completed shut down. A reset (soft or<br>hard) must be issued to clear the error condition.                                 |                                                   |  |
|    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                               | No Scatter Gather Slave Errors                    |  |
|    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Scatter Gather Slave Error. CDMA Engine halts.    |  |
| 10 | Scatter Gather Decode Error. This bit indicates that an AXI<br>decode error has been received by the Scatter Gather<br>Engine during an AXI transfer (transfer descriptor read or<br>write). This error occurs if the Scatter Gather Engine issues<br>an address that does not have a mapping assignment to a<br>slave device. This error condition causes the AXI CDMA to<br>gracefully halt. The CDMA Status register bit-1 is set to 1                       |                                                   |  |

|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | when the CDMA has completed shut down. A reset (soft or hard) must be issued to clear the error condition.             |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--|--|
|       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | No Scatter Gather Decode Errors                                                                                        |  |  |
|       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Scatter Gather Decode Error. CDMA Engine halts.                                                                        |  |  |
| 11    | Res                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | erved                                                                                                                  |  |  |
| 12    | Interrupt on Complete. When set to 1, this bit indicates an<br>interrupt event has been generated on completion of a<br>DMA transfer (either a Simple or Scatter Gather). If the<br>Interrupt on Complete (bit-12) of the CDMA Control register<br>= '1', an interrupt is generated from the AXI CDMA. A CPU<br>write of 1 clears this bit to 0.<br><b>Note:</b> When operating in Scatter Gather mode, the criteria<br>specified by the interrupt threshold must also be met. |                                                                                                                        |  |  |
|       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | No Interrupt on complete                                                                                               |  |  |
|       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Interrupt on complete active                                                                                           |  |  |
| 13    | Interrupt on Delay. When set to 1, this bit indicates an<br>interrupt event has been generated on a delay timer time<br>out. If the Interrupt on Delay Timer bit-13 of the CDMA<br>Control register = '1', an interrupt is generated from the AXI<br>CDMA. A CPU write of 1 clears this bit to 0.                                                                                                                                                                              |                                                                                                                        |  |  |
|       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | No Delay Interrupt                                                                                                     |  |  |
|       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Delay Interrupt Active                                                                                                 |  |  |
| 14    | Interrupt on Error. When set to 1, this bit indicates an<br>interrupt event has been generated due to an error<br>condition. If the Interrupt on Error bit-14 of the CDMA<br>Control register = '1', an interrupt is generated from the AXI<br>CDMA. A CPU write of 1 clears this bit to 0.                                                                                                                                                                                    |                                                                                                                        |  |  |
|       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | No Error Interrupt                                                                                                     |  |  |
|       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Error Interrupt Active                                                                                                 |  |  |
| 15    | Res                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reserved                                                                                                               |  |  |
| 23-16 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Interrupt Threshold Status. This field reflects the current interrupt threshold value in the Scatter Gather Engine.    |  |  |
| 31-24 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Interrupt Delay Time Status. This field reflects the current interrupt delay timer value in the Scatter Gather Engine. |  |  |

### **CDMA Current Descriptor Pointer Register**

| Table 4.8 CDMA Current                                | BIT(s) | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Descriptor Pointer Register<br>(Read/Write) - (BAR0 + | 5-0    | Writing to these bits has no effect and they are always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0x0008)                                               | 31-6   | <ul> <li>Current Descriptor Pointer. This register field is written by the software application (in Scatter Gather Mode) to set the starting address of the first transfer descriptor to execute for a Scatter Gather operation. The address written corresponds to a 32-bit system address with the least significant 6 bits truncated. This register field must contain a valid descriptor address prior to the software application writing the CDMA Tail Descriptor Pointer register value. Failure to do so results in an undefined operation by the CDMA.</li> <li>On error detection, the Current Descriptor Pointer register is updated to reflect the descriptor associated with the detected error.</li> <li>Note: The register should only be written by the Software application when the AXI CDMA is Idle.</li> </ul> |

#### **CDMA Tail Descriptor Pointer Register**

F

This register provides Tail Descriptor Pointer for the AXI CDMA Scatter Gather Descriptor Management

|                                                    | BIT(s) | FUNCTION                                                               |
|----------------------------------------------------|--------|------------------------------------------------------------------------|
| Table 4.9 CDMA Tail<br>Descriptor Pointer Register | 5-0    | Writing to these bits has no effect and they are always read as zeros. |
| (Read/Write) - (BAR0 +<br>0x0010)                  |        |                                                                        |

| 31-6 | Tail Descriptor Pointer. This register field is written by the software application (in Scatter Gather Mode) to set the current pause pointer for descriptor chain execution. The AXI CDMA Scatter Gather Engine pauses descriptor fetching after completing operations on the descriptor whose current descriptor pointer matches the tail descriptor pointer. When the AXI CDMA is in Scatter Gather Mode, a write by the software application to this register causes the AXI CDMA Scatter Gather Engine to start fetching descriptors starting from the Current Descriptor Pointer register value. If the Scatter Gather engine is paused at a tail pointer pause point, the Scatter Gather engine restarts descriptor execution at the next sequential transfer descriptor. If the AXI CDMA is not idle, writing to this register has no effect except to reposition the Scatter Gather pause point. Note: The software application must not move the tail pointer to a location that has not been updated with valid transfer descriptors. The software application must process and reallocate all completed descriptors, clear the completed bits and then move the tail pointer. The software application must move the tail pointer. The software application must move the tail pointer. The software application must move the tail pointer. |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### **CDMA Source Address Register**

This register provides the source address for simple DMA transfers by AXI CDMA.

If a location in system memory is the source address, it must be set with the AXI aperture base address 0x00080000 + the least significant 19-bits of the system memory address.

In addition, the physical address of the location in system memory must be set in the Address Translation Register which is described in the PCIe AXI-Bridge Control section.

Table 4.10 CDMA Source Address Register (Read/Write) – (BAR0 + 0x0018)

| BIT(s) | FUNCTION                                                                                                                                                                          |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0   | Source Address Register. This register is used by Simple DMA operations as the starting read address for DMA data transfers. The address value written can be at any byte offset. |
|        | <b>Note:</b> The software application should only write to this register when the AXI CDMA is Idle.                                                                               |

#### **CDMA Destination Address Register**

This register provides the destination address for simple DMA transfers by AXI CDMA.

If a location in system memory is the destination address it must be set with the AXI aperture base address 0x00080000 + the least significant 19-bits of the system memory address.

In addition, the physical address of the location in system memory must be set in the Address Translation Register which is described in the PCIe AXI-Bridge Control section.

| Table 4.11 CDMA Destination<br>Address Register (Read/Write)<br>– (BAR0 + 0x0020) | BIT(s) | FUNCTION                                                                                                                           |
|-----------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                   | 31-0   | Destination Address Register. This register is used by Simple DMA operations as the starting write address for DMA data transfers. |
|                                                                                   |        | <b>Note:</b> The software application should only write to this register when the AXI CDMA is Idle.                                |

**CDMA Bytes to Transfer Register** 

This register provides the value for the number of bytes to transfer for Simple DMA transfers by the AXI CDMA.

| Table 4.12 CDMA Bytes to                            | BIT(s) | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transfer Register (Read/Write)<br>– (BAR0 + 0x0028) | 22-0   | Bytes to Transfer. This register field is used for Simple DMA<br>transfers and indicates the desired number of bytes to DMA<br>from the Source Address to the Destination Address. A<br>maximum of 8,388,606 bytes of data can be specified by this<br>field for the associated transfer. Writing to this register also<br>initiates the Simple DMA transfer. Note: A value of zero (0)<br>is not allowed and causes a DMA internal error to be set by<br>AXI CDMA. The software application should only write to this<br>register when the AXI CDMA is Idle. |
|                                                     | 31-23  | Writing to these bits has no effect, and they are always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

# **Scatter Gather Transfer Descriptor Definition**

This defines the format and contents of the AXI CDMA Scatter Gather Transfer Descriptors. These are used only by the SG function if the CDMACR.SGMode bit is set to 1. A transfer descriptor consists of eight 32-bit words. The descriptor represents the control and status information needed for a single CDMA transfer plus address linkage to the next sequential descriptor. Each descriptor can define a single CDMA transfer of up to

Table 4.13 Scatter GatherTransfer Descriptor Definition

524,287 Bytes of data. A descriptor chain is defined as a series of descriptors that are sequentially linked through the address linkage built into the descriptor format.

The AXI CDMA SG Engine traverses the descriptor chain following the linkage until the last descriptor of the chain has been completed. The relationship and identification of the AXI CDMA transfer descriptor words is shown in the table below.

Note: Transfer Descriptors must be aligned on sixteen 32-bit word alignment that is 16x4 Bytes = 64 Bytes. Example valid offsets are

| Address Space Offset | Name         | Description                |
|----------------------|--------------|----------------------------|
| 0x00                 | NXTDESC_PNTR | Next Descriptor<br>Pointer |
| 0x04                 |              | Reserved                   |
| 0x08                 | SA           | Source Address             |
| 0x0C                 |              | Reserved                   |
| 0x10                 | DA           | Destination Address        |
| 0x14                 |              | Reserved                   |
| 0x18                 | CONTROL      | Transfer Control           |
| 0x1C                 | STATUS       | Status                     |

0x00, 0x40, 0x80, and 0xC0.

Transfer Descriptor NXTDESC\_PNTR

This word provides the address pointer to the first word of the next transfer descriptor in the descriptor chain.

| Table 4.14 Transfer Descriptor<br>NXTDESC_PNTR | Bit(s) | Function                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                | 5-0    | These bits are reserved and fixed to zeros. This forces the address value programmed in this register to be aligned to 64-byte aligned addresses.                                                                                                                                                                                                                                    |
|                                                | 31-6   | Next Descriptor Pointer. This field is an address pointer<br>(most significant 26 bits) to the first word of the next<br>transfer descriptor to be executed by the CDMA SG Engine.<br>The least-significant 6 bits of this register are appended to<br>this value when used by the SG Engine forcing transfer<br>descriptors to be loaded in memory at 64-byte address<br>alignment. |

# **Transfer Descriptor Source Address**

This word provides the starting address for the data read operations for the associated DMA transfer.

| Table 4.15 Transfer Descriptor | Bit(s) | Function                                                                                                                                                               |
|--------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Source Address                 | 31-0   | Source Address. This value specifies the starting address for<br>data read operations for the associated DMA transfer. The<br>address value can be at any byte offset. |

**Transfer Descriptor Destination Address** 

This word provides the starting address for the data write operations for the associated DMA transfer.

| Table 4.16 Transfer Descriptor |  |
|--------------------------------|--|
| Destination Address            |  |

| Bit(s) | Function                                                                                                                                                                     |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0   | Destination Address. This value specifies the starting address<br>for data write operations for the associated DMA transfer.<br>The address value can be at any byte offset. |

#### Transfer Descriptor CONTROL Word

This word provides the starting address for the data write operations for the associated DMA transfer.

Table 4.17 Transfer Descriptor CONTROL Word

| Bit(s) | Function                                                                                                                                                                                                                                                                                                                                    |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22-0   | Bytes to Transfer. This field in the Control word specifies the desired number of bytes to DMA from the Source Address to the Destination Address. A maximum of 524,287 bytes of data can be specified by this field for the associated transfer. A value of zero (0) is not allowed and causes a DMA internal error to be set by AXI CDMA. |
| 31-23  | Reserved                                                                                                                                                                                                                                                                                                                                    |

**Transfer Descriptor Status Word** 

This word provides the starting address for the data write operations for the associated DMA transfer.

| Table 4.18 | Transfer | Descriptor |
|------------|----------|------------|
| Status Wor | d        |            |

| Bit(s) | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27-0   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 28     | DMA Internal Error. This bit indicates that an internal error<br>was encountered by the AXI CDMA DataMover on the data<br>transport channel during the execution of this descriptor.<br>This error can occur if a 0 value BTT (bytes to transfer) is fed<br>to the AXI DataMover or if the DataMover has an internal<br>processing error. A BTT of 0 only happens if the BTT field in<br>the transfer descriptor CONTROL word is programmed with<br>a value of zero. This error condition causes the AXI CDMA to<br>gracefully halt. The CDMASR.IDLE bit is set to 1 when the<br>CDMA has completed shutdown.<br>0 = No CDMA Internal Errors<br>1 = CDMA Internal Error detected. CDMA Engine halts at this<br>descriptor |
| 29     | DMA Slave Error. This bit indicates that an AXI slave error<br>response was received by the AXI CDMA DataMover during<br>the AXI transfer (read or write) associated with this<br>descriptor. This error condition causes the AXI CDMA to halt<br>gracefully.<br>0 = No CDMA Slave Errors<br>1 = CDMA Slave Error received. CDMA Engine halts at this<br>descriptor.                                                                                                                                                                                                                                                                                                                                                      |

| 30 | DMA Decode Error. This bit indicates that an AXI decode<br>error was received by the AXI CDMA DataMover. This error<br>occurs if the DataMover issues an address that does not<br>have a mapping assignment to a slave device. This error<br>condition causes the AXI CDMA to halt gracefully.<br>0 = No CDMA Decode Errors<br>1 = CDMA Decode Error received. CDMA Engine halts at this<br>descriptor                                                                                                                                                                            |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 | Transfer Completed. This indicates to the software<br>application that the CDMA Engine has completed the<br>transfer as described by the associated descriptor. The<br>software application can manipulate any descriptor with the<br>Completed bit set to 1.<br>0 = Descriptor not completed<br>1 = Descriptor completed<br>If the CDMA SG Engine fetches a descriptor, with this bit set<br>to 1, the descriptor is considered a stale descriptor. An<br>SGIntErr is flagged in the AXI CDMA Status register and the<br>AXI CDMA engine halts with no update to the descriptor. |

#### Simple CDMA Programming Example

1. Verify the CDMA is idle. Read CDMA Status register bit-1 as logic '1'.

2. Program the CDMA Control register bit-12 to the desired state for interrupt generation on transfer completion.

3. Write the source address for the transfer to the Source Address register at 0x0018. In this example, the source is the system memory. The following is required:

a. Given physical address of buffer of 0x0000333012345678.

offset 00001000 is PCIe AXI Bridge Control base + 208 = AXIBAR2PCIEBAR 0 b. AXIBAR2PCIEBAR\_0U <offset 00001208> = 0x00003330.

c. AXIBAR2PCIEBAR\_0L <offset 0000120C> = 0x12345678.

The least significant 19 bits of this address 0x12345678 must be added to the AXI BARO Aperture Base address. The new AXI address is 0x00080000 +0x0045678 = 0x000C5678. Write the value 0x000C5678 to the CDMA Source Address register at location 0x0020.

4. Write the destination address to the Destination Address register at 0x0020. For this example, the destination will be the sample buffer of the DAC interface. Write 0x0006\_0000 to the Destination Address register at 0x0020.

5. Write the number of bytes to transfer to the CDMA Bytes to Transfer register 0x0028. Writing this register also starts the transfer.

6. Poll the CDMA Status register bit-1 (CDMA idle) for logic '1'.

8. When ready for another transfer. Go back to step 1.

| AXI-BAR0 Aperture Base Address               |                                                                                                                                                                                          |          |                                                                                                                |  |
|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------|--|
|                                              | The AXI BARO aperture base ad address on the AXI bus used to transfers.                                                                                                                  |          |                                                                                                                |  |
|                                              | In Xilinx Vivado IP Integrator the address map will show that a 512K address space for the AXI BARO Aperture Base Address is reserved. This 512K address space is fixed for this module. |          |                                                                                                                |  |
| Table 4.19 AXI-BARO Aperture<br>Base Address | 0x00080000→0x000FFFFF                                                                                                                                                                    | 512K     | Window into PCIe Interface AXI<br>BARO Aperture Base Address                                                   |  |
|                                              | The following is another examp address is used.                                                                                                                                          | le of ho | w the AXI BARO aperture base                                                                                   |  |
|                                              | then the AXI Base Address Tran                                                                                                                                                           | slation  | cal address 0x56ABCDEF were given,<br>Configuration registers at BAR0 +<br>and 0x56 ABCDEF, respectively.      |  |
|                                              | the AXI BARO Aperture Base ad                                                                                                                                                            | dress. T | ress 0x56ABCDEF must be added to<br>he new AXI address is 0x00080000 +<br>es are then appended by the PCIe AXI |  |



bridge to give the final PCIe address of the system memory location.

# PCLe AXI Bridge Control

The PCIe AXI Bridge is an AXI interface to the PCIe system. This bridge provides the address translation between the AXI4 memory-mapped embedded system and the PCIe system. The AXI Bridge for PCIe translates the AXI memory read or writes to PCIe Transaction Layer Packets (TLP) packets and translates PCIe memory read and write request TLP packets to AXI interface commands.

| BARO Base Addr+             | Bit(s) | Description                                                |
|-----------------------------|--------|------------------------------------------------------------|
| 0x0000_1000→<br>0x0000_1140 | 31:0   | See Xilinx pg055 Memory<br>Map                             |
| 0x0000_1144                 | 31:0   | PHY Status/Control<br>Register                             |
| 0x0000_1148→                | 31:0   | See Xilinx pg055 Memory<br>Map                             |
| 0x0000_1204                 |        | (These registers are not used)                             |
| 0x0000_1208                 | 31:0   | Address Translation<br>Register Upper<br>AXIBAR2PCIEBAR_0U |
| 0x0000_120C                 | 31:0   | Address Translation<br>Register Lower<br>AXIBAR2PCIEBAR_OL |
| 0x0000_1210                 | 31:0   | Address Translation<br>Register Upper<br>AXIBAR2PCIEBAR_1U |
| 0x0000_1214                 | 31:0   | Address Translation<br>Register Lower<br>AXIBAR2PCIEBAR_1L |
| 0x0000_1210→                | 31:0   | See Xilinx pg055 Memory<br>Map                             |
| 0x0000_1FFF                 |        |                                                            |

#### Table 4.20 PCLe AXI Bridge Control

# PHY Status/Control Register (Read) – (BAR0 + 0x1144)

This register provides the status of the current PHY state, as well as control of speed and rate switching for Gen2-capable cores.

|          | Bit(s) |                                                                                                                                  | Function                                        |
|----------|--------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| /Control |        | Reports the current link rate.                                                                                                   |                                                 |
|          | 0      | 0                                                                                                                                | 2.5 GT/s                                        |
|          |        | 1                                                                                                                                | 5.0 GT/s                                        |
|          |        | Reports                                                                                                                          | the current link width.                         |
|          |        | 00                                                                                                                               | x1                                              |
|          | 2-1    | 01                                                                                                                               | x2                                              |
|          |        | 10                                                                                                                               | x4                                              |
|          |        | 11                                                                                                                               | x8                                              |
|          | 8-3    | Reports the current Link Training and Status State<br>Machine state. Encoding is specific to the underlying<br>Integrated Block. |                                                 |
|          |        | 010110                                                                                                                           | L0 state and core can send/receive data packets |
|          | 10-9   | Reports the current lane reversal mode.                                                                                          |                                                 |
|          |        | 00                                                                                                                               | No reversal                                     |
|          |        | 01                                                                                                                               | Lanes 1:0 reversed                              |
|          |        | 10                                                                                                                               | Lanes 3:0 reversed                              |
|          |        | 11                                                                                                                               | Lanes 7:0 reversed                              |
|          |        | Reports the current PHY Link-up state.                                                                                           |                                                 |
|          | 11     | 0                                                                                                                                | Link down                                       |
|          |        | 1                                                                                                                                | Link up                                         |
|          | 15-12  | Reserved                                                                                                                         |                                                 |
|          | 31-16  | See Xilinx pg055 PHY Status/Control Register                                                                                     |                                                 |
|          |        |                                                                                                                                  |                                                 |

Table 4.21 PHY Status/Control Register

#### **AXI Base Address Translation Configuration Register**

The address space for PCIe is different than the AXI address space. To access one address space from another address space requires an address translation process.

These registers are needed for DMA transfers that move data to the system memory buffer. Two AXI to Host address translation BARs are provided to support scatter-gather DMA operation: AXIBAR2PCIEBAR\_0 and AXIBAR2PCIEBAR\_1. It is expected that two host memory regions will be used, one which contains the scatter-gather descriptor list, and the other which contains DAC or ADC samples. The memory region holding the scatter-gather descriptor list must be physically contiguous. The memory region holding DAC or ADC samples is not required to be contiguous. The location of the system memory buffer is loaded into these registers. For data transfers that cross non-contiguous page boundaries, the scatter-gather descriptor list must include updates to the AXI to Host address translation BARs for each non-contiguous region.

AXI Base Address Translation Configuration register at BAR0 + 0x1208 must be written with the most significant 32 bits of the address in system memory to which the DMA transfer is to read or write. An example of the C code used to set this register with the physical address is shown below.

AXI Base Address Translation Configuration register at BAR0 + 0x120C must be written with the least significant 32 bits of the address in system memory to which the DMA transfer is to read or write.

This sets the system memory physical address which will be appended with the values written into either the DMA source or destination registers at 0x1018 or 0x1020, respectively. See the example in the CDMA section for additional details.

#### **Interrupt Controller**

The AXI Interrupt Controller concentrates multiple interrupt inputs from peripheral devices to a single interrupt output to the system processor using the PCIe bus. The interrupt controller contains programmer accessible registers that allow interrupts to be enabled, queried and cleared under software control over the PCIe bus interface.

| BARO Base Addr+ | Bit(s) | Description                     |
|-----------------|--------|---------------------------------|
| 0x0000_2000     | 31:0   | Interrupt Status Register       |
| 0x0000_2004     | 31:0   | Interrupt Pending Register      |
| 0x0000_2008     | 31:0   | Interrupt Enable Register       |
| 0x0000_200C     | 31:0   | Interrupt Acknowledge Register  |
| 0x0000_2010     | 31:0   | Set Interrupt Enable Register   |
| 0x0000_2014     | 31:0   | Clear Interrupt Enable Register |
| 0x0000_2018     | 31:0   | Reserved                        |
| 0x0000_201C     | 31:0   | Master Enable Register          |

Note that any registers/bits not mentioned will remain at the default value: logic low.

#### Interrupt Status Register (Read/Write) – (BAR0 + 0x2000)

This Interrupt Status register (ISR) at BAR0 base address + offset 0x2000 is used to monitor board interrupts. When read, the contents of this register indicate the presence or absence of an active interrupt for each of the active interrupting sources. Each bit in this register that is set to a '1' indicates an active interrupt signal on the corresponding interrupt input. Bits that are '0'are not active. The bits in the ISR are independent of the interrupt enable bits in the Interrupt Enable register. Interrupts, even if not enabled can still show up as active in the ISR.

# Table 4.22 Interrupt Controller

Table 4.23 Interrupt Status (Read/Write) – (BAR0 + 0x2000)

| Bit(s) | Function |                                                                                                                                                     |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|        | Wh       | en set indicates DAC channel 0 to 7 requires service.                                                                                               |
| 7-0    | 0        | No service required                                                                                                                                 |
|        | 1        | In a single burst mode indicates burst complete.<br>In FIFO mode, indicates FIFO is half full.                                                      |
| 8      | CDI      | en set indicates an AXI CDMA interrupt. See the<br>MA section for more information on the source of the<br>errupt.                                  |
| 0      | 0        | Interrupt Inactive                                                                                                                                  |
|        | 1        | Interrupt Active                                                                                                                                    |
| 9      | nur      | en set indicates that the ADC Data FIFO contains a<br>nber of samples equal to or greater than the value<br>red in the FIFO Full Threshold Register |
| 5      | 0        | Interrupt Inactive                                                                                                                                  |
|        | 1        | Interrupt Active                                                                                                                                    |
| 10     | Coι      | en set indicates an Counter interrupt. See the<br>inter section for more information on the source of<br>interrupt.                                 |
| 10     | 0        | Interrupt Inactive                                                                                                                                  |
|        | 1        | Interrupt Active                                                                                                                                    |
| 11     | sec      | en set indicates a Digital interrupt. See the Digital<br>tion for more information on the source of the<br>errupt.                                  |
|        | 0        | No active Digital interrupt                                                                                                                         |
|        | 1        | Active Digital interrupt                                                                                                                            |

The ISR register is writable by software only until the Hardware Interrupt Enable bit in the MER has been set. Given these restrictions, when this register is written to, any data bits that are set to '1' will activate the corresponding interrupt just as if a hardware input became active. Data bits that are zero have no effect. This allows software to generate interrupts for test purposes.

#### Interrupt Pending Register (Read/Write) - (BAR0 + 0x2004)

This Interrupt Pending register (IPR) at BARO base address + offset 0x2004 is used to monitor board interrupts. Reading the contents of this register indicates the presence or absence of an active interrupt signal that is also enabled. Each bit in this register is the logical AND of the bits in the Interrupt Status register and the Interrupt Enable register.

| Table 4.24 Interrupt Pending |  |
|------------------------------|--|
| (Read/Write) – (BAR0 +       |  |
| 0x2004)                      |  |

| Bit(s) | Function |                                                                                                                                |  |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------|--|
|        | Wh       | en set indicates DAC channel 0 to 7 is pending.                                                                                |  |
| 7-0    | 0        | No Interrupt Pending                                                                                                           |  |
|        | 1        | In a single burst mode indicates burst complete.<br>In FIFO mode, indicates FIFO is half full.                                 |  |
| 8      | See      | ten set indicates an AXI CDMA interrupt is pending.<br>The CDMA section for more information on the<br>arce of the interrupt.  |  |
|        | 0        | No Interrupt Pending                                                                                                           |  |
|        | 1        | Interrupt Pending                                                                                                              |  |
|        |          | en set indicates that the ADC Data FIFO threshold met exceeded interrupt is pending.                                           |  |
| 9      | 0        | No Interrupt Pending                                                                                                           |  |
|        | 1        | Interrupt Pending                                                                                                              |  |
| 10     | the      | en set indicates a Counter interrupt is pending. See<br>Counter section for more information on the source<br>the interrupt.   |  |
| 10     | 0        | No Interrupt Pending                                                                                                           |  |
|        | 1        | Interrupt Pending                                                                                                              |  |
| 11     | Dig      | nen set indicates a Digital interrupt is pending. See the<br>ital section for more information on the source of the<br>errupt. |  |
| **     | 0        | No Interrupt Pending                                                                                                           |  |
|        | 1        | Interrupt Pending                                                                                                              |  |

# Interrupt Enable Register (Read/Write) – (BAR0 + 0x2008)

This is a read/write register. Writing a '1' to a bit in this register enables the corresponding Interrupt Status bit to cause assertion of the interrupt output. The Interrupt Enable bit set to '0' does not inhibit an interrupt condition from being captured. It will still show up in the Interrupt Status register even when not enabled here. To show up in the Interrupt Pending register it needs to be enabled here. Writing a '0' to a bit disables, or masks, the

generation of an interrupt output for the corresponding interrupt input signal. Note however, that disabling an interrupt input is not the same as clearing it. Disabling an active interrupt prevents that interrupt from reaching the IRQ output. When it is re-enabled, the interrupt immediately generates a request on the IRQ output. An interrupt must be cleared by writing to the Interrupt Acknowledge Register, as described below. Reading this Interrupt Enable register indicates which interrupt inputs are enabled; where a '1' indicates the input is enabled and a '0' indicates the input is disabled.

| Bit(s) | Function |                                                                                                                                |  |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------|--|
|        |          | ien set indicates DAC channel 0 to 7 interrupts are abled.                                                                     |  |
| 7-0    | 0        | Interrupt Disabled (default)                                                                                                   |  |
|        | 1        | Interrupt Enabled                                                                                                              |  |
| 8      | See      | ten set indicates an AXI CDMA interrupt is enabled.<br>The CDMA section for more information on the arrow of the interrupt.    |  |
| U      | 0        | Interrupt Disabled (default)                                                                                                   |  |
|        | 1        | Interrupt Enabled                                                                                                              |  |
|        |          | en set indicates that the ADC Data FIFO threshold met exceeded interrupt is enabled.                                           |  |
| 9      | 0        | Interrupt Disabled (default)                                                                                                   |  |
|        | 1        | Interrupt Enabled                                                                                                              |  |
| 10     | the      | en set indicates a Counter interrupt is enabled. See<br>Counter section for more information on the source<br>the interrupt.   |  |
| 10     | 0        | Interrupt Disabled (default)                                                                                                   |  |
|        | 1        | Interrupt Enabled                                                                                                              |  |
| 11     | Dig      | nen set indicates a Digital interrupt is enabled. See the<br>ital section for more information on the source of the<br>errupt. |  |
|        | 0        | Interrupt Disabled (default)                                                                                                   |  |
|        | 1        | Interrupt Enabled                                                                                                              |  |

# Table 4.25 Interrupt Enable (Read/Write) – (BAR0 + 0x2008)

Interrupt Acknowledge Register

The Interrupt Acknowledge register is a write-only location that clears the interrupt request associated with selected interrupt inputs. Note that

writing one to a bit in the Interrupt Acknowledge register clears the corresponding bit in Interrupt Status register, and clears the same bit in the Interrupt Acknowledge register.

Writing a '1' to a bit location in the Interrupt Acknowledge register will clear the interrupt request that was generated by the corresponding interrupt input. An interrupt input that is active and masked by writing a '0' to the corresponding bit in the Interrupt Enable register will remain active until cleared by acknowledging it. Unmasking an active interrupt causes an interrupt request output to be generated (if the Master Interrupt Enable bit-0 in the Master Enable register is set). Writing 0s has no effect as does writing a '1' to a bit that does not correspond to an active input or for which an interrupt input does not exist. The bit locations in the Interrupt Acknowledge register correspond with the bit locations given in the Interrupt Enable Register Table.

Table 4.26 InterruptBit(s)Acknowledge (Read/Write) -<br/>(BAR0 + 0x200C)7-0

| Bit(s) | Function                                                            |
|--------|---------------------------------------------------------------------|
| 7-0    | Clear DAC channel 0 to 7 interrupt request.                         |
| 8      | Clear AXI CDMA interrupt request.                                   |
| 9      | Clear ADC Data FIFO threshold met or exceeded<br>interrupt request. |
| 10     | Clear Counter interrupt request.                                    |
| 11     | Clear Digital interrupt request.                                    |
| 31-12  | Reserved                                                            |

# Set Interrupt Enable Register (Read/Write) – (BAR0 + 0x2010)

Set Interrupt Enable register is a location used to set Interrupt Enable register bits in a single atomic operation, rather than using a read / modify / write sequence. Writing a '1' to a bit location in the Set Interrupt Enable register will set the corresponding bit in the Interrupt Enable register. Writing 0s does nothing, as does writing a '1' to a bit location that corresponds to a non-existing interrupt input. The bit locations in the Set Interrupt Enable register correspond with the bit locations given in the Interrupt Enable Register Table. Table 4.27 Set Interrupt Enable (Read/Write) – (BAR0 + 0x2010)

| Bit(s) | Function                                                       |
|--------|----------------------------------------------------------------|
| 7-0    | Set DAC channel 0 to 7 interrupt request.                      |
| 8      | Set AXI CDMA interrupt request.                                |
| 9      | Set ADC Data FIFO threshold met or exceeded interrupt request. |
| 10     | Set Counter Interrupt request.                                 |
| 11     | Set Digital Interrupt request                                  |
| 31-12  | Reserved                                                       |

# Clear Interrupt Enable Register (Read/Write) – (BAR0 + 0x2014)

Clear Interrupt Enable register is a location used to clear Interrupt Enable register bits in a single atomic operation, rather than using a read / modify / write sequence. Writing a '1' to a bit location in Clear Interrupt Enable register will clear the corresponding bit in the Interrupt Enable register. Writing 0s does nothing, as does writing a '1' to a bit location that corresponds to a non-existing interrupt input. The bit locations in the Clear Interrupt Enable register correspond with the bit locations given in the Interrupt Enable Register Table.

| Bit(s) | Function                                                            |
|--------|---------------------------------------------------------------------|
| 7-0    | Clear DAC channel 0 to 7 interrupt request.                         |
| 8      | Clear AXI CDMA interrupt request.                                   |
| 9      | Clear ADC Data FIFO threshold met or exceeded<br>interrupt request. |
| 10     | Clear Counter Interrupt request.                                    |
| 11     | Clear Digital Interrupt request.                                    |
| 31-12  | Reserved                                                            |

#### Master Enable Register

Table 4.28 Clear Interrupt Enable (Read/Write) – (BAR0 +

**0x2014**)

This is a 2-bit, read / write register. The two bits are mapped to the two least significant bits of the location. The least significant bit contains the Master Enable bit and the next bit contains the Hardware Interrupt Enable bit. Writing a '1' to the Master Enable bit enables the IRQ output signal. Writing a '0' to the Master Enable bit disables the IRQ output, effectively masking all interrupt inputs. The Hardware Interrupt Enable bit is a write-once bit. At reset, this bit is reset to '0', allowing the software to write to the Interrupt Status register to generate interrupts for testing purposes, and disabling any hardware interrupt inputs. Writing a '1' to this bit enables the hardware interrupts input and disables software generated inputs. Writing a '1' also disables any further changes to this bit until the device has been reset. Writing 1s or 0s to any other bit location does nothing. When read, this

register will reflect the state of the Master Enable and Hardware Interrupt Enable bits. All other bits will read as 0s.

|                                            | Bit(s) |                                       | Function                         |  |
|--------------------------------------------|--------|---------------------------------------|----------------------------------|--|
| Table 4.29 Master Enable                   | 0      | Master IRQ Enable                     |                                  |  |
| Register (Read/Write) - (BAR0<br>+ 0x201C) |        | 0                                     | All Interrupts Disabled          |  |
|                                            |        | 1                                     | All Interrupts Enabled           |  |
|                                            | 1      | Hardware Interrupts Enabled           |                                  |  |
|                                            |        | 0                                     | Software Interrupts Enabled      |  |
|                                            |        | 1                                     | Hardware Interrupts Only Enabled |  |
|                                            | 31-2   | Not Used (bits are read as logic "0") |                                  |  |

# AXI XADC Analog to Digital Converter (System Monitor)

The XADC Analog to Digital Converter is used to monitor the die temperature and supply voltages of the FGPA. The XADC channel sequencer is configured to continuously sample the temperature, Vccint and Vccaux channels. The results from the A/D conversions can be read at the addresses given in column one of the Table below.

Data bits 15 to 4 of these registers hold the "ADCcode" representing the temperature, Vccint, or Vccaux value. Data bits 3 to 0 are not used.

The 12-bits output from the ADC can be converted to temperature using the following equation.

Temperature (°C) =  $\frac{ADCcode \times 503.975}{4096} - 273.15$ 

The 12-bits output from the ADC can be converted to voltage using the following equation.

$$SupplyVoltage(volts) = \frac{ADCcode}{4096} \times 3V$$

Additional information regarding the XADC can be found in the Xilinx XADC product guide PG019 and the user guide UG480.

Table 4.30 AXI XADC Analog to Digital Converter (System Monitor)

| Address     | Status Register     |  |  |
|-------------|---------------------|--|--|
| 0x0000_3200 | Temperature         |  |  |
| 0x0000_3204 | V <sub>CCINT</sub>  |  |  |
| 0x0000_3208 | V <sub>CCAUX</sub>  |  |  |
| 0x0000_3280 | Maximum Temperature |  |  |
| 0x0000_3284 | Maximum VCCINT      |  |  |
| 0x0000_3288 | Maximum VCCAUX      |  |  |
| 0x0000_3290 | Minimum Temperature |  |  |
| 0x0000_3294 | Minimum VCCINT      |  |  |
| 0x0000_3298 | Minimum VCCAUX      |  |  |

The expected values for  $V_{\text{CCINT}}, V_{\text{CCINT}}$  and Temperature are shown in the Table below.

| Parameter                    | Min   | Max   |
|------------------------------|-------|-------|
| V <sub>CCINT</sub> Volts     | .95   | 1.05  |
| V <sub>CCAUX</sub>           | 1.71  | 1.89  |
| Temperature<br>(recommended) | -40°C | 100°C |

#### **Firmware Revision Register**

This is a read only register located at BAR0 + 0x4000. The ASCII code representing the current revision of the MCS firmware file is readable from this location. For example, if the firmware is at revision A then this register will read 0x41 in the least significant byte or B= 0x42, C=0x43, etc.

#### ADC, Digital I/O, and Counter Memory Map

The memory space starting at BAR0 base address plus offset 0x7000 to 0x7FFF is reserved to access the ADC control registers, the Digital I/O registers and the Counter Timer registers.

|                                                              | BAR0 Base Address | Bit(s) | Description                      |
|--------------------------------------------------------------|-------------------|--------|----------------------------------|
| Table 4.31:<br>ADC/Digital/Counter Memory                    | 0x0000 7000       | 31:0   | Global Interrupt Status Register |
| Мар                                                          | 0x0000 7004       | 31:0   | Global Interrupt Enable Register |
| Notes:                                                       | 0x0000 7008       | 31:0   | ADC Control Register             |
| <ol> <li>The module will<br/>respond to addresses</li> </ol> | 0x0000 700C       | 31:0   | ADC Range Enable Channel 0 to 7  |

|                                               | r                          | 1    | 1                                                                      |
|-----------------------------------------------|----------------------------|------|------------------------------------------------------------------------|
| that are "Not Used".<br>The board will return | 0x0000 7010                | 31:0 | ADC Range Enable Channel 8 to 15                                       |
| "0" for all address                           | 0x0000 7014                | 31:0 | ADC Conversion Time Register                                           |
| reads that are not used<br>or reserved.       | 0x0000 7018                | 31:0 | ADC FIFO Full Threshold                                                |
|                                               | 0x0000 701C                | 31:0 | ADC Start Conversion Register                                          |
|                                               | 0x0000 7020                | 31:0 | ADC FIFO Data and Tag Register                                         |
|                                               | 0x0000 7024→<br>0x0000703C | 31:0 | NOT USED                                                               |
|                                               | 0x0000 7040                | 31:0 | <u>16-bit Digital I/O Register</u>                                     |
|                                               | 0x0000 7044                | 31:0 | Digital I/O Direction Control Register                                 |
|                                               | 0x0000 7048                | 31:0 | Digital I/O Interrupt Type Register                                    |
|                                               | 0x0000 704C                | 31:0 | Digital I/O Interrupt Polarity Register                                |
|                                               | 0x0000 7050                | 31:0 | Debounce Enable Register                                               |
|                                               | 0x0000 7054                | 31:0 | Debounce Duration Select Register                                      |
|                                               | 0x0000 7058→<br>0x0000706C | 31:0 | NOT USED                                                               |
|                                               | 0x0000 7070                | 31:0 | Counter Trigger, Stop, Load Read<br>Back, and Toggle Constant Register |
|                                               | 0x0000 7074                | 31:0 | Counter Control Register                                               |
|                                               | 0x0000 7078                | 31:0 | Counter Interrupt Information<br>Register                              |
|                                               | 0x0000 707C                | 31:0 | Counter Read Back Register                                             |
|                                               | 0x0000 7080                |      | Counter Constant A Register 1                                          |
|                                               | 0x0000 7084                |      | Counter Constant A Register 2                                          |
|                                               | 0x0000 7088                |      | Counter Constant B Register 1                                          |
|                                               | 0x0000 708C                |      | Counter Constant B Register 2                                          |
|                                               | 0x0000 7090→<br>0x0000709C | 31:0 | NOT USED                                                               |
|                                               | 0x0000 70A0                | 15:0 | ADC Channel 0 Offset                                                   |
|                                               | 0x0000 70A4                | 15:0 | ADC Channel 1 Offset                                                   |
|                                               | 0x0000 70A8                | 15:0 | ADC Channel 2 Offset                                                   |
|                                               | 0x0000 70AC                | 15:0 | ADC Channel 3 Offset                                                   |
|                                               | 0x0000 70B0→<br>0x000070DC | 15:0 | ADC Channel 4- 15 Offset                                               |

| 0x0000 70E0                | 17:0  | ADC Channel 0 Gain     |
|----------------------------|-------|------------------------|
| 0x0000 70E4                | 17:0  | ADC Channel 1 Gain     |
| 0x0000 70E8                | 17:0  | ADC Channel 2 Gain     |
| 0x0000 70EC                | 17:0  | ADC Channel 3 Gain     |
| 0x0000 70F0→<br>0x0000711C | 17:0  | ADC Channel 4- 15 Gain |
| 0x0000 7120→<br>0x000071FC | 31:0  | NOT USED               |
| 0x0000 7200                | 31:0  | NOT USED               |
| 0x0000 7204                | 7:0   | Flash Data             |
| 0x0000 7208                | Bit-0 | Flash Chip Select      |
| 0x0000 720C→<br>0x00007FFF | 31:0  | NOT USED               |

#### Global Interrupt Status Clear Register (Read/Write) - (Base + 7000H)

The Interrupt Status Register reflects the status of each of the Digial interrupting channels, and Counter Timer interrupts.

**Read** of this bit reflects the interrupt pending status.

0 = Interrupt Not Pending

1 = Interrupt Pending

A function that does not have interrupts enabled will never set its interrupt status flag.

Write a logic "1" to this bit to release/clear a pending interrupt.

However, if the condition which caused the interrupt to occur remains, the interrupt will be generated again (unless disabled via its Interrupt Enable Register). Writing "0" to a bit location has no effect; that is, a pending interrupt will remain pending.

The Interrupt Status register at the base address + offset 7000H is used to control channels 0 through 15 via data bits 0 to 15, and counter interrupt via bit-24. For example, digital channel 0 is controlled via data bit-0, and counter interrupt via bit-24. For example, digital channel 0 is controlled via data bit-0. For example, channel 0 is controlled via data bit-0.

The function of each of the interrupt register bits are described in the following table. This register can be read or written with either 8-bit, 16-bit, or 32-bit data transfers. A power-up or system reset sets all interrupt register bits to 0.

| Table 4.32  | Global   | Interrupt |
|-------------|----------|-----------|
| Status Clea | r Regist | er        |

Note that any registers/bits not mentioned will remain at the default value logic low.

| BIT   | FUNCTION                                   |
|-------|--------------------------------------------|
| 0     | Digital Channel 0 Interrupt Pending/Clear  |
| 1     | Digital Channel 1 Interrupt Pending/Clear  |
| :     | :                                          |
| 15    | Digital Channel 15 Interrupt Pending/Clear |
| 16    | NOT USED                                   |
| :     | NOT USED                                   |
| 23    | NOT USED                                   |
| 24    | Counter/Timer Interrupt Pending/Clear      |
| 31-25 | NOT USED                                   |

# Global Interrupt Enable Register (Read/Write) - (Base + 7004H)

The Interrupt Enable Register provides a mask bit for each of the interrupting functions. A "0" bit will prevent the corresponding function from generating an external interrupt. A "1" bit will allow the corresponding function to generate an interrupt.

The Interrupt Enable register at the base address + offset 7004H is used to control channels 0 through 15 via data bits 0 to 15, and counter interrupt via bit-24. For example, digital channel 0 is controlled via data bit-0.

All function interrupts are disabled (set to "0") following a power-on or software reset. Reading or writing to this register is possible via 32-bit, 16-bit or 8-bit data transfers.

| BIT   | FUNCTION                            |
|-------|-------------------------------------|
| 0     | Digital Channel 0 Interrupt Enable  |
| 1     | Digital Channel 1 Interrupt Enable  |
| :     | :                                   |
| 15    | Digital Channel 15 Interrupt Enable |
| 16    | NOT USED                            |
| :     | NOT USED                            |
| 23    | NOT USED                            |
| 24    | Counter/Timer Interrupt Enable      |
| 31-25 | NOT USED                            |

# Table 4.33Global InterruptEnable Register

Note that any registers/bits not mentioned will remain at the default value logic low.

ADC Control Register (Read/Write) - (Base + 7008H)

This read/write register is used to: enable single or continuous conversions, select & control external trigger input/output modes, monitor FIFO status,

and issue a software reset to all but DAC logic, and issue software reset to ADC logic.

The function of each of the control register bits is described in the following table.

Reading or writing to this register is possible via 32-bit, 16-bit or 8-bit data transfers.

|                                                                                              | Bit(s) | FUNCTION                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                             |  |
|----------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                                              | 1 to 0 | Conversion Mode:                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                             |  |
| Table 4.34 ADC Control<br>Register                                                           |        | 00                                                                                                                                                                                                                | Conversions are disabled                                                                                                                                                                                                                                                                    |  |
| Note that any registers/bits not<br>mentioned will remain at the<br>default value logic low. |        | 01                                                                                                                                                                                                                | Enable Single Conversion Mode. A single<br>conversion is initiated per software start convert<br>or external trigger. The internal channel timer<br>controls the start conversion of all channels.<br>Conversions must be disabled and reenabled<br>between consecutive signal conversions. |  |
|                                                                                              |        | 10                                                                                                                                                                                                                | Enable Continuous Conversion Mode. Conversions<br>are initiated by a software start or external trigger<br>and continued by internal hardware triggers<br>generated at the frequency set by the interval<br>timer registers.                                                                |  |
|                                                                                              |        | 11                                                                                                                                                                                                                | Reserved                                                                                                                                                                                                                                                                                    |  |
|                                                                                              | 3 to 2 | Not Use                                                                                                                                                                                                           | ed                                                                                                                                                                                                                                                                                          |  |
| Digital(3) is ADC External<br>Trigger input (active high)                                    | 5 to 4 | External Trigger Mode:                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                             |  |
| Digital(9) is ADC External<br>Trigger output (active high)                                   |        | As an output, internal timer triggers are generated on the External Trigger out pin of the field I/O connector. The External Trigger output signal can be used to synchronize the conversion of multiple modules. |                                                                                                                                                                                                                                                                                             |  |
| triggers. If External Trigger input or output                                                |        |                                                                                                                                                                                                                   | at the External Trigger input can be sensitive to<br>Il EMI noise which can cause erroneous external<br>5. If External Trigger input or output is not required,<br>ernal Trigger should be configured as disabled.                                                                          |  |
|                                                                                              |        | 00 External Trigger Disabled                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                             |  |
|                                                                                              |        | 01                                                                                                                                                                                                                | External Trigger Input                                                                                                                                                                                                                                                                      |  |
| 10 External Trigger Output                                                                   |        |                                                                                                                                                                                                                   | External Trigger Output                                                                                                                                                                                                                                                                     |  |
|                                                                                              |        | 11                                                                                                                                                                                                                | Reserved                                                                                                                                                                                                                                                                                    |  |

| 6           | Auto DMA Transfer:                                                                                                                              |                                                                                                                                |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
|             | With Auto DMA Transfer enabled, a DMA transfer of<br><threshold> size will be automatically kicked off in<br/>hardware.</threshold>             |                                                                                                                                |
|             | Note that the CDMA control, source and destination registers as well as the FIFO threshold register must be properly prior to setting this bit. |                                                                                                                                |
|             | 0                                                                                                                                               | Hardware initiated DMA transfers disabled.                                                                                     |
|             | 1                                                                                                                                               | DMA transfers are initiated automatically in hardware when the FIFO threshold has been met or exceeded.                        |
| 7           | Not Used                                                                                                                                        |                                                                                                                                |
| 8           | FIFO Empty Status:                                                                                                                              |                                                                                                                                |
| status      | 0                                                                                                                                               | FIFO Empty                                                                                                                     |
|             | 1                                                                                                                                               | FIFO Not Empty                                                                                                                 |
| 9           | FIFO Th                                                                                                                                         | reshold Status:                                                                                                                |
| status      | 0                                                                                                                                               | FIFO has less than the number of samples defined by the Threshold Register.                                                    |
|             | 1                                                                                                                                               | FIFO Threshold Reached. This bit is set when the<br>FIFO contains the number of data samples set by<br>the Threshold Register. |
| 10          | FIFO Fu                                                                                                                                         | ll Status:                                                                                                                     |
| status      | 0                                                                                                                                               | FIFO Not Full.                                                                                                                 |
|             | 1                                                                                                                                               | FIFO Full                                                                                                                      |
| 11          | 0                                                                                                                                               | ADC channels 0 to 7 not Busy                                                                                                   |
| Busy Status | 1                                                                                                                                               | ADC channels 0 to 7 Busy                                                                                                       |
| 12          | 0                                                                                                                                               | ADC channels 8 to 15 not Busy                                                                                                  |
| Busy Status | 1                                                                                                                                               | ADC channels 8 to 15 Busy                                                                                                      |
| 13          | Not Used                                                                                                                                        |                                                                                                                                |
| 14          | 1 = Software Reset                                                                                                                              |                                                                                                                                |

|          | This software reset bit will reset the global interrupt<br>enable, Flash logic, digital I/O registers, digital direction<br>registers to input, digital I/O interrupt enable, interrupt<br>type, interrupt polarity, debounce enables, debounce<br>durations, counter logic to cleared and disabled states.  |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15       | 1 = Software Reset<br>The software reset bit will clear this Control Register, the<br>Channel Enable Register, and FIFO buffer. It will also reset<br>the FIFO Threshold Register to its default value of 1023<br>decimal, and set the gain and offset registers to one<br>(0x10000) and zero, respectively. |
| 31 to 16 | Not Used                                                                                                                                                                                                                                                                                                     |

ADC Range Select Channel Enable Register and Corresponding Digital Output Codes (Read/Write) - (BAR0 + 0x700C) and (BAR0 + 0x7010)

Channels 0 to 7 share the one ADC range control of bits 23 to 0 at BAR0 + 0x0000 700C and channels 8 to 15 share the second ADC range control of bits 23 to 0 at BAR0 + 0x0000 7010. Write to this register will set the corresponding ADC range as designated in the following table. Read of this register will return the current setting for corresponding channels.

Bipolar range selections that are available include:

- +10.24 Vdc to -10.24 Vdc
- +10.0 Vdc to -10.0 Vdc
- +5.12 Vdc to -5.12 Vdc
- +5.0 Vdc to -5.0 Vdc

Unipolar ranges selections that are available include:

- +10.24 Vdc to 0 Vdc
- +10.0 Vdc to 0 Vdc
- +5.12 Vdc to 0 Vdc.

The output data coding is in binary two's compliment for all bipolar ranges and in straight binary format for all unipolar ranges. The digital output code corresponding to each of the given ideal analog input values is given in the following table.

Most sensors, signal conditioning amplifiers and filter networks with less than  $10k\Omega$  of source impedance can drive the ADC directly. All unused ADC inputs should be tied to ground.

# Table 4.35 ADC Range Select **Register and Corresponding Digital Output Codes**

*Note that any registers/bits not* mentioned will remain at the default value logic low.

# BAR0 + 0x0000 700C Bits 2 to 0 Bits 5 to 3 Bits 8 to 6 Bits 11 to 9 Bits 14 to 12 Bits 20 to 18 Bits 23 to 21 Channel 00 Channel 01 Channel 02 Channel 03 Channel 04 Channel 05 Channel 06

#### BAR0 + 0x0000 7010

| Bits 2 to 0   | Channel 08 |
|---------------|------------|
| Bits 5 to 3   | Channel 09 |
| Bits 8 to 6   | Channel 10 |
| Bits 11 to 9  | Channel 11 |
| Bits 14 to 12 | Channel 12 |
| Bits 17 to 15 | Channel 13 |
| Bits 20 to 18 | Channel 14 |
| Bits 17 to 15 | Channel 13 |
| Bits 20 to 18 | Channel 14 |
| Bits 23 to 21 | Channel 15 |

Channel 07

| Bits 23<br>- 0 | DESCRIPTION                | ANALC                          | IG INPUT |
|----------------|----------------------------|--------------------------------|----------|
| 111            | + Full Scale Minus One LSB | 10.2396 Volts                  | 7FFF hex |
|                | Midscale                   | 0 Volts                        | 0 hex    |
|                | One LSB Below Midscale     | -312.5 μV                      | FFFF hex |
|                | Minus Full Scale           | -10.24 Volts                   | 8000 hex |
| 110            | + Full Scale               | 9.9996 Volts                   | 7FFF hex |
|                | Midscale                   | 0 Volts                        | 0 hex    |
|                | One LSB Below Midscale     | -305.176 μV                    | FFFF hex |
|                | Minus Full Scale           | -10.0 Volts                    | 8000 hex |
| 101            | + Full Scale               | 10.23984 Volts                 | FFFF hex |
|                | Midscale                   | 5.12 Volts                     | 8000 hex |
|                | One LSB Below Midscale     | -156.25 μV                     | 7FFF hex |
|                | Minus Full Scale           | 0 Volts                        | 0000 hex |
| 100            | + Full Scale               | 9.999847 Volts                 | FFFF hex |
|                | Midscale                   | 5.0 Volts                      | 8000 hex |
|                | One LSB Below Midscale     | 5.0 -152.588<br>μV = 4.99984 V | 7FFF hex |
|                | Minus Full Scale           | 0 Volts                        | 0000 hex |
| 011            | + Full Scale               | 5.119843 Volts                 | 7FFF hex |
|                | Midscale                   | 0 Volts                        | 0 hex    |
|                | One LSB Below Midscale     | -156.25 μV                     | FFFF hex |
|                | Minus Full Scale           | -5.12 Volts                    | 8000 hex |
| 010            | + Full Scale               | 4.999847 Volts                 | 7FFF hex |
|                | Midscale                   | 0 Volts                        | 0 hex    |
|                | One LSB Below Midscale     | -152.588 μV                    | FFFF hex |
|                | Minus Full Scale           | -5.0 Volts                     | 8000 hex |
| 001            | + Full Scale               | 5.11992 Volts                  | FFFF hex |
|                | Midscale                   | 2.56 Volts                     | 8000 hex |

|     | One LSB Below Midscale | 2.56 V -78.125<br>μV = 2.55992 V | 7FFF hex |
|-----|------------------------|----------------------------------|----------|
|     | Minus Full Scale       | 0 Volts                          | 0000 hex |
| 000 | Channel Disabled       |                                  |          |
|     |                        |                                  |          |

Only those channels enabled are stored into the channel data FIFO

ADC Conversion Timer Register (Read/Write) - (BAR0 + 0x0000 7014)

Timed periodic triggering can be used to achieve precise time intervals between conversions. The Conversion Timer register is a 32-bit register value that controls the interval time between conversions of all enabled channels.

The Channel Conversion Timer is used to control the frequency at which the conversion cycle is repeated for all enabled channels. For example, upon software or external trigger, channel 0 is converted. The time programmed into the Conversion Timer Register determines when channel 1 is converted. If Continuous Conversions are selected via the Control Register, the conversions will continue until disabled.

The 32-bit Conversion Timer value divides a 62.5MHz clock signal. The output of the Conversion Timer is used to precisely generate periodic trigger pulses to control the frequency at which all enabled channels are converted. The time period between trigger pulses is described by the following equation:

(Conversion Timer Value + 1) ÷ 62,500,000Hz = T (in seconds)

Where:

**T** = the desired time period between trigger pulses in seconds.

**Conversion Timer Value** can be a minimum of 78 decimal 0x4E hex and the maximum value is 4,294,967,295 decimal 0xFFFFFFF hex.

The maximum period of time which can be programmed to occur between simultaneous conversions is  $(4,294,967,295 + 1) \div 62,500,000 = 68.71947$ seconds. The minimum time interval which can be programmed to occur is  $(78 + 1) \div 62,500,000 = 1.264\mu$  seconds. This minimum of  $1.264\mu$ s is defined by the minimum conversion time of the hardware.

The 1.264µ seconds maximum sample rate corresponds to a maximum sampling frequency of 791,139.24Hz. The maximum analog input frequency should be band limited to one half the sample frequency. An anti-aliasing filter should be added to remove unwanted signals above ½ the sample frequency in the input signal (before the ADC) for critical applications.

The register's contents are cleared upon reset.

#### ADC FIFO Full Threshold Register (Read/Write) - (BAR0 + 0x0000 7018)

The FIFO Full Threshold register is a 10-bit register that is used to control when an interrupt will be generated and/or a DMA transfer will occur. The events, enabled in the ADC Control Register will occur when the FIFO contains the number of samples equal to the FIFO Full Interrupt Threshold value. This register allows selection of any FIFO depth from 13 up to 1023 samples in the 1026 sample FIFO.

This register's contents are cleared upon reset. Any register bits not used will remain at the default value logic low.

An interrupt request will remain asserted to the system as long as the FIFO threshold is met or exceeded and interrupts are enabled. The interrupt request can be removed by 1) disabling interrupts on the module or 2) reading the FIFO until it has fewer samples in it than defined by the threshold register. Note that ADC Data FIFO met or exceeded interrupts must first be enabled in the interrupt enable register at BAR0+ 0x2010. Please see Interrupt Controller section for more details on interrupts. The default FIFO Full Interrupt Threshold is 1023 samples. A reset will program it to this default value.

#### ADC Start Conversion Register (Write) - (BAR0 + 0x0000 701C)

The Start Convert register is write-only and is used to trigger conversions by setting data bit-0 to a logic one. This method of starting conversions is most useful for its simplicity and for when precise timing of conversion is not critical. Typically, software triggering is used for initiating the first conversion. The desired mode of data acquisition must first be configured by setting the following registers to the desired values and modes: Interrupt, Control, ADC Channel Enable, ADC Conversion Timers and CDMA, if necessary.

Data bit-0 must be a logic one to initiate data conversions.

# ADC FIFO Channel Data and Tag Register (Read/Write) - (BAR0 + 0x0000 7020)

Channels 0 to 15 share a 1026 sample deep FIFO buffer. The FIFO samples are 16-bit data values with a 4-bit channel tag.

The FIFO will be cleared by implementing a software or hardware reset. Any bits not used will remain at the default logic low.

# Table 4.36 ADC FIFO ChannelData and Tag Register

Note that any registers/bits not mentioned will remain at the default value logic low.

| BIT      | FUNCTION          |
|----------|-------------------|
| 15 to 0  | FIFO Channel Data |
| 19 to 16 | FIFO Channel Tag  |
| 31-20    | NOT USED          |

Gain and offset correction will be applied to each sample prior to writing the result into the FIFO. The addition and multiplication operations are done in FPGA hardware using the FPGA's DSP blocks. The gain and offset registers are set to one and zero respectively upon reset to pass uncorrected ADC values to the FIFO. Typical start-up operations would include reading factory calibration constants from the flash memory and writing the appropriate correction values for the gain and offset registers for each ADC.

Since all channels share the same FIFO, channel data tagging is implemented. The tag value identifies the channel to which the data corresponds.

Care should be taken when reading data from the FIFO buffer to ensure the FIFO is not empty when a new read is initiated. The FIFO Empty status bit can be read, in the control register, prior to reading the FIFO to avoid reading erroneous data.

If the FIFO exceeds 1026 samples, no more data will be written to the FIFO until data is read and space is freed. It is recommended that interrupts or Auto DMA Transfer be enabled upon meeting the FIFO's set threshold condition.

| Modes of Conversion        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | The XMC730 provides two methods of analog input operation for maximum flexibility with different applications. The following sections describe the Features of each method and how to best use them.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Single Conversion Mode     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                            | In Single Conversion mode of operation, conversions are initiated by a software or external trigger. Upon the trigger, channels 0 to 7 will be sequentially converted with the first ADC while channels 8 to 15 are sequentially converted with the second ADC. All channels enabled, with a valid range code, in the ADC Range Enable Channel 0 to 7 Register and ADC Range Enable Channel 8 to 15 Register will be tagged with their channel number and stored to FIFO memory. No additional conversions will be initiated unless a new software or external trigger is generated.                                                                                                                |
|                            | To select this mode of operation bits 1 and 0 of the Channel Control register<br>must be set to digital code "01". Then, issuing a software start convert or<br>external trigger will initiate conversions. The Conversion Timer must also be<br>programmed for this mode of operation.                                                                                                                                                                                                                                                                                                                                                                                                             |
|                            | This mode of operation can be used to initiate conversions based upon<br>external triggers. This can be used to synchronize multiple modules to a<br>single module running in a continuous conversion mode. The external<br>trigger of an "master" must be programmed as an output. The external<br>trigger output signal of that module must then be connected to the external<br>trigger input signal of all other modules that are to be synchronized. These<br>other modules must be programmed for Single Conversion mode and<br>external trigger input. Data conversion can then be initiated via the Start<br>Convert bit of the master module configured for continuous conversion<br>mode. |
| Continuous Conversion Mode |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                            | In the Continuous Conversion mode of operation, the hardware controls the continuous conversions of all enabled channels. All channels 0 to 15 are converted at the rate specified by the Conversion Timer. Channels 0 to 7 are converted simultaneously with channels 8 to 15.                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                            | To initiate this mode of operation bits 1 and 0 of the Channel Control register must be set to digital code "10". Then, issuing a software start convert or external trigger will initiate the continuous conversions of all enabled channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### **Automatic DMA Transfer**

In the case where data must be quickly read from the FIFO, Auto DMA Transfer is recommended. Initiate this mode of operation by setting bit 6 of the ADC Control Register to '1'.

Auto-DMA Mode will automatically start a DMA transfer in the amount of the threshold value, once the threshold value is met. The CDMA Control Register, Source and Destination Registers must be properly written before the start of conversions. Keyhole Reading must be enabled in the CDMA control register. It is recommended that DMA completion interrupts be used to signal when new data is available at the specified destination.

When choosing a FIFO threshold value, the conversions time, number of channels enabled and the time for a DMA transfer to complete in the system must be considered.

#### **Programming Considerations**

The XMC730 provides different methods of analog input acquisition to give the user maximum flexibility for each application. Examples are presented in the following sections to illustrate programming the different modes of operation.

#### **Continuous Conversion Mode with Interrupt Example**

This example will enable channels 0 through 9 for the continuous conversion mode of operation. Interrupts are enabled and an interrupt threshold of 430 samples is programmed. The Conversion Timer will be set for a  $1.344\mu$  second interval. Conversions can be initiated via software or external trigger.

1. Execute write of 0020H to the Interrupt Enable Register at Base Address + 2008H. This will enable FIFO Threshold met or exceeded interrupts on the module.

2. Execute write of 0002H to the Control Register at Base Address + 7008H.

a) Continuous Conversion mode is selected.

3. Execute write of 00FF FFFFH to the ADC Range Enable Channel 0 to 7 Register at Base Address + 700CH. This will permit the values corresponding to channels 0 to 7 to be stored in the data FIFO using the +/-10.24 volt input range.

4. Execute write of 003FH to the ADC Range Enable Channel 8 to 15 Register at Base Address + 7010H. This will permit the values corresponding to channels 8 and 9 to be stored in the data FIFO using the +/-10.24 volt input range.

5. Execute write of 53H to the Conversion Timer register at Base Address + 7014H. This sets the interval time between conversions to 1.344µ seconds.

6. Execute write of 1AEH to the FIFO Full Threshold register at Base Address + 7018H.

a) The XMC730 will issue an interrupt to the system when 430 or more samples are present in the FIFO.

7. Execute write of 0001H to the Start Convert Bit at Base Address + 701CH.

a) This starts the simultaneous conversion of channels 0 to 7 while channels 8 to 9 are simultaneously converted. The interval between channel conversions is  $1.344\mu$  seconds.

#### Single Conversion Mode Example

This example will enable channels 0, 3, and 6 through 11 for the single conversion mode of operation. Conversions can be initiated via software or external trigger. Channels 8 to 11 will be simultaneously converted with channels 0 to 7.  $16\mu$  seconds after channels 0 and 3.

1. Execute write of 0001H to the Control Register at Base Address + 7008H.

a) Single Conversion is enabled.

3. Execute write of 1C0E07H to the ADC Range Enable Channel 0 to 7 Register at Base Address + 700CH. This will permit the values corresponding to channels 0, 3, and 6 to be stored in the data FIFO using the +/-10.24 volt input range.

4. Execute write of OFFFH to the ADC Range Enable Channel 8 to 15 Register at Base Address + 7010H. This will permit the values corresponding to channels 8 to 11 to be stored in the data FIFO using the +/-10.24 volt input range.

5. Execute write of 0001H to the Start Convert Bit at Base Address + 701CH. This starts the conversion of channels 0, 3, and 6 through 11.

#### Automatic DMA Mode Example

This example will show how to use the Auto-DMA mode to transfer data quickly from the FIFO to a destination location.

1. Execute write of 0010H to the Interrupt Enable Register at Base Address + 2008H. This will enable AXI CDMA interrupts.

2. Execute write of 5010H to the CDMA Control Register at Base Address + 0000H.

- a) Simple DMA mode.
- b) Keyhole Read enabled.

c)Interrupt on complete enabled.

3. Execute write of 7020H to the CDMA Source Register at Base Address + 0018h

4. Write CDMA Destination Register. Refer to the AXI-BARO Aperture Base Address section for more information on how to obtain a destination address in host memory.

5. Execute write of 0042H to the Control Register at Base Address + 7008H.

a) Continuous Conversion mode is selected.

b) Auto-DMA mode enabled.

6. Execute write of 00FF FFFFH to the ADC Range Enable Channel 0 to 7 Register at Base Address + 700CH. This will permit the values corresponding to channels 0 to 7 to be stored in the data FIFO using the +/-10.24 volt input range.

7. Execute write of 00FF FFFFH to the ADC Range Enable Channel 8 to 15 Register at Base Address + 7010H. This will permit the values corresponding to channels 8 to 15 to be stored in the data FIFO using the +/-10.24 volt input range.

8. Execute write of 3E7H to the Conversion Timer Register at Base Address + 7014H for a conversion time of 16µs.

9. Execute write of 200H (512 decimal) to the Threshold Register at Base Address + 7018H.

10. Execute write of 0001H to the Start Convert Bit at Base Address + 701CH. This will start continuous conversion of all channels. When the FIFO threshold is met, a DMA transfer of 512 samples will take place and the completion of the transfer will be signaled in the form of a DMA completion interrupt. Conversions will not stop; the FIFO will continuously be filled and samples will be transferred until conversions are disabled via the ADC Control Register.

#### Digital Input/Output Registers (Read/Write) - (Base + 7040H)

| Digital(0) is CNT InA                                     | Sixteen possible input/output channels numbered 0 through 15 may be                                                                                                                                                                 |
|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Digital(1) is CNT InB                                     | individually accessed via these registers. The Input/Output Digital register is used to monitor/read or set/write channels 0 through 15. Channels 0 to 15                                                                           |
| Digital(2) is CNT InC                                     | are accessed at the carrier base address +7040H via data bits 0 to 15.                                                                                                                                                              |
| Digital(3) is ADC External<br>Trigger input (active high) | Channel read/write operations use 8-bit, 16-bit, or 32-bit data transfers with the lower ordered bits corresponding to the lower-numbered channels for the register of interest. All input/output channels are configured as inputs |
| Digital(4) is DAC External<br>Trigger input (active high) | on a power-on or software reset. The unused upper 16 bits of this register<br>are "Not Used" and will always read low (0's).                                                                                                        |

| Digital(8) is DAC External   | If counter control input signals are used or an ADC or DAC trigger signal is  |
|------------------------------|-------------------------------------------------------------------------------|
| Trigger output (active high) | enabled for input, then the Direction Control Register bit-0 must also be set |
| Digital(9) is ADC External   | to low '0' enabling inputs for channels 0 to 7.                               |
| Trigger output (active high) | If ADC or DAC trigger output signal is enabled then Digital Direction Control |
|                              | Register bit-1 must be set to high '1' enabling outputs (channels 8 to 15).   |

#### Digital Direction Control Register (Read/Write) - (Base + 7044H)

The data direction (input or output) of the 16 digital channels is selected via bit-0 and bit-1 of this register. The data direction of channels 0 to 7 are set/controlled via bit-0 while the data direction for bits 8 to 15 are controlled via bit-1. Setting a bit high configures the corresponding channel data direction for output. Setting the control bit low configures the corresponding channel data direction for input.

The Counter control, ADC and DAC trigger signals can be enabled to use Digital Port bits 0 to 4 as input. DAC and ADC trigger output signals are assigned to Digital bits 8 and 9 as outputs.

If counter control input signals are used or an ADC or DAC trigger signal is enabled for input, then the Direction Control Register must also be set as input for channels 0 to 7.

If ADC or DAC trigger signal is enabled for output, then the data Direction Control Register must also be set as output for channels 8 to 15.

The default power-up state of these registers is logic low. Thus, all channels are configured as inputs on system reset or power-up. The unused upper bits of this register are "Not Used" and will always read low (0's). Reading or writing to this register is possible via 32-bit, 16-bit or 8-bit data transfers.

#### Interrupt Type (COS or H/L) Configuration Register (Read/Write) - (Base + 7048H)

The Interrupt Type Configuration Registers determine the type of input channel transition that will generate an interrupt for each of the 16 possible interrupting channels. A "0" bit selects interrupt on level. An interrupt will be generated when the input channel level specified by the Interrupt Polarity Register occurs (i.e. Low or High level transition interrupt). A "1" bit means the interrupt will occur when a Change-Of-State (COS) occurs at the corresponding input channel (i.e. any state transition, low to high or high to low).

The Interrupt Type Configuration register at base address + offset 7048H is used to control channels 0 through 15. For example, channel 0 is controlled via data bit-0. All bits are set to "0" following a reset which means that, if enabled, the inputs will cause interrupts for the levels specified by the digital input channel Interrupt Polarity Register.

Channel read or write operations use 8-bit, 16-bit, or 32-bit data transfers. Note that interrupts will not occur unless they are enabled. The Interrupt Status register at the carrier's base address + offset 7000H is used to monitor pending interrupts corresponding to channels 0 through 15. For example, channel 0 is monitored via data bit-0.

#### Interrupt Polarity Registers (Read/Write) - (Base + 704CH)

The Interrupt Polarity Register determines the level that will cause a channel interrupt to occur for each of the channels enabled for level interrupts. A "0" bit specifies that an interrupt will occur when the corresponding input channel is low (i.e. a "0" in the digital input channel data register). A "1" bit means that an interrupt will occur when the input channel is high (i.e. a "1" in the digital input channel data register). Note that no interrupts will occur unless they are enabled by the Interrupt Enable Register. Further, the Interrupt Polarity Register will have no effect if the Change-of-State (COS) interrupt type is configured by the Interrupt Type Configuration Register.

The Interrupt Polarity register at the carrier's base address + offset 704CH is used to control channels 0 through 15. For example, channel 0 is controlled via data bit-0.

All bits are set to "0" following a reset which means that the inputs will cause interrupts when they are below TTL threshold (provided they are enabled for interrupt on level).

#### Debounce Enable Register (Read/Write) - - (Base + 7050H)

This register controls debounce enable for each of the 16 digital channels. It controls whether each individual channel is to be passed through the debounce logic before being recognized by the circuitry. A "0" disables the debounce logic for the corresponding channel, and a "1" enables the debounce logic. Debounce applies to both inputs and event sense inputs. Bit 0 of each register corresponds to the lowest numbered I/O point, while Bit 15 corresponds to the highest numbered I/O point.

Furthermore, after enabling the debounce circuitry, wait at least three times the programmed debounce duration prior to reading the input ports or event signals to ensure valid data.

All bits are set to "0" following a reset. Thus, on reset and power-up debounce will be disabled by default. These registers are read/write registers that can be accessed with 8-bit, 16-bit, or 32-bit data transfers.

#### Debounce Duration Select Register (Read/Write) - - (Base + 7054H)

This register controls the duration required by each input signal before it is recognized by each individual input. Two bits control the debounce duration for each channel. A 31.25MHz internal system clock is used for debounce. The debounce times are selected as shown below.

All bits are set to "0" following a reset. Thus, on reset and power-up debounce will be disabled by default. These registers are read/write registers that can be accessed with 8-bit, 16-bit, or 32-bit data transfers.

Table 4.37 DebounceDuration Select Register(Read/Write)

| Bit(s)   | FUNG | CTION                 |
|----------|------|-----------------------|
|          | Chan | nel 0 Debounce Value  |
|          | 00   | 4us                   |
| 1 to 0   | 01   | 64us                  |
|          | 10   | 1ms                   |
|          | 11   | 8ms                   |
|          | Chan | nel 1 Debounce Value  |
|          | 00   | 4us                   |
| 3 to 2   | 01   | 64us                  |
|          | 10   | 1ms                   |
|          | 11   | 8ms                   |
|          | Chan | nel x Debounce Value  |
|          | 00   | 4us                   |
| •        | 01   | 64us                  |
|          | 10   | 1ms                   |
| •        | 11   | 8ms                   |
|          | Chan | nel 14 Debounce Value |
|          | 00   | 4us                   |
| 29 to 28 | 01   | 64us                  |
|          | 10   | 1ms                   |
|          | 11   | 8ms                   |
|          |      | nel 15 Debounce Value |
|          | 00   | 4us                   |
| 31 to 30 | 01   | 64us                  |
|          | 10   | 1ms                   |
|          | 11   | 8ms                   |

Counter Trigger, Stop, Load Read Back, and Toggle Register (Write) - (BAR0 + 0x0000 7070)

**Bit-0** of this register is used to implement software triggering the counter timer. Writing a 1 to trigger bit-0 of this register will cause the counter function to be triggered. The contents of bit-0 is not stored and merely acts to trigger the counter.

Triggering may be used to initiate quadrature position measurement, pulse width modulation, watchdog timer (initiates countdown), event counting, frequency measurement, pulse-width measurement, period measurement, or one-shot mode.

**Bit-8** is used to implement software load of the read back register for the counter/timer. Writing a "1" to the load read back register bit-8 will cause the current count to be loaded into the read back register. Bit-8 is not stored and merely acts to load the counters read back register.

Other methods are available to load the read back register. At the end of pulse, period or frequency measurement the read back register is automatically loaded. With Event Counting a pulse on CNT InA when Control register bits 5 and 4 are set "11" will load the read back register. With Quadrature mode a pulse on CNT InC when the Control register bits 9, 8 and 7 are set to "111" will load the read back register.

**Bit-16** is used to disable the counter. Writing a "1" to the counter stop bit-16 of this register will cause the counter to be disabled. Bits 2, 1, and 0 of the counter control register are cleared to "000" thus disabling the counter. Bit-16 of this register is not stored and merely acts to stop the counter when set logic high.

**Bit-24** is used to toggle Counter Constant A and Counter Constant B. Writing a "1" to the bit-24 will cause the counter to use the values in Counter Constant A Register 2 and Counter Constant B Register 2. Writing a "0" will cause the counter to use the values in Counter Constant A Register 1 and Counter Constant B Register 1. By default, a counter will always use the values in Counter Constant A Register 1 and Counter Constant B Register 1. Bit-24 is a read/write bit. Power-up or system reset clears the Toggle Counter Constants bit-24 to "0".

| BITS  | FUNCTION                        |
|-------|---------------------------------|
| 0     | Counter Trigger                 |
| 7-1   | NOT USED                        |
| 8     | Load Counter Read Back Register |
| 15-9  | NOT USED                        |
| 16    | Counter Stop                    |
| 23-17 | NOT USED                        |
| 24    | Counter Toggle                  |
| 31-25 | NOT USED                        |

#### 31 23 NOT 03ED

Counter Control Register (Read/Write) - (BAR0 + 0x0000 7074)If counter timer function is<br/>used then Digital bits 0 to 2 are<br/>required and Digital Direction<br/>Control Register bit 0 must be<br/>set to low '0' (input direction).This register is used to config<br/>counter mode, output polari<br/>Control Register is cleared (s<br/>counter/timer. Reading or w<br/>bit or 8-bit data transfers.

**Table 4.38 Counter Trigger** 

Note that any registers/bits not mentioned will remain at the default value logic low.

Register

Digital(0) is CNT InA

Digital(1) is CNT InB

Digital(2) is CNT InC

This register is used to configure counter/timer functionality. It defines the counter mode, output polarity, input polarity, and clock source. The Counter Control Register is cleared (set to 0) following a reset, thus disabling the counter/timer. Reading or writing to this register is possible via 32-bit, 16-bit or 8-bit data transfers.

Eight modes of operation are provided: quadrature position measurement, pulse width modulation, watchdog timer, event counting, frequency measurement, pulse width measurement, period measurement, and oneshot pulse mode. The following sections describe the features of each method of operation and how to best use them.

#### **Quadrature Position Measurement**

The counter/timers may be used to perform position measurements from quadrature motion encoders. Bits 2 to 0 of the Counter Control Register set to logic "001" configures the counter for quadrature measurement.

A quadrature encoder can have up to three channels: A, B, and Index. When channel A leads channel B by 90° in a quadrature cycle, the counter increments. When channel B leads channel A by 90° in a quadrature cycle, the counter decrements. The number of increments or decrements per cycle depends on the type of encoding: X1, X2, or X4.





An X1 encoding Increment occurs on the rising edge of channel A when channel A leads channel B. An X1 encoding decrement occurs on the falling edge of channel A when channel B leads channel A.

For X2 encoding, two increments or decrements (on each edge of channel A) result from each cycle. The counter increments when A leads B and decrements when B leads A.

For X4 encoding, four increments or decrements (on each edge of channel A and B) result from each cycle. The counter increments when A leads B and decrements when B leads A.

Quadrature measurement must be triggered internally via the Counter Trigger Register. An initial software trigger starts quadrature position measurement operation.

CNT InA and CNT InB input signals are used to input the channel A and channel B input signals, respectively. The counter will increment when channel A leads channel B and will decrement when channel B leads channel A. Three rates of increments and decrements are available X1, X2, and X4 which are programmed via counter timer control register bits 5 and 4. Channel B is enabled for input by setting bit-6 to a logic "1". CNT InC can be used for the Index signal. Encoders that have an index channel can cause the counter to reload with the Counter Constant B value in a specified phase of the quadrature cycle. Reload can be programmed to occur in any one of the four phases in a quadrature cycle. You must ensure that the Index channel is high during at least a portion of the phase you specify for reload. The phase can be selected via the counter timer control register bits 9, 8, and 7 as seen in the following Table.

CNT InC can alternately be used as an external load of the Read Back Register. The signal will be active high and will cause immediate load of the current count value into the Read Back Register. An interrupt will be generated upon hardware load of the Read Back Register (if interrupts are enabled). Load of the Read Back Register can also be implemented by software via the Load Read Back Register. The quadrature measurement value can be read from the Counter Read Back Register.

## Table 4.39 Counter ControlRegister (Quadrature PositionMeasurement)

| Bit(s)   | FUNCTION                                   |                                                              |                              |  |
|----------|--------------------------------------------|--------------------------------------------------------------|------------------------------|--|
| 2,1,0    | Specifie                                   | es the Counter Mode:                                         |                              |  |
|          | 001 Quadrature Position Measurement        |                                                              |                              |  |
| 3        | Output Polarity (Output Pin ACTIVE Level): |                                                              |                              |  |
|          | 0                                          | Active LOW (Default) <sup>1</sup>                            |                              |  |
|          | 1                                          | Active HIGH <sup>1</sup>                                     |                              |  |
| 5, 4     | CNT InA                                    | / Channel A                                                  |                              |  |
|          | 00                                         | Disabled (Default)                                           |                              |  |
|          | 01                                         | X1 Encoding                                                  |                              |  |
|          | 10                                         | X2 Encoding                                                  |                              |  |
|          | 11                                         | X4 Encoding                                                  |                              |  |
| 6        | CNT InE                                    | 3 / Channel B                                                |                              |  |
|          | 0                                          | Disabled (Default)                                           |                              |  |
|          | 1                                          | Enabled                                                      |                              |  |
| 9,8,7    | CNT InC                                    | / Index: Channel Interru                                     | pt/Reload occurs when        |  |
|          | Index si                                   | gnal=1 and the A & B inpu<br>See Control bits 14 & 13        | It signals are as selected   |  |
|          |                                            | ot/load control.                                             |                              |  |
|          | 000                                        | Disabled (Default) 101                                       | and 110 also Disable         |  |
|          | 001                                        | A = 0 , B = 1                                                |                              |  |
|          | 010                                        | A = 1 , B = 0                                                |                              |  |
|          | 011                                        | A = 1 , B = 1                                                |                              |  |
|          | 100                                        | A = 0 , B = 0                                                |                              |  |
|          | CNT InC                                    | nC / Hardware Load Read Back Register                        |                              |  |
|          | 111                                        | InC = 0: Inactive State                                      |                              |  |
|          |                                            | InC = 1: Load Read Back                                      | Register on logic high pulse |  |
| 12,11,10 | Counter Operational Frequency Select       |                                                              | Select                       |  |
|          | 000                                        |                                                              | 1.953125MHz                  |  |
|          | 001                                        |                                                              | 3.90625MHz                   |  |
|          | 010                                        |                                                              | 7.8125MHz                    |  |
|          | 011                                        |                                                              | 15.625MHz                    |  |
|          | 100                                        |                                                              | 62.5MHz                      |  |
|          | 101                                        | Undefined                                                    | N/A                          |  |
|          | 110                                        | Undefined                                                    | N/A                          |  |
|          | 111                                        | Undefined                                                    | N/A                          |  |
| 14,13    | Output                                     | I and Interrupt Condition S                                  | Select                       |  |
| ,        | 00                                         | No Output or Interrupt Selected                              |                              |  |
|          | 01                                         | Output and Interrupt on counter equal Constant A<br>Register |                              |  |
|          | 10                                         | Output and Interrupt on Index and reload on Index            |                              |  |
|          | 11                                         |                                                              | n Index but do not reload    |  |
| 15       | NOT US                                     | i<br>iED                                                     |                              |  |
|          | 0                                          | NOT USED                                                     |                              |  |
|          | 1                                          | NOT USED                                                     |                              |  |

An interrupt can be generated upon index reload, or when the counter value equals the constant value stored in the Counter Constant A Register. Interrupts must be enabled via the Enable/Disable Counter Interrupts Register. The interrupt type must also be selected via bits 13 and 14 of the Counter Control Register. The interrupt will remain pending until released by setting the required bit of the Counter/Timer Interrupt Status/Clear register. Note that interrupts in Quadrature Position Measurement are generated whenever the interrupt conditions exist. If a pending interrupt is cleared, but the interrupt conditions still exist, another interrupt will be generated.

The Counter Control register bits 14 and 13 are used to control the operation of the counter output signal. With bits 14 and 13 set to "01", the output signal will be driven active while the counter equals the counter Constant A value. With bit 14 set to logic "1" the output signal will be driven active while the index condition remains true.

#### Pulse Width Modulation

Pulse width modulated waveforms may be generated at the counter timer output. The pulse width modulated waveform is generated continuously. Pulse Width Modulation generation is selected by setting Counter Control Register bits 2 to 0 to logic "010".

Counter Constant A value controls the time until the pulse goes active. The duration of the pulse is set via the Counter Constant B register. Note that a high pulse will be generated if active high output is selected while a low pulse will be generated if active low output is selected.

The counter goes through a countdown sequence for each Counter Constant value. When the 0 count is detected, the output toggles to the opposite state. Then the second Counter Constant value is loaded into the counter, and the countdown resumes, decrementing by one for each rising edge of the clock selected via Control Register bits 12, 11, and 10. For example, a counter constant value of 3 will provide a pulse duration of 3 clock cycles of the selected clock. Note, when the maximum internal clock frequency is selected, 62.5MHz, a delay of one extra clock cycle will be added to the counter constant value.

CNT InA can be used as a Gate-Off signal to stop and start the counter and thus the pulse-width modulated output. When CNT InA is enabled via bits 5 and 4 of the control register for active low Gate-Off input, a logic low input will enable pulse-width modulation counting while a logic high will stop PWM counting. When CNT InA is enabled for active high Gate-Off operation, a logic high will enable PWM counting while a logic low will stop PWM counting.

CNT InC can be used to externally trigger Pulse Width Modulation generation. Additionally, PWM can be triggered internally via the Counter Trigger Register. An initial trigger, software or external, causes the pulse width modulated signal to be generated. After an initial trigger do not issue additional triggers. Triggers issued while running will cause the Constant A and B values to load at the wrong time. In addition, changing the Control register setting while running can also cause the Constant A and B values to load at the wrong time.

By enabling interrupts via the Enable/Disable Interrupts Register, an interrupt can be generated when the output pulse transitions from low to high and also for transitions from high to low. Thus, an interrupt is generated at each pulse transition.

## Table 4.40Counter ControlRegister (Pulse WidthModulation)

| Bit(s)   | FUNCTION                                   |                                     |               |
|----------|--------------------------------------------|-------------------------------------|---------------|
| 2,1,0    | Specifies the Counter Mode:                |                                     |               |
|          | 010                                        | Pulse Width Modula                  | tion          |
| 3        | Output Polarity (Output Pin ACTIVE Level): |                                     | CTIVE Level): |
|          | 0                                          | Active LOW (Default                 | )1            |
|          | 1                                          | Active HIGH                         |               |
| 5, 4     | CNT InA                                    | Polarity / Gate-Off Po              | plarity       |
|          | 00                                         | Disabled (Default)                  |               |
|          |                                            | Active LOW                          |               |
|          | 01                                         | In A=0 Counter is                   | Enabled       |
|          |                                            | In A=1 Counter is                   | Disabled      |
|          |                                            | Active HIGH                         |               |
|          | 10                                         | In A=0 Counter is                   | Disabled      |
|          |                                            | In A=1 Counter is                   | Enabled       |
|          | 11                                         | Disabled                            |               |
| 7, 6     | Not Use                                    | lot Used                            |               |
| 9,8      | CNT InC                                    | CNT InC Polarity / External Trigger |               |
|          | 00                                         | Disabled (Default)                  |               |
|          | 01                                         | Active LOW External                 |               |
|          | 10                                         | Active HIGH Externa                 | l Trigger     |
|          | 11                                         | Disabled                            |               |
| 12,11,10 | Clock Enable Frequency                     |                                     |               |
|          | 000                                        | Internal (Default)                  | 1.953125MHz   |
|          | 001                                        | Internal                            | 3.90625MHz    |
|          | 010                                        | Internal                            | 7.8125MHz     |
|          | 011                                        | Internal                            | 15.625MHz     |
|          | 100                                        | Internal                            | 62.5MHz       |
|          | 101                                        | Undefined                           | N/A           |
|          | 110                                        | Undefined                           | N/A           |
|          | 111                                        | Undefined                           | N/A           |
| 15,14,13 | Not Use                                    | ed                                  |               |

#### Watchdog Timer Operation

The watchdog operation counts down from a programmed (Counter Constant A) value until it reaches 0. While counting, the counter output will be in its active state (the output polarity is programmable). Upon time-out, the counter output will return to its inactive state, and an optional interrupt may be generated. Watchdog operation is selected by setting Counter Control Register bits 2 to 0 to logic "011".

A timed-out watchdog timer will not re-cycle until it is reloaded and then followed with a new trigger. Failure to cause a reload would generate an automatic time-out upon re-triggering, since the counter register will contain the 0 it previously counted down to.

CNT InA input can be used to reload the counter with the Constant A register value. CNT InA reload input is enabled via Control register bits 5 and 4. The counter can also be reloaded via a software write to the Counter Constant A register. Writing to the Counter Constant A register will load the value directly into the counter even if watchdog counting is actively counting down.

CNT InC can be used to either continue/stop watchdog counting or as an external trigger input. When control register bits 9 and 8 are set to logic "11", CNT InC functions as a Continue/Stop signal. When the Continue/Stop signal is high the counter continues counting (when low the counter stops counting). Alternately, when control register bits 9 and 8 are set to logic "01" or "10", the CNT InC input functions as an external trigger input. The watchdog timer may also be internally triggered via the Trigger Control Register.

When triggered, the counter/timer contents are decremented by one for each clock cycle, until it reaches 0, upon which a watchdog timer time-out occurs. For example, a counter constant value of 30 will provide a time-out delay of 30 clock cycles of the selected clock. However, due to the asynchronous relationship between the trigger and the selected clock, one clock cycle of error can be expected. The counter can be read from the Counter Readback register at any time during watchdog operation.

Upon time-out, the counter output pin returns to its inactive state. The Counter/Timer Module will also issue an interrupt upon detection of a count value equal to 0, if enabled via the Interrupt Enable/Disable Register. This could be useful for alerting the host that a watchdog timer time-out has occurred and may need to be reinitialized. The interrupt will remain pending until the watchdog timer is reinitialized and the interrupt is released by setting the required bit of the Counter/Timer Interrupt Status/Clear register.

## Table 4.41 Counter ControlRegister (Watchdog Timer)

| Bit(s)   | FUNCTI                                     | ON                                 |                         |
|----------|--------------------------------------------|------------------------------------|-------------------------|
| 2,1,0    | Specifies the Counter Mode:                |                                    |                         |
|          | 011                                        | Watchdog Function                  |                         |
| 3        | Output Polarity (Output Pin ACTIVE Level): |                                    |                         |
|          | 0                                          | Active LOW (Default) <sup>2</sup>  | 1                       |
|          | 1                                          | Active HIGH                        |                         |
| 5,4      |                                            | Polarity / Counter Rele            | oad                     |
|          | 00                                         | Disabled (Default)                 |                         |
|          |                                            | Active LOW                         |                         |
|          | 01                                         | In A=0 Counter Re                  | initialized             |
|          |                                            | In A=1 Inactive Sta                | ite                     |
|          |                                            | Active HIGH                        |                         |
|          | 10                                         | In A=0 Inactive Sta                | ate                     |
|          |                                            | In A=1 Counter Re                  | initialized             |
|          | 11                                         | Disabled                           |                         |
| 7,6      | Not Use                                    | Not Used                           |                         |
| 9,8      | CNT InC                                    | NT InC Polarity / External Trigger |                         |
|          | 00                                         | Disabled (Default)                 |                         |
|          | 01                                         | Active LOW Trigger                 |                         |
|          | 10                                         | Active HIGH Trigger                |                         |
|          | 11                                         | Gate-Off (Continue w               | hen high/Stop when low) |
| 12,11,10 | Clock Enable Frequency                     |                                    |                         |
|          | 000                                        | Internal (Default)                 | 1.953125MHz             |
|          | 001                                        | Internal                           | 3.90625MHz              |
|          | 010                                        | Internal                           | 7.8125MHz               |
|          | 011                                        | Internal                           | 15.625MHz               |
|          | 100                                        | Internal                           | 62.5MHz                 |
|          | 101                                        | Undefined                          | N/A                     |
|          | 110                                        | Undefined                          | N/A                     |
|          | 111                                        | Undefined                          | N/A                     |
| 15,14,13 | Not Use                                    | ed                                 |                         |

#### **Event Counting Operation**

Positive or negative polarity events can be counted. Event Counting is selected by setting Counter Control Register bits 2 to 0 to logic "100" and setting bits 12 to 10 to logic "000".

Input pulses or events occurring at the input CNT InB of the counter will increment the counter until it reaches the Counter Constant A value. Upon reaching the count limit, an output pulse of 1.74µs will be generated at the counter output pin, and an optional interrupt may be generated. Additionally, the internal event counter is cleared. The counter will continue counting, again from 0, until it reaches the Counter Constant A value. Once triggered, event counting will continue until disabled via Control register bits 2 to 0.

CNT InA can be used as a Gate-Off signal to stop and start event counting, or as an active high hardware load of the Read Back Register signal. When CNT InA is enabled via bits 5 and 4 of the control register for active low Gate-Off input, a logic low input will enable event counting while a logic high will stop event counting. When CNT InA is enabled for active high Gate-Off operation, a logic high will enable event counting while a logic low will stop event counting. When CNT InA is enabled for hardware load of the Read Back Register, an active high signal will cause load of the Read Back Register and an interrupt will be generated (if interrupts are enabled). The Read Back Register can also be loaded by software via the Load Read Back Register.

CNT InB is used as the event input signal. Active high or low input events can be selected via Control register bits 7 and 6. A minimum event pulse width (CNT InB) of 30ns is required for correct pulse detection with input debounce disabled. Programmable clock selection is not required in event counter mode.

CNT InC can be used to either control up/down counting or as an external trigger input. When control register bits 9 and 8 are set to logic "11", CNT InC functions as an Up/Down signal. When the Up/Down signal is high the counter is in the count down mode (when low the counter counts up). The counter will not count down below a count of zero. Alternately, when control register bits 9 and 8 are set to logic "01" or "10", the CNT InC input functions as an external trigger input. Event counting may also be internally triggered via the Trigger Control Register.

The Counter Constant A Register holds the count-to value (constant). Reading the Counter Read Back Register will return the current count (variable). **The Counter Constant A value must not be left as 0**. The counter upon trigger starts counting from 0 and since the counter would match the count-to value the counter resets and starts counting from zero again.

If interrupts are enabled via the Enable/Disable Interrupts Register, an interrupt is generated when the number of input pulse events is equal to

the Counter Constant A register value. The internal counter is then cleared and will continue counting events until the counter constant A value is again reached and a new interrupt generated. An interrupt will remain pending until released by setting the required bit of the Counter's Interrupt Status/Clear register.

Table 4.42 Counter ControlRegister (Event Counting)

| Bit(s)   | FUNCTION                                    |                                                               |
|----------|---------------------------------------------|---------------------------------------------------------------|
| 2,1,0    | Specifie                                    | es the Counter Mode:                                          |
|          | 100                                         | Event Counting                                                |
| 3        | Output                                      | Polarity (Output Pin ACTIVE Level):                           |
|          | 0                                           | Active LOW (Default) <sup>1</sup>                             |
|          | 1                                           | Active HIGH                                                   |
| 5, 4     | CNT InA                                     | Polarity / Gate-Off                                           |
|          | 00                                          | Disabled (Default)                                            |
|          |                                             | Active LOW                                                    |
|          | 01                                          | In A=0: Continue Counting                                     |
|          |                                             | In A=1: Stop Counting                                         |
|          |                                             | Active HIGH                                                   |
|          | 10                                          | In A=0: Stop Counting                                         |
|          |                                             | In A=1: Continue Counting                                     |
|          | CNT InA Hardware Capture Count ModeDisabled |                                                               |
|          | 11                                          | InA = logic high pulse: Causes load of the Read Back register |
| 7,6      | CNT InB Polarity / Event Input              |                                                               |
|          | 00                                          | Disabled (Default)                                            |
|          | 01                                          | Active LOW Events                                             |
|          | 10                                          | Active HIGH Events                                            |
|          | 11                                          | Disabled                                                      |
| 9,8      | CNT InC                                     | 2 Polarity / External Trigger                                 |
|          | 00                                          | Disabled (Default)                                            |
|          | 01                                          | Active LOW Trigger                                            |
|          | 10                                          | Active HIGH Trigger                                           |
|          | 11                                          | Count Up when logic low /Down when logic high                 |
| 12,11,10 | Specifies the Counter Mode:                 |                                                               |
|          | 000                                         | Event Counting                                                |
| 15,14,13 | Not Use                                     | ed                                                            |

#### **Frequency Measurement Operation**

Frequency Measurement is selected by setting Counter Control Register bits 2 to 0 to logic "100" and setting bits 12 to 10 to logic "111". The counter counts how many CNT InB edges (low to high or high to low) are received during the CNT InA enable interval. The frequency is the number of counts divided by the duration of the CNT InA enable signal.

CNT InA is used as an enable signal to start frequency measurement. The CNT InA signal must be a pulse of known width. When CNT InA is configured (via bits 5 and 4 of the control register) as an active low enable input, a logic low input will enable frequency measurement while a logic high will stop frequency measurement. When CNT InA is configured as an active high enable signal, a logic high will enable frequency measurement while a logic low will stop frequency measurement.

CNT InB is used to input the signal whose frequency is to be measured. Input pulses occurring at input CNT InB of the counter are counted while the enable signal present on CNT InA is active. When the CNT InA signal goes inactive, the counter output will generate a 1.74 $\mu$ s output pulse and an optional interrupt.

CNT InC can be used as an external trigger input. When control register bits 9 and 8 are set to logic "01" or "10", the CNT InC input functions as an external trigger input. Frequency measurement may also be internally triggered via the Trigger Control Register. An initial trigger, software or external, starts frequency measurement upon the active edge of the CNT InA enable signal.

The Counter Constant A Register is not used for frequency measurement. Do not write to this register while the counter is actively counting since this will cause the counter to be loaded with the Constant A value.

Reading the Counter Read Back Register will return the current count (variable). A minimum event pulse width (30ns CNT InB) is required for correct pulse detection with input debounce disabled. With debounce enabled, a minimum event pulse width of 2.4µs is required for correct pulse detection. Programmable clock selection is not available for frequency measurement.

If interrupts are enabled via the Enable/Disable Interrupts Register, an interrupt is generated when the input CNT InA enable pulse goes inactive. An interrupt will remain pending until released by setting the required bit of the Interrupt Status/Clear register.

#### Table 4.43 Counter Control Register (Frequency Measurement)

| Bit(s)   | FUNCTI                                     | ON                                     |
|----------|--------------------------------------------|----------------------------------------|
| 2,1,0    | Specifies the Counter Mode:                |                                        |
|          | 100                                        | Frequency Measurement                  |
| 3        | Output                                     | Polarity (Output Pin ACTIVE Level):    |
|          | 0                                          | Active LOW (Default) <sup>1</sup>      |
|          | 1                                          | Active HIGH                            |
| 5, 4     | CNT InA                                    | Polarity / Enable Pulse of Known Width |
|          | 00                                         | Disabled (Default)                     |
|          | 01                                         | Active LOW Pulse                       |
|          | 10                                         | Active HIGH Pulse                      |
|          | 11                                         | Disabled                               |
| 7,6      | CNT InB Polarity / Signal Measured/Counted |                                        |
|          | 00                                         | Disabled (Default)                     |
|          | 01                                         | Active LOW Pulse Counted               |
|          | 10                                         | Active HIGH Pulse Counted              |
|          | 11                                         | Disabled                               |
| 9,8      | CNT InC                                    | Polarity / External Trigger            |
|          | 00                                         | Disabled (Default)                     |
|          | 01                                         | Active LOW Trigger                     |
|          | 10                                         | Active HIGH Trigger                    |
|          | 11                                         | Disabled                               |
| 12,11,10 | Specifies the Counter Mode:                |                                        |
|          | 111                                        | Frequency Measurement                  |
| 15,14,13 | Not Use                                    | ed                                     |

#### **Input Pulse Width Measurement**

Setting bits 2 to 0 of the Counter Control Register to logic "101" configures the counter for pulse-width measurement. After pulse-width measurement is triggered, the first input pulse is measured.

CNT InA is used to input the pulse to be measured. An active low or high pulse can be measured.

CNT InC can be used to externally trigger Pulse Width Measurement. Additionally, Pulse Width Measurement can be triggered internally via the Counter Trigger Register. An initial trigger, software or external, starts pulse width measurement at the beginning of the next active pulse.

For pulse-width measurement, the pulse-width being measured serves as an enable control for an up-counter whose value can be read from the Counter Read Back Register. When triggered, the counter is reset and then increments by one for each clock pulse while the input signal level remains in the active state (high or low according to the programmed polarity of input CNT InA). The resultant pulse-width is equivalent to the count value read from the Counter Read Back Register, multiplied by the clock period. An output pulse will be generated at the counter output pin to signal the completion of a given measurement. Note that the measured pulse may be in error by  $\pm 1$  clock cycle.

Reading a counter value of 0xFFFFFFF hex indicates that the pulse duration is longer than the current counter size and clock frequency can measure. Upon reading of this overflow value, you must select a slower frequency and re-measure.

An interrupt can be generated upon completion of a given pulse width measurement (the pulse has returned to the opposite polarity), if enabled via the interrupt Enable/Disable Register. The interrupt will remain pending until released by setting the required bit of the Interrupt Status/Clear register.

# Table 4.44 Counter ControlRegister (Pulse WidthMeasurement)

| Bit(s)    | FUNCT                       | ON                                 |             |
|-----------|-----------------------------|------------------------------------|-------------|
| 2,1,0     | Specifies the Counter Mode: |                                    |             |
|           | 101                         | Pulse-Width Measuremer             | nt          |
| 3         | Output                      | Polarity (Output Pin ACTIV         | E Level):   |
|           | 0                           | Active LOW (Default) <sup>1</sup>  |             |
|           | 1                           | Active HIGH                        |             |
| 5, 4      | CNT In/                     | A Polarity / Pulse Polarity to     | be Measured |
|           | 00                          | Disabled (Default)                 |             |
|           | 01                          | Active LOW Pulse is Meas           | ured        |
|           | 10                          | Active HIGH Pulse is Meas          | sured       |
|           | 11                          | Disabled                           |             |
| 7,6       | Not Used                    |                                    |             |
| 9,8       | CNT In(                     | <u>Polarity / External Trigger</u> |             |
|           | 00                          | Disabled (Default)                 |             |
|           | 01                          | Active LOW Trigger                 |             |
|           | 10                          | Active HIGH Trigger                |             |
|           | 11                          | Disabled                           |             |
| 12,11,10  | Clock E                     | nable Frequency                    |             |
|           | 000                         | Internal(Default)                  | 1.953125MHz |
|           | 001                         | Internal                           | 3.90625MHz  |
|           | 010                         | Internal                           | 7.8125MHz   |
|           | 011                         | Internal                           | 15.625MHz   |
|           | 100                         | Internal                           | 62.5MHz     |
|           | 101                         | Undefined                          | N/A         |
|           | 110                         | Undefined                          | N/A         |
|           | 111                         | Undefined                          | N/A         |
| 15, 14,13 | Not Use                     | ed                                 |             |

#### **Input Period Measurement**

The counter/timer may be used to measure the period of an input signal at the counter input CNT InA. Setting bits 2 to 0 of the Counter Control Register to logic "110" configures the counter for period measurement. The first input cycle after period measurement is triggered will be measured.

CNT InA is used to input the signal to be measured. Period measurement can be initiated on the active low or high portion of the waveform. The period of signal is the time the signal is low added to the time the signal is high, before it repeats.

CNT InC can be used to externally trigger period measurement. Additionally, Period Measurement can be triggered internally via the Counter Trigger Register. An initial trigger, software or external, starts period measurement at the beginning of the next active period.

The period being measured serves as an enable control for an up-counter whose value can be read from the Counter Read Back Register. When triggered the counter is reset. Then, the active polarity of CNT InA starts period measurement. The counter increments by one for each clock pulse during the input signal period (CNT InA). The resultant period is equivalent to the count value read from the Counter Read Back Register, multiplied by the clock period. A 1.728µs output pulse will be generated at the counter output pin to signal the completion of a given measurement. Note that the measured period may be in error by +1 clock cycle (16ns).

Reading a counter value of 0xFFFFFFF hex indicates that the pulse duration is longer than the current counter size and clock frequency can measure. Upon reading of this overflow value, you must select a slower frequency and re-measure.

An interrupt can be generated upon completion of a given period measurement, if enabled via the Interrupt Enable/Disable Register. The interrupt will be generated upon completion of the first complete waveform cycle after the counter is triggered. The interrupt, once driven active, will remain pending until released by setting the required bit of the Interrupt Status/Clear register.

# Table 4.45 Counter ControlRegister (PeriodMeasurement)

| Bit(s)   | FUNC                                | TION                     |                  |
|----------|-------------------------------------|--------------------------|------------------|
| 2,1,0    | Specifies the Counter Mode:         |                          |                  |
| , ,      | 110                                 | Period Measurement       |                  |
| 3        | Outpu                               | t Polarity (Output Pin / | ACTIVE Level):   |
|          | 0                                   | Active LOW (Default)     |                  |
|          | 1                                   | Active HIGH              |                  |
| 5, 4     | CNT Ir                              | A Polarity / Signal Mea  | asured           |
|          | 00                                  | Disabled (Default)       |                  |
|          | 01                                  | Active LOW starts pe     | riod measurement |
|          | 10                                  | Active HIGH starts pe    | riod measurement |
|          | 11                                  | Disabled                 |                  |
| 7,6      | Not U                               | sed                      |                  |
| 9,8      | CNT InC Polarity / External Trigger |                          | rigger           |
|          | 00                                  | Disabled (Default)       |                  |
|          | 01                                  | Active LOW Trigger       |                  |
|          | 10                                  | Active HIGH Trigger      |                  |
|          | 11                                  | Disabled                 |                  |
| 12,11,10 | Clock Enable Frequency              |                          |                  |
|          | 000                                 | Internal(Default)        | 1.953125MHz      |
|          | 001                                 | Internal                 | 3.90625MHz       |
|          | 010                                 | Internal                 | 7.8125MHz        |
|          | 011                                 | Internal                 | 15.625MHz        |
|          | 100                                 | Internal                 | 62.5MHz          |
|          | 101                                 | Undefined                | N/A              |
|          | 110                                 | Undefined                | N/A              |
|          | 111                                 | Undefined                | N/A              |
| 15,14,13 | Not U                               | sed                      |                  |

#### **One-Shot Pulse Mode**

One-Shot pulse mode provides an output pulse that is asserted one time or repeated each time it is re-triggered. One-Shot generation is selected by setting Counter Control Register bits 2 to 0 to logic "111".

The Counter Constant A value controls the time until the pulse goes active. The duration of the pulse high or low is set via the Counter Constant B value. Note that the Constant B value defines the logic high pulse width, if active high output is selected, and a low pulse if active low output is selected.

The counter goes through a full countdown sequence for each Counter Constant value. When the 0 count is detected, on the next rising-edge of the clock, the output toggles to the opposite state, and the Counter Constant B value is loaded into the counter and countdown resumes, decrementing by one each clock cycle. For example, a counter constant value of 7 will provide a pulse duration of 7 clock cycles of the selected clock, then 16ns will be added for the count detection of 0.

CNT InA can be used as a Gate-Off signal to stop and start the counter and, thus output. When CNT InA is enabled via bits 5 and 4 of the control register for active low Gate-Off input, a logic low input will enable the one-shot counter while a logic high will stop the one-shot counter. When CNT InA is enabled for active high Gate-Off operation, a logic high will enable the one-shot counter while a logic low will stop the one-shot counter.

CNT InC can be used to externally trigger One-Shot pulse mode. Additionally, a one-shot pulse can be triggered internally via the Counter Trigger Register. An initial trigger, software or external, causes the one-shot signal to be generated with no additional triggers required. Additional triggers must not be input until the one-shot pulse has completed count down of the Constant B value.

If interrupts are enabled via the Enable/Disable Interrupts Register, an interrupt is generated when the pulse transitions from low to high and also when the pulse transitions from high to low. The interrupt will remain pending until released by setting the required bit of the Interrupt Status/Clear register.

## Table 4.46 Counter ControlRegister (One-Shot Mode)

| Bit(s)   | FUNCTION                                   |                                     |             |
|----------|--------------------------------------------|-------------------------------------|-------------|
| 2,1,0    | Specifies the Counter Mode:                |                                     |             |
|          | 111                                        | <b>One-Shot Generation</b>          |             |
| 3        | Output Polarity (Output Pin ACTIVE Level): |                                     |             |
|          | 0                                          | Active LOW (Default) <sup>1</sup>   | L           |
|          | 1                                          | Active HIGH                         |             |
| 5,4      | CNT InA                                    | Polarity / Gate-Off Pol             | arity       |
|          | 00                                         | Disabled (Default)                  |             |
|          |                                            | Active LOW                          |             |
|          | 01                                         | In A=0 Output Ena                   | bled        |
|          |                                            | In A=1 Output Disa                  | abled       |
|          |                                            | Active HIGH                         |             |
|          | 10                                         | In A=0 Output Disa                  | abled       |
|          |                                            | In A=1 Output Ena                   | bled        |
|          | 11                                         | Disabled                            |             |
| 7,6      | Not Use                                    | ed                                  |             |
| 9,8      | CNT InC                                    | CNT InC Polarity / External Trigger |             |
|          | 00                                         | Disabled (Default)                  |             |
|          | 01                                         | Active LOW Trigger                  |             |
|          | 10                                         | Active HIGH Trigger                 |             |
|          | 11                                         | Disabled                            |             |
| 12,11,10 | Clock Enable Frequency                     |                                     |             |
|          | 000                                        | Internal (Default)                  | 1.953125MHz |
|          | 001                                        | Internal                            | 3.90625MHz  |
|          | 010                                        | Internal                            | 7.8125MHz   |
|          | 011                                        | Internal                            | 15.625MHz   |
|          | 100                                        | Internal                            | 62.5MHz     |
|          | 101                                        | Undefined                           | N/A         |
|          | 110                                        | Undefined                           | N/A         |
|          | 111                                        | Undefined                           | N/A         |
| 15,14,13 | Not Use                                    | ed                                  |             |

#### Counter Interrupt Information Register (Read Only) - (BAR0 + 0x0000 7078)

This read only register provides information on what type of interrupt has been generated. This is useful for Quadrature Position Measurement and Event Counting, as it is possible to have more than one interrupt condition in these modes. Each bit position is representative of an interrupt condition. The interrupt conditions for each of the bits can be seen in Table 4.47 below. A "1" indicates that the interrupt condition represented by that bit has occurred. The bit will remain a "1" until the pending interrupt is cleared by writing a "1" to the corresponding bit in the Interrupt Pending/Clear Register.

A power-up or system reset clears the Counter Interrupt Information Register, setting all bits to "0".

### Table 4.47 Counter InterruptInformation Register

Note that any registers/bits not mentioned will remain at the default value logic low.

| BIT  | FUNCTION                                                                                                                      |
|------|-------------------------------------------------------------------------------------------------------------------------------|
| 0    | Counter equal to value in Counter Constant A Register<br>(available in Event Counting and Quadrature Position<br>Measurement) |
| 1    | Read Back Register has been loaded by hardware (available in Event Counting and Quadrature Position Measurement)              |
| 2    | Index Pulse (available in Quadrature Position Measurement)                                                                    |
| 3    | High to Low or Low to High Transitions (available in Pulse<br>Width Modulation or One-Shot Pulse Mode)                        |
| 4    | End of Measurement (available in Frequency Measurement,<br>Input Period Measurement, or Input Pulse Width<br>Measurement)     |
| 5    | Time Out (available in Watchdog Timer)                                                                                        |
| 31-6 | Not Used                                                                                                                      |

#### Counter Read Back Register (Read Only) - (BAR0 + 0x0000 707C)

This read-only register is a dynamic function register that returns the current value held in the counter. It is updated with the value stored in the internal counter each time a hardware or software load of the Read Back Register is implemented.

The internal counter is generally initialized with the value in the Counter Constant Register, and its value is incremented or decremented according to the application.

This register must be read using 32-bit accesses.

#### Counter Constant A Register 1 (Read/Write) - (BAR0 + 0x0000 7080)

Note that the Counter ConstantThis read/write register is used to store the counter/timer constant A valueRegisters are cleared (set to 0)(initial value) for the various counting modes. It is necessary to load the

following a system or softwareconstant value into the counter in one clock cycle. Thus, access to thisreset.register is allowed on a 32-bit basis, only.

The contents of the Counter Constant A Register 1 and Counter Constant A Register 2 can be toggled for the counter/timers. Writing a "1" to the counter's corresponding toggle counter constants bit will cause the counter to use the values in Counter Constant A Register 2. Writing a "0" will cause the counter to use the values in Counter Constant A Register 1. By default, a counter will always use the values in Counter Constant A Register 1.

#### Counter Constant A Register 2 (Read/Write) - (BAR0 + 0x0000 7084)

Note that the Counter Constant<br/>Registers are cleared (set to 0)<br/>following a system or software<br/>reset.This read/write register is used to store the counter/timer constant A<br/>register 2 value (initial value) for the various counting modes. It is necessary<br/>to load the constant value into the counter in one clock cycle. Thus, access<br/>to this register is allowed on a 32-bit basis, only.The contents of the Counter Constant A<br/>Persister 1 and Counter Constant A

The contents of the Counter Constant A Register 1 and Counter Constant A Register 2 can be toggled for the counter/timers. Writing a "1" to the counter's corresponding toggle counter constants bit will cause the counter to use the values in Counter Constant A Register 2. Writing a "0" will cause the counter to use the values in Counter Constant A Register 1. By default, a counter will always use the values in Counter Constant A Register 1.

#### Counter Constant B Register 1 (Read/Write) - (BAR0 + 0x0000 7088)

| Note that the Counter Constant   | This read/write register is used to store the counter/timer constant B    |
|----------------------------------|---------------------------------------------------------------------------|
| Registers are cleared (set to 0) | Register 1 value (initial value) for the various counting modes. It is    |
| following a system or software   | necessary to load the constant value into the counter in one clock cycle. |
| reset.                           | Thus, access to this register is allowed on a 32-bit basis, only.         |
|                                  |                                                                           |

The contents of the Counter Constant B Register 1 and Counter Constant B Register 2 can be toggled for the counter/timers. Writing a "1" to the counter's corresponding toggle counter constants bit will cause the counter to use the values in Counter Constant B Register 2. Writing a "0" will cause the counter to use the values in Counter Constant B Register 1. By default, a counter will always use the values in Counter Constant B Register 1.

#### Counter Constant B Register 2 (Read/Write) - (BAR0 + 0x0000 708C)

Note that the Counter Constant Registers are cleared (set to 0) following a system or software reset. This read/write register is used to store the counter/timer constant B register 2 value (initial value) for the various counting modes. It is necessary to load the constant value into the counter in one clock cycle. Thus, access to this register is allowed on a 32-bit basis, only.

The contents of the Counter Constant B Register 1 and Counter Constant B Register 2 can be toggled for the counter/timers. Writing a "1" to the

counter's corresponding toggle counter constants bit will cause the counter to use the values in Counter Constant B Register 2. Writing a "0" will cause the counter to use the values in Counter Constant B Register 1. By default, a counter will always use the values in Counter Constant B Register 1.

#### ADC Offset Register (Read/Write) - (BAR0 + 0x70A0 to 0x70DC)

The offset register is a 16-bit 2's complement fractional number ranging from -128 to 127.99609375 weighted as shown in the table below. This offset number is added to the uncorrected ADC value to correct for offset errors.

All channels 0 to 15 have a unique offset register. Each ADC channel can be programmed for any one of the 7 available ADC ranges. The offset value corresponding to the range and channel selected must be read from Flash memory and then written to its corresponding ADC offset channel register.

Channel 0 to Channel 7 coefficients start at 0xFF F800 to 0xFF F9BF as shown in <u>Table 7.2</u>.

Channel 8 to Channel 15 coefficients start at 0xFF F9C0 to 0xFF FB7F and are also shown in Table 7.2.

For example, if Channel 3 is programmed for the 0 to 10.24 VDC unipolar range then the offset stored in Flash at 0xFF F8C8 must be read and then written to BAR0 + 0x70AC.

Flash Memory

| 0xFF F8CB | Channels 3 (0 to 10.24V)             | 0xFF F8C8 |
|-----------|--------------------------------------|-----------|
|           | Offset Coefficients (2's complement) |           |

#### ADC Channel 3 Offset Register

| 0x0000 70AC | 15:0 | ADC Channel 3 Offset |
|-------------|------|----------------------|
|-------------|------|----------------------|

Note that the coefficients are stored as 2's complement format for this unipolar example. All bipolar ranges are also stored as 2's complement to allow use of plus and minus values. The offset register value is added to the output value from the ADC to correct offset errors.

The offset registers are set to zero upon reset of the board so that uncorrected ADC values may be stored in the FIFO.

### Table 4.48 Offset Constant

**Number Formant** 

| BIT | Binary Fixed Point |
|-----|--------------------|
| 15  | Sign bit -128      |
| 14  | 64                 |
| 13  | 32                 |
| 12  | 16                 |
| 11  | 8                  |
| 10  | 4                  |
| 9   | 2                  |
| 8   | 1                  |
| 7   | 1/2                |
| 6   | 1⁄4                |
| 5   | 1/8                |
| 4   | 1/16               |
| 3   | 1/32               |
| 2   | 1/64               |
| 1   | 1/128              |
| 0   | 1/256              |

#### ADC Gain Register (Read/Write) - (BAR0 + 0x70E0 to 0x711C)

The gain register is a 17-bit fixed point positive fractional number ranging from 0 to 1.999984 weighted as shown in the table below. The 17-bit fixed point number is least significant bit justified in a 32-bit register. This number is multiplied by the offset corrected ADC value to correct for gain errors.

All channels 0 to 15 have a unique gain register. Each ADC channel can be programmed for any one of the 7 available ADC ranges. The gain value corresponding to the range and channel selected must be read from Flash memory and then written to its corresponding ADC Gain register.

Channel 0 to Channel 7 coefficients start at 0xFF F800 to 0xFF F9BF as shown in <u>Table 7.2</u>.

Channel 8 to Channel 15 coefficients start at 0xFF F9C0 to 0xFF FB7F and are also shown in Table 7.2.

For example, if Channel 3 is programmed for the 0 to 10.24 VDC unipolar range then the Gain Coefficient stored in Flash at 0xFF F8CC must be read and then written to BAR0 + 0x70EC.

Flash Memory

| 0xFF F8CF | Channel 3 (0 to 10.24V)           | 0xFF F8CC |
|-----------|-----------------------------------|-----------|
|           | Gain Coefficient (2's complement) |           |

ADC Channel 3 Gain Register

| <b>0x0000 70EC</b> 17:0 | ADC Channel 3 Gain |
|-------------------------|--------------------|
|-------------------------|--------------------|

Gain correction values must be loaded from the flash to correct new ADC data. The gain registers are set to one upon reset of the board so that uncorrected ADC values may be stored in the FIFO.

### Table 4.49 Gain ConstantNumber Formant

| BIT     | Binary Fixed Point  |  |
|---------|---------------------|--|
| 31 – 17 | (unused, read as 0) |  |
| 16      | 1                   |  |
| 15      | γ <sub>2</sub>      |  |

| BIT | Binary Fixed Point |
|-----|--------------------|
| 14  | 1/4                |
| 13  | 1/8                |
| 12  | 1/16               |
| 11  | 1/32               |
| 10  | 1/64               |
| 9   | 1/128              |
| 8   | 1/256              |
| 7   | 1/512              |
| 6   | 1/1024             |
| 5   | 1/2048             |
| 4   | 1/4096             |
| 3   | 1/8192             |
| 2   | 1/16536            |
| 1   | 1/32768            |
| 0   | 1/65536            |

#### **Flash Memory**

The Serial flash memory provides non-volatile memory for storing the FPGA configuration bitstream. The lower portion of the flash address space is used to store the FPGA configuration bitstream. The upper portion is available for general non-volatile / program storage. The flash device is Cypress Semiconductor part number S25FL128S or equivalent.

#### Flash Data Register (Read/Write) - (BAR0 + 0x0000 7204)

A byte write to this address triggers a write/read serial transfer to/from the serial FLASH device. A byte read from this address returns the data read from a previous write/read serial transfer.

WARNING: Factory calibration data is stored in FLASH. Writing to FLASH could result in loss of factory calibration data. See Tables 7.1, 7.2, and 7.3 Flash Memory Maps.

Note that the Flash chip select must be set prior to the start of any instruction. Flash chip select must also be driven high (inactive) after the instruction is issued.

### Table 4.50Flash DataRegister

| BIT    | Function   |
|--------|------------|
| 31 - 8 | Unused     |
| 7 - 0  | Flash Data |

Note that any registers/bits not used will remain at the default value logic low.

Flash Chip Select (Write Only) - (BAR0 + 0x0000 7208)

Asserting bit-0 to logic "0" drives the Flash chip select signal active. The default state of this bit is logic "1" which is the inactive state of the Flash chip select signal.

Note that the Flash chip select must be set prior to the start of a Flash memory instruction. Flash chip select must also be driven high after the instruction is issued.

#### **DAC Registers**

This section describes the AD5761 interface shown in Figure 4.2 "AD5761 DAC Converter Interface Block Diagram" that connects the AXI interface to the eight DAC converters and the sample memory that is shared among all eight channels. Each of the channels can be independently configured to operate in one of four modes: direct access, single burst, continuous, or FIFO mode. In either single burst, continuous, or FIFO mode, a channel sequencer retrieves samples from the sample memory and writes the sample data to its DAC. The portion of sample memory allocated to each channel is programmable. There are six channel specific registers per channel and three registers that affect all channels.

| BARO Base Addr+ | Bits | Register Description        |
|-----------------|------|-----------------------------|
| 0x0004_0000     | 31:0 | Channel 0 Start Address     |
| 0x0004_0004     | 31:0 | Channel 0 End Address       |
| 0x0004_0008     | 31:0 | Channel 0 FIFO              |
| 0x0004_000C     | 31:0 | Reserved                    |
| 0x0004_0010     | 31:0 | Channel 0 Control           |
| 0x0004_0014     | 31:0 | Channel 0 Status            |
| 0x0004_0018     | 31:0 | Channel 0 DAC Direct Access |
| 0x0004_001C     | 31:0 | Reserved                    |
| 0x0004_0020     | 31:0 | Channel 1 Start Address     |
| 0x0004_0024     | 31:0 | Channel 1 End Address       |
| 0x0004_0028     | 31:0 | Channel 1 FIFO              |
| 0x0004_002C     | 31:0 | Reserved                    |
| 0x0004_0030     | 31:0 | Channel 1 Control           |
| 0x0004_0034     | 31:0 | Channel 1 Status            |
| 0x0004_0038     | 31:0 | Channel 1 D/A Direct Access |
| 0x0004_003C     |      | Reserved                    |
| :               | ÷    | :                           |
| 0x0004_00E0     | 31:0 | Channel 7 Start Address     |

#### Table 4.51 DAC Registers

| BARO Base Addr+ | Bits | Register Description        |
|-----------------|------|-----------------------------|
| 0x0004_00E4     | 31:0 | Channel 7 End Address       |
| 0x0004_00E8     | 31:0 | Channel 7 FIFO              |
| 0x0004_00EC     | 31:0 | Reserved                    |
| 0x0004_00F0     | 31:0 | Channel 7 Control           |
| 0x0004_00F4     | 31:0 | Channel 7 Status            |
| 0x0004_00F8     | 31:0 | Channel 7 DAC Direct Access |
| 0x0004_00FC     | 31:0 | Reserved                    |
| :               | :    | :                           |
| 0x0004_01FF     | 31:0 | Reserved                    |
| 0x0004_0200     | 31:0 | <u>Control</u>              |
| 0x0004_0204     | 31:0 | <u>Timer Divider</u>        |
| 0x0004_0208     | 31:0 | Software Trigger            |
| 0x0004_020C     | 31:0 | Reserved                    |
| :               | :    | :                           |
| 0x0005_FFFC     | 31:0 | Reserved                    |
| 0x0006 0000     | 31:0 | Sample Memory               |
| :               | :    | :                           |
| 0X0007 FFFC     | 31:0 | Sample Memory               |





The Sample Memory is a dual-port memory that provides buffer space for storage of waveforms. It is organized as 64K 16-bit values. To meet varying application requirements, the portion of the sample memory allocated to each channel is configurable. DAC channels that output a static value, or channels that are not used, do not require any of the sample memory. Channels that output a repetitive waveform at a lower frequency require a larger portion of sample memory than a channel with higher frequency output. Channels that output a non-repetitive waveform will require a continuous stream of data from the host. For these channels, a portion of the sample memory may be configured as a FIFO to buffer the data stream. The host processor can directly read and write the sample memory concurrent with the channel sequencer reads.

The address offset used by the host processor to access sample memory is a byte address relative to PCI BAR0.

**Channel X Start Address** 

For channels configured in Single Burst mode, Continuous mode or FIFO mode, this register contains the start address in sample memory of the waveform to be written to the DAC. Addressing is relative to the first location in sample memory. A write to the Start Address register will also

initialize the hidden FIFO read and write pointers when the channel is configured in FIFO mode

Table 4.52 Channel X StartAddress

**Channel X End Address** 

| Bit(s) | Description   |
|--------|---------------|
| 15-0   | Start address |
| 31-16  | Reserved      |

For channels configured in Single Burst mode, Continuous mode, or FIFO mode, this register contains the end address in sample memory of the waveform to be written to the DAC. Addressing is relative to the first location in sample memory.

#### Table 4.53 Channel X End Address

| Bit(s) | Description |
|--------|-------------|
| 15-0   | End address |
| 31-16  | Reserved    |

#### **Channel X FIFO**

For channels configured in FIFO mode, write to this address to add one or two samples to the FIFO. A 32-bit write operation will write two samples, a 16-bit write operation adds one sample. Use the key hole feature of the DMA controller when the FIFO is the destination of the DMA transfer.

#### Table 4.54 Channel X FIFO

| Bit(s) | Description |
|--------|-------------|
| 15-0   | Sample 0    |
| 31-16  | Sample 1    |

#### **Channel X Control Resistor**

The channel specific control and status registers configure each channel's operating mode and trigger mode, and include a FIFO underflow flag clear function.

Table 4.55 Channel X Control Resistor

| BIT(s) | Description                            |
|--------|----------------------------------------|
|        | Operating mode:                        |
| 1-0    | 00-stopped<br>01-continuous<br>10-FIFO |
|        | 11-Single burst                        |

٦

|      | Trigger source:                                                                                                                                                                                                                                                               |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3-2  | 00-software                                                                                                                                                                                                                                                                   |
|      | 01-timer                                                                                                                                                                                                                                                                      |
|      | 10-external                                                                                                                                                                                                                                                                   |
| 4    | When set, clear channel:<br>Start Address Register is cleared to 0<br>End Address Register is cleared to 0<br>Internal Read Pointer is cleared to 0<br>Internal Write Pointer is cleared to 0<br>FIFO Empty Flag is set = 1<br>FIFO half full is set = 1<br>FIFO full set = 0 |
| 31-5 | Reserved                                                                                                                                                                                                                                                                      |

#### **Channel X Status Resistor**

The channel specific status registers indicate the mode dependent status of each channel.

Т

| Table  | 4.56 | Channel | X | Status |
|--------|------|---------|---|--------|
| Resist | or   |         |   |        |

| BIT(s) | FUNCTION                                                                                                                                     |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | FIFO empty (read only)<br>0- FIFO not empty<br>1- FIFO empty                                                                                 |
|        | FIFO half full (read only):                                                                                                                  |
| 1      | 0-FIFO is more than half full<br>1-FIFO is half full or less                                                                                 |
|        | FIFO full (read only):                                                                                                                       |
| 2      | 0-FIFO is not full<br>1-FIFO is full                                                                                                         |
|        | FIF0 underflow (write to reset):                                                                                                             |
| 3      | 0-underflow has not occured<br>1-an attempt was made to read from an empty FIFO                                                              |
|        | Write '1' to this bit to clear it.                                                                                                           |
|        | Burst Single Complete – (write to reset) this flag indicates<br>the last sample in the burst has been copied to the D/A data<br>register     |
| 4      | 0-burst in progress<br>1-burst complete                                                                                                      |
|        | Write '1' to this bit to clear it.                                                                                                           |
| 5      | Busy – (read only) when operating in direct access mode,<br>this bit indicates that a serial transfer to the D/A converter is<br>in progress |
|        | 0-not busy<br>1-busy                                                                                                                         |
| 31-6   | Reserved                                                                                                                                     |

#### **Channel X DAC Direct Access**

A write to this address issues a command to the DAC. The contents of the DAC Channel registers are serially transferred to their corresponding converter input buffer serially. This serial data transfer takes 1µs. Thus, a new write of the same DAC register can be performed no sooner than 1µs after the previous write. The Channel X Status register includes a bit to indicate the busy status of the write operation. The channel's Status busy bit will be set high upon initiation of a write operation and will remain high until the requested write operation has completed. New write accesses to the same DAC Channel register, should not be initiated unless its write busy status bit is low. Read of the DAC registers is not supported.

| BIT(s) | Description                                             |                                                                                                                                                                           |  |
|--------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15-0   | voltage data or control data depending on address bits. |                                                                                                                                                                           |  |
|        | Address                                                 | 4-bits                                                                                                                                                                    |  |
|        | 0000                                                    | No Operation                                                                                                                                                              |  |
|        | 0001                                                    | Write to input register (no DAC output update,<br>input register only written) a trigger is needed to<br>transfer the data from the input register to the<br>DAC register |  |
|        | 0010                                                    | Update DAC register from input register (Updates DAC output voltage)                                                                                                      |  |
|        | 0011                                                    | Write and Update DAC register (Updates the input register and DAC register without waiting for a trigger)                                                                 |  |
|        | 0100                                                    | Write to control register (see control register bit assignment below)                                                                                                     |  |
| 19-16  | 0101                                                    | No Operation                                                                                                                                                              |  |
|        | 0110                                                    | No Operation                                                                                                                                                              |  |
|        | 0111                                                    | <b>Software Data Reset</b> (Reset to zero scale,<br>midscale, or full scale as specified by PV1 and PV0<br>bits of control register)                                      |  |
|        | 1000                                                    | Reserved                                                                                                                                                                  |  |
|        | 1001                                                    | <b>Disable daisy-chain functionality</b> (executing this command tri-states unused SDO pin to save power)                                                                 |  |
|        | 1010                                                    | Not supported (Read input register)                                                                                                                                       |  |
|        | 1011                                                    | Not supported (Read DAC register)                                                                                                                                         |  |
|        | 1101                                                    | No operation                                                                                                                                                              |  |
|        | 1110                                                    | No operation                                                                                                                                                              |  |
|        | 1111                                                    | Software full reset (Device set to power up state,<br>output at GND and output buffer is powered<br>down)                                                                 |  |
| 20     | 0 (this bi                                              | t must be zero)                                                                                                                                                           |  |
| 31-21  | Reserved                                                |                                                                                                                                                                           |  |

#### Table 4.57 Channel X DAC Direct Access

| BIT(s) | Description                                                                                                                                                                                                                      |                                          |               |  |  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|---------------|--|--|
|        | Output Range (Software full reset is also issued when the output range is reconfigured.)                                                                                                                                         |                                          |               |  |  |
|        | 000                                                                                                                                                                                                                              | -10V to +10V                             |               |  |  |
|        | 001                                                                                                                                                                                                                              | 0V to +10V                               |               |  |  |
| 2.0    | 010                                                                                                                                                                                                                              | -5V to +5V                               |               |  |  |
| 2-0    | 011                                                                                                                                                                                                                              | 0V to +5V                                |               |  |  |
|        | 100                                                                                                                                                                                                                              | -2.5V to +7.5V                           |               |  |  |
|        | 101                                                                                                                                                                                                                              | -3V to +3V                               |               |  |  |
|        | 110                                                                                                                                                                                                                              | 0V to 16V Not Suppor                     |               |  |  |
|        | 111<br>Devuer vie                                                                                                                                                                                                                | OV to 20V Not Suppor                     | ted           |  |  |
|        | Power-up                                                                                                                                                                                                                         | voltage                                  |               |  |  |
|        | 00                                                                                                                                                                                                                               | Zero scale                               |               |  |  |
| 4,3    | 01                                                                                                                                                                                                                               | Mid scale                                |               |  |  |
|        | 10                                                                                                                                                                                                                               | Full scale                               |               |  |  |
|        | 11                                                                                                                                                                                                                               | Full scale                               |               |  |  |
| 5      | 0                                                                                                                                                                                                                                | Fixed at 0                               |               |  |  |
|        | Thermal S                                                                                                                                                                                                                        | hutdown alert                            |               |  |  |
| 6      | 0                                                                                                                                                                                                                                | Die temperature > 150C do not power down |               |  |  |
|        | 1                                                                                                                                                                                                                                | Die temperature > 150                    | 0C power down |  |  |
| 7      | Data Format Control Bit<br>When a channel is configured for 0-10 or 0-5 ranges, this bit<br>is ignored and anything written to the DAC is treated as<br>straight binary. See the table below for example<br>corresponding codes. |                                          |               |  |  |
|        | 0                                                                                                                                                                                                                                | Straight binary coded                    |               |  |  |
|        | 1                                                                                                                                                                                                                                | Twos complement coded                    |               |  |  |
|        | 5% Over-I                                                                                                                                                                                                                        | range                                    |               |  |  |
| 8      | 0                                                                                                                                                                                                                                | 5% over-range disabled                   |               |  |  |
|        | 1                                                                                                                                                                                                                                | 5% over-range enable                     | d             |  |  |
| 10.0   | Clear volt                                                                                                                                                                                                                       | Clear voltage selection                  |               |  |  |
| 10,9   | 00                                                                                                                                                                                                                               | Z                                        | ero scale     |  |  |

When the Write to Control register address (bits 19-16) is selected (0100) bits 0-15 are control register bit as described below.

|       | 01       | Mid scale  |
|-------|----------|------------|
|       | 10       | Full scale |
|       | 11       | Full scale |
| 15-11 | Not used |            |

Table 4.58 Data Format

| Straight Binary | Decimal Code | Twos Complement |
|-----------------|--------------|-----------------|
| 1111            | +7           | 0111            |
| 1110            | +6           | 0110            |
| 1101            | +5           | 0101            |
| 1100            | +4           | 0100            |
| 1011            | +3           | 0011            |
| 1010            | +2           | 0010            |
| 1001            | +1           | 0001            |
| 1000            | 0            | 0000            |
| 0111            | -1           | 1111            |
| 0110            | -2           | 1110            |
| 0101            | -3           | 1101            |
| 0100            | -4           | 1100            |
| 0011            | -5           | 1011            |
| 0010            | -6           | 1010            |
| 0001            | -7           | 1001            |
| 0000            | -8           | 1000            |

Control Register (Read/Write) - (BAR0 + 0x0004 0200)

This control register provides control functions that affect all channels.

#### **Table 4.59 Control Register**

| Bit(s) | Description                                                                           |
|--------|---------------------------------------------------------------------------------------|
| _      | Waveform Output Enable                                                                |
| 0      | 0-stop waveform output<br>1-start waveform output                                     |
|        | DAC reset                                                                             |
| 1      | 0-DAC normal operation<br>1-sets all outputs to ground output buffers<br>powered down |

|      | DAC clear                                                                                                                                       |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | 0-DAC normal operation<br>1-sets all DAC outputs to their pre-configured<br>value (zero-scale, mid-scale, full-scale) setup for<br>each channel |
|      | Trigger Direction                                                                                                                               |
| 3    | 0-accepts trigger input from an external source<br>1-outputs trigger to external devices                                                        |
|      | Software Reset                                                                                                                                  |
| 4    | 0-normal operation<br>1-resets the registers in the AD5721 interface                                                                            |
| 31-5 | Reserved                                                                                                                                        |

#### Timer Divider Register (Read/Write) - (BAR0 + 0x0004 0204)

This 32-bit register controls the period of the internal trigger. The timer is clocked at a rate of 31.25 MHz. The period of the internal trigger is calculated by multiplying the Timer Divider register contents by 32 nanoseconds. The minimum recommended value is 310. With this value the frequency of triggering is 100 KHz, which is the maximum frequency the DACs can operate at and still settle to within 1 LSB accuracy.

#### Table 4.60 Timer Divider

| Bit(s) | Description                                                             |
|--------|-------------------------------------------------------------------------|
| 31-0   | Timer Divider- count of 32 ns clock periods between DAC output samples. |

#### Software Trigger Register (Read/Write) - (BAR0 + 0x0004 0208)

Write to this address to trigger the DAC outputs for all channels configured to respond to a software trigger.

Table 4.61 Software Trigger

| Bit(s) | Description                                   |
|--------|-----------------------------------------------|
| 31-0   | Any Value can be written. Data is not stored. |

# 5.0 DAC USE OF CALIBRATION DATA

|                          | Calibration data is provided in the form of calibration coefficients, so the user can adjust and improve the accuracy of the analog output voltage over the uncalibrated state. Each channel's unique offset and gain calibration coefficients are stored in Flash memory. The use of software calibration allows the elimination of hardware calibration potentiometers traditionally used in producing precision analog outputs. A comparison of the uncalibrated and software calibrated performance is shown to illustrate the importance of the software calibration. |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | Software calibration uses some fairly complex equations. Acromag provides software products (sold separately) to make communication with the board and calibration easy. It relieves you from having to turn the equations of the following sections into debugged software calibration code.                                                                                                                                                                                                                                                                              |
| Uncalibrated Performance |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                          | The uncalibrated performance is affected by two primary error sources.<br>These are the channel's offset and gain errors. The use of channel specific<br>calibration coefficients to accurately adjust offset and gain is important<br>because the worst case uncalibrated error can be significant (although the<br>typical uncalibrated errors observed may be much less). The maximum<br>uncalibrated error is summarized as follows.                                                                                                                                   |
|                          | AD5761 @ -40°C to 85°C:<br>Linearity Error is +/- 0.003% FSR maximum (i.e. +/-2 LSB).<br>Offset Error is +/- 0.05% FSR (i.e. full-scale range would be 20V SPAN for the<br>-10 to 10V range) maximum.<br>Gain Error is +/- 0.1% FSR maximum.<br>Total Error +/- 0.153% FSR maximum (+/-98.5 LSB)                                                                                                                                                                                                                                                                           |
|                          | Typically, each error component is much less than its maximum and all error components do not reinforce each other. Thus, typical errors are much less than that shown above.                                                                                                                                                                                                                                                                                                                                                                                              |
| Calibrated Performance   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                          | Accurate calibration of the DAC can be accomplished through software control by using calibration coefficients to adjust the analog output voltage. Unique calibration coefficients are stored in Flash memory as 1/16 LSB's for each specific channel. Once retrieved, the channel's unique offset and gain coefficients can be used to correct the data value sent to the DAC channel to accurately generate the desired output voltage.                                                                                                                                 |
|                          | The maximum calibrated error combining the linearity and adjusted offset and gain errors:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                          | AD5761<br>Linearity Error is +/-2 LSB<br>Offset Error is +/-0.0625 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Gain Error is +/-0.0625 LSB Total Error +/-2.125 LSB (+/- 0.0032% FSR) maximum

Calibration coefficients are determined near room temperature. The Total Error does not include shifts over temperature.

Thus, correcting the value programmed to the DAC Channel Register using the stored calibration coefficients provides the means to obtain excellent accuracy.

Data is corrected using a couple of formulas. Equation (1) expresses the ideal relationship between the value (IdealCode) written to the 16-bit DAC to achieve a specified voltage within output range assuming Straight Binary (also called Bipolar Offset Binary) or 2's Complement data format (see Table 5.1).

Equation (1):

IdealCode = [IdealSlope × DesiredVoltage] + IdealZeroCode

Where,

| Range        | IdealSlope | IdealZeroCode             |
|--------------|------------|---------------------------|
|              |            | Straight Binary(2's Comp) |
| -10 to 10V   | 3276.8     | 32768 (0)                 |
| -5 to 5V     | 6553.6     | 32768 (0)                 |
| -3 to 3V     | 10922.67   | 32768 (0)                 |
| -2.5 to 7.5V | 6553.6     | 16384 (-16384)            |
| 0 to 10V     | 6553.6     | 0 (-32768)                |
| 0 to 5V      | 13107.2    | 0 (-32768)                |

Using equation (1), one can determine the IdealCode for any desired voltage within the range. For example, if it is desired to output a voltage of +5 Volts for -10 to 10V range, equation (1) returns the result 49,152 for IdealCode. If this value is used to program the DAC output (following conversion to Hex 0xC000), the output value will approach +5 Volts to within the uncalibrated error. This will be acceptable for some applications.

For applications needing better accuracy, the software calibration coefficients should be used to correct the IdealCode into the CorrectedCode required to accurately produce the output voltage. This is illustrated in equation (2):

Table 5.1 Ideal slope and zerovalues for supported ranges.

### Equation (2)

The GainCoef and OffsetCoef are stored and retrieved from Flash memory at the addresses shown in Table 7.1. Coefficients are unique to each of the 8 channels. The GainCoef and OffsetCoef values are calculated using the following equations at room temperature and then stored in Flash memory. Note that the coefficients are stored as 2's complement to allow use of plus and minus values.

$$GainCoef = 65536 \times 16 \left( \frac{ActualSlope}{IdealSlope} - 1 \right)$$

 $OffsetCoef = (ActualZeroCode - IdealZeroCode) \times 16$ 

ActualSlope =  $\left(\frac{Code2-Code1}{MeasuredV2-MeasuredV1}\right)$ 

ActualZeroCode = Code1 - (ActualSlope × *MeasuredV*1)

Where: Code1 = 655(0x28F hex) Code2 = 64880 (0xFD70 hex)

Measured values (MeasuredV2 and MeasuredV1) are taken using data averaging.

### 6.0 ADC USE OF CALIBRATION DATA

|                          | Factory calibration constants used to correct gain and offset errors are<br>stored in on-board flash memory. Gain and offset correction constants are<br>stored for each ADC. Software calibration uses some fairly complex<br>equations. Acromag provides you with the AcroPack Software Library to<br>make communication with the board and calibration easy. It relieves you<br>from having to turn the equations of the following sections into debugged<br>software calibration code. The functions are written in the "C"<br>programming language and can be linked into your application. |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Uncalibrated Performance |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                          | The uncalibrated performance is affected by two primary error sources.<br>These are the external reference voltage and the Analog to Digital Converter<br>(ADC). The untrimmed ADC's have significant offset and gain errors (see<br>specifications) which reveal the need for software calibration.                                                                                                                                                                                                                                                                                             |
| Calibrated Performance   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Note 1:                  | Very accurate calibration can be accomplished by applying external precision calibration voltages. The calibration voltages are used to determine two points of a straight line which defines the analog input characteristic.                                                                                                                                                                                                                                                                                                                                                                   |

IdealSlope is calculated using the FullScaleRange which can be one of the following:

5.12V (0 to 5.12V)

10V (-5.0 to 5.0V) or (0 to 10V)

10.24V (-5.12 to 5.12V) or (0 to 10.24V)

20V (-10.0 to 10.0V)

20.48V (-10.24 to 10.24V)

Note: The equation given here can be used for both the unipolar and bipolar ranges. For unipolar ranges must first XOR 0x8000 with the ADC count value. The XMC730 has two separate ADC circuits. ADC circuit 1 implements channels 0 through 7 while ADC circuit 2 implements channels 8 to 15. Each of the 16 ADC channels will have their own unique offset and gain errors for each of the seven ranges. The calibration voltages will need to be converted through each ADC circuit for each channel and the seven ranges to calculate the gain and offset calibration constants as shown in the equations below.

OffsetCorrection = -ActualIntercept (Equation 1)

ActualIntercept = CountCALHI – (ActualSlope \* VoltsCALHI)

 $\begin{aligned} & \textit{IdealSlope}^{1} = \frac{2^{16}}{FullScaleRange} = \frac{2^{16}}{5.12} \text{ or } \frac{2^{16}}{10} \text{ or } \frac{2^{16}}{10.24} \text{ or } \frac{2^{16}}{20} \text{ or } \frac{2^{16}}{20.48} \end{aligned}$   $& \textit{ActualSlope} = \frac{CountCALHI-CountCALLO}{VoltsCALH-VoltsCALLO} \end{aligned}$   $& \textit{CorrectionFactor} = \frac{\textit{IdealSlope}}{\textit{ActualSlope}} \end{aligned}$ 

 $GainCorrection = CorrectionFactor * 2^{16} (Equation 2)$ 

#### Where:

*CountCALHI* = uncorrected ADC data (16-bit) with high external precision calibration voltage applied +4.88V recommended for 0 to 5.12V, -5.0 to 5.0V, and -5.12 to 5.12V ranges while +9.88V is recommended for 0 to 10V, 0 to 10.24V, -10.0 to 10.0V, and-10.24 to 10.24V ranges.

*CountCALLO* = uncorrected ADC data (16-bit) with high external precision calibration voltage applied -4.88V recommended for -5.0 to 5.0V, and -5.12 to 5.12V ranges while -9.88V is recommended for -10.0 to 10.0V, and-10.24 to 10.24V ranges, and 0.1V recommended for the 0 to 5.12V, 0 to 10V, and 0 to 10.24V ranges.

VoltsCALHI = actual external precision calibration voltage high

*VoltCALLO* = actual external precision calibration voltage low

The values calculated for *OffsetCorrection* and *GainCorrection* are stored in flash memory for each ADC channel. The values are then used in the following equation to correct each input sample for offset and gain errors.

 $CorrectedData = \frac{(CountIN+OffsetCorrection)*GainCorrection}{2^{16}}$  (Equation 3)

Note: The average of many ADC values (e.g. 2048) should be used when calculating new correction coefficients to reduce the measurement uncertainty.

#### **Calibration Programming Example**

Calibration constants are calculated and stored in flash memory in the factory, however, in the case that new constants must be calculated, the calibration parameters CountCALHI and CountCALLO need to be determined for the two ADC circuits for each of the ranges. These parameters are then used to calculate OffsetCorrection and GainCorrection constants.

#### **Determination of CountCALLO Value**

1. Execute write of 0200H to the Interrupt Enable Register at Base Address + 2008H. This will enable FIFO Threshold met or exceeded interrupts on the module.

2. Execute write of 0002H to the Control Register at Base Address + 7008H.

a) Continuous Mode Enabled

b) External Trigger Disabled

c) Hardware initiated DMA transfers disabled

3. Execute write of 0007H to the ADC Range Enable Channel 0 to 7 Register at Base Address + 700CH. This will permit the values corresponding to channel 0 to be stored in the data FIFO.

4. Execute write of 53H to the Conversion Timer register at Base Address + 7014H. This sets the interval time between conversions to  $1.344\mu$  seconds.

5. Execute write of 3COH to the FIFO Full Threshold register at Base Address + 7018H. Since interrupts are enabled in the control register, an interrupt request will be issued when 960 values of the calibration voltage have been stored in the FIFO.

6. Apply a low (negative) calibration voltage, OV is recommended, to channel 0. Execute write of 0001H to the Start Convert Bit at Base Address + 701CH. This starts the continuous mode of conversions.

7. Upon system interrupt execute write of 00H to the Control register at Base Address + 7008H. This disables conversions. Software must calculate a CountCALLO value for channel 0, by averaging the 960 values for channel 0. Note that more samples will reduce measurement uncertainty.

#### Determination of CountCALHI Value

8. Execute write of 0002H to the Control Register at Base Address + 7008H.

a)Continuous Mode Enabled

b) External Trigger Disabled

c) Hardware initiated DMA transfers disabled

9. Writing the Channel Enable register, Conversion Timer Value, and the FIFO Full Threshold is not necessary because they need not change from that programmed in the previous steps.

10. Apply a high (positive) calibration voltage, +9.88V is recommended, to channel 0. Execute write of 0001H to the Start Convert Bit at Base Address + 701CH. This starts the continuous mode of conversions.

11. Upon system interrupt execute write of 00H to the Control register at Base Address + 7008H. This disables conversions. Software must calculate a CountCALHI value for channel 0, by averaging the 960 values for channel 0. Note that more samples will reduce measurement uncertainty.

### **Calculate the Calibration Constants to Store in Flash**

12. Use the CountCALLO and CountCALHI values in Equation 1 and Equation 2 in the beginning of this section to obtain new OffsetCorrection and GainCorrection constants for each ADC. These values can then be stored in the flash memory and loaded into the gain and offset registers.

13. Since OffsetCorrection and GainCorrection constants are known, corrected input data values can now be calculated. Data is corrected in firmware and stored into the FIFO.

# 7.0 FLASH MEMORY MAP

|                                                                         | The Serial flash memory provides 16M bytes of non-volatile memory for<br>storing the FPGA configuration bitstream. The lower portion of the flash<br>address space is used to store the FPGA configuration bitstream. The upper<br>address space is reserved for the storage of calibration constants and the<br>ASCII model identifier string as shown in the tables below. The serial flash is<br>accessible through Flash Data and Flash Chip Select registers at 0x7204 and<br>0x7208. |
|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note: Flash device defaults to<br>bottom 4-kbyte sectors<br>memory map. | Calibration coefficients are stored in Flash memory starting at the last sector SA285. This corresponds to the Flash address range of 0xFF0000 to 0xFFFFF.                                                                                                                                                                                                                                                                                                                                 |
|                                                                         | The calibration constants are calculated and stored in flash memory at the factory.                                                                                                                                                                                                                                                                                                                                                                                                        |
| DAC Calibration Coefficients                                            | Channel 0 coefficients start at 0xFF F000 to 0xFF F017 as shown in Table 7.1.                                                                                                                                                                                                                                                                                                                                                                                                              |
| (Table 7.1)                                                             | Channel 1 coefficients start at 0xFF F100 to 0xFF F117.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                         | Channel 2 coefficients start at 0xFF F200 to 0xFF F217.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                         | Etc.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                         | Channel 7 coefficients start at 0xFF F700 to 0xFF F717.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                         | Note that the coefficients are stored as 2's complement numbers to allow use of plus and minus values.                                                                                                                                                                                                                                                                                                                                                                                     |
| ADC Calibration Coefficients                                            | Channel 0 to Channel 7 coefficients start at 0xFF F800 to 0xFF F9BF as shown                                                                                                                                                                                                                                                                                                                                                                                                               |
| (Table 7.2)                                                             | in Table 7.2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                         | Channel 8 to Channel 15 coefficients start at 0xFF F9C0 to 0xFF FB7F.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                         | Note that the coefficients are stored as 2's complement numbers to allow<br>use of plus and minus values, for the bipolar ranges. All Unipolar range<br>coefficients are stored in 2's complement format.                                                                                                                                                                                                                                                                                  |

Table 7.1 DAC Calibration Coefficient Map

| Flash Addr | D15 down to D00            | Flash Addr |
|------------|----------------------------|------------|
| 0xFF F001  | Channel 0 (-10.0 to 10.0V) | 0xFF F000  |
|            | Offset Coefficient         |            |
| 0xFF F003  | Channel 0 (-10.0 to 10.0V) | 0xFF F002  |
|            | Gain Coefficient           |            |
|            | Channel 0 (0 to 10.0V)     | 0xFF F004  |
| 0xFF F005  | Offset Coefficient         | 0.04       |
|            | Channel 0 (0 to 10.0V)     | 0xFF F006  |
| 0xFF F007  | Gain Coefficient           |            |
| 0xFF F009  | Channel 0 (-5.0 to 5.0V)   | 0xFF F008  |
|            | Offset Coefficient         |            |
| 0xFF F00B  | Channel 0 (-5.0 to 5.0V)   | 0xFF F00A  |
|            | Gain Coefficient           |            |
| 0xFF F00D  | Channel 0 (0 to 5.0V)      | 0xFF F00C  |
|            | Offset Coefficient         |            |
| 0          | Channel 0 (0 to 5.0V)      | 0          |
| 0xFF F00F  | Gain Coefficient           | 0xFF F00E  |
| 0xFF F011  | Channel 0 (-2.5 to 7.5V)   | 0xFF F010  |
|            | Offset Coefficient         |            |
| 0xFF F013  | Channel 0 (-2.5 to 7.5V)   | 0xFF F012  |
|            | Gain Coefficient           |            |
| 0          | Channel 0 (-3 to 3V)       | 0          |
| 0xFF F015  | Offset Coefficient         | 0xFF F014  |
| 0          | Channel 0 (-3 to 3V)       | 0          |
| 0xFF F017  | Gain Coefficient           | 0xFF F016  |
| OxFF FOFF  | Reserved                   | 0xFF F018  |
| 0xFF F117  | Channel 1                  | 0xFF F100  |
|            | Coefficients               |            |
| OxFF F1FF  | Reserved                   | 0xFF F118  |
| 0xFF F217  | Channel 2                  | 0xFF F200  |
|            | Coefficients               |            |

| -         |              |           |
|-----------|--------------|-----------|
| 0xFF F2FF | Reserved     | 0xFF F218 |
| 0xFF F317 | Channel 3    | 0xFF F300 |
|           | Coefficients |           |
| 0xFF F3FF | Reserved     | 0xFF F318 |
| 0xFF F417 | Channel 4    | 0xFF F400 |
|           | Coefficients |           |
| 0xFF F4FF | Reserved     | 0xFF F418 |
| 0xFF F517 | Channel 5    | 0xFF F500 |
|           | Coefficients |           |
| 0xFF F5FF | Reserved     | 0xFF F518 |
| 0xFF F617 | Channel 6    | 0xFF F600 |
|           | Coefficients |           |
| 0xFF F6FF | Reserved     | 0xFF F618 |
| 0xFF F717 | Channel 7    | 0xFF F700 |
|           | Coefficients |           |
| 0xFF F7FF | Reserved     | 0xFF F718 |

Table 7.2 ADC Calibration Coefficient Map

| Flash Addr | D31 down to D00                      | Flash Addr |
|------------|--------------------------------------|------------|
| 0xFF F803  | Channels 0 (0 to 5.12V)              | 0xFF F800  |
|            | Offset Coefficients (2's complement) |            |
| 0xFF F807  | Channels 0 (0 to 5.12V)              | 0xFF F804  |
|            | Gain Coefficients (2's complement)   |            |
| 0xFF F80B  | Channels 0 (-5.0 to 5.0V)            | 0xFF F808  |
|            | Offset Coefficients (2's complement) |            |
| 0xFF F80F  | Channels 0 (-5.0 to 5.0V)            | 0xFF F80C  |
|            | Gain Coefficients (2's complement)   | 0,111000   |
| 0xFF F813  | Channels 0 (-5.12 to 5.12V)          | 0xFF F810  |
|            | Offset Coefficients (2's complement) |            |
| 0xFF F817  | Channels 0 (-5.12 to 5.12V)          | 0xFF F814  |
|            | Gain Coefficients (2's complement)   |            |
| 0xFF F80B  | Channels 0 (0 to 10V)                | 0xFF F818  |
|            | Offset Coefficients (2's complement) | 0,111010   |
| 0xFF F81F  | Channels 0 (0 to 10V)                | 0xFF F81C  |
|            | Gain Coefficients (2's complement)   |            |
| 0xFF F823  | Channels 0 (0 to 10.24V)             | 0xFF F820  |
|            | Offset Coefficients (2's complement) |            |
| 0xFF F827  | Channels 0 (0 to 10.24V)             | 0xFF F824  |
|            | Gain Coefficients (2's complement)   |            |
| 0xFF F82B  | Channels 0 (-10.0 to 10.0 V)         | 0xFF F828  |
| 0,111020   | Offset Coefficients (2's complement) | 0,111020   |
| 0xFF F82F  | Channels 0 (-10.0 to 10.0V)          | 0xFF F82C  |
| 0,111021   | Gain Coefficients (2's complement)   | 0,111020   |
| 0xFF F833  | Channels 0 (-10.24 to 10.24V)        | 0xFF F830  |
|            | Offset Coefficients (2's complement) |            |
| 0xFF F837  | Channels 0 (-10.24 to 10.24V)        | 0xFF F834  |
|            | Gain Coefficients (2's complement)   |            |
| 0xFF F83B  | Channel 1                            | 0xFF F838  |

| n         |             |           |
|-----------|-------------|-----------|
| 0xFF F86F |             | 0xFF F86C |
| 0xFF F873 | Channel 2   | 0xFF F870 |
| 0xFF F8A7 |             | 0xFF F8A4 |
| 0xFF F8AB | Channel 3   | 0xFF F8A8 |
| 0xFF F8DF | Channel 5   | 0xFF F8DC |
| 0xFF F8E3 | Channel 4   | 0xFF F8E0 |
| 0xFF F917 | Channel 4   | 0xFF F914 |
| 0xFF F91B | Channel 5   | 0xFF F918 |
| 0xFF F94F | Channel 5   | 0xFF F94C |
| 0xFF F953 | Channel 6   | 0xFF F950 |
| 0xFF F987 | charmero    | 0xFF F984 |
| 0xFF F98B | Channel 7   | 0xFF F988 |
| 0xFF F9BF | Channel 7   | 0xFF F9BC |
| 0xFF F9C3 | Channel 8   | 0xFF F9C0 |
| 0xFF F9F7 | Channel o   | 0xFF F9F4 |
| 0xFF F9FB | Channel 9   | 0xFF F9F8 |
| 0xFF FA2F | Channel 9   | 0xFF FA2C |
| 0xFF FA33 | Channel 10  | 0xFF FA30 |
| 0xFF FA67 | Channel 10  | 0xFF FA64 |
| 0xFF FA6B | Channel 11  | 0xFF FA68 |
| 0xFF FA9F |             | 0xFF FA9C |
| 0xFF FAA3 | Channel 12  | 0xFF FAA0 |
| 0xFF FAD7 |             | 0xFF FAD4 |
| 0xFF FADB | Channel 13  | 0xFF FAD8 |
| 0xFF FB0F | Chalinel 13 | 0xFF FB0C |
| 0xFF FB13 | Channel 14  | 0xFF FB10 |

| 0xFF FB47 |            | 0xFF FB44 |
|-----------|------------|-----------|
| OxFF FB4B | Channel 15 | 0xFF FB48 |
| 0xFF FB7F |            | 0xFF FB7C |
| ÷         | Reserved   | :         |
| OxFF FFEF | Reserved   | 0xFF FFEC |

### Table 7.3 Flash ASCII String Identifier

| Flash Address | Bit(s) | XMC730 Model       |
|---------------|--------|--------------------|
| 0xFF FFF0     | 7:0    | X = 0x58           |
| 0xFF FFF1     | 7:0    | M = 0x4D           |
| 0xFF FFF2     | 7:0    | C = 0x43           |
| 0xFF FFF3     | 7:0    | 7 = 0x37           |
| 0xFF FFF4     | 7:0    | 3 = 0x33           |
| 0xFF FFF5     | 7:0    | 0 = 0x30           |
| 0xFF FFF6     | 7:0    | 0 (null Character) |
| 0xFF FFF7->   | 7:0    | Reserved           |
| 0xFF FFFF     | 7:0    | Reserved           |

# 8.0 DAC SUGGESTED PROGRAMMING FOR STREAMING MODE

Streaming mode is available to support output of non-repetitive waveforms. In this mode, the host processor must keep the DACs supplied with data. The host must manage the transfer of data from host memory to the XMC730 module. If all eight channels were operating at the maximum frequency, the host would have to supply data at 1.6 M bytes/sec. The Central Direct Memory Access (CDMA) controller is included in the FPGA firmware to assist the host processor in moving data from host memory to the XMC730 on-board sample memory. Each channel will be configured in FIFO mode to buffer the samples written by the host. The on-chip block memory will be used to store a scatter-gather descriptor chain list used by the CDMA controller. Host memory will hold sample data that has been scaled and corrected for gain and offset errors. For this example, it is assumed the host memory used to store the sample data is contiguous, which would allow the addresses in the AXI2PCIeBARs to remain constant. This section will describe the suggested programming sequence to support streaming data. The management of the DMA controller will be done within an interrupt handler.

1. Start in a known state by writing the Control Register with the Software Reset bit set to logic '1'.

2. Reset the DACs by writing the Control Register with the DAC reset bit set to logic '1'.

3. Configure each DAC channel by writing to the appropriate Channel Direct Access register. Set the output range, power-up voltage, clear voltage, and data format.

4. Set the initial output voltage for all DACs by writing the Control Register with the DAC clear bit set to logic '1'. This will power up the DAC outputs. The DACs will output the voltage configured with the previous step.

5. Set the FIFO size for each channel by writing the Channel Start Address and Channel End Address registers. If all channels will be outputting data at the same frequency, make all the FIFOs equal size.

6. Configure the operating mode of each channel as FIFO mode, and set the appropriate bits to select the trigger source.

7. Initialize the DMA scatter-gather descriptor chain list in block RAM. Up to eight descriptors could be needed each time a transfer is initiated. All the host memory addresses written to the descriptors must take into consideration the address translation that is performed by the PCIe interface. The Next Descriptor Pointer field must be set for each of the eight descriptors. The destination address will be the appropriate Channel FIFO register. Set the bytes to transfer field in the descriptor to one half the size of the sample memory allocated to each channel. The source address will be a host memory address where the next set of sample data for each channel

is stored. Write zeroes to the Transfer Descriptor Status Word for each descriptor to indicate that it has not completed.

8. Reset the CDMA by writing the Reset bit in the CDMA Control Register.

9. Poll the CDMA control register until the Reset bit indicates reset is not in progress.

10. Configure the CDMA by writing the CMDA Control Register with Tail Pointer Mode enabled, Scatter Gather Mode selected, Key Hole write enabled, and Cyclic BD Disabled.

11. Write the address of the first scatter-gather descriptor to the CDMA Current Descriptor Pointer Register.

12. Write the address of the descriptor set up for channel seven to the CDMA Tail Descriptor Pointer Register. This initiates the DMA transfers.

13. Poll the CDMA Status Register until the CDMA idle bit indicates the CDMA is in the idle state. Each of the FIFOs are now half full.

14. Write the Interrupt Enable register with 0xFF. This enables each DAC channel to generate interrupts. Since each channel is configured in FIFO mode, an interrupt will be generated when any of the channels' FIFOs becomes half full. Also, note the CDMA interrupt is not enabled.

15. Write the following fields of the Master Enable Register:

Master IRQ Enable = 1

Hardware Interrupt Enable = 1

16. Write the Waveform Output Enable bit in the Control Register to start waveform output. The DACs will output the data stored in their FIFOs at the rate of the trigger pulses.

17. Wait for an interrupt from the XMC730 module.

18. Read the Interrupt Pending Register. Store the value read for later use in the DMA complete interrupt handler. For each DAC channel interrupt bit in the Interrupt Pending Register that is set to a logic '1' set up the scatter-gather descriptor to transfer up to one half of the channel's FIFO size.

19. For each DAC channel interrupt bit in the Interrupt Pending Register that is not set to a logic '1', remove the channel's descriptor from the scatter-gather chain.

20. Write the address of the scatter-gather descriptor of the first channel requiring service to the CDMA Current Descriptor Pointer Register.

21. Write the following fields of the CDMA control register:

Scatter Gather Mode = 1

Key Hole Write = 1

Cyclic BD Enable = 0

Interrupt on Complete Interrupt Enable = 1

Interrupt on Delay Timer = 0

Interrupt on Error Interrupt Enable = 1

Interrupt Threshold Value = number of descriptors to transfer

Interrupt Delay Timeout = 0

22. Write 0x100 to the Interrupt Enable Register. This disables all DAC channel interrupts and enables the CDMA interrupt.

23. Write the address of the descriptor of the last channel requiring service to the CMDA Tail Descriptor Pointer Register. This will initiate the DMA transfers.

24. Wait for an interrupt from the XMC730 module.

25. Read the CMDA status register. Check for error bits that are set.

26. Write the Interrupt Acknowledge Register with the saved value from the Interrupt Pending Register from above. This will clear the interrupts for the channels that were serviced by the DMA transfer.

27. Write 0xFF to the Interrupt Enable Register to re-enable the DAC interrupts.

# 9.0 THEORY OF OPERATION

This section contains information regarding the design of the board. A description of the basic functionality of the circuitry used on the board is also provided. Refer to the XM730 block diagrams, as you review this material.



### XM730 BLOCK DIAGRAM

### PCI INTERFACE LOGIC

The PCIe bus interface logic is embedded within the FPGA. This logic includes support for PCIe commands, including: configuration read/write, and memory read/write. A PCIe interface to the carrier/CPU board provides access to all board functions.

The PCIe bus endpoint interface logic is contained within the FPGA. This logic includes support for PCIe commands, including: configuration read/write, and memory read/write. In addition, the PCIe interface supports requester and/or completion accesses. Maximum payload size of up to 1024 bytes is supported.

|                      | The logic also implements interrupt requests via message signaled interrupts. Messages are used to assert and de-assert virtual interrupt lines on the link to emulate the Legacy PCI interrupt INTA# signal.                                                                                                                                                                                         |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| System Monitor       | The System Monitor provides status information for the XMC730 module.<br>The system monitor is located in the center of the FPGA die. The System<br>Monitor function is built around dual 12-bit, 1-megasamples per second<br>Analog-to-Digital Converters. The system monitor is used to measure FPGA<br>physical operating parameters such as on-chip power supply voltages and<br>die temperature. |
| Clock Generation     |                                                                                                                                                                                                                                                                                                                                                                                                       |
|                      | All clocks are derived from the 100 MHz PCIe REF_CLK signal. The PCIe interface includes a PLL that generates a 62.5 MHz clock that is used to clock the bus interfaces. The 62.5 MHz clock is further divided to produce a 31.25 MHz clock that is used to clock the timer and the serial interface to the ADC, DAC, and counter logic.                                                              |
| 128Mb Serial Flash   |                                                                                                                                                                                                                                                                                                                                                                                                       |
|                      | The serial FLASH memory provides 128 megabits or 16 megabytes of non-<br>volatile storage that is used for FPGA configuration and data storage. The<br>FLASH device is Spansion part number 25FL128S, or equivalent. The lower<br>64 megabytes of memory space are dedicated to storage of the FPGA<br>bitstream. Calibration coefficients are stored in the upper half of the FLASH.                 |
|                      | The program for the FGPA is stored in this Flash memory and loaded upon power-up.                                                                                                                                                                                                                                                                                                                     |
| Counter Timer        |                                                                                                                                                                                                                                                                                                                                                                                                       |
|                      | Counter timer input control signals are available from the Digital I/O channels 0 to 2 which function as CNT InA, CNT InB, and CNT InC respectively. See Tables 3.2 to 3.3 for the list of these signals and their corresponding pin assignments.                                                                                                                                                     |
|                      | One counter output signal, drive by 60V MOSFET, is available at pin C3 of<br>the P16 connector or pin 1 of P4 connector for the XMC730CC model. The<br>counter output signal is available on pin 1 of the XMC730(E) front I/O<br>connector.                                                                                                                                                           |
|                      | The counter output MOSFET can be set to either +5 Volt with 1K pullup, +12 Volt with a 1K pull up resistor, or open. See Board Configuration section of chapter 3 for switch settings corresponding to pullup and voltage options.                                                                                                                                                                    |
| Digital Input/Output |                                                                                                                                                                                                                                                                                                                                                                                                       |
|                      | Digital input/output signals to the FPGA are buffered using TTL drivers. Field<br>inputs to these buffers include a 4.7K pullup resistor to +5V. Output<br>operation is considered 'Fail-safe'. That is, the Digital Input/Output signals<br>are always configured as input upon FPGA configuration during power-up.                                                                                  |

|               | This is done for safety reasons to ensure reliable control under all conditions. After configured the digital channels can be set as output. 10K pullup resistors to +5 volts are tied to each of the digital I/O channels.                                                                                                          |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Analog Input  |                                                                                                                                                                                                                                                                                                                                      |
|               | Up to 16 differential analog inputs are available. The ADC is a 16-bit,<br>successive approximation converter with a built-in sample and hold circuit.<br>The ADC can be configured on a channel to channel basis to one of the<br>seven available ranges.                                                                           |
|               | Bipolar ranges of +/-10.24, +/-10, +/-5.12, +/-5.0                                                                                                                                                                                                                                                                                   |
|               | Unipolar ranges of +10.24 to 0, +10.0 to 0, +5.12 to 0.                                                                                                                                                                                                                                                                              |
|               | All channels can be configured individually to one of 7 ranges.                                                                                                                                                                                                                                                                      |
| Analog Output |                                                                                                                                                                                                                                                                                                                                      |
|               | Up to 8 DAC 16-bit voltage output channels are available with a 7.5uS output settling time. Eight individual DAC chips interface to an FPGA which provides the serial shift digital data that is converted.                                                                                                                          |
|               | Each channel may be independently configured to operate in direct access, single burst, continuous, or streaming (FIFO) mode.                                                                                                                                                                                                        |
|               | The on-board 64K x 16-bit sample memory is shared among the eight<br>channels. The amount of memory allocated to each channel is configurable<br>with a start and end address unique to each channel. This memory is used<br>for the continuous, FIFO, and single conversion mode of operation.                                      |
|               | <b>Direct Access</b> – Each DAC can be individually address and updated with direct register write operation.                                                                                                                                                                                                                        |
|               | <b>Continuous Output Mode</b> - Continuous conversions are implemented by continuously cycling through the waveform memory, from Start Address to End Address, until halted by software. The interval between conversions is controlled by the interval timer. Conversions are initiated by issue of a software or external trigger. |
|               | <b>FIFO Output Mode -</b> Each of the channel's FIFOs can be filled/loaded with new data without stopping output waveform generation.                                                                                                                                                                                                |
|               | <b>Single Conversion Mode</b> - Conversions are started with the Start Address and can continue until the channel's End Address is reached.                                                                                                                                                                                          |
|               | Software selectable output ranges available include:                                                                                                                                                                                                                                                                                 |
|               | 0 to 10 Volts, 0 to 5 Volts, +/-10 Volts, +/-5 Volts, +/-3 Volts,<br>- 2.5V to +7.5 Volts                                                                                                                                                                                                                                            |
|               |                                                                                                                                                                                                                                                                                                                                      |

# **10.0 SERVICE AND REPAIR**

| Service and Repair Assistance |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               | Surface-Mounted Technology (SMT) boards like the AcroPack family of<br>carrier boards are generally difficult to repair. The board can be easily<br>damaged unless special SMT repair and service tools are used. For these<br>and other reasons, it is strongly recommended that a non-functioning board<br>be returned to Acromag for repair. Acromag has automated diagnostic and<br>test equipment that thoroughly checks the performance of suspect boards.<br>Furthermore, when any repair is made, the board is retested before return<br>shipment to the customer. |
|                               | Please refer to Acromag's Service Policy Bulletin or contact Acromag for complete details on how to obtain parts, or return parts for repair.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Preliminary Service Procedure |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                               | Before beginning repair, be sure that all of the procedures in the<br>"Preparation for Use" section have been followed. Also, refer to the<br>documentation of your carrier board to verify that it is correctly configured.<br>Replacement of the board with one that is known to work correctly is a good<br>technique for isolating a faulty part.                                                                                                                                                                                                                      |

## CAUTION: POWER MUST BE TURNED OFF BEFORE SERVICING BOARDS

#### Where to Get Help

If you continue to have problems, your next step should be to visit the Acromag web site at <u>https://www.acromag.com</u>. Our web site contains the most up-to-date product and software information.

For assistance from Acromag's website go to the "Support" tab and submit/search the Acromag forum or fill out the contact us form. You can get additional documentation on XMC730 product webpage by using the search feature. If you'd like to speak with an application engineer:

- Email: <u>solutions@acromag.com</u>
- Phone: 248-295-0310

# **11.0 SPECIFICATIONS**

| Physical                     |                                                            |                                        |  |  |  |
|------------------------------|------------------------------------------------------------|----------------------------------------|--|--|--|
|                              | Length 149                                                 | .0 mm (5.866 in)                       |  |  |  |
|                              | Width 74.0                                                 | dth74.0 mm (2.913 in)                  |  |  |  |
|                              | Stacking Height 10.0                                       | tacking Height 10.0 mm (0.394 in)      |  |  |  |
|                              | Unit Weight (does not include shipping material):          |                                        |  |  |  |
|                              | Weight XMC730(E) 3.354                                     | 45 oz. (95.1 g)                        |  |  |  |
|                              | Weight XMC730CC 3.04                                       | 8 oz (86.41 g)                         |  |  |  |
| Power Requirements           |                                                            |                                        |  |  |  |
| rower nequirements           | I                                                          |                                        |  |  |  |
|                              | Summarized below are the expected c power supply voltages. | urrent draws for each of the specified |  |  |  |
|                              | Power Supply Voltage                                       | Current Draw                           |  |  |  |
|                              | • 3.3 Volts +/- 5%                                         | 0.567 A Typical, 0.7 A maximum         |  |  |  |
|                              | • 3.3 Aux Volts +/- 5%                                     | Not Used                               |  |  |  |
|                              | • +12/5 Volts VPWR +/- 5% <sup>1</sup>                     | 0.1 A Typical, 0.11 A maximum          |  |  |  |
|                              | • +12 VDC +/- 5% <sup>1</sup>                              | 0.03 A Typical, 0.037 A maximum        |  |  |  |
|                              | • -12 VDC +/- 5% <sup>1</sup>                              | Not Used                               |  |  |  |
|                              |                                                            |                                        |  |  |  |
| Environmental Considerations | l                                                          |                                        |  |  |  |
|                              | Summarized below are the ope                               | erating temperature range, airflow     |  |  |  |

Summarized below are the operating temperature range, airflow and other environmental requirements and applicable standards for the XMC730 module.

#### **Operating Temperature**

| MODELS                | ı/o               | OPERATING<br>TEMPERATURE RANGE       |  |  |
|-----------------------|-------------------|--------------------------------------|--|--|
| XMC730 <sup>1</sup>   |                   | 0°C to + 70°C (200 LFM<br>airflow)   |  |  |
| XMC730E <sup>1</sup>  |                   | -40°C to + 85°C (200 LFM<br>airflow) |  |  |
| XMC730CC <sup>2</sup> | Rear (P16 and P4) | -40°C to +85° C cold-plate           |  |  |

**Note 1**: An air cooled application with an XMC730 or XMC730E module will require a minimum airflow of 200 LFM.

**Note 2**: Applications requiring operating temperatures of 70°C to 85°C will require use of thermal interface material between FPGA and the carrier conduction cooling plate.

| Other Environmental Requirem  | ents                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Relative Humidity             | The range of acceptable relative humidity is 5% to 95% non-condensing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Isolation                     | The PCIe bus and field commons are non-isolated and have a direct electrical connection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Vibration and Shock Standards | The XMC730 is designed to comply with the following Vibration and Shock standards.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                               | <b>Vibration, Random Operating:</b> Designed to comply with VITA 47 Class V1. Shall withstand vibration from 5 to 100Hz with Power Spectral Density (PSD) = $0.04g^2$ /Hz, for 1 hour per axis. Testing shall be in accordance with MIL-STD-810, Method 514, Procedure 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                               | <b>Shock, Operating:</b> Designed to comply with VITA 47 Class OS1, 20g, 11ms half sine and terminal sawtooth shock pulses. 3 shock pulses in each direction along 3 axes (36 shocks, total). Testing shall be in accordance with MIL-STD-810, Method 516, Procedure 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| EMC Directives                | <ul> <li>Electromagnetic Compatibility (EMC): CE Marked, per EMC Directive 2014/30/EU Class A.</li> <li>Complies with EMC Directive 2014/30/EC. <ul> <li>Immunity per EN 61000-6-2:</li> <li>Electrostatic Discharge Immunity (ESD), per IEC 61000-4-2.</li> <li>Radiated Field Immunity (RFI), per IEC 61000-4-3.</li> <li>Electrical Fast Transient Immunity (EFT), per IEC 61000-4-4.</li> <li>Surge Immunity, per IEC 61000-4-5.</li> <li>Conducted RF Immunity (CRFI), per IEC 61000-4-6.</li> </ul> </li> <li>Emissions per EN 61000-6-4: <ul> <li>Enclosure Port, per CISPR 16.</li> <li>Low Voltage AC Mains Port, per CISPR 16.</li> <li>Note: This is a Class A product</li> </ul> </li> <li>RoHS Directive 2011/65/EU – All Models <ul> <li>In compliance per EN 50581</li> </ul> </li> </ul> |
| FCC US/Canada                 | <ul> <li>FCC Part 15, Class A Digital Device:<br/>This device complies with part 15 of the FCC Rules. Operation is subject to the following two conditions: (1) This device may not cause harmful interference, and (2) this device must accept any interference received, including interference that may cause undesired operation.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

### **Reliability Prediction**

Table 8.1 XMC730

MTBF (Mean Time Between Failure): MTBF in hours using MIL-HDBK-217F, FN2. Per MIL-HDBK-217, Ground Benign, Controlled, G<sub>B</sub>G<sub>C</sub>

| Temperature         | emperature MTBF (Hours) |       | Failure Rate (FIT <sup>1</sup> ) |  |  |
|---------------------|-------------------------|-------|----------------------------------|--|--|
| 25°C                | 1,406,456               | 160.6 | 711.0                            |  |  |
| <b>40°C</b> 773,497 |                         | 88.3  | 1,292.8                          |  |  |

<sup>1</sup> FIT is Failures in 10<sup>9</sup> hours.

| DAC Analog Output          |                                                                                                                                                                                                                                                                                                   |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output Cannels             | Eight Single Ended                                                                                                                                                                                                                                                                                |
| Output Signal Type         | Voltage (Non-isolated)                                                                                                                                                                                                                                                                            |
| Resolution                 | 16-bits                                                                                                                                                                                                                                                                                           |
| Settling Time              | 12.5 $\mu s$ 20 V step to 1 LSB at 16-bit resolution maximum                                                                                                                                                                                                                                      |
|                            | 8.5 $\mu$ s 10 V step to 1 LSB at 16-bit resolution maximum                                                                                                                                                                                                                                       |
|                            | 7.5 μs typical                                                                                                                                                                                                                                                                                    |
| Output Ranges              | Bipolar: +/-10 Volts, +/-5 Volts, +/-3 Volts, - 2.5V to +7.5 Volts                                                                                                                                                                                                                                |
|                            | Unipolar: 0 to 10 Volts, 0 to 5 Volts                                                                                                                                                                                                                                                             |
|                            | (software selectable)                                                                                                                                                                                                                                                                             |
| Output Current             | -10mA to 10mA (Maximum); this corresponds to a minimum load resistance of 1K $\Omega$ with a 10 volt output.                                                                                                                                                                                      |
| Data Format                | Input coding to the DAC is Straight binary code when channel is configured for 0-10 or 0-5 ranges.                                                                                                                                                                                                |
|                            | Twos complement coded for bipolar ranges (software selectable)                                                                                                                                                                                                                                    |
| Monotonicity               | ±1 LSB maximum                                                                                                                                                                                                                                                                                    |
|                            | The DAC is monotonic over the full operating temperature range. The output either increases or remains constant for increasing digital input code.                                                                                                                                                |
| Linearity Error            | ± 2 LSB (maximum)                                                                                                                                                                                                                                                                                 |
| Maximum Uncalibrated Error | AD5761 @ -40°C to 85°C:<br>Linearity Error is +/- 0.003% FSR maximum (i.e. +/-2 LSB).<br>Offset Error is +/- 0.05% FSR (i.e. full-scale range would be 20V SPAN for the -<br>10 to 10V range) maximum.<br>Gain Error is +/- 0.1% FSR maximum.<br>Total Error +/- 0.153% FSR maximum (+/-98.5 LSB) |

| Maximum Calibrated Error   | The maximum calibrated error combining the linearity and adjusted offset and gain errors:                                                                                                                                                                                                                        |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | AD5761<br>Linearity Error is +/-2 LSB maximum<br>Offset Error is +/-0.0625 LSB maximum<br>Gain Error is +/-0.0625 LSB maximum<br>Total Error +/-2.125 LSB (+/- 0.0032% FSR) maximum                                                                                                                              |
|                            | Calibration coefficients are determined near room temperature. The Total Error does not include shifts over temperature.                                                                                                                                                                                         |
| ADC Analog Input           |                                                                                                                                                                                                                                                                                                                  |
| Input Cannels              | 16 Differential Ended                                                                                                                                                                                                                                                                                            |
| Input Signal Type          | Voltage (Non-isolated)                                                                                                                                                                                                                                                                                           |
| Resolution                 | 16-bits                                                                                                                                                                                                                                                                                                          |
| Conversion Rate            | 791,139.24Hz maximum                                                                                                                                                                                                                                                                                             |
| Settling Time              | Full-Scale Step 420 ns to 0.005% of FSR                                                                                                                                                                                                                                                                          |
| Input Ranges               | Bipolar ranges of +/-10.24, +/-10, +/-5.12, +/-5.0                                                                                                                                                                                                                                                               |
|                            | Unipolar ranges of 0 to+10.24, 0 to +10.0, 0 to+5.12.                                                                                                                                                                                                                                                            |
|                            | (software selectable) Selected range applies to each channel and can be individually selected on a per channel basis.                                                                                                                                                                                            |
| Input Resistance           | >1000 GΩ typical                                                                                                                                                                                                                                                                                                 |
| Input Leakage Current      | 500pA maximum                                                                                                                                                                                                                                                                                                    |
| Data Format                | The output data coding is in binary two's compliment for all bipolar ranges and in straight binary format for all unipolar ranges.                                                                                                                                                                               |
| No Missing Codes           | 16-bit                                                                                                                                                                                                                                                                                                           |
| Linearity Error            | ± 2 LSB All Ranges but 0V to 5.12V Range (maximum)                                                                                                                                                                                                                                                               |
|                            | ± 3 LSB 0V to 5.12V Range (maximum)                                                                                                                                                                                                                                                                              |
| Maximum Uncalibrated Error | LTC2333-16 @ 25°C:<br>Offset Error ± 700 μV maximum<br>8.96 LSB (0 to 5.1V Range,)<br>4.59 LSB (± 5.0V Range and 0 to 10V Range)<br>4.48 LSB (± 5.12V Range and 0 to 10.24 V Range)<br>2.29 LSB (± 10.0V Range)<br>2.24 LSB (± 10.24V Range)<br>Gain Error is ± 0.1% FSR or (± 65.5 LSB) maximum.<br>Total Error |

|                                   | 78 LSB (0 to 5.1V Range,)<br>73 LSB (± 5.0V Range and 0 to 10V Range)<br>72LSB (± 5.12V Range and 0 to 10.24 V Range)<br>70 LSB (± 10.0V Range)<br>70 LSB (± 10.24V Range)<br>The Total Error does not include shifts over temperature. |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Maximum Calibrated Error          | Total Error all but 0V to 5.12V Range ± 2.125 LSB maximum                                                                                                                                                                               |
|                                   | Total Error 0V to 5.12V Range ± 3.125 LSB maximum                                                                                                                                                                                       |
|                                   | Calibration coefficients are determined near room temperature. The Total Error does not include shifts over temperature.                                                                                                                |
| Counter/Timers                    |                                                                                                                                                                                                                                         |
|                                   | <b>Counter Functions:</b> Quadrature Position Measurement, Pulse Width Modulation, Watchdog Timer, Event Counting, Frequency Measurement, Period Measurement, Pulse-Width Measurement, and One Shot/Repetitive                          |
| Counter Input                     | <b>Counter has an CNT InA, CNT InB, and CNT InC input port.</b> These TTL input ports are used to control Start/Stop, Reload, Event Input, Trigger, and Up/Down operations.                                                             |
| Counter Output                    | <b>Counter has an Output port.</b> This MOSFET output port is used for waveform output, watchdog active indicator, or $1.74\mu$ s pulse upon counter function completion. Counter output is programmable as active high or low.         |
| Counter Output pull-up<br>voltage | Set DIP switch SW1 is needed to enable: +5V pullup voltage, +12V pullup voltage, or External pullup and voltage for MOSFET counter output pin-1.                                                                                        |

| Switch Function             | Switch SW1 Setting    |  |  |  |
|-----------------------------|-----------------------|--|--|--|
| +5V with 1K Pullup          | 1= ON, 4= ON          |  |  |  |
| +12V with 1K Pullup         | 3= ON, 4= ON          |  |  |  |
| External Voltage and Pullup | 6= ON, 1= ON or 3= ON |  |  |  |

| Counter Output MOSFET | Vds 60 V Maximum      |  |
|-----------------------|-----------------------|--|
| (BSS138PS)            | Vgs +/-20 V Maximum   |  |
|                       | Id 320 mA Maximum     |  |
|                       | Rdson 1.6 ohm Maximum |  |

| Debounce Interval                                      | Input signals with duration less then $2.4\mu s$ are filtered with debounce enabled via counter control register.                   |
|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Counter Clock Enable<br>Frequencies                    | 62.5MHz, 15.625MHz, 7.8125MHz, 3.90625MHz, or 1.953125MHz                                                                           |
| Minimum Input Event:                                   | 32nS                                                                                                                                |
| Minimum Pulse<br>Measurement:                          | 32nS                                                                                                                                |
| Minimum Period<br>Measurement:                         | 64nS                                                                                                                                |
| Minimum Gate/Trigger Pulse:                            | 32nS                                                                                                                                |
| Counter Input/Output,<br>External Trigger Input/Output | <ul> <li>VIH: 2.0V minimum</li> <li>VIL: 0.8V maximum</li> </ul>                                                                    |
| Electrical Characteristics                             | <ul> <li>IOH: -24 mA maximum</li> <li>IOL: 24mA maximum</li> <li>VOH: 3.7V minimum VCCA</li> <li>VOL: 0.55V maximum VCCA</li> </ul> |
| PCIe Bus Specifications                                |                                                                                                                                     |
| Compatibility                                          | Conforms to PCI Express Base Specification, Revision 2.1                                                                            |
| Line Speed                                             | Gen1 PCIe Interface                                                                                                                 |
| BAR0 Memory Size                                       | 1M Byte Memory Size                                                                                                                 |

# **Certificate of Volatility**

| Acromag Model                          | Mai           | nufacturer:        |                                         |                       |                     |                      |                                 |
|----------------------------------------|---------------|--------------------|-----------------------------------------|-----------------------|---------------------|----------------------|---------------------------------|
| XMC730(E)                              | Acro          | omag, Inc.         |                                         |                       |                     |                      |                                 |
| XMC730CC                               | 307           | 65 Wixom Rd        |                                         |                       |                     |                      |                                 |
|                                        | Wix           | om, MI 48393       |                                         |                       |                     |                      |                                 |
|                                        | ·             |                    | Volatile Mem                            | ory                   |                     |                      |                                 |
| Does this product o                    | contain Volat | ile memory (i.e    | . Memory of whose                       | content               | s are lost when I   | ром                  | ver is removed)                 |
| ■ Yes 🗆 No                             |               |                    |                                         |                       |                     |                      |                                 |
| Type (SRAM, SDRA<br>Configurable Logic | · · J         | ize:               | User Modifiable<br>■ Yes                | Functi<br>FPGA l      | on:<br>logic blocks |                      | ocess to Sanitize:<br>ower Down |
| and Block RAM Blo                      | cks 7         | 5,520 Logic        | □ No                                    | and RA                | AM blocks           |                      |                                 |
|                                        | С             | ells and           |                                         |                       |                     |                      |                                 |
|                                        | 3             | 780 Kb             |                                         |                       |                     |                      |                                 |
|                                        | -             | lock RAM           |                                         |                       |                     |                      |                                 |
|                                        |               |                    |                                         |                       |                     |                      |                                 |
|                                        |               |                    |                                         |                       |                     |                      |                                 |
| Type (SRAM, SDRA                       | Metc) Si      | ize:               | User Modifiable                         | Functi                | on.                 | Pr                   | ocess to Sanitize:              |
|                                        |               | 120.               |                                         | i uncu                | 011.                |                      |                                 |
|                                        |               |                    |                                         |                       |                     |                      |                                 |
|                                        |               |                    | Non-Volatile Me                         | emory                 |                     | I                    |                                 |
| Does this product o                    | contain Non-  | Volatile memor     | y (i.e. Memory of w                     | hose co               | ntents is retained  | d w                  | hen power is removed)           |
| ∎ Yes 🗆 No                             |               |                    | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |                       |                     |                      | , ,                             |
|                                        |               | ocess to Sanitize: |                                         |                       |                     |                      |                                 |
| Flash                                  | 1             | 28 Meg x           | ■ Yes                                   | Data s                | torage for          | Er                   | ase using JTAG                  |
|                                        |               | bit                | □ No                                    | FPGA                  |                     |                      |                                 |
|                                        |               | ize:1024-byte      | User Modifiable                         | Function:             |                     | Process to Sanitize: |                                 |
| One Time Programmable                  |               | ,                  | ■ Yes                                   | The O                 | TP area has         | Pr                   | otect from Programming          |
| area in flash device                   |               | 0 0                |                                         |                       |                     |                      |                                 |
|                                        |               |                    |                                         | writing the lock bits |                     |                      |                                 |
|                                        |               |                    |                                         | with lo               |                     |                      |                                 |
| Acromag Representative                 |               |                    |                                         |                       |                     |                      |                                 |
| Name:                                  | Title:        | Email:             |                                         |                       | Office Phone:       |                      | Office Fax:                     |
| Russ Nieves                            | Sales and     | solutions@         |                                         |                       | 248-624-9234        |                      |                                 |
| Marketing                              |               |                    |                                         |                       |                     |                      |                                 |
|                                        |               |                    |                                         |                       |                     |                      |                                 |

# **Revision History**

The revision history for this document is summarized in the table below.

| Release Date<br>(DD MMM YYYY) | Version | EGR/DOC | Description of Revision                                                                 |
|-------------------------------|---------|---------|-----------------------------------------------------------------------------------------|
| 07 JUL 2018                   | А       | LMP/LMP | Preliminary Document Publication.                                                       |
| 26 OCT 2018                   | В       | CAP/ARP | Added CE Mark statement.                                                                |
| 09 OCT 2019                   | С       | LMP/ARP | Corrected ADC Offset and Gain register descriptions;<br>updated MTBF Predictions table. |
| 05 MAY 2021                   | D       | LMP/ARP | Corrected PCIe Generation and Lanes                                                     |